/* Garage OS — file-first, theme toggle */
:root{
  --bg:#0b0c10; --panel:#111319; --panel2:#0f1117; --text:#e9ecf1; --muted:#a7b0c0; --line:#242a36;
  --brand:#8b5cf6; --brand2:#22c55e; --danger:#ef4444;
  --shadow:0 14px 40px rgba(0,0,0,.35); --radius:18px; --gap:14px;
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}
html[data-theme="light"]{
  --bg:#f5f7fb; --panel:#ffffff; --panel2:#fbfbfe; --text:#131722; --muted:#5c6476; --line:#e6e9f2;
  --shadow:0 14px 40px rgba(15,20,35,.12);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font-family:var(--font); color:var(--text);
  background:radial-gradient(1200px 700px at 15% 0%, rgba(139,92,246,.18), transparent 50%),
             radial-gradient(900px 600px at 90% 10%, rgba(34,197,94,.12), transparent 55%),
             var(--bg);
}
.topbar{
  position:sticky; top:0; z-index:10;
  display:flex; justify-content:space-between; align-items:center; gap:12px;
  padding:14px 18px; border-bottom:1px solid var(--line);
  background:color-mix(in oklab, var(--panel) 86%, transparent);
  backdrop-filter:saturate(150%) blur(10px);
}
.brand{display:flex; gap:12px; align-items:center}
.logo{
  width:44px; height:44px; border-radius:16px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, var(--brand), color-mix(in oklab, var(--brand) 55%, var(--brand2)));
  font-weight:900; box-shadow:var(--shadow);
}
.brandtext .title{font-weight:900; font-size:16px}
.brandtext .subtitle{font-size:12px; color:var(--muted)}
.top-actions{display:flex; gap:10px; align-items:center; flex-wrap:wrap; justify-content:flex-end}
.filepill{display:inline-flex; align-items:center; gap:8px; padding:8px 10px; border-radius:999px; border:1px solid var(--line);
  background:color-mix(in oklab, var(--panel2) 75%, transparent); color:var(--muted); font-size:12px;}
.dot{width:10px; height:10px; border-radius:999px; background:var(--danger)}
.dot.ok{background:var(--brand2)}
.btn{border:1px solid color-mix(in oklab, var(--brand) 30%, var(--line));
  background:linear-gradient(135deg, color-mix(in oklab, var(--brand) 30%, var(--panel)), var(--panel));
  color:var(--text); padding:9px 12px; border-radius:12px; cursor:pointer; font-weight:700;}
.btn.ghost{background:transparent; border:1px solid var(--line)}
.btn.danger{background:transparent; border:1px solid color-mix(in oklab, var(--danger) 55%, var(--line)); color:color-mix(in oklab, var(--danger) 80%, var(--text))}
label.btn.file{position:relative; overflow:hidden}
label.btn.file input{position:absolute; inset:0; opacity:0; cursor:pointer}
.shell{display:flex; min-height:calc(100vh - 120px)}
.sidebar{width:260px; padding:14px; border-right:1px solid var(--line); background:color-mix(in oklab, var(--panel) 92%, transparent)}
.navitem{width:100%; padding:10px 12px; margin:6px 0; border-radius:12px; border:1px solid transparent;
  background:transparent; color:var(--text); cursor:pointer; font-weight:750;}
.navitem:hover{background:color-mix(in oklab, var(--panel2) 65%, transparent)}
.navitem.active{background:linear-gradient(135deg, color-mix(in oklab, var(--brand) 28%, var(--panel)), var(--panel));
  border:1px solid color-mix(in oklab, var(--brand) 40%, var(--line))}
.navsep{height:10px; border-bottom:1px dashed var(--line); margin:10px 0}
.navitem.danger{color:color-mix(in oklab, var(--danger) 85%, var(--text))}
.content{flex:1; padding:16px; max-width:1220px; margin:0 auto}
.view{display:none}
.view.active{display:block}
.hero{display:flex; justify-content:space-between; align-items:flex-end; gap:14px; padding:18px; border:1px solid var(--line);
  border-radius:var(--radius); background:linear-gradient(135deg, color-mix(in oklab, var(--brand) 26%, var(--panel)),
  color-mix(in oklab, var(--brand2) 14%, var(--panel))); box-shadow:var(--shadow);}
.h-title{font-size:22px; font-weight:950}
.h-sub{color:color-mix(in oklab, var(--text) 76%, var(--muted)); margin-top:6px}
.h-row{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px}
.hero-card{min-width:280px; border:1px solid color-mix(in oklab, var(--line) 70%, transparent);
  background:color-mix(in oklab, var(--panel2) 80%, transparent); border-radius:16px; padding:12px 14px;}
.big{font-size:28px; font-weight:950; margin-top:6px}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:var(--gap); margin-top:14px}
@media (max-width: 1020px){.shell{flex-direction:column}.sidebar{width:100%; display:flex; gap:8px; overflow:auto; white-space:nowrap}.navitem{width:auto}.grid2{grid-template-columns:1fr}}
.card{background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:14px; margin-top:14px}
.card.inner{box-shadow:none; background:var(--panel2)}
.cardhead{display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:10px}
h2,h3{margin:0} h2{font-size:18px} h3{font-size:15px; color:color-mix(in oklab, var(--text) 92%, var(--muted))}
.row{display:flex; align-items:center} .gap{gap:10px}
.pill{padding:6px 10px; border-radius:999px; border:1px solid var(--line); color:var(--muted); font-size:12px;
  background:color-mix(in oklab, var(--panel2) 75%, transparent)}
.muted{color:var(--muted)} .small{font-size:12px}
.kpis{display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin:12px 0}
@media (max-width: 1020px){.kpis{grid-template-columns:repeat(2,1fr)}}
.kpi{padding:12px; border:1px solid var(--line); border-radius:14px; background:color-mix(in oklab, var(--panel2) 70%, transparent)}
.kpi .label{color:var(--muted); font-size:12px}
.kpi .value{font-weight:950; font-size:18px; margin-top:4px}
.kpi .hint{color:var(--muted); font-size:12px; margin-top:3px}
.filters{display:grid; grid-template-columns:220px 1fr; gap:10px; margin:10px 0 14px}
@media (max-width: 1020px){.filters{grid-template-columns:1fr}}
.field label{display:block; font-size:12px; color:var(--muted); margin-bottom:6px}
input,select,textarea{width:100%; padding:10px 11px; border-radius:12px; border:1px solid var(--line); background:transparent; color:var(--text); outline:none}
textarea{min-height:90px; resize:vertical}
.table{width:100%; border-collapse:separate; border-spacing:0 8px}
.table th{font-size:12px; color:var(--muted); text-align:left; font-weight:750; padding:0 10px 6px}
.table td{background:color-mix(in oklab, var(--panel2) 75%, transparent); border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:10px}
.table tr td:first-child{border-left:1px solid var(--line); border-radius:12px 0 0 12px}
.table tr td:last-child{border-right:1px solid var(--line); border-radius:0 12px 12px 0}
.badge{display:inline-flex; padding:4px 8px; border-radius:999px; font-size:12px; border:1px solid var(--line); color:var(--muted);
  background:color-mix(in oklab, var(--panel2) 70%, transparent)}
.badge.ok{border-color:color-mix(in oklab, var(--brand2) 45%, var(--line)); color:color-mix(in oklab, var(--brand2) 75%, var(--text))}
.badge.warn{border-color:color-mix(in oklab, #f59e0b 55%, var(--line)); color:color-mix(in oklab, #f59e0b 80%, var(--text))}
.badge.bad{border-color:color-mix(in oklab, var(--danger) 55%, var(--line)); color:color-mix(in oklab, var(--danger) 80%, var(--text))}
.iconbtn{border:1px solid var(--line); background:transparent; color:var(--text); border-radius:12px; padding:8px 10px; cursor:pointer}
.form{display:grid; grid-template-columns:1fr 1fr; gap:10px}
@media (max-width: 860px){.form{grid-template-columns:1fr}}
.kv{display:grid; grid-template-columns:1fr 1fr; gap:10px}
.kv .item{padding:10px; border:1px solid var(--line); border-radius:14px; background:color-mix(in oklab, var(--panel2) 72%, transparent)}
.kv .k{font-size:12px; color:var(--muted)}
.kv .v{font-weight:850; margin-top:4px}
.modal{position:fixed; inset:0; display:none; z-index:50}
.modal[aria-hidden="false"]{display:block}
.modalback{position:absolute; inset:0; background:rgba(0,0,0,.55)}
.modalbox{position:relative; width:min(760px, calc(100% - 24px)); margin:40px auto; background:var(--panel); border:1px solid var(--line);
  border-radius:18px; box-shadow:var(--shadow)}
.modalhead,.modalfoot{display:flex; justify-content:space-between; align-items:center; padding:12px 14px; border-bottom:1px solid var(--line)}
.modalfoot{border-top:1px solid var(--line); border-bottom:none}
.modalbody{padding:14px}
.footer{display:flex; justify-content:space-between; gap:10px; flex-wrap:wrap; padding:14px 18px; border-top:1px solid var(--line); color:var(--muted); font-size:12px}
.bullets{margin:0; padding-left:18px}

.sr{position:absolute; left:-10000px; top:auto; width:1px; height:1px; overflow:hidden;}
.selectpill select{border:none; padding:0; background:transparent; color:var(--text); font-weight:800}
.selectpill{display:inline-flex; align-items:center; gap:8px}
.overlay{position:fixed; inset:0; display:none; z-index:80; background:rgba(0,0,0,.55); backdrop-filter: blur(8px) saturate(140%);}
.overlay[aria-hidden="false"]{display:grid; place-items:center}
.overlay-card{width:min(720px, calc(100% - 24px)); background:var(--panel); border:1px solid var(--line); border-radius:22px; box-shadow:var(--shadow); padding:18px}
.overlay-title{font-weight:950; font-size:20px}
.overlay-sub{color:var(--muted); margin-top:6px}
.chips{display:flex; flex-wrap:wrap; gap:8px}
.chip{border:1px solid var(--line); background:color-mix(in oklab, var(--panel2) 70%, transparent); padding:8px 10px; border-radius:999px; cursor:pointer; color:var(--text); font-weight:750; font-size:12px}
.chip:hover{filter:brightness(1.05)}
