:root{--navy: #1B2D6B;--navy-2: #243980;--navy-3: #EEF2FF;--green: #059669;--green-2:#D1FAE5;--green-3:#065F46;--bg: #F1F5F9;--surface:#FFFFFF;--surface-2:#F8FAFC;--border: #E2E8F0;--border-2:#CBD5E1;--text: #0F172A;--text-2:#475569;--text-3:#94A3B8;--amber: #D97706;--amber-2:#FEF3C7;--amber-3:#92400E;--red: #DC2626;--red-2: #FEF2F2;--purple: #7C3AED;--purple-2:#EDE9FE;--blue: #2563EB;--blue-2: #EFF6FF;--teal: #0D9488;--teal-2: #CCFBF1;--font: "Inter", system-ui, sans-serif;--mono: "JetBrains Mono", monospace;--sidebar: 230px;--radius: 8px;--radius-lg:12px;--radius-xl:16px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 8px rgba(0,0,0,.04);--shadow-md:0 4px 20px rgba(0,0,0,.1);--shadow-lg:0 8px 40px rgba(0,0,0,.15)}@media (prefers-color-scheme: dark){:root{--navy: #7B9BFF;--navy-2: #5A7DE0;--navy-3: #202020;--green: #4ADE80;--green-2:#1A3A2A;--green-3:#86EFAC;--bg: #1A1A1A;--surface:#262626;--surface-2:#2E2E2E;--border: #3A3A3A;--border-2:#4A4A4A;--text: #E8E8E8;--text-2:#B0B0B0;--text-3:#787878;--amber: #FBBF24;--amber-2:#3D2800;--amber-3:#FDE68A;--red: #F87171;--red-2: #3D1010;--purple: #A78BFA;--purple-2:#2A1A4A;--blue: #7BB8FF;--blue-2: #1A2A4A;--teal: #5EEAD4;--teal-2: #0A2A2A;--shadow: 0 1px 3px rgba(0,0,0,.4), 0 1px 8px rgba(0,0,0,.3);--shadow-md:0 4px 20px rgba(0,0,0,.5);--shadow-lg:0 8px 40px rgba(0,0,0,.6)}.b-draft,.b-closed,.b-pending{background:#333!important;color:#888!important}.b-active,.b-completed{background:#1a3a2a!important;color:#4ade80!important}.b-sent,.b-won{background:#1a2a4a!important;color:#7bb8ff!important}.b-lost,.b-overdue{background:#3d1010!important;color:#f87171!important}.b-hold,.b-revised{background:#3d2800!important;color:#fbbf24!important}input,select,textarea{background:#2e2e2e!important;color:#e8e8e8!important;border-color:#3a3a3a!important}.table-wrap table tbody tr:hover{background:#2e2e2e!important}.card,.stat-card{background:#262626;border-color:#3a3a3a}.project-card{background:#262626!important}.sidebar{background:#1a1a1a!important;border-right:1px solid #3A3A3A}.nav-item.active{background:#333!important;color:#4ade80!important}.sidebar-section{color:#787878!important}.bom-table thead tr{background:#333!important}.bom-table thead th{color:#b0b0b0!important}.bom-table tbody tr:hover{background:#2e2e2e!important}[style*="background: white"],[style*="background:white"]{background:#262626!important}.quote-preview-wrap table tr:nth-child(2n){background:#2e2e2e!important}.quote-preview-wrap table tr:nth-child(odd){background:#262626!important}.quote-preview-wrap table th{color:#b0b0b0!important}.quote-preview-wrap [style*=navy]{color:#7b9bff!important}.tab-bar{background:var(--surface)!important;border-color:#3a3a3a!important}.tab-btn{color:#787878!important}.tab-btn.active{color:#7b9bff!important;border-bottom-color:#4ade80!important}.progress-bar{background:#3a3a3a!important}.info-box{background:#1a2a4a!important;border-color:#3a3a3a!important;color:#7bb8ff!important}.warn-box{background:#3d2800!important;border-color:#3a3a3a!important;color:#fbbf24!important}.success-box{background:#1a3a2a!important;border-color:#3a3a3a!important;color:#4ade80!important}.app-header{background:#262626;border-color:#3a3a3a}.login-wrap{background:#1a1a1a}.login-card{background:#262626}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}#root{min-height:100vh}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:4px}a{text-decoration:none;color:inherit}button,input,select,textarea{font-family:var(--font)}.login-page{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy) 0%,#1e3a8a 50%,#312e81 100%);padding:16px}.login-card{background:var(--surface);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.login-logo{text-align:center;margin-bottom:24px}.login-logo img{height:56px;background:#fff;border-radius:10px;padding:6px 12px}.login-title{font-size:18px;font-weight:700;color:var(--navy);text-align:center;margin-bottom:4px}.login-sub{font-size:12px;color:var(--text-3);text-align:center;margin-bottom:28px}.sidebar{width:var(--sidebar);min-width:var(--sidebar);background:var(--navy);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:50}.sidebar-logo{padding:16px 14px 14px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:10px}.sidebar-logo img{height:32px;flex-shrink:0;background:#fff;border-radius:6px;padding:3px 6px}.sidebar-logo-name{font-size:11px;font-weight:700;color:#ffffffe6;line-height:1.3}.sidebar-logo-sub{font-size:9px;color:#fff6;margin-top:2px}.sidebar-section{padding:16px 14px 5px;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#ffffff4d}.sidebar-nav{flex:1;padding:6px 8px;overflow-y:auto}.nav-group{margin-bottom:2px}.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--radius);cursor:pointer;color:#fff9;font-size:12.5px;font-weight:400;transition:all .15s;margin-bottom:2px;border:none;background:none;width:100%;text-align:left;text-decoration:none}.nav-item:hover{background:#ffffff14;color:#ffffffe6}.nav-item.active{background:var(--green);color:#fff;font-weight:600}.nav-item svg{width:15px;height:15px;flex-shrink:0}.nav-item .badge-count{margin-left:auto;background:var(--red);color:#fff;border-radius:10px;padding:0 6px;font-size:10px;font-weight:700;min-width:18px;text-align:center}.sidebar-user{padding:12px;border-top:1px solid rgba(255,255,255,.1)}.user-chip{background:#ffffff14;border-radius:var(--radius);padding:10px 12px;display:flex;align-items:center;justify-content:space-between}.user-name{font-size:12px;font-weight:600;color:#fff}.user-role{font-size:10px;color:#ffffff80;margin-top:2px}.main-area{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.page-header{background:var(--surface);border-bottom:1px solid var(--border);padding:14px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:20;gap:12px}.page-title{font-size:16px;font-weight:700;color:var(--navy)}.page-sub{font-size:12px;color:var(--text-3);margin-top:2px}.page-body{padding:20px 24px;flex:1;overflow-y:auto}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow)}.card-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:14px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow)}.stat-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:6px}.stat-num{font-family:var(--mono);font-size:26px;font-weight:700;color:var(--navy);line-height:1}.stat-sub{font-size:11px;color:var(--text-3);margin-top:4px}.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:14px}.g21{display:grid;grid-template-columns:2fr 1fr;gap:16px}.g31{display:grid;grid-template-columns:3fr 1fr;gap:16px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;border:1px solid transparent;font-family:var(--font);white-space:nowrap;line-height:1}.btn-navy{background:var(--navy);color:#fff}.btn-navy:hover{filter:brightness(1.15)}.btn-green{background:var(--green);color:#fff}.btn-green:hover{filter:brightness(1.1)}.btn-outline{background:transparent;color:var(--text-2);border-color:var(--border-2)}.btn-outline:hover{background:var(--bg)}.btn-ghost{background:transparent;color:var(--text-3);border-color:transparent}.btn-ghost:hover{background:var(--bg);color:var(--text-2)}.btn-danger{background:transparent;color:var(--red);border-color:var(--red)}.btn-danger:hover{background:var(--red);color:#fff}.btn-amber{background:var(--amber);color:#fff}.btn-amber:hover{filter:brightness(1.1)}.btn-sm{padding:5px 11px;font-size:12px}.btn-lg{padding:11px 22px;font-size:14px}.btn-icon{padding:7px;border-radius:var(--radius)}.btn:disabled{opacity:.4;cursor:not-allowed}.w-full{width:100%;justify-content:center}.form-group{margin-bottom:14px}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}label{display:block;font-size:11px;font-weight:600;color:var(--text-2);margin-bottom:5px;letter-spacing:.03em;text-transform:uppercase}input,select,textarea{width:100%;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius);color:var(--text);font-size:13px;padding:8px 11px;transition:border-color .15s;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1b2d6b14}select{cursor:pointer}textarea{resize:vertical;min-height:80px}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;-moz-appearance:none;appearance:none}input[type=checkbox]{width:auto;margin:0}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border)}table{width:100%;border-collapse:collapse}thead tr{background:var(--navy)}thead th{padding:9px 13px;text-align:left;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#ffffffb3;white-space:nowrap}tbody tr{border-bottom:1px solid var(--border);transition:background .1s}tbody tr:hover{background:var(--bg)}tbody tr:last-child{border-bottom:none}td{padding:10px 13px;font-size:13px;color:var(--text);vertical-align:middle}td.mono{font-family:var(--mono);font-size:12px}td.dim{color:var(--text-3)}td.num{text-align:right;font-family:var(--mono);font-size:12px}td.act{text-align:right;white-space:nowrap}.tr-click{cursor:pointer}.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.b-draft{background:#f1f5f9;color:#64748b}.b-active{background:#d1fae5;color:#065f46}.b-sent{background:#eff6ff;color:#2563eb}.b-won{background:#d1fae5;color:#065f46}.b-lost{background:#fef2f2;color:#dc2626}.b-hold{background:#fef3c7;color:#92400e}.b-closed{background:#f1f5f9;color:#64748b}.b-revised{background:#fef3c7;color:#92400e}.b-pending{background:#f8fafc;color:#94a3b8}.b-completed{background:#d1fae5;color:#065f46}.b-overdue,.b-delayed{background:#fef2f2;color:#dc2626}.b-bfl{background:#eef2ff;color:#1b2d6b}.b-deif{background:#ede9fe;color:#7c3aed}.b-flovel{background:#d1fae5;color:#065f46}.b-woodward{background:#fef3c7;color:#92400e}.b-high{background:#fef2f2;color:#dc2626}.b-medium{background:#fef3c7;color:#92400e}.b-low{background:#d1fae5;color:#065f46}.b-critical{background:#dc2626;color:#fff}.b-major{background:#fef2f2;color:#dc2626}.b-minor{background:#fef3c7;color:#92400e}.progress-bar{height:6px;background:var(--border);border-radius:6px;overflow:hidden}.progress-fill{height:100%;border-radius:6px;transition:width .3s;background:var(--green)}.progress-fill.amber{background:var(--amber)}.progress-fill.red{background:var(--red)}.stage-track{display:flex;align-items:center;gap:0;overflow-x:auto;padding:4px 0}.stage-item{display:flex;align-items:center;flex-shrink:0}.stage-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;border:2px solid var(--border-2);background:var(--bg);transition:all .2s;cursor:default}.stage-dot.done{background:var(--green);border-color:var(--green)}.stage-dot.active{background:var(--navy);border-color:var(--navy);box-shadow:0 0 0 4px var(--navy-3)}.stage-dot.delayed{background:var(--red);border-color:var(--red)}.stage-line{width:32px;height:2px;background:var(--border-2);flex-shrink:0}.stage-line.done{background:var(--green)}.stage-label{font-size:10px;color:var(--text-3);text-align:center;margin-top:4px;max-width:60px;white-space:nowrap}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-height:90vh;overflow-y:auto}.modal-sm{max-width:420px}.modal-md{max-width:580px}.modal-lg{max-width:780px}.modal-xl{max-width:960px}.modal-hdr{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:15px;font-weight:700;color:var(--navy)}.modal-body{padding:22px}.modal-ftr{padding:14px 22px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}.toast-container{position:fixed;top:16px;right:16px;z-index:2000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--green);border-radius:var(--radius);padding:11px 16px;font-size:13px;color:var(--text);box-shadow:var(--shadow-md);animation:toastIn .2s ease;max-width:320px;pointer-events:all}.toast.err{border-left-color:var(--red)}.toast.warn{border-left-color:var(--amber)}.toast.info{border-left-color:var(--blue)}@keyframes toastIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.notif-dot{width:8px;height:8px;background:var(--red);border-radius:50%;position:absolute;top:-2px;right:-2px}.notif-panel{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:360px;max-height:480px;overflow-y:auto;z-index:200}.notif-item{padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.notif-item:hover{background:var(--bg)}.notif-item.unread{background:var(--blue-2)}.notif-title{font-size:13px;font-weight:500;margin-bottom:3px}.notif-msg{font-size:11px;color:var(--text-3)}.notif-time{font-size:10px;color:var(--text-3);margin-top:3px}.search-row{display:flex;gap:10px;margin-bottom:14px;align-items:center}.search-wrap{position:relative;flex:1}.search-wrap input{padding-left:34px}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-3);width:15px;height:15px}.tab-bar{display:flex;gap:2px;border-bottom:2px solid var(--border);margin-bottom:20px}.tab-btn{padding:9px 18px;font-size:13px;font-weight:400;color:var(--text-3);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-family:var(--font);transition:all .15s;margin-bottom:-2px}.tab-btn:hover{color:var(--text-2)}.tab-btn.active{color:var(--navy);font-weight:600;border-bottom-color:var(--navy)}.section-hdr{background:var(--navy-3);border-left:3px solid var(--navy);padding:8px 14px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--navy);margin:18px 0 12px;display:flex;align-items:center;gap:8px}.timeline{display:flex;flex-direction:column;gap:0}.tl-item{display:flex;gap:12px;position:relative}.tl-item:before{content:"";position:absolute;left:15px;top:32px;bottom:-4px;width:1px;background:var(--border)}.tl-item:last-child:before{display:none}.tl-dot{width:30px;height:30px;border-radius:50%;background:var(--navy-3);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px;border:2px solid var(--border-2)}.tl-content{flex:1;padding-bottom:16px}.tl-title{font-size:13px;font-weight:500;margin-bottom:3px}.tl-meta{font-size:11px;color:var(--text-3)}.empty-state{text-align:center;padding:48px 20px;color:var(--text-3)}.empty-icon{font-size:40px;margin-bottom:12px;opacity:.5}.empty-state h3{font-size:14px;color:var(--text-2);margin-bottom:6px}.empty-state p{font-size:12px}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow);transition:box-shadow .15s;cursor:pointer;display:block;text-decoration:none;color:inherit}.project-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-2)}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.project-name{font-size:14px;font-weight:700;color:var(--navy)}.project-meta{font-size:11px;color:var(--text-3);margin-top:2px}.kpi-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.kpi{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;flex:1;min-width:120px}.kpi-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:4px}.kpi-value{font-family:var(--mono);font-size:18px;font-weight:700;color:var(--navy)}.kpi-sub{font-size:10px;color:var(--text-3);margin-top:2px}.bom-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-lg);border:1px solid var(--border)}.bom-table{width:100%;border-collapse:collapse;min-width:600px}.bom-table thead tr{background:var(--navy)}.bom-table thead th{padding:8px 10px;text-align:left;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#ffffffb3;white-space:nowrap}.bom-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.bom-table tbody tr:hover{background:var(--bg)}.bom-table td{padding:4px 6px;font-size:12px;vertical-align:middle}.bom-table td.rn{color:var(--text-3);font-family:var(--mono);font-size:11px;text-align:center;width:32px}.bom-table td.subtotal{text-align:right;font-family:var(--mono);font-size:12px;font-weight:600;color:var(--green-3);white-space:nowrap}.steps{display:flex;align-items:center;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:4px 0 8px;gap:0}.step{display:flex;align-items:center;flex-direction:column;flex-shrink:0;cursor:pointer}.step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;border:2px solid var(--border-2);background:var(--bg);color:var(--text-3);transition:all .2s;flex-shrink:0}.step-dot.done{background:var(--green);border-color:var(--green);color:#fff}.step-dot.active{background:var(--navy);border-color:var(--navy);color:#fff;box-shadow:0 0 0 4px var(--navy-3)}.step-label{font-size:10px;color:var(--text-3);margin-top:4px;white-space:nowrap;text-align:center}.step.active .step-label{color:var(--navy);font-weight:700}.step-line{width:40px;height:2px;background:var(--border-2);flex-shrink:0;margin-bottom:14px}.step-line.done{background:var(--green)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.text-sm{font-size:12px}.text-xs{font-size:11px}.dim{color:var(--text-3)}.mono{font-family:var(--mono)}.bold{font-weight:600}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-right{text-align:right}.text-center{text-align:center}.w-full{width:100%}hr{border:none;border-top:1px solid var(--border);margin:16px 0}.danger-zone{border:1px solid rgba(220,38,38,.3);border-radius:var(--radius-lg);padding:16px}.info-box{background:var(--blue-2);border:1px solid rgba(37,99,235,.2);border-radius:var(--radius);padding:10px 14px;font-size:12px;color:var(--blue)}.warn-box{background:var(--amber-2);border:1px solid rgba(217,119,6,.2);border-radius:var(--radius);padding:10px 14px;font-size:12px;color:var(--amber-3)}.success-box{background:var(--green-2);border:1px solid rgba(5,150,105,.2);border-radius:var(--radius);padding:10px 14px;font-size:12px;color:var(--green-3)}.app-shell{display:flex;min-height:100vh;width:100%}.app-header{background:var(--surface);border-bottom:1px solid var(--border);padding:8px 20px;display:flex;align-items:center;gap:10px;position:sticky;top:0;z-index:30}.app-header-right{display:flex;align-items:center;gap:8px;margin-left:auto}.header-user-name{font-size:12px;color:var(--text-3);padding-left:8px;border-left:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.hamburger-btn{display:none;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-2);padding:6px;border-radius:var(--radius);flex-shrink:0}.hamburger-btn:hover{background:var(--bg)}.mobile-logo{display:none;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--navy);flex:1;min-width:0}.mobile-logo img{height:28px;background:var(--navy);border-radius:6px;padding:3px 6px;flex-shrink:0}.mobile-logo span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drawer-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:149;opacity:0;transition:opacity .25s ease}.drawer-backdrop.open{opacity:1}.drawer-close{display:none;position:absolute;top:12px;right:12px;background:#ffffff1f;border:none;border-radius:var(--radius);color:#fffc;cursor:pointer;padding:6px;z-index:10;align-items:center;justify-content:center}.drawer-close:hover{background:#fff3}aside.drawer{position:fixed;top:0;left:0;height:100vh;width:var(--sidebar);z-index:150;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}aside.drawer.open{transform:translate(0)}@media (min-width: 769px) and (max-width: 1024px){:root{--sidebar: 200px}.g4{grid-template-columns:repeat(2,1fr)}.g31{grid-template-columns:2fr 1fr}.page-body{padding:16px 20px}}@media (max-width: 768px){.app-shell>aside.sidebar:not(.drawer){display:none}.hamburger-btn,.mobile-logo{display:flex}.drawer-backdrop{display:none}.drawer-backdrop.open{display:block}.drawer-close{display:flex}aside.drawer .sidebar-logo{padding-right:44px}.page-header{padding:10px 14px;flex-wrap:wrap;gap:8px;align-items:flex-start}.page-body{padding:12px 14px}.g4,.g3{grid-template-columns:repeat(2,1fr);gap:10px}.g2,.g21,.g31{grid-template-columns:1fr}.form-row-2,.form-row-3{grid-template-columns:1fr;gap:0}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.notif-panel{width:calc(100vw - 24px);right:-4px;max-height:70vh}.overlay{padding:0;align-items:flex-end}.modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:92vh;max-width:100%!important}.modal-body{padding:16px}.modal-hdr{padding:14px 16px}.modal-ftr{padding:12px 16px;flex-wrap:wrap}.search-row{flex-wrap:wrap}.search-row select{width:100%!important}.stat-card{padding:12px 14px}.stat-num{font-size:20px!important}.header-user-name{display:none}.tab-bar{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.tab-btn{white-space:nowrap;padding:8px 12px;font-size:12px}.steps{overflow-x:auto;flex-wrap:nowrap}.step-label{font-size:9px;max-width:60px}.stage-track{overflow-x:auto;padding-bottom:8px}.kpi{min-width:100px}.page-header .btn{font-size:11px;padding:5px 9px}.page-header .btn svg{width:12px;height:12px}.card{padding:14px}.section-hdr{font-size:10px;padding:6px 10px}.bom-table{min-width:500px}.quote-preview-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.quote-preview-wrap>div{min-width:480px}}@media (max-width: 480px){.g4{grid-template-columns:1fr 1fr;gap:8px}.g3{grid-template-columns:1fr}.login-card{padding:24px 18px}.page-header,.page-body{padding:10px 12px}.modal{max-height:96vh}.toast-container{left:12px;right:12px}.toast{max-width:100%}}
