:root{--accent:#3b82f6;--accent-dark:#2563eb;--bar-bg:#1e293b;--bar-fg:#cbd5e1;--bar-active:#334155;--bg:#f1f5f9;--card:#fff;--border:#e2e8f0;--text:#0f172a;--muted:#64748b;--ok:#16a34a;--warn:#ef4444;--info:#0ea5e9;--radius:10px}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--text);background:var(--bg);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5}.shell{flex-direction:column;min-height:100vh;display:flex}.appbar{background:var(--bar-bg);color:#fff;align-items:center;gap:1rem;padding:.7rem 1.25rem;display:flex}.appbar .brand{font-size:1.15rem;font-weight:700}.appbar .spacer{flex:1}.appbar .user{color:var(--bar-fg);font-size:.9rem}.appbar .user .logout{color:#93c5fd;cursor:pointer;margin-left:.5rem}.navbar{background:#273449;border-bottom:1px solid #0f172a;align-items:center;gap:.25rem;padding:0 .75rem;display:flex}.navbar a{color:var(--bar-fg);border-bottom:3px solid #0000;padding:.7rem .9rem;font-size:.92rem;text-decoration:none}.navbar a:hover{color:#fff;background:var(--bar-active)}.navbar a.active{color:#fff;border-bottom-color:var(--accent)}.navbar .spacer{flex:1}.content{min-width:0;padding:1.5rem 2rem}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.page-head h1{font-size:1.5rem}.section-title{text-transform:uppercase;color:var(--muted);letter-spacing:.04em;margin:1.25rem 0 .6rem;font-size:.85rem}.btn{border:1px solid var(--border);color:var(--text);border-radius:var(--radius);cursor:pointer;background:#fff;align-items:center;gap:.4rem;padding:.5rem .9rem;font-size:.9rem;text-decoration:none;display:inline-flex}.btn:hover{background:#f8fafc}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-dark)}.btn.danger{color:var(--warn)}.btn.small{padding:.35rem .6rem;font-size:.82rem}.btn:disabled,.btn.disabled{opacity:.5;cursor:not-allowed}.app-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.tile{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.5rem;padding:1rem;display:flex}.tile .tname{font-weight:600}.tile .tstatus{color:var(--muted);font-size:.85rem}.tile .tactions{align-items:center;gap:.6rem;margin-top:auto;display:flex}.tile .ext{color:var(--muted);font-size:.85rem;text-decoration:none}.dot{vertical-align:middle;border-radius:50%;width:9px;height:9px;margin-right:.4rem;display:inline-block}.dot.ok{background:var(--ok)}.dot.warn{background:var(--warn)}.dot.info{background:var(--info)}.dot.neutral{background:#cbd5e1}.muted{color:var(--muted)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.25rem;overflow:hidden}.card .card-body{padding:1rem 1.25rem}.card h2{border-bottom:1px solid var(--border);padding:.9rem 1.25rem;font-size:1rem}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--border);padding:.7rem 1rem}th{color:var(--muted);text-transform:uppercase;letter-spacing:.03em;font-size:.8rem}tr:last-child td{border-bottom:none}tbody tr:hover{background:#f8fafc}td.actions{text-align:right;white-space:nowrap}.skeleton{background:linear-gradient(90deg,#eef2f7 25%,#e2e8f0 37%,#eef2f7 63%) 0 0/400% 100%;border-radius:6px;height:.9rem;animation:1.4s infinite shimmer}.skeleton.block{height:4.5rem}@keyframes shimmer{0%{background-position:100% 0}to{background-position:0 0}}.state-box{background:var(--card);border:1px dashed var(--border);border-radius:var(--radius);text-align:center;color:var(--muted);padding:1.5rem}.state-box.error{color:#b91c1c;background:#fef2f2;border-style:solid;border-color:#fecaca}.notice{border-radius:8px;margin:.5rem 0;padding:.6rem .9rem;font-size:.88rem}.notice.ok{color:#166534;background:#dcfce7}.notice.err{color:#b91c1c;background:#fee2e2}.notice.info{color:#075985;background:#e0f2fe}.app-context{justify-content:space-between;align-items:center;margin-bottom:.6rem;display:flex}.app-context h1{font-size:1.25rem}.app-context a{color:var(--accent-dark);font-size:.88rem;text-decoration:none}.app-frame{border:1px solid var(--border);border-radius:var(--radius);background:#fff;min-height:420px;overflow:hidden}.tablist{border:1px solid var(--border);border-radius:var(--radius);background:#fff;margin-bottom:1.1rem;display:inline-flex;overflow:hidden}.tablist .tab{cursor:pointer;color:var(--muted);border:none;border-right:1px solid var(--border);background:#fff;padding:.5rem 1rem;font-size:.9rem}.tablist .tab:last-child{border-right:none}.tablist .tab.active{background:var(--accent);color:#fff}.tablist .tab:disabled{color:#94a3b8;cursor:not-allowed}.field{flex-direction:column;gap:.3rem;max-width:420px;margin-bottom:.8rem;display:flex}.field label{color:var(--muted);font-size:.85rem}input[type=text],input[type=password],input[type=email],select,textarea{border:1px solid var(--border);background:#fff;border-radius:8px;padding:.5rem .7rem;font-family:inherit;font-size:.9rem}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:-1px}.hint{color:var(--muted);font-size:.82rem}.login-wrap{place-items:center;min-height:100vh;padding:1rem;display:grid}.login-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:1rem;width:min(360px,92vw);padding:2rem;display:flex}.login-card h1{text-align:center;font-size:1.3rem}dialog{border-radius:var(--radius);border:none;width:min(460px,92vw);margin:auto;padding:0;box-shadow:0 20px 50px #00000040}dialog::backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a73}.dlg-head{border-bottom:1px solid var(--border);padding:1rem 1.25rem;font-weight:600}.dlg-body{flex-direction:column;gap:.6rem;padding:1.25rem;display:flex}.dlg-actions{justify-content:flex-end;gap:.5rem;padding:0 1.25rem 1.25rem;display:flex}.btn.danger-solid{background:var(--warn);border-color:var(--warn);color:#fff}.btn.danger-solid:hover{background:#dc2626}@media (width<=768px){.navbar{flex-wrap:wrap}.content{padding:1rem}}
