/* Hexarion app UI — login / account / admin. Matches the public site's dark-blue theme.
   Fonts come from /__static/fonts.css (woff2 served by nginx from /assets). */

:root{
  --bg:#050912; --panel:#0b172a; --panel2:#0e2038;
  --line:rgba(96,160,240,.16); --line-hi:rgba(111,211,255,.5);
  --txt:#E9F1FC; --muted:#A9BDD8; --dim:#7e93b2;
  --accent:#2e9bff; --accent2:#5cc8ff; --cyan:#6fd3ff;
  --danger:#ff6b6b; --ok:#37d39b;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; min-height:100vh; background:var(--bg); color:var(--txt);
  font-family:'IBM Plex Sans',system-ui,sans-serif; -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(1100px 720px at 78% -8%,rgba(28,110,210,.22),transparent 60%),
    radial-gradient(900px 600px at 8% 18%,rgba(20,70,150,.16),transparent 62%);
  background-attachment:fixed;
}
a{color:var(--cyan);text-decoration:none;}
a:hover{color:#bfe6ff;}
.mono{font-family:'IBM Plex Mono',monospace;}
.display{font-family:'Space Grotesk',sans-serif;}

/* ---- centered auth screen ---- */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 20px;}
.auth-card{
  width:100%;max-width:404px;position:relative;border-radius:18px;
  border:1px solid rgba(96,160,240,.22);
  background:linear-gradient(150deg,rgba(14,32,60,.7),rgba(8,16,30,.94));
  padding:38px 34px;box-shadow:0 40px 120px -40px rgba(2,8,20,.9);overflow:hidden;
}
.auth-card::before{content:"";position:absolute;top:-1px;left:30px;right:30px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(111,211,255,.6),transparent);}
.auth-logo{display:flex;justify-content:center;margin-bottom:8px;}
.auth-logo img{height:30px;filter:drop-shadow(0 1px 11px rgba(70,150,255,.4));}
.auth-sub{text-align:center;font-family:'IBM Plex Mono',monospace;font-size:11px;
  letter-spacing:.22em;color:#8fb8e8;margin:14px 0 26px;text-transform:uppercase;}

.field{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;}
.field label{font-size:13px;font-weight:600;color:#cfdcef;}
.input{
  background:rgba(6,14,28,.7);border:1px solid rgba(96,160,240,.22);border-radius:10px;
  padding:13px 15px;color:var(--txt);font-family:'IBM Plex Sans',sans-serif;font-size:14px;
  outline:none;transition:border-color .2s;width:100%;
}
.input:focus{border-color:rgba(111,211,255,.7);}
.code-input{letter-spacing:.5em;text-align:center;font-family:'IBM Plex Mono',monospace;font-size:20px;}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;
  font-family:'IBM Plex Mono',monospace;font-size:14px;font-weight:500;letter-spacing:.03em;
  color:#062038;background:linear-gradient(180deg,#5cc8ff,#2e9bff);border:none;
  padding:15px;border-radius:10px;cursor:pointer;
  box-shadow:0 14px 38px -12px rgba(46,155,255,.8);transition:transform .2s,box-shadow .2s;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 18px 44px -10px rgba(46,155,255,.95);}
.btn-ghost{
  background:rgba(11,23,42,.6);color:#cfe2fb;border:1px solid rgba(96,160,240,.28);box-shadow:none;
}
.btn-ghost:hover{transform:none;border-color:var(--line-hi);background:rgba(20,44,78,.6);}
.btn-sm{width:auto;padding:8px 14px;font-size:12px;border-radius:8px;box-shadow:none;}
.btn-danger{background:rgba(255,107,107,.14);color:#ffb4b4;border:1px solid rgba(255,107,107,.4);box-shadow:none;}
.btn-danger:hover{transform:none;background:rgba(255,107,107,.22);}

.alert{border-radius:10px;padding:11px 14px;font-size:13px;margin-bottom:18px;border:1px solid;}
.alert-error{background:rgba(255,107,107,.1);border-color:rgba(255,107,107,.35);color:#ffb4b4;}
.alert-ok{background:rgba(55,211,155,.1);border-color:rgba(55,211,155,.35);color:#9af0cf;}
.alert-info{background:rgba(46,155,255,.08);border-color:rgba(96,160,240,.3);color:#bcd7f5;}

.foot-link{text-align:center;margin-top:22px;font-size:12.5px;color:var(--dim);}

/* ---- app shell (account / admin) ---- */
.shell{max-width:1180px;margin:0 auto;padding:0 clamp(18px,4vw,40px);}
.topbar{
  position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(18px,4vw,40px);border-bottom:1px solid var(--line);
  background:rgba(6,11,21,.82);backdrop-filter:blur(14px);
}
.topbar .brand{display:flex;align-items:center;gap:12px;}
.topbar .brand img{height:24px;}
.topbar .who{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted);}
.tabs{display:flex;gap:6px;flex-wrap:wrap;padding:18px 0 0;}
.tab{
  font-family:'IBM Plex Mono',monospace;font-size:13px;letter-spacing:.02em;color:#9fb3cf;
  padding:9px 16px;border-radius:9px 9px 0 0;border:1px solid transparent;border-bottom:none;
}
.tab:hover{color:#EAF2FD;}
.tab.active{color:#EAF2FD;background:rgba(14,32,58,.6);border-color:var(--line);}

.panel{
  border:1px solid var(--line);border-radius:0 14px 14px 14px;
  background:linear-gradient(162deg,rgba(16,32,58,.7),rgba(8,16,30,.9));
  padding:26px 26px 30px;margin-bottom:30px;
}
.panel h1,.panel h2{font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:-.01em;margin:0 0 6px;}
.panel h1{font-size:24px;}
.panel .lead{color:var(--muted);font-size:14px;margin:0 0 22px;}

.card{border:1px solid var(--line);border-radius:14px;background:rgba(11,23,42,.5);padding:22px 24px;margin-bottom:18px;}

table{width:100%;border-collapse:collapse;font-size:13.5px;}
th{text-align:left;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:#647ea0;padding:10px 12px;border-bottom:1px solid var(--line);}
td{padding:12px;border-bottom:1px solid rgba(96,160,240,.08);color:#cdd9ec;vertical-align:middle;}
tr:hover td{background:rgba(46,155,255,.04);}

.badge{display:inline-block;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.06em;
  padding:3px 9px;border-radius:100px;border:1px solid var(--line);color:#bcd7f5;}
.badge-admin{border-color:rgba(111,211,255,.4);color:var(--cyan);}
.badge-ok{border-color:rgba(55,211,155,.4);color:#9af0cf;}
.badge-off{border-color:rgba(255,107,107,.4);color:#ffb4b4;}
.badge-soon{border-color:rgba(255,180,84,.4);color:#ffce91;}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.row-actions{display:flex;gap:8px;flex-wrap:wrap;}
.impersonate-banner{background:rgba(255,180,84,.12);border:1px solid rgba(255,180,84,.4);
  color:#ffce91;padding:10px 16px;border-radius:10px;font-size:13px;margin:16px 0;
  display:flex;align-items:center;justify-content:space-between;gap:12px;}
.kv{display:grid;grid-template-columns:160px 1fr;gap:10px 18px;font-size:14px;}
.kv .k{color:var(--dim);font-family:'IBM Plex Mono',monospace;font-size:12px;}
.code-box{font-family:'IBM Plex Mono',monospace;font-size:15px;background:rgba(6,14,28,.8);
  border:1px solid var(--line-hi);border-radius:10px;padding:14px 16px;color:#cfe9ff;
  word-break:break-all;user-select:all;}
.muted{color:var(--dim);}
.soon-note{font-size:13px;color:#ffce91;background:rgba(255,180,84,.08);
  border:1px solid rgba(255,180,84,.3);border-radius:10px;padding:12px 16px;margin-bottom:20px;}
