.note-form{background:var(--surface);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}.note-form h2{font-size:1rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.note-form input,.note-form textarea{background:var(--bg);border:1px solid var(--surface2);border-radius:var(--radius);color:var(--text);padding:.6rem .8rem;outline:none;resize:vertical;transition:border-color .15s}.note-form input:focus,.note-form textarea:focus{border-color:var(--accent)}.note-form button{background:var(--accent);color:#fff;border:none;border-radius:var(--radius);padding:.65rem 1.2rem;cursor:pointer;font-weight:600;align-self:flex-end;transition:opacity .15s}.note-form button:disabled{opacity:.5;cursor:not-allowed}.form-error{color:var(--accent);font-size:.85rem}.note-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.note-card{background:var(--surface);border-radius:var(--radius);padding:1rem 1rem 1rem 1.25rem;display:flex;gap:1rem;align-items:flex-start;border-left:3px solid var(--accent)}.note-body{flex:1;min-width:0}.note-body h3{font-size:.95rem;font-weight:600;margin-bottom:.3rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-body p{font-size:.9rem;color:var(--text-muted);word-break:break-word}.note-body time{display:block;font-size:.75rem;color:var(--surface2);margin-top:.4rem}.delete-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:2px 4px;border-radius:4px;flex-shrink:0;transition:color .15s}.delete-btn:hover{color:var(--accent)}.empty-msg{color:var(--text-muted);text-align:center;padding:3rem 0}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0f0f1a;padding:1rem}.login-card{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:12px;padding:2.5rem 2rem;width:100%;max-width:380px;box-shadow:0 8px 32px #0006}.login-title{font-size:1.5rem;font-weight:700;color:#e2e8f0;margin:0 0 .25rem;text-align:center}.login-subtitle{color:#718096;font-size:.9rem;text-align:center;margin:0 0 2rem}.login-form{display:flex;flex-direction:column;gap:.75rem}.login-form input{background:#0f0f1a;border:1px solid #2a2a4a;border-radius:8px;color:#e2e8f0;font-size:.95rem;padding:.75rem 1rem;outline:none;transition:border-color .2s}.login-form input:focus{border-color:#63b3ed}.login-form button{background:#3182ce;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;margin-top:.5rem;padding:.75rem;transition:background .2s}.login-form button:hover:not(:disabled){background:#2b6cb0}.login-form button:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#fc8181;font-size:.85rem;margin:0;text-align:center}.user-management{display:flex;flex-direction:column;gap:1.25rem}.um-header{display:flex;align-items:center;justify-content:space-between}.um-header h2{font-size:1.2rem;font-weight:700}.um-status{color:var(--text-muted);text-align:center;padding:2rem}.um-error{color:var(--accent)}.table-wrap{overflow-x:auto}.user-table{width:100%;border-collapse:collapse;font-size:.875rem}.user-table th{text-align:left;padding:.5rem .75rem;border-bottom:2px solid var(--surface2);font-weight:600;color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.user-table td{padding:.6rem .75rem;border-bottom:1px solid var(--surface2);vertical-align:middle}.row-inactive td{opacity:.5}.td-user{display:flex;align-items:center;gap:.4rem}.username{font-weight:500}.tag-self{font-size:.65rem;background:var(--surface2);color:var(--text-muted);padding:1px 5px;border-radius:99px}.role-badge{font-size:.7rem;padding:2px 7px;border-radius:99px;font-weight:600}.role-admin{background:#3b4fd8;color:#fff}.role-user{background:var(--surface2);color:var(--text-muted)}.status-dot{font-size:.75rem}.status-dot.active{color:#22c55e}.status-dot.inactive{color:var(--text-muted)}.inline-input,.inline-select{background:var(--surface1);border:1px solid var(--surface2);border-radius:4px;color:var(--text);font-size:.8rem;padding:3px 6px;width:100%;max-width:160px}.td-actions{display:flex;gap:.4rem;flex-wrap:wrap}.btn{border:none;border-radius:5px;cursor:pointer;font-size:.75rem;font-weight:600;padding:4px 10px;transition:opacity .15s}.btn:disabled{cursor:not-allowed;opacity:.4}.btn-primary{background:var(--accent);color:#fff;font-size:.85rem;padding:6px 14px}.btn-edit{background:var(--surface2);color:var(--text)}.btn-save{background:#22c55e;color:#fff}.btn-cancel{background:var(--surface2);color:var(--text-muted)}.btn-deactivate{background:#f87171;color:#fff}.btn-activate{background:#22c55e;color:#fff}.create-form{background:var(--surface1);border:1px solid var(--surface2);border-radius:8px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.create-form h3{font-size:1rem;font-weight:700;margin:0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}@media (max-width: 500px){.form-grid{grid-template-columns:1fr}}.form-grid label{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:var(--text-muted)}.form-grid input,.form-grid select{background:var(--surface1);border:1px solid var(--surface2);border-radius:5px;color:var(--text);font-size:.875rem;padding:6px 8px}.form-actions{display:flex;gap:.5rem}.form-error{color:var(--accent);font-size:.8rem;margin:0}.service-badge{display:inline-block;font-size:.72rem;padding:.15rem .45rem;border-radius:4px;margin-right:.25rem;font-weight:500}.service-all{background:#d1fae5;color:#065f46}.service-notes{background:#dbeafe;color:#1e40af}.service-lunch{background:#fef3c7;color:#92400e}.service-none{color:#aaa;font-size:.82rem}.service-checks{display:flex;flex-direction:column;gap:.2rem}.service-check-label{display:flex;align-items:center;gap:.35rem;font-size:.82rem;cursor:pointer;white-space:nowrap}.create-services{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin:.5rem 0 .25rem}.create-services-label{font-size:.82rem;color:#555;font-weight:500}.lunch-overview{display:flex;flex-direction:column;gap:1.25rem;padding-bottom:2rem}.lunch-warning{background:#d299221f;border:1px solid rgba(210,153,34,.4);color:#e3b341;border-radius:var(--radius);padding:.7rem 1rem;font-size:.875rem}.lunch-error{background:#f851491a;border:1px solid rgba(248,81,73,.35);color:var(--red);border-radius:var(--radius);padding:.7rem 1rem;font-size:.875rem}.lunch-status{text-align:center;color:var(--text-muted);padding:2rem}.lunch-empty{color:var(--text-muted);font-size:.875rem;padding:.5rem 0}.lunch-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.lunch-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.lunch-section-header h2{font-size:1rem;font-weight:600;color:var(--text);margin:0}.lunch-header-btns{display:flex;gap:.5rem}.btn-refresh{background:var(--surface2);color:var(--accent);border:1px solid var(--border);padding:.35rem .8rem;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s}.btn-refresh:hover:not(:disabled){border-color:var(--accent);background:var(--accent-dim)}.btn-refresh:disabled{opacity:.5;cursor:not-allowed}.btn-add{background:var(--accent);color:#fff;border:none;padding:.35rem .8rem;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-add:hover{opacity:.85}.lunch-form{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.6rem}.lunch-form h3{font-size:.9rem;font-weight:600;color:var(--text);margin:0 0 .25rem}.lunch-form label{display:flex;flex-direction:column;font-size:.78rem;color:var(--text-muted);gap:.25rem}.lunch-form input{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.875rem;padding:.45rem .65rem;outline:none;transition:border-color .15s}.lunch-form input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim)}.form-btns{display:flex;gap:.5rem;margin-top:.35rem}.form-btns button[type=submit]{background:var(--accent);color:#fff;border:none;padding:.45rem 1rem;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.form-btns button[type=submit]:hover{opacity:.85}.form-btns button[type=button]{background:transparent;color:var(--text-muted);border:1px solid var(--border);padding:.45rem 1rem;border-radius:6px;font-size:.85rem;cursor:pointer;transition:border-color .15s,color .15s}.form-btns button[type=button]:hover{border-color:var(--text-muted);color:var(--text)}.account-list{display:flex;flex-direction:column;gap:.5rem}.account-card{display:flex;align-items:center;justify-content:space-between;padding:.65rem .9rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface2);gap:.75rem;transition:border-color .15s}.account-card:hover{border-color:var(--accent)}.account-card.inactive{opacity:.5}.account-info{display:flex;align-items:center;gap:.6rem;flex:1;min-width:0}.account-name{font-weight:600;font-size:.9rem;color:var(--text)}.account-nr{font-size:.78rem;color:var(--text-muted);font-family:SF Mono,Consolas,monospace}.badge-off{background:#d2992233;color:#e3b341;border:1px solid rgba(210,153,34,.35);font-size:.68rem;padding:.1rem .45rem;border-radius:4px}.account-actions{display:flex;gap:.4rem;align-items:center;flex-shrink:0}.btn-scrape{background:var(--surface);color:var(--accent);border:1px solid var(--border);width:2rem;height:2rem;border-radius:6px;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s}.btn-scrape:hover:not(:disabled){border-color:var(--accent);background:var(--accent-dim)}.btn-scrape:disabled{opacity:.4;cursor:not-allowed}.btn-edit,.btn-toggle{background:transparent;color:var(--text-muted);border:1px solid var(--border);padding:.28rem .6rem;border-radius:6px;font-size:.78rem;cursor:pointer;transition:border-color .15s,color .15s}.btn-edit:hover,.btn-toggle:hover{border-color:var(--text-muted);color:var(--text)}.week-block{margin-bottom:1.25rem}.week-block:last-child{margin-bottom:0}.week-heading{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin:0 0 .5rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}.day-row{display:flex;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--surface2);align-items:flex-start}.day-row:last-child{border-bottom:none}.day-label{min-width:115px;flex-shrink:0}.day-wd{display:block;font-weight:600;font-size:.875rem;color:var(--text)}.day-dt{display:block;font-size:.75rem;color:var(--text-muted);font-family:SF Mono,Consolas,monospace}.day-meals{display:flex;flex-direction:column;gap:.3rem;flex:1}.meal-item{display:flex;gap:.5rem;align-items:baseline;flex-wrap:wrap}.meal-account{font-size:.72rem;font-weight:600;color:var(--accent);background:var(--accent-dim);border:1px solid rgba(88,166,255,.2);padding:.1rem .4rem;border-radius:4px;white-space:nowrap;font-family:SF Mono,Consolas,monospace}.meal-title{font-size:.875rem;color:var(--text-muted)}@media (max-width: 600px){.lunch-section{padding:1rem}.day-row{flex-direction:column;gap:.2rem}.day-label{min-width:unset}.account-card{flex-wrap:wrap}}.tj-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.5rem}@media (max-width: 600px){.tj-stats{grid-template-columns:repeat(2,1fr)}}.tj-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.875rem 1rem}.tj-stat-label{font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-subtle);margin-bottom:.3rem}.tj-stat-value{font-size:1.3rem;font-weight:700;font-family:SF Mono,Consolas,monospace;color:var(--text)}.tj-stat-value.green{color:#3fb950}.tj-stat-value.red{color:var(--red)}.tj-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.tj-header h3{font-size:.95rem;font-weight:600;color:var(--text);margin:0}.tj-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .9rem;border-radius:6px;font-size:.82rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s;border:1px solid var(--border);background:var(--surface2);color:var(--text-muted)}.tj-btn:hover{border-color:var(--accent);color:var(--accent)}.tj-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.tj-btn.primary:hover{background:#79c0ff;border-color:#79c0ff;color:#fff}.tj-btn.danger:hover{border-color:var(--red);color:var(--red)}.tj-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.5rem}.tj-form-title{font-size:.82rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:1rem}.tj-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}@media (max-width: 520px){.tj-form-grid{grid-template-columns:1fr}}.tj-form-grid .span2{grid-column:1 / -1}.tj-field{display:flex;flex-direction:column;gap:.3rem}.tj-field label{font-size:.72rem;font-weight:600;letter-spacing:.04em;color:var(--text-muted);text-transform:uppercase}.tj-field input,.tj-field select,.tj-field textarea{background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.875rem;padding:.5rem .7rem;outline:none;width:100%;box-sizing:border-box;transition:border-color .15s;font-family:inherit}.tj-field input:focus,.tj-field select:focus,.tj-field textarea:focus{border-color:var(--accent)}.tj-field textarea{resize:vertical;min-height:72px}.tj-form-actions{display:flex;gap:.6rem;margin-top:1rem;justify-content:flex-end}.tj-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}.tj-table{width:100%;border-collapse:collapse;font-size:.845rem}.tj-table th{text-align:left;padding:.6rem .875rem;font-size:.65rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text-subtle);border-bottom:1px solid var(--border);background:var(--surface);white-space:nowrap}.tj-table td{padding:.65rem .875rem;border-bottom:1px solid var(--border);color:var(--text-muted);white-space:nowrap}.tj-table tr:last-child td{border-bottom:none}.tj-table tr:hover td{background:var(--surface2)}.tj-table .mono{font-family:SF Mono,Consolas,monospace;font-size:.82rem}.badge{display:inline-block;padding:2px 7px;border-radius:4px;font-size:.7rem;font-weight:600;letter-spacing:.04em}.badge-long{background:#3fb95026;color:#3fb950}.badge-short{background:#f8514926;color:var(--red)}.badge-open{background:#d2992226;color:#d29922}.badge-closed{background:var(--surface2);color:var(--text-muted)}.badge-win{background:#3fb95026;color:#3fb950}.badge-loss{background:#f8514926;color:var(--red)}.badge-be{background:var(--surface2);color:var(--text-subtle)}.pnl-pos{color:#3fb950;font-family:SF Mono,Consolas,monospace;font-size:.82rem}.pnl-neg{color:var(--red);font-family:SF Mono,Consolas,monospace;font-size:.82rem}.pnl-nil{color:var(--text-subtle)}.tj-actions{display:flex;gap:.4rem}.tj-action-btn{background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.72rem;padding:3px 8px;transition:border-color .15s,color .15s}.tj-action-btn:hover{border-color:var(--accent);color:var(--accent)}.tj-action-btn.del:hover{border-color:var(--red);color:var(--red)}.tj-empty{text-align:center;padding:3rem;color:var(--text-subtle);font-size:.875rem}.tj-notes-cell{max-width:180px;overflow:hidden;text-overflow:ellipsis;color:var(--text-subtle);font-style:italic;font-size:.78rem}.ta-page{display:flex;flex-direction:column;gap:1.75rem}.ta-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.ta-title{font-size:1.35rem;font-weight:700;color:var(--text);margin:0 0 .25rem}.ta-subtitle{font-size:.85rem;color:var(--text-muted);margin:0}.ta-refresh-btn{background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:1.1rem;width:34px;height:34px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .15s,border-color .15s}.ta-refresh-btn:hover{color:var(--accent);border-color:var(--accent)}.ta-section{display:flex;flex-direction:column;gap:.75rem}.ta-section-label{font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-subtle)}.ta-status-bar{display:flex;align-items:center;gap:.6rem;padding:.65rem .875rem;border-radius:6px;border:1px solid var(--border);background:var(--surface)}.bar-ok{border-color:#3fb95059}.bar-err{border-color:#f8514959}.ta-status-text{font-size:.875rem;font-weight:500;color:var(--text);flex:1}.ta-status-updated{font-size:.72rem;color:var(--text-subtle);font-family:SF Mono,Consolas,monospace}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;display:inline-block}.dot-ok{background:#3fb950;box-shadow:0 0 6px #3fb95080}.dot-warn{background:#d29922;box-shadow:0 0 6px #d2992280}.dot-err{background:var(--red);box-shadow:0 0 6px #f8514980}.ta-collectors{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.75rem}.ta-collector-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.875rem 1rem;display:flex;flex-direction:column;gap:.75rem}.ta-collector-top{display:flex;align-items:flex-start;gap:.6rem}.ta-collector-icon{font-size:1.15rem;color:var(--accent);flex-shrink:0;margin-top:1px}.ta-collector-info{flex:1;min-width:0}.ta-collector-name{font-size:.875rem;font-weight:600;color:var(--text)}.ta-collector-desc{font-size:.72rem;color:var(--text-subtle);margin-top:2px}.ta-collector-stats{display:flex;gap:1rem;padding-top:.5rem;border-top:1px solid var(--border)}.ta-cstat{display:flex;flex-direction:column;gap:.15rem}.ta-cstat-label{font-size:.62rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-subtle)}.ta-cstat-value{font-size:.85rem;font-weight:600;color:var(--text-muted)}.ta-cstat-value.mono{font-family:SF Mono,Consolas,monospace}.ta-no-service{padding:1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:.875rem;line-height:1.6}.ta-no-service-hint{font-size:.8rem;color:var(--text-subtle);margin-top:.5rem}.ta-no-service-hint code{background:var(--surface2);padding:1px 5px;border-radius:3px;font-family:SF Mono,Consolas,monospace;font-size:.78rem}.ta-coming-soon{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-subtle);font-size:.85rem}.ta-cs-icon{font-size:1.25rem;color:var(--accent);opacity:.5;flex-shrink:0}.shell{display:flex;min-height:100vh;position:relative}.sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:200;transform:translate(calc(-1 * var(--sidebar-w)));transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s;overflow-y:auto}.sidebar.open{transform:translate(0);box-shadow:8px 0 32px #00000080}.sidebar-head{display:flex;align-items:center;gap:.75rem;padding:1rem;border-bottom:1px solid var(--border);min-height:var(--topbar-h)}.sidebar-logo{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),#1f6feb);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:800;color:#fff;font-family:SF Mono,Consolas,monospace;letter-spacing:-.05em;flex-shrink:0;box-shadow:0 0 10px #58a6ff59}.sidebar-name{font-size:.82rem;font-weight:600;font-family:SF Mono,Consolas,monospace;color:var(--text);line-height:1.2}.sidebar-name small{display:block;font-size:.68rem;color:var(--text-muted);font-weight:400}.sidebar-nav{flex:1;padding:.5rem 0}.nav-section-label{font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-subtle);padding:1rem 1rem .35rem}.nav-item{position:relative;display:flex;align-items:center;gap:.65rem;width:100%;padding:.6rem 1rem;border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:.875rem;text-align:left;transition:background .15s,color .15s}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--accent-dim);color:var(--accent)}.nav-item.active:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;background:var(--accent);border-radius:0 2px 2px 0}.nav-icon{font-size:1rem;width:20px;text-align:center;flex-shrink:0;line-height:1}.sidebar-footer{padding:.75rem;border-top:1px solid var(--border)}.user-block{display:flex;align-items:center;gap:.6rem;padding:.6rem .5rem;border-radius:6px;background:var(--surface2);margin-bottom:.6rem;overflow:hidden}.user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#1f6feb);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0;text-transform:uppercase}.user-meta{flex:1;min-width:0}.user-meta-name{font-size:.8rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-meta-role{font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.sidebar-logout{width:100%;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:.8rem;padding:6px 12px;transition:border-color .2s,color .2s;text-align:center}.sidebar-logout:hover{border-color:var(--red);color:var(--red)}.backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fade-in .2s}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.main-wrap{flex:1;display:flex;flex-direction:column;min-height:100vh;min-width:0}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:.75rem;padding:0 1rem;height:var(--topbar-h);background:#161b22eb;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.menu-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:6px;transition:background .15s,color .15s;flex-shrink:0}.menu-btn:hover{background:var(--surface2);color:var(--text)}.menu-btn svg{width:18px;height:18px}.topbar-brand{font-size:.88rem;font-weight:600;font-family:SF Mono,Consolas,monospace;color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-brand span{color:var(--accent)}.topbar-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.topbar-user{font-size:.75rem;color:var(--text-muted);padding:3px 9px;background:var(--surface2);border:1px solid var(--border);border-radius:99px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-logout{background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:.78rem;padding:4px 10px;transition:border-color .2s,color .2s;white-space:nowrap}.topbar-logout:hover{border-color:var(--red);color:var(--red)}.content{flex:1;padding:1.75rem 1.25rem;max-width:820px;width:100%;margin:0 auto}.home-page{display:flex;flex-direction:column;gap:2rem}.home-hero{padding:1.5rem 0 .5rem}.home-hero h2{font-size:1.6rem;font-weight:700;color:var(--text);margin-bottom:.4rem}.home-hero h2 .accent{color:var(--accent)}.home-hero p{color:var(--text-muted);font-size:.92rem}.home-section-title{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-subtle);margin-bottom:.75rem}.service-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:.875rem}.service-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1rem;cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:.45rem;transition:border-color .2s,box-shadow .2s,transform .15s;color:var(--text)}.service-card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-dim),0 6px 20px var(--accent-glow);transform:translateY(-2px)}.card-icon{font-size:1.4rem;line-height:1;margin-bottom:.2rem}.card-label{font-size:.92rem;font-weight:600;color:var(--text)}.card-desc{font-size:.78rem;color:var(--text-muted);line-height:1.4}.home-meta{display:flex;gap:1.5rem;flex-wrap:wrap;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-top:.5rem}.meta-item{display:flex;flex-direction:column;gap:.2rem}.meta-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-subtle)}.meta-value{font-size:.82rem;font-family:SF Mono,Consolas,monospace;color:var(--text-muted)}.nav-group{justify-content:flex-start}.nav-group.has-active{color:var(--text)}.nav-chevron{margin-left:auto;font-size:.8rem;color:var(--text-subtle);transition:transform .2s ease;display:inline-block;line-height:1}.nav-chevron.open{transform:rotate(90deg)}.nav-sub{overflow:hidden}.nav-sub-item{position:relative;display:flex;align-items:center;gap:.65rem;width:100%;padding:.48rem 1rem .48rem 2.6rem;border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:.82rem;text-align:left;transition:background .15s,color .15s}.nav-sub-item:hover{background:var(--surface2);color:var(--text)}.nav-sub-item.active{background:var(--accent-dim);color:var(--accent)}.nav-sub-item.active:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;background:var(--accent);border-radius:0 2px 2px 0}.placeholder-page{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:4rem 2rem;text-align:center;color:var(--text-muted)}.placeholder-icon{font-size:2.5rem;line-height:1;color:var(--accent);opacity:.6}.placeholder-page h2{font-size:1.4rem;font-weight:600;color:var(--text);margin:0}.placeholder-page p{font-size:.9rem;color:var(--text-muted);margin:0}.placeholder-badge{display:inline-block;margin-top:.5rem;padding:3px 10px;border:1px solid var(--border);border-radius:99px;font-size:.72rem;font-family:SF Mono,Consolas,monospace;letter-spacing:.04em;color:var(--text-subtle)}.status-msg{color:var(--text-muted);text-align:center;padding:2rem}.status-msg.error{color:var(--red)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d1117;--surface: #161b22;--surface2: #21262d;--border: #30363d;--accent: #58a6ff;--accent-dim: rgba(88, 166, 255, .12);--accent-glow: rgba(88, 166, 255, .25);--green: #3fb950;--red: #f85149;--yellow: #d29922;--text: #e6edf3;--text-muted: #8b949e;--text-subtle: #6e7681;--radius: 8px;--surface1: #161b22;--sidebar-w: 240px;--topbar-h: 52px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5;background-image:radial-gradient(circle,#21262d 1px,transparent 1px);background-size:24px 24px}input,textarea,button,select{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
