.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:210px;flex-shrink:0;background:#fff;border-right:.5px solid rgba(0,0,0,.08);display:flex;flex-direction:column;overflow:hidden;transition:transform .25s ease;z-index:200}.sidebar-logo{padding:14px 16px;border-bottom:.5px solid rgba(0,0,0,.08);flex-shrink:0}.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;min-width:0}.mobile-topbar{display:none;align-items:center;justify-content:space-between;padding:10px 14px;background:#fff;border-bottom:.5px solid rgba(0,0,0,.08);flex-shrink:0}.hamburger-btn{width:40px;height:40px;border:none;background:none;cursor:pointer;font-size:24px;color:#1d9e75;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .15s}.hamburger-btn:hover{background:#f0efe9}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:199}@media (max-width: 768px){.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0);box-shadow:4px 0 20px #0003}.sidebar-overlay{display:block}.mobile-topbar{display:flex}.app-main{width:100%}.g2,.g3{grid-template-columns:1fr!important}.g4{grid-template-columns:repeat(2,minmax(0,1fr))!important}.data-table{font-size:13px}.page-content{padding:12px}.page-topbar{padding:0 12px;height:56px}.page-topbar-title{font-size:1.25rem}.btn-sm{font-size:13px;padding:8px 14px}.page-topbar-full{height:auto!important;flex-direction:column;align-items:stretch;padding:10px 12px!important;gap:8px}.page-topbar-full .btn-primary{width:100%;justify-content:center}}.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}.upload-zone:hover{border-color:#1d9e75;background:#e1f5ee}.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}.modal-close{background:none;border:none;cursor:pointer;font-size:16px;color:#888;line-height:1;padding:2px}.modal-close:hover{color:#1a1a1a}.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}@media (max-width: 768px){.cfg-layout{grid-template-columns:1fr!important}.cfg-grid{grid-template-columns:repeat(3,1fr)!important}}.metrics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.metric{background:#fff;border:.5px solid rgba(0,0,0,.08);border-radius:10px;padding:14px 16px}.metric-label{font-size:12px;color:#888;margin-bottom:4px;white-space:nowrap}.metric-value{font-size:1.6rem;font-weight:700;color:#1a1a1a;line-height:1.1}.metric-sub{font-size:11px;color:#aaa;margin-top:3px}.metric-up{color:#1d9e75!important}.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.mb{margin-bottom:14px}.card{background:#fff;border:.5px solid rgba(0,0,0,.08);border-radius:10px;padding:14px 16px}.card-header{font-size:13px;font-weight:600;color:#1a1a1a;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}.data-table{width:100%;border-collapse:collapse;font-size:12px}.data-table th{padding:9px 12px;text-align:left;font-size:11px;font-weight:600;color:#888;border-bottom:.5px solid rgba(0,0,0,.08);white-space:nowrap}.data-table td{padding:10px 12px;border-bottom:.5px solid #f5f5f5;vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:#fafafa}.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.badge-warn{background:#fef3e2;color:#92400e}.badge-gray{background:#f3f4f6;color:#6b7280}.badge-danger{background:#fee2e2;color:#991b1b}.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:8px;border:.5px solid rgba(0,0,0,.15);background:#fff;color:#333;font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}.btn:hover{background:#f5f4f1}.btn-primary{background:#1d9e75;color:#fff;border-color:#1d9e75}.btn-primary:hover{background:#178a64}.btn-danger{color:#e24b4a;border-color:#fca5a5}.btn-danger:hover{background:#fee2e2}.btn-sm{padding:5px 10px;font-size:12px;border-radius:6px}.filter-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.filter-btn{padding:5px 12px;border-radius:20px;border:.5px solid rgba(0,0,0,.15);background:#fff;font-size:12px;cursor:pointer;color:#555;transition:all .15s;white-space:nowrap}.filter-btn:hover{background:#f0efe9}.filter-btn.active{background:#1d9e75;color:#fff;border-color:#1d9e75;font-weight:600}.page-topbar{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:60px;background:#fff;border-bottom:.5px solid rgba(0,0,0,.08);flex-shrink:0}.page-topbar-title{font-size:1.4rem;font-weight:700;color:#1a1a1a}.page-content{flex:1;overflow-y:auto;padding:16px 20px}.field{margin-bottom:12px}.field label{display:block;font-size:12px;font-weight:600;color:#555;margin-bottom:4px}.field input,.field select,.field textarea{width:100%;padding:8px 11px;border:.5px solid rgba(0,0,0,.2);border-radius:8px;font-size:13px;font-family:inherit;background:#fff;color:#1a1a1a;box-sizing:border-box;transition:border-color .15s}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:#1d9e75}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-box{background:#fff;border-radius:14px;padding:20px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-header{display:flex;align-items:center;justify-content:space-between;font-size:15px;font-weight:700;margin-bottom:16px;color:#1a1a1a}.modal-close{background:none;border:none;cursor:pointer;font-size:18px;color:#888;padding:2px;line-height:1}.avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.bar-chart{display:flex;align-items:flex-end;gap:6px;padding:4px 0 0}.bc-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}.bc-val{font-size:8px;color:#aaa}.bc-bar{width:100%;border-radius:3px 3px 0 0;min-height:3px}.bc-lbl{font-size:9px;color:#aaa}.prog-bar{height:7px;background:#f0efe9;border-radius:4px;overflow:hidden}.prog-fill{height:100%;border-radius:4px;transition:width .4s ease}.spin{animation:spin .7s linear infinite;display:inline-block}.tabs{display:flex;gap:4px;border-bottom:1.5px solid #e8e8e8;margin-bottom:16px}.tab{padding:7px 16px;font-size:13px;font-weight:500;color:#888;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1.5px;transition:all .15s}.tab:hover{color:#1d9e75}.tab.active{color:#1d9e75;border-bottom-color:#1d9e75;font-weight:600}.mat-pills{display:flex;gap:6px;margin-bottom:14px}.mat-pill{padding:5px 14px;border-radius:20px;border:.5px solid rgba(0,0,0,.15);background:#fff;font-size:12px;cursor:pointer;color:#555;transition:all .15s}.mat-pill:hover{background:#f0efe9}.mat-pill.pvc{background:#e1f5ee;color:#085041;border-color:#9fe1cb;font-weight:600}.mat-pill.alu{background:#eef2ff;color:#3730a3;border-color:#a5b4fc;font-weight:600}.mat-pill.bois{background:#fef3e2;color:#92400e;border-color:#fcd34d;font-weight:600}.item-row{display:flex;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid #f0f0f0}.item-row:last-of-type{border-bottom:none}.item-row-name{font-size:13px;font-weight:500;color:#1a1a1a;flex:1}.item-row-sub{font-size:11px;color:#aaa;flex:2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.color-swatch{width:20px;height:20px;border-radius:50%;border:.5px solid rgba(0,0,0,.15);flex-shrink:0}.badge-info{background:#eef2ff;color:#3730a3}.devis-cards-mobile{display:none}.devis-table-desktop{display:table}.clients-cards-mobile{display:none}.clients-table-desktop{display:table}@media (max-width: 768px){.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.devis-cards-mobile{display:block}.devis-table-desktop{display:none}.clients-cards-mobile{display:block}.clients-table-desktop{display:none}}*,*: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-regle{background:#085041;color:#fff}.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}@media (max-width: 768px){html{font-size:15px}.btn{padding:8px 12px;font-size:.9rem}.btn-sm{padding:5px 10px;font-size:.8rem}.card{padding:14px}.g2,.g3,.g4{grid-template-columns:1fr!important;gap:10px}.data-table th,.data-table td{padding:10px 8px;font-size:.82rem}.field input,.field select,.field textarea{font-size:.95rem;padding:10px 11px}.win-wrap{min-height:220px!important;height:220px!important}}
