@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}body{place-items:flex-start;min-width:320px;min-height:100vh;margin:0;display:flex}#root{width:100%;margin:0;padding:0}*,:before,:after{box-sizing:border-box;margin:0;padding:0}input:not([type=checkbox]):not([type=radio]),select,textarea{background:var(--bg-card)!important;color:var(--text-main)!important}input:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px var(--bg-card) inset!important;-webkit-text-fill-color:var(--text-main)!important}input:-webkit-autofill:hover{-webkit-box-shadow:0 0 0 1000px var(--bg-card) inset!important;-webkit-text-fill-color:var(--text-main)!important}input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px var(--bg-card) inset!important;-webkit-text-fill-color:var(--text-main)!important}input[type=number]::-webkit-inner-spin-button{background:var(--bg-card);opacity:1}input[type=number]::-webkit-outer-spin-button{background:var(--bg-card);opacity:1}:root{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-bg:#eff6ff;--bg-main:#fff;--bg-card:#fff;--bg-sidebar:#f8fafc;--bg-subtle:#f8fafc;--bg-hover:#f1f5f9;--header-bg:#fff;--text-main:#0f172a;--text-strong:#1e293b;--text-muted:#64748b;--text-secondary:#475569;--text-faint:#94a3b8;--border:#e2e8f0;--border-strong:#cbd5e1;--btn-primary-bg:#0f172a;--btn-primary-hover:#1e293b}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--primary:#3b82f6;--primary-hover:#2563eb;--primary-bg:#0f1f38;--bg-main:#060b14;--bg-card:#0d1525;--bg-sidebar:#080e1c;--bg-subtle:#080e1c;--bg-hover:#131f33;--header-bg:#0d1525;--text-main:#d1d9e6;--text-strong:#e8edf5;--text-muted:#7a8fa8;--text-secondary:#5d7490;--text-faint:#3a4e66;--border:#182235;--border-strong:#243348;--btn-primary-bg:#3b82f6;--btn-primary-hover:#2563eb;scrollbar-color:#243348 #080e1c;scrollbar-width:thin}[data-theme=dark] ::-webkit-scrollbar{width:7px;height:7px}[data-theme=dark] ::-webkit-scrollbar-track{background:#080e1c}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#243348;border-radius:4px}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#3a4e66}[data-theme=dark] ::-webkit-scrollbar-corner{background:#080e1c}body{background:var(--bg-main);color:var(--text-main);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,sans-serif}.layout{width:100%;min-height:100vh;display:flex}.content-area{background:var(--bg-main);flex-direction:column;flex:1;min-width:0;display:flex}.page-container{flex-direction:column;flex:1;width:100%;display:flex}.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border);flex-direction:column;width:280px;height:100vh;padding:2rem 1rem;display:flex;position:sticky;top:0}.sidebar-header{padding:0 .75rem 2.5rem}.logo-container{color:var(--text-main);align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;display:flex}.logo-icon{color:var(--primary)}.sidebar-nav{scrollbar-width:none;flex:1;min-height:0;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{display:none}.nav-group{margin-bottom:2.5rem}.nav-group-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;padding-left:.75rem;font-size:.7rem;font-weight:700}.sidebar-item{color:var(--text-muted);border-radius:.5rem;align-items:center;gap:.75rem;margin-bottom:.25rem;padding:.75rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.sidebar-item:hover{background:var(--bg-hover);color:var(--text-main)}button.sidebar-item{cursor:pointer;text-align:left;width:100%;font:inherit;background:0 0;border:none}.sidebar-item.active{background:var(--bg-card);color:var(--primary);border:1px solid var(--border);box-shadow:0 1px 3px #0000000d,0 1px 2px #00000005}.sidebar-footer{border-top:1px solid var(--border);padding:1.5rem .75rem 0}.user-info{align-items:center;gap:.75rem;display:flex}.user-avatar{background:var(--primary);color:#fff;border-radius:.5rem;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:600;display:flex}.user-details{flex:1}.user-name{color:var(--text-main);font-size:.8125rem;font-weight:600}.user-role{color:var(--text-muted);font-size:.75rem}.header{background:var(--bg-main);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.5rem 1rem;display:flex}.header-titles h1{color:var(--text-main);letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.subtitle{color:var(--text-muted);font-size:.875rem}.main{flex:1;padding:1.5rem 1rem}.state{text-align:center;color:var(--text-muted);padding:5rem;font-size:1rem}.state.error{color:#ef4444}.table-wrapper{border:1px solid var(--border);background:var(--bg-card);border-radius:.5rem;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.875rem}thead{background:var(--bg-subtle)}thead th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.65rem;font-weight:600}tbody tr{border-bottom:1px solid var(--border);cursor:pointer;transition:all .15s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg-hover)}tbody td{color:var(--text-main);padding:.875rem 1rem}.details-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.details-card{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 2px #0000000d}.details-card h3{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;border-bottom:1px solid var(--bg-hover);margin-bottom:1rem;padding-bottom:.5rem;font-size:.75rem}.piece-section{transition:transform .2s}.piece-section:hover{border-color:#3b82f6!important}.mini-table{border-collapse:collapse;width:100%;font-size:.85rem}.mini-table td{border-bottom:1px solid var(--bg-hover);padding:.4rem 0}.mini-table tr:last-child td{border-bottom:none}.cost-group{background:var(--bg-subtle);border-radius:6px;padding:1rem}.costs-grid{margin-top:1rem}.pieces-total-badge{border:1px solid var(--border);background:var(--bg-subtle,#f8fafc);border-radius:.5rem;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;width:fit-content;padding:.75rem 1.5rem;display:flex}.pieces-total-badge-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.7rem;font-weight:600}.pieces-total-badge-value{color:var(--text-main);font-size:1.4rem;font-weight:800}.devis-total-bar{border-bottom:2px solid var(--border);align-items:baseline;gap:2rem;margin-bottom:1rem;padding:0 0 .75rem;display:flex}.devis-total-main{flex-shrink:0;align-items:baseline;gap:.6rem;display:flex}.devis-total-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;font-weight:600}.devis-total-value{color:var(--text-main);letter-spacing:-.02em;font-size:1.6rem;font-weight:800}.devis-total-breakdown{color:var(--text-muted);flex-wrap:wrap;gap:.4rem 1.25rem;font-size:.78rem;display:flex}.devis-total-breakdown span{align-items:center;gap:.35rem;display:flex}.breakdown-dot{border-radius:2px;flex-shrink:0;width:7px;height:7px;display:inline-block}.info-item{justify-content:space-between;margin-bottom:.75rem;font-size:.875rem;display:flex}.info-label{color:var(--text-muted)}.info-value{font-weight:500}.mono{color:var(--text-muted);font-family:JetBrains Mono,SF Mono,monospace;font-size:.8rem}.prix{color:var(--text-main);font-variant-numeric:tabular-nums;font-weight:600}.page-actions{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.search-bar{align-items:center;width:280px;display:flex;position:relative}.search-bar-icon{color:var(--text-muted);pointer-events:none;flex-shrink:0;position:absolute;left:10px}.search-bar-input{border:1.5px solid var(--border);background:var(--bg-main);width:100%;color:var(--text-main);border-radius:8px;outline:none;padding:7px 32px 7px 34px;font-size:.85rem;transition:border-color .15s}.search-bar-input:focus{border-color:var(--primary,#2563eb)}.search-bar-input::placeholder{color:var(--text-muted)}.search-bar-clear{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;display:flex;position:absolute;right:8px}.search-bar-clear:hover{color:var(--text-main);background:var(--bg-subtle)}.pagination-footer{justify-content:center;align-items:center;margin-top:2rem;padding:1rem 0;display:flex}.pagination-container{align-items:center;gap:.5rem;display:flex}.pagination-numbers{gap:.25rem;display:flex}.pagination-number,.pagination-arrow{background:var(--bg-card);border:1px solid var(--border);min-width:2.25rem;height:2.25rem;color:var(--text-main);cursor:pointer;border-radius:.375rem;justify-content:center;align-items:center;padding:0 .5rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.pagination-number:hover,.pagination-arrow:hover:not(:disabled){background:var(--bg-subtle);border-color:var(--border-strong)}.pagination-number.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pagination-arrow:disabled{opacity:.4;cursor:not-allowed}.pagination-dots{color:var(--text-muted);padding:0 .5rem}.pagination-info{color:var(--text-muted);margin-left:1rem;font-size:.8125rem}.btn-new{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 1px 2px #2563eb33}.btn-new:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-back{background:var(--bg-card);color:var(--text-main);border:1px solid var(--border);cursor:pointer;border-radius:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.btn-back:hover{background:var(--bg-subtle);border-color:var(--border-strong)}.badge{background:var(--bg-hover);color:var(--text-secondary);border-radius:9999px;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:1rem;padding:3rem;box-shadow:0 1px 3px #0000000d}.devis-page-grid{grid-template-columns:3fr 2fr;align-items:stretch;gap:1.5rem;width:100%;min-width:0;display:grid}.devis-form-col{min-width:0}.devis-graph-col{flex-direction:row;align-items:stretch;gap:1rem;width:100%;min-width:0;display:flex}.tab-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:.4rem;padding:.3rem .85rem;font-size:.8rem;font-weight:600;transition:background .15s,color .15s}.tab-btn:hover{background:var(--bg-subtle,#f1f5f9);color:var(--text-main)}.tab-btn--active{background:var(--primary,#2563eb);border-color:var(--primary,#2563eb);color:#fff}.tab-btn--active:hover{background:var(--primary,#2563eb);color:#fff}.devis-chart-card{box-sizing:border-box;flex-direction:column;flex:1;justify-content:center;align-items:stretch;min-width:0;display:flex}.pie-chart-inner{flex-direction:column;flex:1;justify-content:space-between;align-items:center;gap:.75rem;width:100%;min-width:0;display:flex}.pie-svg{flex-shrink:0;width:100%;max-width:220px;height:auto}.pie-legend{flex-direction:column;flex:1;justify-content:center;gap:.35rem;width:100%;min-width:0;display:flex}.pie-legend-row{align-items:center;gap:.4rem;min-width:0;font-size:.75rem;display:flex}.pie-legend-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px}.pie-legend-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text-main);flex:1;overflow:hidden}.pie-legend-pct{color:var(--text-main);text-align:right;flex-shrink:0;min-width:2rem;font-weight:700}.pie-legend-val{color:var(--text-muted);text-align:right;flex-shrink:0;min-width:4.5rem;font-size:.7rem}@media (width<=900px){.devis-page-grid{grid-template-columns:1fr}.devis-graph-col{position:static}}.devis-form{flex-direction:column;gap:2rem;display:flex}.form-section{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem}.form-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:1.25rem;padding-bottom:.75rem;font-size:.8rem;font-weight:700}.form-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem;display:grid}.form-group{flex-direction:column;gap:.4rem;min-width:0;display:flex}.form-group--full{grid-column:1/-1}.form-group label{color:var(--text-main);font-size:.8125rem;font-weight:500}.form-group input,.form-group select{border:1px solid var(--border);width:100%;min-width:0;color:var(--text-main);background:var(--bg-card);border-radius:.5rem;outline:none;padding:.5rem .75rem;font-family:inherit;font-size:.875rem;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb14}.form-group input::placeholder{color:var(--text-faint)}.checkbox-label{cursor:pointer;align-items:center;gap:.5rem;padding-top:1.5rem;flex-direction:row!important;display:flex!important}.checkbox-label input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--primary)}.required{color:#ef4444}.login-page{background:linear-gradient(135deg,#1e40af 0%,#2563eb 50%,#3b82f6 100%);min-height:100vh;display:flex}.login-left{color:#fff;flex-direction:column;flex:1;justify-content:center;padding:4rem;display:flex}.login-logo{align-items:center;gap:.75rem;margin-bottom:3rem;display:flex}.login-logo-icon{background:#fff3;border-radius:.75rem;padding:.6rem;display:flex}.login-logo-name{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.login-left h1{letter-spacing:-.02em;margin-bottom:1rem;font-size:2.25rem;font-weight:700;line-height:1.2}.login-left p{opacity:.8;max-width:360px;font-size:1rem;line-height:1.6}.login-right{background:var(--bg-card);flex-direction:column;justify-content:center;width:460px;padding:3rem;display:flex}.login-form-wrap{width:100%;max-width:360px;margin:0 auto}.login-form-wrap h2{color:var(--text-main);letter-spacing:-.02em;margin-bottom:.375rem;font-size:1.5rem;font-weight:700}.login-form-wrap>p{color:var(--text-muted);margin-bottom:2rem;font-size:.875rem}.login-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca;border-radius:.5rem;margin-bottom:1.25rem;padding:.75rem 1rem;font-size:.875rem}.login-form{flex-direction:column;gap:1.25rem;display:flex}.login-field{flex-direction:column;gap:.375rem;display:flex}.login-field label{color:#374151;font-size:.8125rem;font-weight:600}.login-input{border:1.5px solid var(--border);color:var(--text-main);background:var(--bg-card);box-sizing:border-box;border-radius:.5rem;outline:none;width:100%;padding:.625rem .875rem;font-family:inherit;font-size:.9375rem;transition:border-color .15s}.login-input:focus{border-color:#2563eb}.login-submit{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:.5rem;width:100%;margin-top:.25rem;padding:.75rem;font-family:inherit;font-size:.9375rem;font-weight:600;transition:background .15s}.login-submit:hover:not(:disabled){background:#1d4ed8}.login-submit:disabled{cursor:not-allowed;background:#93c5fd}body:has(.modal-overlay){overflow:hidden}.modal-overlay{z-index:1000;background:#0000006b;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg-card);color:var(--text-strong);border-radius:10px;max-height:90vh;padding:24px;overflow-y:auto;box-shadow:0 8px 32px #0000002e}.modal-box--no-pad{background:var(--bg-card);border-radius:10px;flex-direction:column;max-height:85vh;display:flex;box-shadow:0 8px 40px #0003}.modal--sm{width:min(420px,94vw)}.modal--md{width:min(600px,94vw)}.modal--lg{width:min(1100px,96vw);height:95vh;max-height:95vh}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header--border{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.modal-title{color:var(--text-strong);margin:0;font-size:15px;font-weight:600}.modal-body{flex-direction:column;flex:1;gap:1rem;padding:20px 24px;display:flex;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;padding:14px 24px;display:flex}.field-label{color:var(--text-muted);margin-bottom:4px;font-size:12px;font-weight:600;display:block}.field-input{box-sizing:border-box;border:1.5px solid var(--border-strong);background:var(--bg-card);width:100%;color:var(--text-strong);border-radius:6px;outline:none;padding:7px 10px;font-size:14px;transition:border-color .15s}.field-input:focus{border-color:var(--primary,#2563eb)}.field-select{box-sizing:border-box;border:1.5px solid var(--border-strong);background:var(--bg-card);width:100%;color:var(--text-strong);cursor:pointer;border-radius:6px;outline:none;padding:7px 10px;font-size:14px}.field-group{margin-bottom:12px}.btn-icon{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex}.btn-icon:hover{color:var(--text-main);background:var(--bg-subtle)}.btn-icon--danger{cursor:pointer;color:#ef4444;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex}.btn-icon--danger:hover{background:#fef2f2}.btn-cancel{border:1px solid var(--border-strong);background:var(--bg-card);cursor:pointer;color:var(--text-strong);border-radius:6px;padding:6px 14px;font-size:13px}.btn-cancel:hover{background:var(--bg-subtle)}.btn-primary{background:var(--btn-primary-bg);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 14px;font-size:13px}.btn-primary:hover{background:var(--btn-primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.grid-2col{grid-template-columns:1fr 1fr;gap:0 12px;display:grid}.grid-3col{grid-template-columns:1fr 1fr 1fr;gap:0 12px;display:grid}.header-actions{align-items:center;gap:.75rem;display:flex}.table-fade{transition:opacity .15s}.error-msg{color:#dc2626;margin-bottom:8px;font-size:13px}.operation-tag{color:#0369a1;background:#e0f2fe;border-radius:12px;margin-bottom:2px;margin-right:4px;padding:1px 8px;font-size:12px;font-weight:500;display:inline-block}.field-label--upper{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px;font-size:11px;font-weight:600;display:block}.field-input--sm{box-sizing:border-box;border:1.5px solid var(--border-strong);background:var(--bg-card);width:100%;color:var(--text-strong);border-radius:6px;outline:none;padding:7px 10px;font-size:13px;transition:border-color .15s}.field-input--sm:focus{border-color:var(--primary,#2563eb)}.field-select--sm{box-sizing:border-box;border:1.5px solid var(--border-strong);background:var(--bg-card);width:100%;color:var(--text-strong);cursor:pointer;border-radius:6px;outline:none;padding:7px 10px;font-size:13px}.cost-row{border:1px solid var(--border);border-radius:8px;margin-bottom:12px;overflow:hidden}.cost-row--pad{border:1px solid var(--border);border-radius:8px;margin-bottom:12px;padding:12px;position:relative}.cost-row-header{background:var(--bg-subtle);border-bottom:1px solid var(--border);color:var(--text-secondary);justify-content:space-between;align-items:center;padding:8px 12px;font-size:12px;font-weight:600;display:flex}.cost-row-body{padding:12px}.cost-row-del{cursor:pointer;color:var(--text-faint);background:0 0;border:none;padding:2px;position:absolute;top:8px;right:8px}.btn-add-row{cursor:pointer;color:var(--text-muted);background:0 0;border:1.5px dashed #cbd5e1;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;display:inline-flex}.btn-add-row:hover{border-color:var(--text-faint);color:var(--text-secondary)}.modal-tabs{border-bottom:1px solid var(--border);padding:0 24px;display:flex}.modal-tab{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 14px;font-size:13px;font-weight:400;transition:color .15s}.modal-tab.active{color:var(--text-main);border-bottom-color:var(--text-main);font-weight:600}.btn-filters{border:1.5px solid var(--border);background:var(--bg-card);cursor:pointer;color:var(--text-muted);white-space:nowrap;border-radius:8px;align-items:center;gap:6px;padding:7px 12px;font-size:.875rem;transition:border-color .15s,color .15s;display:flex}.btn-filters:hover,.btn-filters--active{border-color:var(--primary);color:var(--primary)}.filters-badge{background:var(--primary);color:#fff;border-radius:10px;padding:1px 6px;font-size:.7rem;font-weight:700;line-height:1.4}.pieces-filter-panel{background:var(--bg-card);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px;padding:12px 24px;display:flex}.btn-filters-clear{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;padding:6px 10px;font-size:.8rem;transition:color .15s,background .15s;display:flex}.btn-filters-clear:hover{color:#ef4444;background:var(--bg-hover)}.filter-bar{flex-wrap:wrap;gap:12px;margin-bottom:1.5rem;display:flex}.filter-input{border:1px solid var(--border);border-radius:6px;outline:none;width:180px;padding:7px 12px;font-size:13px}.filter-select{border:1px solid var(--border);background:var(--bg-card);cursor:pointer;border-radius:6px;outline:none;width:200px;padding:7px 12px;font-size:13px}.tpp-hint{color:#2563eb;margin-bottom:12px;font-size:12px;font-weight:600}.mf-root{flex-direction:column;gap:1rem;display:flex}.mf-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.75rem;font-weight:600}.mf-shape-grid{grid-template-columns:repeat(3,1fr);gap:.4rem;display:grid}.mf-shape-btn{border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);cursor:pointer;border-radius:.5rem;flex-direction:column;align-items:center;gap:.3rem;padding:.5rem .25rem;font-size:.7rem;font-weight:500;transition:all .15s;display:flex}.mf-shape-btn.active{border:2px solid var(--primary);background:var(--primary-bg);color:var(--primary)}.mf-dim-grid{grid-template-columns:repeat(2,1fr);gap:.5rem;display:grid}.mf-dim-label{flex-direction:column;gap:.2rem;display:flex}.mf-dim-label span{color:var(--text-muted);font-size:.72rem;font-weight:500}.mf-dim-input{border:1px solid var(--border);background:var(--bg-card);color:var(--text-main);box-sizing:border-box;border-radius:.375rem;outline:none;width:100%;padding:.35rem .5rem;font-size:.875rem}.mf-canvas{border:1px solid var(--border);border-radius:.5rem;width:100%;height:220px;overflow:hidden}.mobile-topbar{display:none}@media (width<=1024px){.sidebar{z-index:200;height:100%;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.is-open{transform:translate(0)}.sidebar-overlay{z-index:199;background:#00000059;position:fixed;inset:0}.content-area{margin-left:0}.mobile-topbar{background:var(--sidebar-bg,#0f172a);color:#fff;z-index:100;align-items:center;gap:.75rem;padding:.625rem 1rem;display:flex;position:sticky;top:0}.hamburger-btn{color:#fff;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:4px;display:flex}.mobile-topbar-title{letter-spacing:.02em;font-size:1rem;font-weight:600}.sidebar-item{min-height:44px}}@media (width<=480px){.modal-grid-2col,.form-row-2col{grid-template-columns:1fr!important}}@media (width<=640px){.hide-mobile{display:none}table{white-space:nowrap;font-size:13px}.table-wrapper{-webkit-overflow-scrolling:touch}.header{flex-direction:column;align-items:flex-start;gap:.75rem}.header>div:last-child{flex-wrap:wrap;width:100%}.search-bar{width:100%;max-width:100%}.form-grid{grid-template-columns:1fr!important}.form-section{padding:1rem}.page-container{padding:.75rem}}@media (width<=1024px){.btn-new,.btn-back{min-height:44px;padding:0 1rem}td button{min-width:36px;min-height:36px}}@media (width<=640px){h1{font-size:1.2rem}.subtitle{font-size:.8rem}.header-titles h1{font-size:1.1rem}}.qr-hidden{opacity:0;pointer-events:none;position:absolute}.btn-icon-label{vertical-align:middle;margin-right:6px}.pd-top-grid{grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem;display:grid}.pd-top-grid>*{min-width:0}@media (width<=640px){.pd-top-grid{grid-template-columns:1fr}}.pd-pie{flex-direction:column;align-items:center;gap:.75rem;display:flex}.pd-pie-legend{flex-direction:column;gap:.3rem;width:100%;display:flex}.pd-pie-legend-item{align-items:center;gap:.5rem;font-size:.75rem;display:flex}.pd-pie-dot{border-radius:2px;flex-shrink:0;width:10px;height:10px}.pd-section-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:baseline;margin-bottom:1.25rem;padding-bottom:.75rem;display:flex}.pd-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0;font-size:.8rem;font-weight:700}.pd-section-total{color:var(--text-main);font-size:.875rem;font-weight:700}.pd-table-wrap{overflow-x:auto}.pd-table{border-collapse:collapse;width:100%;min-width:max-content;font-size:.85rem}.pd-table thead tr{background:var(--bg-subtle)}.pd-th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap;padding:.4rem .75rem;font-size:.7rem;font-weight:600}.pd-td{color:var(--text-main);border-bottom:1px solid var(--border);padding:.5rem .75rem}.pd-cost-layout{align-items:flex-start;gap:1.5rem;display:flex}.pd-cost-amounts{flex:1}.pd-cost-chart{flex-shrink:0;width:160px}.pd-cost-totals{border-top:2px solid var(--border);margin-top:.25rem;padding-top:.75rem}.info-item--lg{font-size:1rem;font-weight:700}.info-item--xl{font-size:1.1rem;font-weight:700}.pd-detail-title{margin-bottom:1rem;font-size:1rem;font-weight:700}.sm-page{background:var(--bg-subtle);flex-direction:column;align-items:center;min-height:100vh;padding:24px 16px;display:flex}.sm-header{text-align:center;width:100%;max-width:480px;margin-bottom:24px}.sm-brand{color:#2563eb;letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px;font-size:13px;font-weight:700}.sm-title{color:var(--text-main);margin:0 0 4px;font-size:20px;font-weight:700}.sm-subtitle{color:var(--text-muted);margin:0;font-size:14px}.sm-card{background:var(--bg-card);border-radius:12px;width:100%;max-width:480px;padding:24px;box-shadow:0 2px 12px #00000014}.sm-form{flex-direction:column;gap:16px;display:flex}.sm-label{color:var(--text-muted);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.sm-input{box-sizing:border-box;border:1.5px solid var(--border);border-radius:8px;outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:16px}.sm-input:focus{border-color:#2563eb}.sm-input--select{background:var(--bg-card);cursor:pointer}.sm-grid-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.sm-tpp{color:#1d4ed8;background:#eff6ff;border-radius:6px;padding:10px 14px;font-size:14px;font-weight:600}.sm-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:16px;font-weight:600;display:flex}.sm-btn:disabled{opacity:.7;cursor:not-allowed}.sm-btn--sm{width:auto;margin:0 auto;padding:12px 24px;font-size:15px;display:block}.sm-success{text-align:center;padding:16px 0}.sm-success-title{color:#16a34a;margin-bottom:8px;font-size:18px;font-weight:700}.sm-success-text{color:var(--text-muted);margin-bottom:24px;font-size:14px}.sm-error{color:#dc2626;margin:0;font-size:13px}.sm-section-title{color:var(--text-main);margin:0 0 4px;font-size:16px;font-weight:700}.sm-login-title{color:var(--text-main);margin-bottom:20px;font-size:16px;font-weight:700}.sm-state{text-align:center;color:var(--text-muted);margin:0}.sm-state--error{color:#dc2626}.qty-editable{cursor:text;border-radius:3px;align-items:center;gap:4px;padding:1px 4px;transition:background .15s;display:inline-flex}.qty-editable:hover{background:var(--bg-hover)}.qty-pencil{opacity:0;color:var(--text-muted);flex-shrink:0;transition:opacity .15s}.qty-editable:hover .qty-pencil{opacity:1}.rich-textarea-wrap{flex-direction:column;gap:0;display:flex}.rich-toolbar{background:var(--bg-hover);border:1.5px solid var(--border-strong);border-bottom:none;border-radius:6px 6px 0 0;gap:2px;padding:3px 6px;display:flex}.rich-btn{cursor:pointer;width:24px;height:24px;color:var(--text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.rich-btn:hover{background:var(--bg-card);color:var(--text-strong)}.rich-content{white-space:pre-wrap;overflow-wrap:break-word;word-break:break-word;border-radius:0 0 6px 6px!important}.rich-content b,.rich-content strong{font-weight:700}.rich-content i,.rich-content em{font-style:italic}.rich-content u{text-decoration:underline}.rich-content:empty:before{content:attr(data-placeholder);color:var(--text-muted);pointer-events:none}.rich-content:focus{border-color:var(--primary,#2563eb);outline:none}.kiosque-page .sm-header,.kiosque-page .sm-card{max-width:900px}.kiosque-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-top:12px;display:grid}.kiosque-btn-employe{background:var(--bg-card,#fff);border:2px solid var(--border,#e2e8f0);cursor:pointer;text-align:center;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:20px 12px;font-family:inherit;transition:border-color .15s,background .15s;display:flex}.kiosque-btn-employe:hover{border-color:var(--primary,#2563eb);background:#eff6ff}.kiosque-nom{color:var(--text-strong,#1e293b);font-size:1rem;font-weight:700}.kiosque-prenom{color:var(--text-muted,#64748b);font-size:.85rem}.kiosque-logout{color:var(--text-muted,#64748b);cursor:pointer;background:0 0;border:none;margin:24px auto 0;font-family:inherit;font-size:.85rem;text-decoration:underline;display:block}.kiosque-of{margin-bottom:20px}.kiosque-of-header{color:var(--text-muted,#64748b);border-bottom:1px solid var(--border,#e2e8f0);margin-bottom:8px;padding-bottom:4px;font-size:.85rem;font-weight:600}.kiosque-client{font-weight:400}.kiosque-pieces{flex-direction:column;gap:8px;display:flex}.kiosque-btn-piece{background:var(--bg-card,#fff);border:2px solid var(--border,#e2e8f0);cursor:pointer;text-align:left;border-radius:8px;justify-content:space-between;align-items:center;width:100%;padding:14px 16px;font-family:inherit;transition:border-color .15s,background .15s;display:flex}.kiosque-btn-piece:hover{border-color:var(--primary,#2563eb);background:#eff6ff}.kiosque-piece-nom{color:var(--text-strong,#1e293b);font-size:.95rem;font-weight:600}.kiosque-piece-qte{color:var(--text-muted,#64748b);white-space:nowrap;margin-left:12px;font-size:.82rem}.kiosque-recap{color:var(--text-muted,#64748b);margin:-8px 0 8px;font-size:.85rem}.kiosque-back{color:#fffc;cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;margin-top:4px;font-family:inherit;font-size:.85rem;display:flex}.kiosque-back:hover{color:#fff}
