:root{
  --bg:#070b12; --bg-2:#0d1422; --card:#101a2b; --card-2:#142036;
  --line:#23324a; --line-soft:#1a2640;
  --txt:#e7ecf3; --txt-soft:#9aabc2; --txt-mut:#6b7a93;
  --accent:#2ea3d6; --accent-2:#5cc4ec; --accent-ink:#04131d; --navy:#003060;
  --ok:#34d399; --warn:#fbbf24; --danger:#f87171;
  --r:14px; --r-sm:10px; --sp2:8px; --sp3:12px; --sp4:16px; --sp5:24px;
  --shadow:0 8px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
[hidden]{display:none!important}
html,body{margin:0}
body{background:radial-gradient(1100px 560px at 50% -10%, #0a1e36 0%, var(--bg) 55%);color:var(--txt);font-family:Inter,system-ui,sans-serif;min-height:100dvh;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:"Space Grotesk",Inter,sans-serif;margin:0}
a{color:var(--accent-2)}

/* topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--sp3);padding:calc(var(--sp4) + env(safe-area-inset-top)) var(--sp4) var(--sp3);border-bottom:1px solid var(--line-soft);position:sticky;top:0;background:rgba(7,11,18,.85);backdrop-filter:blur(10px);z-index:10}
.brand{display:flex;align-items:center;gap:var(--sp3)}
.brand-mark{width:40px;height:40px;border-radius:11px;overflow:hidden;background:#fff;box-shadow:0 0 0 1px var(--line)}
.brand-mark img{width:100%;height:100%;object-fit:contain}
.brand h1{font-size:1rem}
.brand-sub{margin:0;font-size:.7rem;color:var(--txt-mut);font-family:"JetBrains Mono",monospace}
nav.tabs{display:flex;gap:4px;padding:var(--sp2) var(--sp4) 0;overflow-x:auto;border-bottom:1px solid var(--line-soft);position:sticky;top:62px;background:rgba(7,11,18,.85);backdrop-filter:blur(10px);z-index:9}
nav.tabs button{background:none;border:none;color:var(--txt-mut);font:inherit;font-weight:600;padding:10px 14px;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap}
nav.tabs button.active{color:var(--txt);border-bottom-color:var(--accent)}

.wrap{max-width:860px;margin:0 auto;padding:var(--sp5) var(--sp4) 64px;display:grid;gap:var(--sp4)}
.card{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--r);padding:var(--sp5);box-shadow:var(--shadow)}
.row{display:flex;gap:var(--sp3);flex-wrap:wrap;align-items:end}
.field{display:grid;gap:6px;flex:1;min-width:160px}
.label{font-size:.78rem;font-weight:600;color:var(--txt-soft)}
input,select,textarea{width:100%;background:var(--bg-2);color:var(--txt);border:1px solid var(--line);border-radius:var(--r-sm);padding:11px 13px;font:inherit;font-size:1rem}
textarea{min-height:110px;resize:vertical;line-height:1.6}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(46,163,214,.18)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font:inherit;font-weight:600;border-radius:var(--r-sm);padding:12px 18px;border:1px solid transparent;min-height:44px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.btn-primary{background:linear-gradient(145deg,var(--accent),var(--accent-2));color:var(--accent-ink)}
.btn-primary:active{transform:translateY(1px)}
.btn-ghost{background:var(--card-2);color:var(--txt-soft);border-color:var(--line)}
.btn-ghost:hover{color:var(--txt);border-color:var(--accent)}
.btn-sm{padding:8px 12px;min-height:0;font-size:.85rem}

.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--sp3)}
.tile{background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:var(--sp4);text-align:center}
.tile .n{font-family:"Space Grotesk";font-size:1.8rem;color:var(--accent-2)}
.tile .l{font-size:.78rem;color:var(--txt-mut)}

table{width:100%;border-collapse:collapse;font-size:.9rem}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line-soft)}
th{color:var(--txt-soft);font-size:.74rem;text-transform:uppercase;letter-spacing:.4px}
tbody tr:hover{background:var(--card-2)}
.tag{font-family:"JetBrains Mono",monospace;font-size:.66rem;border:1px solid var(--line);border-radius:6px;padding:2px 7px;color:var(--txt-mut)}
.tag.ok{color:var(--ok);border-color:rgba(52,211,153,.4)}
.tag.warn{color:var(--warn);border-color:rgba(251,191,36,.35)}

.salida{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:14px;line-height:1.7;white-space:pre-wrap;min-height:90px}
.muted{color:var(--txt-mut);font-size:.85rem}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp3)}

/* login */
.login{min-height:100dvh;display:grid;place-items:center;padding:var(--sp4)}
.login .card{width:100%;max-width:360px;text-align:center;display:grid;gap:var(--sp4)}
.login .brand-mark{width:64px;height:64px;margin:0 auto;border-radius:16px}

.loader{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:rgba(7,11,18,.7);backdrop-filter:blur(3px);z-index:40;color:var(--txt-soft)}
.spinner{width:32px;height:32px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.toast{position:fixed;left:50%;bottom:calc(20px + env(safe-area-inset-bottom));transform:translateX(-50%);background:var(--card-2);color:var(--txt);border:1px solid var(--accent);border-radius:10px;padding:10px 16px;font-size:.88rem;box-shadow:var(--shadow);z-index:50;max-width:90vw;text-align:center}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
