*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5f6f8;--bg2: #ffffff;--bg3: #f2f3f6;--bg4: #e9eaef;--border: #e6e7ec;--border2: #d5d7e0;--text: #23272f;--text2: #5d6470;--text3: #8c93a3;--accent: #62801d;--accent2: #54701a;--accent-bright: #c8f04a;--accent-dim: rgba(140, 180, 40, .12);--red: #d63b3b;--red-dim: rgba(214, 59, 59, .1);--blue: #2f6fce;--blue-dim: rgba(47, 111, 206, .1);--purple: #7c5cd6;--purple-dim: rgba(124, 92, 214, .1);--amber: #b07c10;--amber-dim: rgba(217, 160, 30, .14);--teal: #0e9384;--teal-dim: rgba(14, 147, 132, .1);--on-accent: #ffffff;--on-accent-bright: #2a3309;--row-hover: #fafbf4;--glow: rgba(200, 240, 74, .13);--sidebar-w: 232px;--radius: 10px;--radius-sm: 7px;--shadow-sm: 0 1px 2px rgba(20, 24, 40, .05);--shadow-md: 0 4px 16px rgba(20, 24, 40, .08);--shadow-lg: 0 12px 40px rgba(20, 24, 40, .16);--font: "Hanken Grotesk", sans-serif;--mono: "IBM Plex Mono", monospace;--card: var(--bg2);--text1: var(--text);--text-1: var(--text);--text-2: var(--text2);--text-3: var(--text3);--bg-2: var(--bg2);--bg-3: var(--bg3)}[data-theme=plum]{--accent: #714B67;--accent2: #5f3d56;--accent-bright: #d8a7c8;--on-accent-bright: #3a2034;--accent-dim: rgba(113, 75, 103, .12);--glow: rgba(216, 167, 200, .2);--row-hover: #fbf7fa}[data-theme=ocean]{--accent: #2563c4;--accent2: #1e54aa;--accent-bright: #6fc2ff;--on-accent-bright: #0c2438;--accent-dim: rgba(37, 99, 196, .12);--glow: rgba(111, 194, 255, .18);--row-hover: #f6f9fd}[data-theme=sunset]{--accent: #c05621;--accent2: #a8481a;--accent-bright: #ffb84a;--on-accent-bright: #3d2200;--accent-dim: rgba(192, 86, 33, .12);--glow: rgba(255, 184, 74, .2);--row-hover: #fdf9f3}[data-theme=dark],[data-theme=midnight],[data-theme=plumdark],[data-theme=forest],[data-theme=black]{--text: #e8e9ee;--text2: #a6a8b4;--text3: #747782;--border: rgba(255, 255, 255, .09);--border2: rgba(255, 255, 255, .17);--red: #ff7a7a;--red-dim: rgba(255, 122, 122, .13);--blue: #6fb1ff;--blue-dim: rgba(111, 177, 255, .13);--purple: #b48aff;--purple-dim: rgba(180, 138, 255, .13);--amber: #ffc56a;--amber-dim: rgba(255, 197, 106, .13);--teal: #4ad9c0;--teal-dim: rgba(74, 217, 192, .13);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .35);--shadow-md: 0 4px 16px rgba(0, 0, 0, .45);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .6)}[data-theme=dark]{--bg: #141519;--bg2: #1b1d22;--bg3: #23252c;--bg4: #2d3039;--accent: #9ec33b;--accent2: #aed44b;--on-accent: #1a2206;--accent-bright: #c8f04a;--accent-dim: rgba(200, 240, 74, .13);--glow: rgba(200, 240, 74, .09);--row-hover: #21241c}[data-theme=midnight]{--bg: #0e1320;--bg2: #151b2b;--bg3: #1c2335;--bg4: #273048;--accent: #79aaff;--accent2: #8fb9ff;--on-accent: #0a1428;--accent-bright: #9cc4ff;--on-accent-bright: #0a1428;--accent-dim: rgba(121, 170, 255, .14);--glow: rgba(121, 170, 255, .09);--row-hover: #1a2133}[data-theme=plumdark]{--bg: #16121a;--bg2: #1e1825;--bg3: #271f30;--bg4: #33293f;--accent: #b993d6;--accent2: #c9a7e2;--on-accent: #22132e;--accent-bright: #d8b5ee;--on-accent-bright: #2a1838;--accent-dim: rgba(185, 147, 214, .14);--glow: rgba(216, 181, 238, .09);--row-hover: #241c2d}[data-theme=forest]{--bg: #0d1614;--bg2: #13201c;--bg3: #1a2a25;--bg4: #25382f;--accent: #38c793;--accent2: #4cd8a4;--on-accent: #04231a;--accent-bright: #5eead4;--on-accent-bright: #042f2a;--accent-dim: rgba(56, 199, 147, .13);--glow: rgba(94, 234, 212, .08);--row-hover: #17241f}[data-theme=black]{--bg: #000000;--bg2: #0c0c0d;--bg3: #151517;--bg4: #202023;--accent: #9ec33b;--accent2: #aed44b;--on-accent: #1a2206;--accent-bright: #c8f04a;--accent-dim: rgba(200, 240, 74, .12);--glow: rgba(200, 240, 74, .07);--row-hover: #121408}::selection{background:var(--accent-bright);color:var(--on-accent-bright)}:focus-visible{outline:2px solid var(--accent);outline-offset:1px}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;display:flex;height:100vh;height:100dvh;overflow:hidden}#root{display:flex;width:100%;height:100%}.sidebar{width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-logo{padding:18px 16px 14px;border-bottom:1px solid var(--border)}.logo-mark{display:flex;align-items:center;gap:10px}.logo-icon{width:34px;height:34px;background:var(--accent-bright);border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;color:var(--on-accent-bright);flex-shrink:0}.logo-text{font-size:14px;font-weight:700}.logo-sub{font-size:11px;color:var(--text3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:150px}.sidebar-section{padding:14px 10px 4px}.sidebar-label{font-size:11px;font-weight:600;color:var(--text3);padding:0 10px;margin-bottom:4px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text2);font-size:13.5px;font-weight:500;transition:background .12s,color .12s;-webkit-user-select:none;user-select:none;text-decoration:none}.nav-item:hover{background:var(--bg3);color:var(--text)}.nav-item.active{background:var(--accent-dim);color:var(--accent);font-weight:700}.nav-icon{width:18px;text-align:center;font-size:14px;flex-shrink:0}.nav-badge{margin-left:auto;background:var(--accent-dim);color:var(--accent);font-size:11px;font-weight:600;padding:1px 7px;border-radius:999px}.sidebar-bottom{margin-top:auto;padding:12px 10px;border-top:1px solid var(--border)}.user-pill{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background .12s}.user-pill:hover{background:var(--bg3)}.user-name{font-size:13px;font-weight:600}.user-role{font-size:11px;color:var(--text3)}.user-menu{position:absolute;bottom:calc(100% - 4px);left:10px;right:10px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px;box-shadow:var(--shadow-md);z-index:10}.user-menu-item{display:flex;align-items:center;width:100%;background:none;border:none;color:var(--text2);font-size:13px;font-family:var(--font);padding:8px 10px;border-radius:5px;cursor:pointer;text-align:left}.user-menu-item:hover{background:var(--bg3);color:var(--text)}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:54px;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0}.topbar-title{flex:1}.topbar-actions{display:flex;align-items:center;gap:8px}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--text3)}.breadcrumb span:last-child{color:var(--text);font-weight:700}.breadcrumb-sep{font-size:12px}.content{flex:1;overflow-y:auto;padding:24px}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .18s ease}.avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-bright);color:var(--on-accent-bright);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;border:none;transition:background .12s,color .12s,border-color .12s,box-shadow .12s}.btn-primary{background:var(--accent);color:var(--on-accent);box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--accent2)}.btn-ghost{background:var(--bg2);color:var(--text2);border:1px solid var(--border2)}.btn-ghost:hover{background:var(--bg3);color:var(--text)}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid transparent}.btn-danger:hover{background:var(--red);color:#fff}.icon-btn{width:27px;height:27px;border-radius:6px;background:var(--bg2);border:1px solid var(--border2);color:var(--text3);cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:all .12s}.icon-btn:hover{background:var(--bg3);color:var(--text);border-color:var(--text3)}.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:999px;font-size:11.5px;font-weight:600}.badge-green{background:var(--accent-dim);color:var(--accent)}.badge-red{background:var(--red-dim);color:var(--red)}.badge-blue{background:var(--blue-dim);color:var(--blue)}.badge-amber{background:var(--amber-dim);color:var(--amber)}.badge-purple{background:var(--purple-dim);color:var(--purple)}.badge-teal{background:var(--teal-dim);color:var(--teal)}.badge-gray{background:var(--bg4);color:var(--text2)}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:16px}.card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.card-title{font-size:14px;font-weight:700}.card-body{padding:18px}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px 18px;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;bottom:0;width:3px}.stat-card.green:before{background:var(--accent-bright)}.stat-card.blue:before{background:var(--blue)}.stat-card.purple:before{background:var(--purple)}.stat-card.amber:before{background:var(--amber)}.stat-label{font-size:12px;font-weight:500;color:var(--text3);margin-bottom:8px}.stat-value{font-size:25px;font-weight:800;line-height:1;letter-spacing:-.3px}.stat-value.green{color:var(--accent)}.stat-value.blue{color:var(--blue)}.stat-value.purple{color:var(--purple)}.stat-value.amber{color:var(--amber)}.stat-sub{font-size:11.5px;color:var(--text3);margin-top:7px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13.5px}thead tr{background:var(--bg3)}th{padding:9px 14px;text-align:left;font-size:11.5px;font-weight:700;color:var(--text2);white-space:nowrap}td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--text2)}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background .1s}tbody tr:hover td{background:var(--row-hover);color:var(--text)}.mono{font-family:var(--mono);font-size:12.5px}.row-actions{display:flex;gap:4px;opacity:0;transition:opacity .12s}tbody tr:hover .row-actions{opacity:1}.search-bar{display:flex;align-items:center;gap:8px;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:0 12px;flex:1;max-width:320px;transition:border-color .12s,box-shadow .12s}.search-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.search-bar input{background:none;border:none;outline:none;font-size:13px;color:var(--text);font-family:var(--font);padding:7px 0;width:100%}.search-bar input::placeholder{color:var(--text3)}.search-icon{color:var(--text3);font-size:13px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-full{grid-column:1 / -1}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:12px;font-weight:600;color:var(--text2)}.form-input{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:9px 12px;font-size:13.5px;color:var(--text);font-family:var(--font);outline:none;width:100%;transition:border-color .12s,box-shadow .12s}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-input::placeholder{color:var(--text3)}select.form-input{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238c93a3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#1e222d73;z-index:100;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-overlay.open{display:flex}.modal{background:var(--bg2);border-radius:14px;width:520px;max-width:96vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modalIn .18s ease}.modal-lg{width:720px}@keyframes modalIn{0%{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:700}.modal-close{width:28px;height:28px;border-radius:7px;background:var(--bg3);border:none;color:var(--text2);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .12s}.modal-close:hover{background:var(--bg4)}.modal-body{padding:20px}.modal-footer{display:flex;gap:8px;justify-content:flex-end;padding:14px 20px;border-top:1px solid var(--border);background:var(--bg3)}.feed{display:flex;flex-direction:column}.feed-item{display:flex;gap:12px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--border)}.feed-item:last-child{border-bottom:none}.feed-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}.feed-text{font-size:12.5px;color:var(--text2);line-height:1.5}.feed-time{font-size:11px;color:var(--text3);margin-top:2px}.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px}.inv-line{display:grid;grid-template-columns:2fr 80px 100px 100px 36px;gap:8px;align-items:center;margin-bottom:8px}.inv-totals{display:flex;justify-content:flex-end;gap:32px;font-size:13.5px;color:var(--text2);padding:12px 0;margin-top:16px;border-top:1px solid var(--border2)}.inv-totals .total-amount{font-size:17px;font-weight:800;color:var(--accent)}.stock-bar-wrap{display:flex;align-items:center;gap:8px}.stock-bar-bg{background:var(--bg4);border-radius:4px;height:5px;width:80px}.stock-bar{height:5px;border-radius:4px;background:var(--bg4)}.stock-bar-fill{height:100%;border-radius:4px}.task-board{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.task-col{background:var(--bg3);border-radius:var(--radius);padding:12px;border:1px solid var(--border)}.task-col-header{font-size:12px;font-weight:700;color:var(--text2);margin-bottom:10px;display:flex;align-items:center;gap:8px}.col-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.task-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:8px;cursor:pointer;transition:border-color .12s,box-shadow .12s}.task-card:hover{border-color:var(--border2);box-shadow:var(--shadow-md)}.task-card-title{font-size:13px;font-weight:600;margin-bottom:6px}.task-card-desc{font-size:12px;color:var(--text3);margin-bottom:6px}.task-card-meta{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--text3)}.task-avatar{width:18px;height:18px;border-radius:50%;font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.phase-list{display:flex;flex-direction:column;gap:8px}.phase-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg2);border-radius:var(--radius-sm);border:1px solid var(--border)}.phase-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.phase-name{font-size:13.5px;font-weight:600;flex:1}.phase-desc{font-size:12px;color:var(--text3)}.phase-badge{background:transparent;font-size:11px;font-weight:600;padding:2px 9px;border-radius:999px;border:1px solid;white-space:nowrap}.roadmap-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}.roadmap-stat{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px 18px;min-width:0}.roadmap-stat-label{font-size:12px;font-weight:500;color:var(--text3);margin-bottom:5px}.roadmap-stat-value{font-size:22px;font-weight:800;color:var(--text)}.roadmap-progress-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px 18px;margin-bottom:18px}.roadmap-progress-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:12.5px;font-weight:600;color:var(--text2)}.roadmap-progress-pct{font-size:16px;font-weight:800;color:var(--accent)}.roadmap-progress-bar{height:8px;background:var(--bg4);border-radius:999px;overflow:hidden}.roadmap-progress-fill{height:100%;background:var(--accent-bright);border-radius:999px;transition:width .3s ease}.phase-card{background:var(--bg2);border:1px solid var(--border);border-left:3px solid var(--text3);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);padding:12px 14px;margin-bottom:10px;cursor:pointer;transition:box-shadow .12s,border-color .12s;display:flex;flex-direction:column;gap:8px}.phase-card:hover{box-shadow:var(--shadow-md)}.phase-card.dragging{opacity:.45}.phase-card.drop-target{border:2px dashed var(--accent)}.phase-card-head{display:flex;align-items:flex-start;gap:8px}.phase-card-num{font-size:10.5px;font-weight:700;color:var(--text3);background:var(--bg3);padding:2px 7px;border-radius:5px;flex-shrink:0}.phase-card-title{font-size:13.5px;font-weight:700;flex:1;line-height:1.3}.phase-card-desc{font-size:12px;color:var(--text3);line-height:1.4}.phase-card-meta{display:flex;align-items:center;gap:10px;font-size:11.5px;color:var(--text3);flex-wrap:wrap}.phase-card-meta .meta-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--bg3);border-radius:999px}.phase-card-meta .meta-chip.overdue{color:var(--red);background:var(--red-dim)}.phase-mini-progress{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text3)}.phase-mini-bar{flex:1;height:5px;background:var(--bg4);border-radius:999px;overflow:hidden}.phase-mini-fill{height:100%;background:var(--accent-bright);border-radius:999px;transition:width .3s}.phase-actions{display:flex;gap:4px;margin-left:auto}.checklist-list{display:flex;flex-direction:column;gap:4px}.checklist-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;background:var(--bg3);font-size:13px}.checklist-row:hover{background:var(--bg4)}.checklist-row.done .checklist-text{text-decoration:line-through;color:var(--text3)}.checklist-check{width:18px;height:18px;border:1.5px solid var(--border2);border-radius:5px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;background:var(--bg2);color:#fff;font-size:12px;font-weight:700}.checklist-check.done{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.checklist-text{flex:1;cursor:pointer}.checklist-remove{background:none;border:none;color:var(--text3);cursor:pointer;font-size:14px;padding:0 4px}.checklist-remove:hover{color:var(--red)}.checklist-add{display:flex;gap:6px;margin-top:6px}.checklist-add input{flex:1;background:var(--bg2);border:1px solid var(--border2);border-radius:6px;padding:6px 10px;color:var(--text);font-size:13px;font-family:var(--font);outline:none}.checklist-add input:focus{border-color:var(--accent)}.view-toggle{display:flex;border:1px solid var(--border2);border-radius:var(--radius-sm);overflow:hidden}.view-toggle button{padding:6px 12px;background:var(--bg2);color:var(--text2);border:none;cursor:pointer;font-size:12.5px;font-weight:600;font-family:var(--font)}.view-toggle button.active{background:var(--accent);color:var(--on-accent)}.row-avatar{display:flex;align-items:center;gap:8px}.row-avatar-circle{width:28px;height:28px;border-radius:50%;font-size:10px;font-weight:700;color:var(--on-accent-bright);display:flex;align-items:center;justify-content:center;flex-shrink:0}.empty-state{text-align:center;padding:48px 24px;color:var(--text3);font-size:13px}.empty-state-icon{font-size:32px;margin-bottom:12px;opacity:.45}.home-screen{display:flex;flex-direction:column;align-items:center;padding:48px 24px;animation:fadeIn .18s ease}.home-title{font-size:23px;font-weight:800;letter-spacing:-.3px;margin-bottom:6px}.home-sub{font-size:13.5px;color:var(--text3);margin-bottom:40px}.home-grid{display:grid;grid-template-columns:repeat(auto-fill,112px);gap:18px;justify-content:center;width:100%;max-width:700px}.home-app-icon{display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;text-decoration:none;color:var(--text);padding:16px 8px;border-radius:var(--radius);border:1px solid transparent;transition:all .12s}.home-app-icon:hover{background:var(--bg2);border-color:var(--border);box-shadow:var(--shadow-sm)}.home-app-bubble{width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;box-shadow:var(--shadow-sm)}.home-app-label{font-size:12.5px;font-weight:600;text-align:center;line-height:1.3}.home-empty{display:flex;flex-direction:column;align-items:center;gap:16px;padding:64px 24px;color:var(--text3);text-align:center}.home-empty-icon{font-size:48px;opacity:.35}.home-empty h3{font-size:16px;font-weight:700;color:var(--text2)}.home-empty p{font-size:13px;max-width:320px;line-height:1.6}.apps-header{margin-bottom:24px}.apps-header h2{font-size:19px;font-weight:800;margin-bottom:4px}.apps-header p{font-size:13.5px;color:var(--text3)}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.app-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px;display:flex;flex-direction:column;gap:12px;transition:box-shadow .12s,border-color .12s}.app-card:hover{box-shadow:var(--shadow-md)}.app-card.installed{border-color:#8cb42873}.app-card-top{display:flex;align-items:flex-start;gap:14px}.app-card-bubble{width:48px;height:48px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.app-card-info{flex:1}.app-card-name{font-size:14.5px;font-weight:700;margin-bottom:4px}.app-card-desc{font-size:12.5px;color:var(--text3);line-height:1.5}.app-card-footer{display:flex;align-items:center;justify-content:space-between}.app-card-tag{font-size:11px;font-weight:600;color:var(--text3)}.loading-screen{display:flex;align-items:center;justify-content:center;width:100%;height:100%;flex:1;flex-direction:column;gap:16px;color:var(--text3);font-size:13px}.spinner{width:38px;height:38px;border:3px solid var(--bg4);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-msg{text-align:center;max-width:320px;padding:0 24px;line-height:1.5;animation:loadingMsgIn .45s ease}@keyframes loadingMsgIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.sub-nav{background:var(--bg2);border-bottom:1px solid var(--border);padding:0 24px;display:flex;gap:2px;flex-shrink:0;overflow-x:auto}.sub-nav::-webkit-scrollbar{height:0}.sub-nav-item{display:inline-flex;align-items:center;gap:6px;padding:11px 14px;font-size:13px;font-weight:600;color:var(--text3);text-decoration:none;border-bottom:2px solid transparent;white-space:nowrap;transition:color .12s,border-color .12s;cursor:pointer;font-family:var(--font)}.sub-nav-item:hover{color:var(--text2)}.sub-nav-item.active{color:var(--accent);border-bottom-color:var(--accent)}.sub-nav-icon{font-size:12px}.nav-sub-list{overflow:hidden}.nav-sub-item{display:flex;align-items:center;gap:8px;padding:6px 10px 6px 38px;font-size:12.5px;color:var(--text3);text-decoration:none;border-radius:var(--radius-sm);transition:all .1s;-webkit-user-select:none;user-select:none}.nav-sub-item:hover{background:var(--bg3);color:var(--text2)}.nav-sub-item.active{color:var(--accent);background:var(--accent-dim);font-weight:600}.nav-sub-icon{width:14px;text-align:center;font-size:11px;flex-shrink:0}.auth-screen{width:100%;height:100vh;height:100dvh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top,var(--glow),transparent 55%),var(--bg);padding:24px;overflow-y:auto}.auth-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-md);padding:36px 32px;width:100%;max-width:420px;animation:fadeIn .3s ease}.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px}.auth-logo-text{font-size:16px;font-weight:800;color:var(--text)}.auth-logo-sub{font-size:11.5px;color:var(--text3);margin-top:2px}.auth-title{font-size:23px;font-weight:800;letter-spacing:-.3px;margin-bottom:6px}.auth-sub{font-size:13.5px;color:var(--text3);margin-bottom:24px}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-error{background:var(--red-dim);color:var(--red);border:1px solid rgba(214,59,59,.25);border-radius:var(--radius-sm);padding:10px 12px;font-size:12.5px;line-height:1.4}.auth-submit{justify-content:center;padding:11px 18px;font-size:14px;font-weight:700;margin-top:4px}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:12px;margin:16px 0;font-size:12px;color:var(--text3)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.google-btn{width:100%;justify-content:center;gap:10px;padding:11px 18px;font-size:14px;font-weight:600;background:#fff;color:#3c4043;border:1px solid var(--border2)}.google-btn:hover:not(:disabled){background:#f5f6f7}.google-btn:disabled{opacity:.6;cursor:not-allowed}.auth-footer{margin-top:20px;font-size:12.5px;color:var(--text3);text-align:center}.auth-footer a{color:var(--accent);text-decoration:none;font-weight:700}.auth-footer a:hover{text-decoration:underline}.onboarding-screen{width:100%;height:100vh;height:100dvh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top,var(--glow),transparent 55%),var(--bg);padding:24px;overflow-y:auto}.onboarding-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-md);padding:32px 36px;width:100%;max-width:620px;animation:fadeIn .3s ease}.onboarding-progress{width:100%;height:6px;background:var(--bg4);border-radius:999px;overflow:hidden;margin-bottom:8px}.onboarding-progress-fill{height:100%;background:var(--accent-bright);border-radius:999px;transition:width .25s ease}.onboarding-step-label{font-size:11.5px;font-weight:600;color:var(--text3);margin-bottom:24px}.onboarding-title{font-size:26px;font-weight:800;margin-bottom:8px;letter-spacing:-.4px}.onboarding-sub{font-size:13.5px;color:var(--text2);line-height:1.6;margin-bottom:24px}.onboarding-feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}.onboarding-feature{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.onboarding-feature-icon{font-size:20px;color:var(--accent);margin-bottom:6px}.onboarding-feature-title{font-size:13.5px;font-weight:700;margin-bottom:3px}.onboarding-feature-desc{font-size:12px;color:var(--text3);line-height:1.4}.onboarding-sample-summary{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;margin-bottom:24px;display:flex;flex-direction:column;gap:8px}.onboarding-sample-row{font-size:13.5px;color:var(--text2);display:flex;align-items:center;gap:10px}.onboarding-sample-icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:var(--accent-dim);color:var(--accent);font-size:12px;flex-shrink:0}.onboarding-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:12px}.onboarding-next{padding:11px 22px;font-size:14px;font-weight:700}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--text3)}.menu-btn{display:none;flex-direction:column;justify-content:center;gap:4px;width:36px;height:36px;padding:0 8px;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0}.menu-btn span{display:block;height:2px;width:100%;background:var(--text2);border-radius:2px;transition:background .12s}.menu-btn:hover span{background:var(--accent)}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#1e222d66;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:210;opacity:0;pointer-events:none;transition:opacity .25s ease}@media (max-width: 900px){.menu-btn{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:min(280px,84vw);z-index:220;transform:translate(-105%);transition:transform .28s cubic-bezier(.32,.72,.2,1)}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-lg)}.sidebar-backdrop{display:block}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.topbar{padding:0 16px;gap:12px}.content{padding:16px}.sub-nav{padding:0 16px}.stats-row,.roadmap-stats{grid-template-columns:repeat(2,1fr);gap:10px}.dash-grid{grid-template-columns:1fr}.task-board{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:12px;padding-bottom:8px;-webkit-overflow-scrolling:touch}.task-board .task-col{flex:0 0 min(300px,82vw);scroll-snap-align:start}}@media (max-width: 600px){.content{padding:12px}.topbar .kbd-hint,.topbar .breadcrumb-root{display:none}.topbar-actions .search-bar{max-width:none}.stat-value{font-size:21px}.card-header{flex-wrap:wrap;gap:10px}.card-header .search-bar{min-width:160px}.card-body{padding:14px}.form-grid{grid-template-columns:1fr;gap:12px}.onboarding-feature-grid{grid-template-columns:1fr}.onboarding-card{padding:24px 20px}.auth-card{padding:28px 22px}.modal-overlay{align-items:flex-end}.modal,.modal-lg{width:100%;max-width:100%;max-height:92dvh;border-radius:16px 16px 0 0;animation:sheetIn .28s cubic-bezier(.32,.72,.2,1)}.table-wrap{-webkit-overflow-scrolling:touch}.table-wrap td{white-space:nowrap}.inv-line{grid-template-columns:1fr 1fr}.inv-line>:first-child{grid-column:1 / -1}.inv-totals{flex-wrap:wrap;gap:12px 24px}}@keyframes sheetIn{0%{opacity:0;transform:translateY(48px)}to{opacity:1;transform:translateY(0)}}@media (hover: none){.row-actions,.phase-actions{opacity:1}.icon-btn{width:32px;height:32px}.nav-item,.nav-sub-item{padding-top:10px;padding-bottom:10px}}
