@import"https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=Barlow+Condensed:wght@400;600;700;900&family=Barlow:wght@400;500;600&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.dashboard{display:flex;flex-direction:column;min-height:calc(100vh - 64px);background:#0f1015}.dashboard-hero{background:#13151b;border-bottom:1px solid #2A2D35;padding:24px 32px}.dashboard-week-label{font-family:DM Mono,monospace;font-size:11px;color:#666;letter-spacing:1px;text-transform:uppercase;margin-bottom:16px}.dashboard-kpi-row{display:flex;gap:16px;flex-wrap:wrap}.dash-kpi{background:#1a1d23;border:1px solid #2A2D35;border-radius:2px;padding:12px 20px;min-width:120px}.dash-kpi-warn{border-color:#e74c3c44}.dash-kpi-val{font-family:Barlow Condensed,sans-serif;font-size:28px;font-weight:700;color:#fff;line-height:1}.dash-kpi-warn .dash-kpi-val{color:#e74c3c}.dash-kpi-lbl{font-size:11px;color:#666;margin-top:4px}.dashboard-body{padding:24px 32px;display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}@media(max-width:900px){.dashboard-body{grid-template-columns:1fr}.dashboard-hero,.dashboard-body{padding:16px 20px}}.dash-section{background:#13151b;border:1px solid #2A2D35;border-radius:2px}.dash-section-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #2A2D35}.dash-section-title{font-family:Barlow Condensed,sans-serif;font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:#888}.dash-section-count{background:#1a1d23;border:1px solid #2A2D35;border-radius:10px;padding:2px 8px;font-size:11px;color:#666;font-family:DM Mono,monospace}.dash-empty{padding:24px 16px;font-size:13px;color:#555;display:flex;flex-direction:column;gap:4px}.dash-empty-hint{font-size:12px;color:#444;font-style:italic}.dash-row-ok{border-left:3px solid #27AE60}.dash-list{display:flex;flex-direction:column}.dash-list-row{display:flex;align-items:center;padding:10px 16px;border-bottom:1px solid #1A1D23;cursor:pointer;gap:12px;transition:background .1s}.dash-list-row:last-child{border-bottom:none}.dash-list-row:hover{background:#1a1d23}.dash-row-danger{border-left:3px solid #E74C3C}.dash-row-warn{border-left:3px solid #F5A623}.dash-list-left{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.dash-list-mid{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.dash-list-right{display:flex;flex-direction:column;gap:4px;align-items:flex-end;flex-shrink:0}.dash-project-tag{font-size:10px;color:#555;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-phase-name{font-size:12px;color:#d4cfc8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-date-range{font-family:DM Mono,monospace;font-size:10px;color:#555}.dash-progress{display:flex;align-items:center;gap:6px}.dash-progress-bar{flex:1;height:3px;background:#2a2d35;border-radius:2px;overflow:hidden;min-width:60px}.dash-progress-fill{height:100%;border-radius:2px}.dash-progress-pct{font-size:10px;color:#666;font-family:DM Mono,monospace;width:28px;text-align:right;flex-shrink:0}.dash-week-hours{font-family:DM Mono,monospace;font-size:11px;color:#4a90d9;background:#4a90d91a;border:1px solid rgba(74,144,217,.2);padding:2px 6px;border-radius:2px}.dash-installers{font-size:10px;color:#555}.dash-tag-danger{font-size:11px;color:#e74c3c;text-align:right}.dash-tag-warn{font-size:11px;color:#f5a623;max-width:200px;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}*{box-sizing:border-box;margin:0;padding:0}:root{--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sidebar-w: 220px;--sidebar-w-collapsed: 60px}body{background:#0f1015;color:#d4cfc8;font-family:Barlow,sans-serif;font-size:14px;min-height:100vh}*:focus-visible{outline:2px solid #E8A020;outline-offset:2px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#1a1c22}::-webkit-scrollbar-thumb{background:#444;border-radius:3px}.app{min-height:100vh;background:#0f1015;display:flex;flex-direction:column}.app-layout{display:flex;flex:1;min-height:calc(100vh - 64px)}.sidebar{width:var(--sidebar-w);background:#13151b;border-right:1px solid #2A2D35;display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:64px;height:calc(100vh - 64px);overflow-y:auto;transition:width .2s ease;z-index:50}.sidebar.collapsed{width:var(--sidebar-w-collapsed)}.sidebar-nav{flex:1;padding:var(--sp-3) 0;display:flex;flex-direction:column;gap:var(--sp-1)}.sidebar-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:transparent;border:none;border-left:3px solid transparent;color:#888;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase;cursor:pointer;width:100%;text-align:left;transition:color .15s,border-color .15s,background .15s;white-space:nowrap;overflow:hidden}.sidebar-item:hover{color:#ccc;background:#ffffff0a}.sidebar-item.active{color:#e8a020;border-left-color:#e8a020;background:#e8a02014}.sidebar-icon{font-size:16px;flex-shrink:0;width:20px;text-align:center;line-height:1}.sidebar-label{flex:1;transition:opacity .15s}.sidebar.collapsed .sidebar-label{opacity:0;pointer-events:none;width:0;overflow:hidden}.sidebar-collapse-btn{padding:var(--sp-3) var(--sp-4);border-top:1px solid #2A2D35;display:flex;align-items:center;justify-content:flex-end;background:none;border-left:none;border-right:none;border-bottom:none;color:#555;cursor:pointer;font-size:12px;transition:color .15s}.sidebar.collapsed .sidebar-collapse-btn{justify-content:center}.sidebar-collapse-btn:hover{color:#aaa}.app-content{flex:1;min-width:0;display:flex;flex-direction:column}.header{background:#13151b;border-bottom:2px solid #2A2D35;padding:0 var(--sp-8);display:flex;align-items:center;justify-content:space-between;height:64px;position:sticky;top:0;z-index:100}.header-hamburger{display:none;background:none;border:1px solid #333;color:#888;cursor:pointer;font-size:18px;padding:6px 10px;margin-right:var(--sp-3);transition:color .15s,border-color .15s}.header-hamburger:hover{color:#ccc;border-color:#666}.header-logo{display:flex;align-items:center;gap:12px}.header-icon{width:32px;height:32px;background:#e8a020;clip-path:polygon(0 0,85% 0,100% 15%,100% 100%,15% 100%,0 85%);display:flex;align-items:center;justify-content:center;font-size:14px;color:#0f1015;font-weight:900}.header-title{font-family:Barlow Condensed,sans-serif;font-weight:900;font-size:20px;letter-spacing:2px;text-transform:uppercase;color:#fff}.header-sub{font-family:DM Mono,monospace;font-size:11px;color:#666;letter-spacing:1px}.header-actions{display:flex;align-items:center;gap:var(--sp-4)}.header-nav{display:none}.stat-pill{background:#1e2028;border:1px solid #2A2D35;padding:6px 14px;border-radius:2px;display:flex;flex-direction:column;align-items:center}.stat-pill-val{font-family:DM Mono,monospace;font-size:16px;font-weight:500;color:#e8a020}.stat-pill-label{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:#888}.btn-primary{background:#e8a020;color:#0f1015;border:none;padding:10px 20px;font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;clip-path:polygon(0 0,92% 0,100% 30%,100% 100%,8% 100%,0 70%);transition:all .15s}.btn-primary:hover{background:#f5b535}.btn-secondary{background:transparent;color:#aaa;border:1px solid #444;padding:8px 16px;font-family:Barlow Condensed,sans-serif;font-weight:600;font-size:12px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all .15s}.btn-secondary:hover{border-color:#888;color:#eee}.btn-danger{background:transparent;color:#e74c3c;border:1px solid #E74C3C44;padding:6px 12px;font-family:Barlow Condensed,sans-serif;font-weight:600;font-size:11px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all .15s}.btn-danger:hover{background:#e74c3c22;border-color:#e74c3c88}.main{padding:var(--sp-6) var(--sp-8);flex:1}.toolbar{display:flex;align-items:center;gap:var(--sp-4);margin-bottom:var(--sp-6);flex-wrap:wrap}.filter-btn{padding:7px 16px;border:1px solid #2A2D35;background:#13151b;color:#aaa;font-family:Barlow,sans-serif;font-size:13px;cursor:pointer;transition:all .15s;border-radius:2px}.filter-btn.active{border-color:#e8a020;color:#e8a020;background:#e8a02015}.filter-btn:hover:not(.active){border-color:#555;color:#eee}.search-input{background:#13151b;border:1px solid #2A2D35;color:#d4cfc8;padding:8px 14px;font-family:Barlow,sans-serif;font-size:13px;outline:none;width:260px;transition:border-color .15s,box-shadow .15s;border-radius:2px}.search-input:focus{border-color:#e8a020;box-shadow:0 0 0 3px #e8a02026}.search-input::placeholder{color:#555}.kanban{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px}.project-card{background:#13151b;border:1px solid #2A2D35;border-top:3px solid #E8A020;position:relative;transition:transform .15s,box-shadow .15s;cursor:pointer;display:flex;flex-direction:column}.project-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0006}.project-card:after{content:"→ Avaa";position:absolute;bottom:10px;right:14px;font-family:Barlow Condensed,sans-serif;font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:#e8a020;opacity:0;transition:opacity .15s;pointer-events:none}.project-card:hover:after{opacity:1}.project-card.viivästynyt{border-top-color:#e74c3c}.project-card.valmis{border-top-color:#27ae60}.project-card.suunnittelu{border-top-color:#4a90d9}.card-header{padding:18px 20px 14px;border-bottom:1px solid #1E2028}.card-id{font-family:DM Mono,monospace;font-size:11px;color:#666;letter-spacing:1px;margin-bottom:6px}.card-name{font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:18px;color:#eee;letter-spacing:.5px;line-height:1.2;margin-bottom:10px}.card-meta{display:flex;gap:var(--sp-4);flex-wrap:wrap}.meta-item{display:flex;flex-direction:column;gap:2px}.meta-label{font-size:11px;color:#666;font-family:DM Mono,monospace}.meta-value{font-size:13px;color:#bbb;font-family:Barlow,sans-serif}.card-body{padding:14px 20px}.card-expand-toggle{background:none;border:none;cursor:pointer;color:#555;font-size:11px;font-family:DM Mono,monospace;letter-spacing:.5px;padding:var(--sp-1) 0 var(--sp-3) 0;display:flex;align-items:center;gap:var(--sp-1);transition:color .15s;width:100%;text-align:left}.card-expand-toggle:hover{color:#aaa}.budget-bar-wrap{margin-bottom:14px}.budget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.budget-label{font-family:DM Mono,monospace;font-size:11px;color:#666;letter-spacing:1px;text-transform:uppercase}.budget-nums{font-family:DM Mono,monospace;font-size:12px;color:#aaa}.budget-bar{height:4px;background:#1e2028;border-radius:0;overflow:hidden}.budget-fill{height:100%;transition:width .5s;border-radius:0}.phases-label{font-family:DM Mono,monospace;font-size:11px;color:#666;letter-spacing:1px;text-transform:uppercase;margin-bottom:var(--sp-2)}.phases-list{display:flex;flex-direction:column;gap:5px}.phase-row{display:flex;align-items:center;gap:var(--sp-2)}.phase-dot{width:8px;height:8px;border-radius:0;flex-shrink:0;transform:rotate(45deg)}.phase-name{font-size:13px;color:#999;flex:1}.phase-status-badge{font-family:DM Mono,monospace;font-size:10px;letter-spacing:.5px;padding:2px 7px;border-radius:1px}.phase-warning{font-size:12px;color:#e74c3c;margin-left:2px}.card-footer{padding:10px 20px 28px;border-top:1px solid #1E2028;display:flex;justify-content:space-between;align-items:center;margin-top:auto}.date-range{font-family:DM Mono,monospace;font-size:11px;color:#666}.status-badge{font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:11px;letter-spacing:2px;text-transform:uppercase;padding:3px 10px;border-radius:1px}.phase-progress-mini{flex:1;height:3px;background:#2a2d35;border-radius:2px;overflow:hidden;min-width:30px;max-width:60px}.phase-progress-mini-fill{height:100%;background:#4a90d9;border-radius:2px}.modal-overlay{position:fixed;inset:0;background:#000000bf;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}.modal{background:#13151b;border:1px solid #2A2D35;border-top:3px solid #E8A020;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease;display:flex;flex-direction:column}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--sp-5) var(--sp-6);border-bottom:1px solid #1E2028;display:flex;justify-content:space-between;align-items:flex-start;gap:var(--sp-4);flex-shrink:0}.modal-breadcrumb{font-family:DM Mono,monospace;font-size:11px;color:#555;letter-spacing:.5px;margin-bottom:var(--sp-1);display:flex;align-items:center;gap:var(--sp-1)}.modal-breadcrumb-sep{color:#3a3d45}.modal-breadcrumb-current{color:#888}.modal-title{font-family:Barlow Condensed,sans-serif;font-weight:900;font-size:22px;color:#fff;letter-spacing:.5px}.modal-tabs{display:flex;border-bottom:1px solid #2A2D35;background:#0f1015;flex-shrink:0}.modal-tab{background:transparent;border:none;border-bottom:2px solid transparent;color:#666;font-family:Barlow,sans-serif;font-size:13px;font-weight:500;padding:12px 20px;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap;display:flex;align-items:center;gap:var(--sp-2)}.modal-tab:hover{color:#bbb}.modal-tab.active{color:#e8a020;border-bottom-color:#e8a020}.modal-tab-panel{display:none}.modal-tab-panel.active{display:block}.modal-body{padding:24px}.modal-section-card{border:1px solid #2A2D35;background:#0f1015;padding:14px;margin-bottom:14px}.modal-section-header{font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:#e8a020;margin-bottom:12px}.modal-section-sub{font-family:DM Mono,monospace;font-size:11px;color:#678;letter-spacing:.8px;text-transform:uppercase;margin-bottom:var(--sp-2)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);margin-bottom:24px}.form-group{display:flex;flex-direction:column;gap:var(--sp-2)}.form-group.full{grid-column:1 / -1}.form-label{font-family:Barlow,sans-serif;font-size:12px;color:#888;font-weight:500}.form-input,.form-select{background:#0f1015;border:1px solid #2A2D35;color:#d4cfc8;padding:9px 12px;font-family:Barlow,sans-serif;font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s;width:100%;border-radius:2px}.form-input:focus,.form-select:focus{border-color:#e8a020;box-shadow:0 0 0 3px #e8a0201f}.form-select option{background:#13151b}.phases-editor{border:1px solid #2A2D35;background:#0f1015}.phases-editor-header{padding:10px 14px;border-bottom:1px solid #2A2D35;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--sp-2)}.phases-editor-title{font-family:Barlow,sans-serif;font-size:12px;color:#666;font-weight:500}.phase-color-dot{width:8px;height:8px;transform:rotate(45deg);display:inline-block;margin-right:6px;flex-shrink:0}.phase-edit-name{display:flex;align-items:center;font-size:13px;color:#bbb}.modal-footer{padding:var(--sp-4) var(--sp-6);border-top:1px solid #1E2028;display:flex;justify-content:flex-end;gap:10px;flex-shrink:0}.x-btn{background:none;border:1px solid transparent;color:#777;cursor:pointer;font-size:20px;line-height:1;padding:4px 8px;transition:color .15s,border-color .15s;border-radius:2px}.x-btn:hover{color:#ccc;border-color:#555}.section-title{font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:13px;letter-spacing:2px;text-transform:uppercase;color:#e8a020;margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid #E8A02033}.empty-state{text-align:center;padding:80px 32px;color:#555}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-title{font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:20px;letter-spacing:1px;text-transform:uppercase;color:#666;margin-bottom:var(--sp-2)}.empty-hint{font-size:13px;color:#555;margin-top:var(--sp-2)}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px}.skeleton-card{background:#13151b;border:1px solid #2A2D35;border-top:3px solid #2A2D35;overflow:hidden}.skeleton-line{background:linear-gradient(90deg,#1e2028 25%,#2a2d35,#1e2028 75%);background-size:400% 100%;animation:shimmer 1.5s infinite;border-radius:2px}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.phase-item-wrap{border-bottom:1px solid #1A1C22}.phase-item-wrap:last-child{border-bottom:none}.phase-item-wrap.expanded{border-color:#2a2d35}.phase-edit-row{padding:var(--sp-2) 14px;display:flex;flex-wrap:nowrap;gap:6px;align-items:center}.phase-edit-row-primary{padding:var(--sp-2) 14px var(--sp-1) 14px;display:flex;flex-wrap:nowrap;gap:6px;align-items:center}.phase-toggle-btn{background:#1e2028;border:1px solid #2A2D35;color:#777;cursor:pointer;font-size:10px;padding:3px 7px;display:flex;align-items:center;gap:4px;transition:all .15s;flex-shrink:0;height:28px;white-space:nowrap;border-radius:2px}.phase-toggle-btn:hover{border-color:#e8a020;color:#e8a020}.phase-toggle-btn.active{border-color:#e8a020;color:#e8a020;background:#e8a02010}.history-badge{background:#e8a020;color:#0f1015;font-size:8px;font-weight:700;padding:1px 5px;border-radius:8px;font-family:DM Mono,monospace}.phase-detail-panel{display:grid;grid-template-columns:1fr 1.4fr;gap:0;background:#0a0c10;border-top:1px solid #1E2028}.phase-detail-col{padding:14px 16px;display:flex;flex-direction:column;gap:10px}.phase-detail-col+.phase-detail-col{border-left:1px solid #1A1C22}.phase-detail-heading{font-family:Barlow,sans-serif;font-size:11px;color:#666;font-weight:500}.poikkeama-input{background:#13151b;border:1px solid #2A2D35;color:#d4cfc8;padding:var(--sp-2) 10px;font-family:Barlow,sans-serif;font-size:13px;outline:none;resize:vertical;min-height:68px;width:100%;transition:border-color .15s,box-shadow .15s;box-sizing:border-box;border-radius:2px}.poikkeama-input:focus{border-color:#e74c3c;box-shadow:0 0 0 3px #e74c3c1f}.poikkeama-input::placeholder{color:#444}.history-no-data{font-family:DM Mono,monospace;font-size:12px;color:#444;padding:var(--sp-2) 0}.history-stats-row{display:flex;gap:var(--sp-2)}.history-stat-box{flex:1;display:flex;flex-direction:column;align-items:center;background:#13151b;border:1px solid #2A2D35;padding:5px 8px;border-radius:2px}.history-stat-val{font-family:DM Mono,monospace;font-size:14px;font-weight:500;color:#e8a020}.history-stat-lbl{font-size:9px;text-transform:uppercase;letter-spacing:1px;color:#555;font-family:DM Mono,monospace}.history-vs-badge{display:inline-flex;align-items:center;gap:4px;font-family:DM Mono,monospace;font-size:11px;padding:3px 8px;border-radius:2px}.history-vs-under{background:#27ae6020;color:#27ae60;border:1px solid #27AE6040}.history-vs-over{background:#e74c3c20;color:#e74c3c;border:1px solid #E74C3C40}.history-vs-equal{background:#4a90d920;color:#4a90d9;border:1px solid #4A90D940}.history-list{display:flex;flex-direction:column;gap:0;max-height:160px;overflow-y:auto}.history-row{display:grid;grid-template-columns:1fr 44px;gap:6px;padding:5px 0;border-bottom:1px solid #141618;align-items:start}.history-row:last-child{border-bottom:none}.history-row-name{font-size:12px;color:#999;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-row-days{font-family:DM Mono,monospace;font-size:12px;color:#bbb;text-align:right}.history-row-deviation{grid-column:1 / -1;font-size:11px;color:#e74c3c;font-style:italic;padding-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-bar-wrap{grid-column:1 / -1;height:3px;background:#1e2028;margin-top:1px}.history-bar-fill{height:100%}.bottom-nav{display:none}@media(max-width:900px){.sidebar{position:fixed;top:64px;left:0;bottom:0;height:auto;transform:translate(-100%);transition:transform .25s ease,width .2s ease;z-index:90;box-shadow:4px 0 16px #0006}.sidebar.mobile-open{transform:translate(0);width:var(--sidebar-w)}.sidebar-overlay{display:none;position:fixed;inset:64px 0 0;background:#00000080;z-index:89}.sidebar-overlay.visible{display:block}.header-hamburger{display:flex;align-items:center;justify-content:center}.app-layout{flex-direction:column}.app-content{width:100%}.header{padding:0 var(--sp-4);height:auto;min-height:64px;flex-wrap:wrap;gap:var(--sp-2)}.header-title{font-size:16px;letter-spacing:1px}.header-sub{display:none}.header-icon{width:28px;height:28px;font-size:12px}.header-actions{flex-wrap:wrap;gap:var(--sp-2);width:100%;padding-bottom:var(--sp-2)}.stat-pill{padding:4px 10px}.stat-pill-val{font-size:13px}.stat-pill-label{font-size:9px}.main{padding:14px 16px}.toolbar{flex-wrap:wrap;gap:var(--sp-2)}.search-input{width:100%;order:-1}.kanban{grid-template-columns:1fr;gap:14px}.modal-overlay{padding:var(--sp-2)}.modal{max-height:95vh}.modal-body{padding:var(--sp-4)}.modal-header{padding:14px 16px}.modal-footer{padding:12px 16px}.modal-title{font-size:18px}.form-grid{grid-template-columns:1fr;gap:12px}.form-group.full{grid-column:1}.phase-edit-row{flex-wrap:wrap;padding:var(--sp-2) 10px}.phase-detail-panel{grid-template-columns:1fr}.card-header{padding:14px 16px 12px}.card-body{padding:12px 16px}.card-footer{padding:10px 16px 28px}.card-name{font-size:16px}}@media(max-width:480px){.header-actions .stat-pill.hide-xs{display:none}.phase-edit-row{flex-wrap:wrap}.modal{max-width:100%;max-height:100vh;border-radius:0;border-top:none;margin:0}.modal-overlay{padding:0;align-items:flex-end}.modal-footer{flex-direction:column-reverse;gap:var(--sp-2)}.modal-footer button{width:100%;text-align:center}.btn-primary{padding:10px 14px;font-size:13px}.card-meta{flex-direction:column;gap:6px}.phases-editor-header{flex-direction:column;align-items:flex-start;gap:var(--sp-2)}}.token-limit-banner{background:#2a1a00;border-bottom:1px solid #E8A02044;padding:var(--sp-2) 24px;display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:13px;color:#e8a020}.token-limit-banner.critical{background:#2a0a00;border-bottom-color:#e74c3c44;color:#e74c3c}.token-limit-banner-bar{flex:1;max-width:200px;height:4px;background:#1e2028;border-radius:2px;overflow:hidden}.token-limit-banner-bar-fill{height:100%;border-radius:2px;background:#e8a020;transition:width .4s ease}.token-limit-banner.critical .token-limit-banner-bar-fill{background:#e74c3c}.token-limit-banner-dismiss{background:none;border:none;color:inherit;cursor:pointer;font-size:16px;opacity:.6;padding:0 4px;line-height:1}.token-limit-banner-dismiss:hover{opacity:1}.confirm-overlay{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:400;padding:16px}.confirm-modal{width:100%;max-width:420px;background:#13151b;border:1px solid #2A2D35;border-top:3px solid #E74C3C;padding:20px;border-radius:2px}.confirm-title{font-family:Barlow Condensed,sans-serif;font-size:18px;color:#eee;letter-spacing:1px;margin-bottom:10px}.confirm-text{font-size:13px;color:#aaa;line-height:1.6;margin-bottom:16px}.confirm-actions{display:flex;justify-content:flex-end;gap:var(--sp-2)}.nav-tab{background:transparent;border:none;border-bottom:2px solid transparent;color:#666;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:22px 18px;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}.nav-tab:hover{color:#bbb}.nav-tab.active{color:#e8a020;border-bottom-color:#e8a020}.add-phase-overlay{z-index:300}.add-phase-modal{background:#13151b;border:1px solid #2A2D35;border-top:3px solid #E8A020;width:480px;max-width:92vw;border-radius:4px;padding:20px 22px;animation:slideUp .2s ease}.add-phase-title{font-size:16px;font-weight:600;color:#eee;margin-bottom:6px}.add-phase-hint{font-size:12px;color:#888;line-height:1.5;margin-bottom:16px}.add-phase-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.add-phase-field{display:flex;flex-direction:column;gap:5px}.add-phase-field-code{grid-column:1 / 2}.add-phase-field-name{grid-column:2 / 3}.add-phase-label{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:.5px}.add-phase-modal .form-input{width:100%;background:#1a1d23;border:1px solid #333;color:#ddd;padding:8px 10px;border-radius:4px;font-size:13px}.add-phase-error{color:#e74c3c;font-size:11px;margin-top:2px}.add-phase-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.add-phase-installers{margin-top:16px}.add-phase-installer-list{display:flex;flex-wrap:wrap;gap:6px;max-height:140px;overflow-y:auto}.add-phase-installer{display:flex;align-items:center;gap:6px;font-size:12px;color:#ccc;background:#1a1d23;border:1px solid #2A2D35;border-radius:4px;padding:5px 9px;cursor:pointer}.add-phase-installer.on{border-color:#4a90d9;background:#4a90d914;color:#eee}.add-phase-installer input{accent-color:#4A90D9}.add-phase-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.add-phase-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#eee;background:#4a90d914;border:1px solid #4A90D9;border-radius:12px;padding:3px 6px 3px 10px}.add-phase-chip button{background:none;border:none;color:#9cc4e8;cursor:pointer;font-size:14px;line-height:1;padding:0 2px}.add-phase-chip button:hover{color:#fff}.add-phase-installers .form-input{margin-bottom:8px}.add-phase-installer-empty{font-size:12px;color:#555;padding:8px 4px}
