/* POIS Cockpit — brand: scuro #222/#0a0a0a, oro #d9ae38, sfondo #efefef */
:root{
  --dark:#0a0a0a; --dark2:#222; --gold:#d9ae38; --bg:#efefef;
  --txt:#222; --muted:#666; --line:#e3e3e3; --green:#16a34a; --red:#c0392b;
  --card:#fff;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--txt)}
a{color:inherit}

/* ── Login ── */
.login-bg{display:flex;min-height:100vh;align-items:center;justify-content:center;background:var(--dark)}
.login-card{background:var(--card);padding:2.4rem;border-radius:14px;width:320px;display:flex;flex-direction:column;gap:1rem;box-shadow:0 12px 40px rgba(0,0,0,.4)}
.login-logo{font-size:1.7rem;font-weight:800;letter-spacing:-.02em;text-align:center}
.login-logo span{color:var(--gold)}
.login-card input{padding:.8rem 1rem;border:1px solid var(--line);border-radius:8px;font-size:1rem}
.login-card button{padding:.8rem;border:0;border-radius:8px;background:var(--gold);color:#222;font-weight:700;font-size:1rem;cursor:pointer}
.login-card button:hover{filter:brightness(1.05)}
.err{color:var(--red);font-size:.85rem;text-align:center;margin:-.3rem 0}

/* ── Layout ── */
header.top{background:var(--dark);color:#fff;display:flex;align-items:center;gap:1.2rem;padding:0 1.4rem;height:60px;position:sticky;top:0;z-index:20}
header.top .logo{font-weight:800;font-size:1.25rem;letter-spacing:-.02em}
header.top .logo span{color:var(--gold)}
header.top .spacer{flex:1}
header.top select{background:#1a1a1a;color:#fff;border:1px solid #333;border-radius:8px;padding:.45rem .7rem;font-size:.9rem}
header.top .logout{color:#bbb;text-decoration:none;font-size:.85rem}
header.top .logout:hover{color:var(--gold)}

nav.tabs{background:var(--dark2);display:flex;gap:.2rem;padding:0 1rem;overflow-x:auto}
nav.tabs button{background:none;border:0;color:#bbb;padding:.85rem 1.1rem;cursor:pointer;font-size:.9rem;border-bottom:3px solid transparent;white-space:nowrap}
nav.tabs button:hover{color:#fff}
nav.tabs button.active{color:var(--gold);border-bottom-color:var(--gold);font-weight:600}

main{max-width:1200px;margin:0 auto;padding:1.5rem}
section.tab{display:none}
section.tab.active{display:block}
h2.sec{font-size:1.05rem;margin:.2rem 0 1rem}
.sub{color:var(--muted);font-size:.85rem;margin-bottom:1rem}

/* ── Cards / KPI ── */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}
.kpi{background:var(--card);border-radius:12px;padding:1.1rem 1.2rem;box-shadow:0 1px 3px rgba(0,0,0,.07)}
.kpi .l{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.kpi .v{font-size:1.6rem;font-weight:800;margin-top:.25rem}
.kpi .v.gold{color:#b8902a}.kpi .v.green{color:var(--green)}

.card{background:var(--card);border-radius:12px;padding:1.3rem;margin-bottom:1.3rem;box-shadow:0 1px 3px rgba(0,0,0,.07)}
.card h3{font-size:.95rem;margin-bottom:.9rem;display:flex;align-items:center;gap:.5rem}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
@media(max-width:820px){.grid2{grid-template-columns:1fr}}

table{width:100%;border-collapse:collapse;font-size:.85rem}
th{text-align:left;padding:.5rem;border-bottom:2px solid var(--line);color:var(--muted);font-size:.7rem;text-transform:uppercase}
td{padding:.5rem;border-bottom:1px solid #f3f3f3}
td.r,th.r{text-align:right}
tr:hover td{background:#fafafa}

.badge{display:inline-block;padding:.12rem .5rem;border-radius:99px;font-size:.7rem;font-weight:700}
.badge.on{background:#e8f5e9;color:#1b5e20}.badge.off{background:#f0f0f0;color:#888}
.badge.star{background:#fff5d6;color:#8a6d00}

.btn{padding:.55rem .9rem;border:0;border-radius:8px;background:var(--gold);color:#222;font-weight:700;cursor:pointer;font-size:.85rem}
.btn:hover{filter:brightness(1.05)}
.btn.sec{background:#eee;color:#333}
.btn.danger{background:var(--red);color:#fff}
.btn:disabled{opacity:.5;cursor:default}
textarea,input.txt{width:100%;border:1px solid var(--line);border-radius:8px;padding:.7rem;font:inherit;font-size:.9rem}
textarea{min-height:90px;resize:vertical}
.row{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;margin-top:.7rem}

pre.out{background:#0d1117;color:#d6e2ef;padding:1rem;border-radius:10px;overflow:auto;font-size:.78rem;line-height:1.45;max-height:460px;white-space:pre-wrap}
.muted{color:var(--muted)}
.alert{background:#fff5f5;border:1px solid #ffd9d9;color:#922;border-radius:10px;padding:.8rem 1rem;font-size:.85rem;margin-bottom:1rem}
.ok{color:var(--green)}.warn{color:var(--red)}
.loading{color:var(--muted);font-size:.85rem;padding:1rem 0}
.chip{font-size:.72rem;color:var(--muted);border:1px solid var(--line);border-radius:99px;padding:.1rem .5rem}
.toast{position:fixed;bottom:1.2rem;left:50%;transform:translateX(-50%);background:#222;color:#fff;padding:.8rem 1.3rem;border-radius:10px;font-size:.88rem;box-shadow:0 8px 30px rgba(0,0,0,.3);opacity:0;transition:opacity .25s;z-index:50}
.toast.show{opacity:1}
.toast.good{background:#16462a}.toast.bad{background:#5a1b1b}
.cap{font-size:.95rem;font-weight:700;margin:.2rem 0 .4rem}
ul.feat{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.5rem}
ul.feat li{background:#fafafa;border:1px solid var(--line);border-radius:8px;padding:.6rem .8rem;font-size:.85rem}
ul.feat li b{color:#b8902a}
.brand{display:flex;align-items:center;gap:.5rem}
.logo-img{height:26px;width:auto;filter:brightness(0) invert(1);display:block}
.logo-sub{font-weight:800;color:var(--gold);font-size:1.05rem}
.login-logo-img{height:40px;width:auto;display:block;margin:0 auto}
.login-sub{text-align:center;font-weight:800;color:var(--gold);font-size:1.1rem}
hr.sep{border:0;border-top:1px solid #eee;margin:.6rem 0}
