:root{--bg: #0f0f10;--surface: #1a1a1c;--border: #2a2a2e;--text: #f4f4f5;--muted: #a1a1aa;--accent: #e4e4e7;--danger: #f87171;--radius: 12px;font-family:Inter,system-ui,sans-serif;line-height:1.5;font-weight:400;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh;min-height:100dvh}button,input{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem 1.25rem 3rem}.app-shell--dashboard{padding:0;align-items:stretch;max-width:none;width:100%;height:100vh;height:100dvh;min-height:100vh;min-height:100dvh;box-sizing:border-box;overflow:hidden}.app-shell--dashboard>.dashboard-shell{flex:1;min-height:0;display:flex}.app-loading-placeholder{flex:1;display:flex;align-items:center;justify-content:center}.card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;box-shadow:0 24px 48px #00000059}.card-wide{max-width:560px}h1{font-size:1.35rem;font-weight:600;margin:0 0 .25rem;letter-spacing:-.02em}.subtitle{color:var(--muted);font-size:.9rem;margin:0 0 1.5rem}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.field label{font-size:.8rem;font-weight:500;color:var(--muted)}.field input{padding:.65rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text)}.field input:focus{outline:none;border-color:var(--muted)}.field textarea,.textarea-mono{width:100%;padding:.65rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:ui-monospace,monospace;font-size:.8rem;resize:vertical}.field textarea:focus,.textarea-mono:focus{outline:none;border-color:var(--muted)}.btn{width:100%;padding:.7rem 1rem;border-radius:8px;border:none;font-weight:600;margin-top:.25rem}.btn-primary{background:var(--accent);color:var(--bg)}.btn-primary:hover{filter:brightness(1.05)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border);margin-top:.75rem}.btn-ghost:hover{color:var(--text);border-color:var(--muted)}.error{color:var(--danger);font-size:.85rem;margin:0 0 1rem}.header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.brand-mark{display:block;border-radius:10px;object-fit:contain}.header-brand{line-height:0}.brand-mark--header{width:44px;height:44px}.brand-mark--sidebar{width:40px;height:40px;border-radius:0}.brand-mark--login{width:5.5rem;height:5.5rem;margin:0 auto 1.25rem}.card-brand{text-align:center}.btn-small{width:auto;padding:.45rem .75rem;font-size:.8rem;font-weight:500;margin-top:0;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:8px}.btn-small:hover{color:var(--text)}.slate-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}.slate-item{padding:1rem 1.1rem;border-radius:10px;border:1px solid var(--border);background:var(--bg)}.slate-item h2{font-size:1rem;font-weight:600;margin:0 0 .35rem}.slate-meta{font-size:.8rem;color:var(--muted);margin:0;line-height:1.45}.slate-rotation-picker{margin-top:.75rem;padding:.65rem .75rem;border-radius:8px;border:1px solid var(--border);background:#ffffff05}.slate-rotation-label{display:block;font-size:.78rem;font-weight:600;color:var(--muted);margin-bottom:.35rem}.slate-rotation-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem}.slate-rotation-btn{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.45rem .25rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--muted);font-size:.7rem;min-width:0}.slate-rotation-btn:hover:not(:disabled){border-color:var(--muted);color:var(--text)}.slate-rotation-btn.is-active{border-color:var(--accent);color:var(--accent);background:#e4e4e70f}.slate-rotation-btn:disabled{opacity:.5;cursor:wait}.slate-rotation-icon{display:block;width:14px;height:20px;border:2px solid currentColor;border-radius:3px;box-sizing:border-box}.slate-rotation-deg{font-weight:600;font-size:.68rem;letter-spacing:-.02em}.empty{text-align:center;color:var(--muted);font-size:.9rem;padding:2rem .5rem}.loading{color:var(--muted);font-size:.9rem;text-align:center;padding:1.5rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:flex-start;justify-content:center;padding:1.5rem;z-index:100;overflow-y:auto}.modal{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.35rem 1.5rem;margin-top:2rem;margin-bottom:2rem;box-shadow:0 24px 48px #00000073}.modal-wide{max-width:440px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.75rem}.modal-header h2{font-size:1.1rem;font-weight:600;margin:0}.modal-close{background:none;border:none;color:var(--muted);font-size:1.5rem;line-height:1;padding:.2rem .4rem;cursor:pointer}.modal-close:hover{color:var(--text)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.field select{padding:.65rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text)}.checkbox-row{display:flex;align-items:center;gap:.5rem;font-size:.9rem;margin:.75rem 0 1rem;cursor:pointer}.modal-actions{display:flex;gap:.5rem;margin-top:.25rem}.modal-actions .btn{flex:1}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border);width:100%;padding:.65rem 1rem;border-radius:8px;font-weight:600;margin-top:.35rem}.btn-secondary:hover{border-color:var(--muted)}.provision-block{display:flex;flex-direction:column;gap:1rem}.qr-wrap{display:flex;justify-content:center;padding:1rem;background:var(--bg);border-radius:10px;border:1px solid var(--border)}.provision-actions{display:flex;flex-direction:column;gap:.5rem}.provision-json summary{cursor:pointer;font-size:.85rem;color:var(--muted);margin-bottom:.35rem}.provision-json pre{font-size:.7rem;overflow-x:auto;padding:.75rem;background:var(--bg);border-radius:8px;border:1px solid var(--border);margin:0;max-height:160px}.provision-hint{font-size:.78rem;color:var(--muted);line-height:1.45;margin:0}.copy-hint{font-size:.85rem;color:var(--accent);margin:0;text-align:center}.toolbar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;flex-shrink:0}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.media-panel{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.media-panel-title{font-size:.85rem;font-weight:600;margin:0 0 .65rem;color:var(--muted)}.media-grid{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.65rem}.media-card{width:88px;display:flex;flex-direction:column;gap:.25rem}.media-thumb{width:88px;height:88px;object-fit:cover;border-radius:8px;border:none;background:transparent}.media-thumb--loading{min-height:88px;background:linear-gradient(90deg,var(--border),var(--surface),var(--border));background-size:200% 100%;animation:media-shimmer 1.2s ease-in-out infinite;border-radius:8px;border:none}@keyframes media-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.media-card-name{font-size:.65rem;color:var(--muted);line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.slate-assign{margin-top:.85rem;padding-top:.85rem;border-top:1px solid var(--border)}.slate-assign-label{display:block;font-size:.78rem;font-weight:500;color:var(--muted);margin-bottom:.35rem}.slate-assign-row{display:flex;gap:.5rem;align-items:center}.slate-assign-row--stack{flex-wrap:wrap}.slate-assign-select--narrow{flex:0 0 auto;min-width:11rem;max-width:100%}.slate-assign-select{flex:1;min-width:0;padding:.5rem .65rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem}.slate-assign-hint{font-size:.78rem;color:var(--muted);margin:.4rem 0 0}.assign-ok{font-size:.78rem;color:#86efac;margin:.45rem 0 0}.btn-small-primary{background:var(--accent);color:var(--bg);border-color:var(--accent);flex-shrink:0}.btn-small-primary:hover:not(:disabled){filter:brightness(1.05);color:var(--bg)}.btn-small-primary:disabled{opacity:.45}.card-dashboard{max-width:760px}.dashboard-shell{display:flex;flex-direction:row;width:100%;flex:1;min-height:0;height:100%;overflow:hidden;background:var(--bg)}.app-sidebar{width:72px;flex-shrink:0;align-self:stretch;display:flex;flex-direction:column;align-items:center;padding:.75rem 0;background:var(--surface);border-right:1px solid var(--border);min-height:0;overflow:hidden}.sidebar-nav-icons{display:flex;flex-direction:column;gap:.45rem;align-items:center}.sidebar-icon-btn{display:flex;align-items:center;justify-content:center;width:48px;height:48px;padding:0;border:none;border-radius:12px;background:transparent;color:var(--muted);cursor:pointer;transition:color .12s ease,background .12s ease}.sidebar-icon-btn:hover{color:var(--text);background:#ffffff0f}.sidebar-icon-btn.is-active{color:var(--accent);background:#e4e4e71a}.sidebar-icon-btn--ghost{color:var(--muted)}.sidebar-icon-btn--ghost:hover{color:var(--text)}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding-bottom:.35rem}.sidebar-home-link{display:block;line-height:0;border-radius:0;opacity:.9;transition:opacity .12s ease}.sidebar-home-link:hover{opacity:1}.sidebar-home-link:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:0}.app-main{flex:1;min-width:0;min-height:0;padding:1.25rem 1.5rem 2rem;overflow-x:hidden;overflow-y:auto;display:flex;flex-direction:column}.page-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.1rem;flex-shrink:0}.page-title{margin:0;font-size:1.4rem;font-weight:600;letter-spacing:-.03em;color:var(--text)}.btn-add-icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;flex-shrink:0;padding:0;border:1px solid var(--border);border-radius:14px;background:var(--surface);color:var(--accent);cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.btn-add-icon:hover:not(:disabled){border-color:var(--muted);background:#ffffff0d}.btn-add-icon:disabled{opacity:.55;cursor:not-allowed}.btn-add-icon-spinner{width:22px;height:22px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:btn-add-spin .7s linear infinite}@keyframes btn-add-spin{to{transform:rotate(360deg)}}.slate-mosaic-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.slate-mosaic-card{border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.65rem}.slate-delete-btn{align-self:flex-start;margin-top:.15rem}.slate-mosaic-preview{display:flex;align-items:center;justify-content:center;padding:.35rem 0 .5rem;background:transparent;border:none}.slate-frame-preview-wrap{display:flex;align-items:center;justify-content:center}.slate-frame-preview{position:relative;flex-shrink:0;border:1px solid rgba(255,255,255,.14);border-radius:0;overflow:hidden;background:var(--bg);box-shadow:none}.slate-frame-thumb,.slate-frame-preview .media-thumb--loading{display:block;width:100%;height:100%;object-fit:contain}.slate-frame-empty{width:100%;height:100%;min-height:48px;opacity:.45;background:repeating-linear-gradient(-45deg,transparent,transparent 8px,rgba(255,255,255,.06) 8px,rgba(255,255,255,.06) 16px)}.slate-name-display{display:block;width:100%;margin:0;padding:.4rem .5rem;text-align:center;font-size:1rem;font-weight:600;letter-spacing:-.02em;color:var(--text);background:transparent;border:none;border-radius:6px;cursor:pointer}.slate-name-display:hover{background:#ffffff0f}.slate-name-inline{display:flex;align-items:stretch;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--bg)}.slate-name-inline-input{flex:1;min-width:0;margin:0;border:none;background:transparent;color:var(--text);padding:.55rem .65rem;font-size:.95rem;font-weight:500}.slate-name-inline-input:focus{outline:none}.slate-name-inline-commit{flex-shrink:0;width:46px;margin:0;padding:0;border:none;border-left:1px solid var(--border);background:var(--surface);color:var(--accent);font-size:1.05rem;line-height:1;cursor:pointer}.slate-name-inline-commit:hover:not(:disabled){background:#ffffff0f}.slate-name-inline-commit:disabled{opacity:.4;cursor:not-allowed}.tab-panel{flex:1;min-height:0;min-width:0;display:flex;flex-direction:column}.empty-tab{color:var(--muted);font-size:.88rem;padding:1.5rem .5rem;text-align:center}.images-tab-layout{display:grid;grid-template-columns:1fr minmax(220px,280px);gap:1.25rem;align-items:start}@media(max-width:640px){.images-tab-layout{grid-template-columns:1fr}}.images-scroll{max-height:min(70vh,520px);overflow-y:auto;padding-right:.35rem}.images-picker-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(112px,1fr));gap:.65rem}.image-picker-tile{display:flex;flex-direction:column;align-items:stretch;width:100%;padding:.35rem;border-radius:10px;border:2px solid var(--border);background:var(--bg);color:var(--text);text-align:left;cursor:pointer}.image-picker-tile:hover{border-color:var(--muted)}.image-picker-tile.is-selected{border-color:var(--accent);box-shadow:0 0 0 1px #e4e4e726}.image-picker-tile .media-thumb,.image-picker-tile .media-thumb--loading{width:100%;height:120px;object-fit:cover;border-radius:6px}.image-picker-name{font-size:.65rem;color:var(--muted);margin-top:.35rem;line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.images-side-panel{position:sticky;top:0;padding:.85rem 1rem;border-radius:10px;border:1px solid var(--border);background:#0003}.side-panel-title{font-size:.82rem;font-weight:600;margin:0 0 .65rem;color:var(--muted)}.side-panel-thumb-wrap{margin-bottom:.75rem}.side-panel-thumb-wrap .media-thumb,.side-panel-thumb-wrap .media-thumb--loading{width:100%;max-height:200px;object-fit:contain;border-radius:8px}.side-panel-actions{display:flex;flex-wrap:wrap;gap:.5rem}.btn-danger-outline{border-color:var(--danger);color:var(--danger)}.btn-danger-outline:hover:not(:disabled){background:#f871711f}.assign-slate-buttons{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.45rem}.btn-assign-slate{width:100%;text-align:left;padding:.55rem .7rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem;font-weight:500}.btn-assign-slate:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.assign-ok-inline{display:block;font-size:.72rem;color:#86efac;margin-top:.2rem}.slate-name-row{display:flex;gap:.5rem;align-items:flex-end;margin-bottom:.5rem}.slate-name-field{min-width:0}.images-flex-grid{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.65rem;align-items:flex-start;align-content:flex-start;flex:1;min-height:0;overflow-y:auto;padding-bottom:.5rem}.image-grid-cell{position:relative;flex:0 1 auto;max-height:200px}.image-grid-cell-inner{position:relative;max-height:200px;display:flex;align-items:center;justify-content:center}.image-tile-assign{display:block;padding:0;margin:0;border:none;border-radius:10px;overflow:hidden;background:transparent;cursor:pointer;line-height:0;max-height:200px;box-shadow:0 0 0 1px #ffffff14}.image-tile-assign:hover{box-shadow:0 0 0 1px #ffffff29}.image-tile-assign:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.media-thumb-natural,.image-tile-assign .media-thumb--loading{display:block;max-height:200px;width:auto;max-width:min(320px,85vw);height:auto;object-fit:contain}.image-tile-pencil{position:absolute;top:6px;right:6px;width:34px;height:34px;padding:0;border-radius:8px;border:1px solid var(--border);background:#0f0f10e0;color:var(--accent);font-size:1rem;line-height:1;cursor:pointer;opacity:0;transition:opacity .12s ease;z-index:2}.image-grid-cell:hover .image-tile-pencil,.image-tile-pencil:focus-visible{opacity:1}.image-tile-pencil:hover{background:var(--surface);border-color:var(--accent)}@media(hover:none){.image-tile-pencil{opacity:.92}}.modal-assign-image{max-width:440px}.modal-assign-preview{margin-bottom:1rem;border-radius:10px;overflow:hidden;background:transparent;border:none;box-shadow:0 0 0 1px #ffffff14}.modal-assign-preview .media-thumb-modal,.modal-assign-preview .media-thumb--loading{width:100%;max-height:min(42vh,320px);object-fit:contain;display:block;margin:0 auto}.modal-assign-warning{color:var(--danger);font-size:.88rem;margin:0 0 .5rem}.margin-color-row{display:flex;align-items:center;gap:.75rem}.input-color-margin{width:52px;height:40px;padding:0;border:1px solid var(--border);border-radius:8px;cursor:pointer;background:transparent}.margin-hex-hint{font-size:.78rem;color:var(--muted)}.btn-pipette{display:flex;align-items:center;justify-content:center;width:44px;height:40px;padding:0;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--accent);cursor:pointer;flex-shrink:0}.btn-pipette:hover:not(:disabled){border-color:var(--muted);background:#ffffff0f}.btn-pipette:disabled{opacity:.45;cursor:not-allowed}.margin-pick-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:1.25rem;background:#000000b8}.margin-pick-panel{max-width:min(920px,100%);width:100%;padding:1rem 1.1rem 1.15rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);box-shadow:0 24px 48px #00000073}.margin-pick-hint{margin:0 0 .75rem;font-size:.88rem;color:var(--muted);text-align:center}.margin-pick-img{display:block;width:100%;max-height:min(72vh,640px);height:auto;margin:0 auto .85rem;object-fit:contain;cursor:crosshair;border-radius:8px;border:1px solid var(--border);background:var(--bg)}.margin-pick-loading{text-align:center;color:var(--muted);padding:2rem}.margin-pick-cancel{display:block;margin:0 auto}.modal-afficher-btn{width:100%;margin-top:.25rem}.media-edit-modal{max-width:520px}.media-edit-title-wrap{flex:1;min-width:0}.media-edit-title-click{margin:0;font-size:1rem;font-weight:600;cursor:pointer;color:var(--text);word-break:break-word;line-height:1.3}.media-edit-title-click:hover{color:var(--accent)}.media-edit-rename-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.media-edit-title-input{flex:1;min-width:0;padding:.5rem .65rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.9rem}.media-edit-crop-wrap{position:relative;width:100%;height:380px;background:#0a0a0b;border-radius:10px;overflow:hidden}.media-edit-crop-placeholder{height:380px;display:flex;align-items:center;justify-content:center;color:var(--muted);border-radius:10px;border:1px solid var(--border)}.media-edit-zoom{display:flex;align-items:center;gap:.75rem;margin:.85rem 0 .25rem;font-size:.82rem;color:var(--muted)}.media-edit-zoom input[type=range]{flex:1}.media-edit-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}
