.auth-bg{min-height:100vh;background:#f5f4f1;display:flex;align-items:center;justify-content:center;padding:20px}.auth-card{background:#fff;border:.5px solid rgba(0,0,0,.1);border-radius:14px;padding:36px 32px;width:100%;max-width:400px;box-shadow:0 2px 20px #0000000f}.auth-logo{font-size:22px;font-weight:500;color:#1d9e75;margin-bottom:2px;text-align:center}.auth-subtitle{font-size:13px;color:#888;text-align:center;margin-bottom:28px}.auth-title{font-size:17px;font-weight:500;margin-bottom:20px;color:#1a1a1a}.auth-form{display:flex;flex-direction:column;gap:0}.auth-field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.auth-field label{font-size:13px;color:#666;font-weight:500}.auth-field input{font-size:15px;padding:9px 11px;border:.5px solid rgba(0,0,0,.18);border-radius:8px;background:#f8f7f4;color:#1a1a1a;transition:border-color .15s,background .15s;width:100%}.auth-field input:focus{outline:none;border-color:#1d9e75;background:#fff}.auth-forgot{text-align:right;margin-bottom:16px;margin-top:-4px}.auth-forgot a{font-size:13px;color:#1d9e75;text-decoration:none}.auth-btn{width:100%;padding:10px;background:#1d9e75;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:opacity .15s;display:flex;align-items:center;justify-content:center;gap:6px;margin-top:4px;text-decoration:none}.auth-btn:hover{opacity:.88}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-error{background:#fcebeb;color:#a32d2d;border:.5px solid #F7C1C1;border-radius:8px;padding:9px 12px;font-size:14px;margin-bottom:16px;display:flex;align-items:center;gap:6px}.auth-success{background:#e1f5ee;color:#085041;border:.5px solid #9FE1CB;border-radius:8px;padding:20px;font-size:15px;text-align:center;line-height:1.6}.auth-switch{text-align:center;font-size:14px;color:#888;margin-top:20px}.auth-switch a{color:#1d9e75;text-decoration:none;font-weight:500}.auth-cgu{font-size:13px;color:#888;line-height:1.5;margin-bottom:14px}.auth-cgu a{color:#1d9e75;text-decoration:none}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:#fff;border-right:.5px solid rgba(0,0,0,.08);display:flex;flex-direction:column;overflow:hidden}.sidebar-logo{padding:18px;border-bottom:.5px solid rgba(0,0,0,.08);flex-shrink:0}.sidebar-logo-name{font-size:1.25rem;font-weight:700;color:#1d9e75}.sidebar-logo-sub{font-size:.78rem;color:#888;margin-top:2px}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:11px 18px;font-size:.95rem;color:#555;text-decoration:none;border-left:3px solid transparent;transition:all .15s}.nav-item:hover{background:#f5f4f1;color:#1a1a1a}.nav-item.active{background:#f5f4f1;color:#1d9e75;border-left-color:#1d9e75;font-weight:600}.nav-item i{font-size:1.2rem;width:22px;text-align:center;flex-shrink:0}.sidebar-footer{padding:14px 18px;border-top:.5px solid rgba(0,0,0,.08);flex-shrink:0}.sidebar-company{font-size:.9rem;font-weight:600;color:#1a1a1a;margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-logout{display:flex;align-items:center;gap:6px;font-size:.85rem;color:#888;background:none;border:none;cursor:pointer;padding:0;font-family:inherit;transition:color .15s}.sidebar-logout:hover{color:var(--danger)}.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#f5f4f1}.stepper{display:flex;gap:0;margin-bottom:14px;background:#f0efe9;border-radius:10px;padding:3px}.stepper-item{flex:1;text-align:center;padding:6px 2px;border-radius:8px;font-size:14px;cursor:pointer;color:#888;transition:all .15s;-webkit-user-select:none;user-select:none}.stepper-item.active{background:#fff;color:#1d9e75;font-weight:500;border:.5px solid rgba(0,0,0,.08)}.stepper-item.done{color:#1d9e75}.cfg-section-label{font-size:13px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.05em;margin:8px 0 5px;padding-bottom:4px;border-bottom:.5px solid rgba(0,0,0,.08)}.cfg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;margin-bottom:4px}.cfg-item{cursor:pointer;border:1.5px solid rgba(0,0,0,.1);border-radius:8px;padding:5px;text-align:center;transition:all .15s;background:#f8f7f4}.cfg-item:hover,.cfg-item.active{border-color:#1d9e75;background:#e1f5ee}.cfg-item-label{font-size:12px;color:#888;margin-top:2px}.cfg-item.active .cfg-item-label{color:#0f6e56;font-weight:500}.win-wrap{background:#6e6e6e;border-radius:10px;overflow:hidden;width:100%;height:560px;display:flex;align-items:center;justify-content:center;margin-bottom:6px}.win-wrap svg{width:100%;height:100%;display:block}.cfg-hint{font-size:13px;color:#aaa;text-align:center;margin-bottom:8px}.qbtn{width:22px;height:22px;border-radius:4px;border:.5px solid rgba(0,0,0,.12);background:#f5f4f1;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .15s}.qbtn:hover{background:#e1f5ee;border-color:#1d9e75}.upload-zone{border:2px dashed rgba(0,0,0,.15);border-radius:8px;padding:16px;text-align:center;cursor:pointer;transition:all .15s;background:#f8f7f4}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000007a;display:flex;align-items:center;justify-content:center;z-index:9999}.modal-box{background:#fff;border-radius:14px;padding:16px;width:320px;max-height:85vh;overflow-y:auto;box-shadow:0 8px 32px #00000038}.modal-header{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:500;margin-bottom:12px}.ouv-section-label{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#888;margin-bottom:6px;margin-top:6px}.ouv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;margin-bottom:6px}.ouv-item{display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:5px 2px;border-radius:7px;border:1.5px solid rgba(0,0,0,.1);background:#f8f7f4;transition:all .15s}.ouv-item:hover,.ouv-item.selected{border-color:#1d9e75;background:#e1f5ee}.ouv-label{font-size:12px;color:#888;text-align:center}.ouv-item.selected .ouv-label{color:#0f6e56;font-weight:500}.form-error{background:#fcebeb;color:#a32d2d;border:.5px solid #F7C1C1;border-radius:7px;padding:8px 11px;font-size:13px;margin-bottom:10px}.filter-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.filter-btn{padding:4px 11px;border-radius:20px;font-size:13px;cursor:pointer;border:.5px solid rgba(0,0,0,.12);background:#f5f4f1;color:#666;transition:all .15s;-webkit-user-select:none;user-select:none}.filter-btn:hover{background:#ebe9e2;color:#1a1a1a}.filter-btn.active{background:#1d9e75;color:#fff;border-color:#1d9e75}.tabs{display:flex;border-bottom:.5px solid rgba(0,0,0,.1);margin-bottom:14px}.tab{padding:7px 14px;font-size:14px;cursor:pointer;color:#888;border-bottom:2px solid transparent;margin-bottom:-.5px;transition:all .15s}.tab:hover{color:#1a1a1a}.tab.active{color:#1d9e75;border-bottom-color:#1d9e75;font-weight:500}.mat-pills{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:11px}.mat-pill{padding:3px 10px;border-radius:20px;font-size:13px;cursor:pointer;border:.5px solid rgba(0,0,0,.12);background:#f5f4f1;color:#666;transition:all .15s}.mat-pill:hover{background:#ebe9e2}.mat-pill.pvc{background:#e6f1fb;border-color:#185fa5;color:#0c447c}.mat-pill.alu{background:#eeedfe;border-color:#534ab7;color:#3c3489}.mat-pill.bois{background:#faeeda;border-color:#ef9f27;color:#633806}.item-row{display:flex;align-items:center;gap:8px;padding:8px 11px;background:#f8f7f4;border-radius:8px;margin-bottom:5px;border:.5px solid rgba(0,0,0,.08)}.item-row-name{font-size:14px;font-weight:500;flex:1}.item-row-sub{font-size:13px;color:#888;flex:1}.color-swatch{width:14px;height:14px;border-radius:50%;border:.5px solid rgba(0,0,0,.18);flex-shrink:0}.prog-bar{height:5px;background:#ebe9e2;border-radius:3px;overflow:hidden;margin-top:3px}.prog-fill{height:100%;border-radius:3px}.avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000075;display:flex;align-items:center;justify-content:center;z-index:9999}.modal-box{background:#fff;border-radius:14px;padding:18px;width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-header{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:500;margin-bottom:14px}.modal-close{background:none;border:none;cursor:pointer;font-size:16px;color:#888;line-height:1;padding:2px}.modal-close:hover{color:#1a1a1a}.upload-zone{border:2px dashed rgba(0,0,0,.13);border-radius:8px;padding:16px;text-align:center;cursor:pointer;background:#f8f7f4;transition:all .15s}.upload-zone:hover{border-color:#1d9e75;background:#e1f5ee}.bar-chart{display:flex;align-items:flex-end;gap:6px;height:100px}.bc-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}.bc-bar{width:100%;border-radius:3px 3px 0 0;min-height:3px}.bc-lbl{font-size:12px;color:#888}.bc-val{font-size:12px;font-weight:500}.alert{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;border-radius:8px;font-size:14px;margin-bottom:10px}.alert-warn{background:#faeeda;color:#854f0b;border:.5px solid #FAC775}.alert-info{background:#e6f1fb;color:#185fa5;border:.5px solid #B5D4F4}.alert-success{background:#e1f5ee;color:#085041;border:.5px solid #9FE1CB}.toggle{width:36px;height:20px;border-radius:10px;cursor:pointer;position:relative;flex-shrink:0;transition:background .2s}.toggle-thumb{width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:2px;transition:left .2s}.toggle.on{background:#1d9e75}.toggle.off{background:#d0cfc9}.toggle.on .toggle-thumb{left:18px}.toggle.off .toggle-thumb{left:2px}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:.5px solid rgba(0,0,0,.06);font-size:14px}.stat-row:last-child{border:none}.accent-dot{width:20px;height:20px;border-radius:50%;border:.5px solid rgba(0,0,0,.15);cursor:pointer}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:17px}:root{--accent: #1D9E75;--accent-dark: #085041;--accent-light: #E1F5EE;--danger: #E24B4A;--warning: #EF9F27;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--sidebar-w: 200px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1rem;color:#1a1a1a;background:#f5f4f1;line-height:1.6;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d0cfc9;border-radius:3px}@keyframes spin{to{transform:rotate(360deg)}}.spin{display:inline-block;animation:spin .7s linear infinite}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:2rem;color:var(--accent)}.btn{border:1px solid #d0cfc9;border-radius:8px;padding:10px 18px;font-size:1rem;cursor:pointer;background:transparent;color:#1a1a1a;transition:background .15s;display:inline-flex;align-items:center;gap:7px;font-family:inherit}.btn:hover{background:#f0efe9}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{opacity:.88;background:var(--accent)}.btn-danger{color:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:#fcebeb}.btn-sm{padding:7px 13px;font-size:.88rem}.badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.82rem;font-weight:600}.badge-ok{background:#e1f5ee;color:#085041}.badge-warn{background:#faeeda;color:#854f0b}.badge-danger{background:#fcebeb;color:#791f1f}.badge-info{background:#e6f1fb;color:#0c447c}.badge-gray{background:#f1efe8;color:#5f5e5a}.badge-pro{background:#eeedfe;color:#3c3489}.card{background:#fff;border:.5px solid rgba(0,0,0,.1);border-radius:12px;padding:20px;margin-bottom:16px}.card-header{font-size:1rem;font-weight:600;margin-bottom:16px;padding-bottom:12px;border-bottom:.5px solid rgba(0,0,0,.08);display:flex;align-items:center;justify-content:space-between}.metric{background:#f0efe9;border-radius:8px;padding:18px}.metric-label{font-size:.85rem;color:#666;margin-bottom:7px}.metric-value{font-size:1.7rem;font-weight:600}.metric-sub{font-size:.82rem;margin-top:5px;color:#666}.metric-up{color:#0f6e56}.metric-down{color:#a32d2d}.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.mb{margin-bottom:18px}.data-table{width:100%;border-collapse:collapse;font-size:1rem}.data-table th{text-align:left;padding:12px 14px;color:#555;font-weight:600;border-bottom:.5px solid rgba(0,0,0,.08);font-size:.88rem}.data-table td{padding:14px;border-bottom:.5px solid rgba(0,0,0,.06);vertical-align:middle}.data-table tr:last-child td{border:none}.data-table tr:hover td{background:#f8f7f4}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:.9rem;color:#444;font-weight:600}.field input,.field select,.field textarea{font-size:1rem;padding:11px 13px;border:1px solid rgba(0,0,0,.18);border-radius:8px;background:#f8f7f4;color:#1a1a1a;width:100%;font-family:inherit;transition:border-color .15s}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:#fff}.page-topbar{height:56px;background:#fff;border-bottom:.5px solid rgba(0,0,0,.08);display:flex;align-items:center;justify-content:space-between;padding:0 22px;flex-shrink:0}.page-topbar-title{font-size:1.2rem;font-weight:700}.page-content{flex:1;overflow-y:auto;padding:22px}
