/* ============================================================================
   AION Protocol — Design System  (ui-ux-pro-max: "Vault dark blue + secure green", OLED dark)
   Fira Sans / Fira Code · deep midnight · secure-green accent · minimal glow.
   Class names consumed by injected JS are preserved: badge(+active/pending/rejected/
   revoked), sectag(+fs/static), callbtn, mono, ok-msg, err, note, pill, stat(+n/l),
   grid, card(+narrow), brand(+dot), topbar, wrap, center, sub.
============================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fira+Code:wght@400;500;600&family=Fira+Sans:wght@300;400;500;600;700&display=swap');

:root{
  /* surfaces */
  --bg:#080d18; --bg2:#0b1322; --panel:#101a2e; --panel2:#0c1322; --panel3:#16223c;
  --border:rgba(255,255,255,.085); --border2:rgba(255,255,255,.14);
  /* brand */
  --primary:#1E3A5F; --primary-br:#2e5a8f;
  --accent:#10b981; --accent-deep:#059669; --accent-br:#34e3a8; --accent-ink:#04140d;
  --glow:rgba(16,185,129,.30); --glow-soft:rgba(16,185,129,.16);
  /* text */
  --text:#f2f6fc; --text2:#dbe5f2; --muted:#93a3bd; --faint:#5f6f8a;
  /* status */
  --ok:#10b981; --warn:#f5b13b; --bad:#f0556a; --gold:#c79a4e;
  --ring:rgba(16,185,129,.55);
  --r:14px; --r-sm:10px; --r-xs:8px;
  --sh:0 10px 30px rgba(0,0,0,.45); --sh-sm:0 4px 16px rgba(0,0,0,.35);
}
*{box-sizing:border-box;margin:0;padding:0}
html{color-scheme:dark}
body{
  background:
    radial-gradient(1100px 600px at 82% -8%, rgba(30,58,95,.55), transparent 60%),
    radial-gradient(900px 520px at 8% 0%, rgba(16,185,129,.10), transparent 55%),
    linear-gradient(180deg,#0a1120 0%, var(--bg) 60%);
  background-attachment:fixed;
  color:var(--text);
  font-family:'Fira Sans',-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  line-height:1.55; letter-spacing:.1px; min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--accent-br);text-decoration:none;transition:color .15s}
a:hover{color:#7df3c8}
.mono{font-family:'Fira Code',ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:var(--muted);letter-spacing:0}

.wrap{max-width:1140px;margin:0 auto;padding:30px 24px 64px}
.center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}

/* ---- cards ---- */
.card{
  position:relative;background:linear-gradient(180deg,rgba(255,255,255,.02),transparent 40%),var(--panel);
  border:1px solid var(--border);border-radius:var(--r);padding:26px 28px;box-shadow:var(--sh-sm);
}
.card::before{content:"";position:absolute;inset:0 0 auto;height:1px;border-radius:var(--r) var(--r) 0 0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.14),transparent);opacity:.7}
.card.narrow{width:100%;max-width:430px;padding:32px}

/* ---- type ---- */
h1{font-size:24px;font-weight:700;letter-spacing:.2px;line-height:1.2}
h2{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1.3px;color:var(--text);
  display:flex;align-items:center;gap:9px;margin:0 0 4px}
h2 svg{width:16px;height:16px;color:var(--accent);flex:0 0 16px}
.card-sub,.sub{color:var(--muted);font-size:13px;margin:6px 0 18px;max-width:62ch}
.sub{margin-bottom:20px}
.eyebrow{font-family:'Fira Code',monospace;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent-deep);font-weight:500}

/* ---- brand / logo ---- */
.brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.brand .logo{width:42px;height:42px;flex:0 0 42px;display:flex;align-items:center;justify-content:center;
  border-radius:12px;background:linear-gradient(160deg,#16304d,#0c1626);border:1px solid var(--border2);
  box-shadow:0 0 18px rgba(16,185,129,.18), inset 0 1px 0 rgba(255,255,255,.06)}
.brand .logo svg{width:24px;height:24px;color:var(--accent);filter:drop-shadow(0 0 6px var(--glow))}
/* GRMG "11:11" emblem brand mark (transparent PNG) */
.brand .brandmark{width:46px;height:46px;flex:0 0 46px;object-fit:contain;
  filter:drop-shadow(0 0 9px rgba(199,154,78,.32)) drop-shadow(0 1px 1px rgba(0,0,0,.5))}
.brand h1{font-size:20px}
.brand small{color:var(--muted);font-size:11.5px;display:block;letter-spacing:.3px;font-family:'Fira Code',monospace}
/* legacy .dot repurposed into a glowing sigil so old markup still looks intentional */
.brand .dot{width:42px;height:42px;flex:0 0 42px;border-radius:12px;background:linear-gradient(160deg,#16304d,#0c1626);
  border:1px solid var(--border2);position:relative;box-shadow:0 0 18px rgba(16,185,129,.18)}
.brand .dot::after{content:"";position:absolute;inset:0;border-radius:12px;
  background:radial-gradient(circle at 50% 45%, var(--accent), transparent 62%);opacity:.9}

/* ---- topbar ---- */
.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;
  padding:14px 20px;background:linear-gradient(180deg,rgba(255,255,255,.025),transparent),var(--panel);
  border:1px solid var(--border);border-radius:16px;box-shadow:var(--sh-sm)}
.topbar .brand{margin:0}
.topbar .links{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.topbar .links a{font-size:13px;color:var(--muted);font-weight:500;display:inline-flex;align-items:center;gap:6px}
.topbar .links a:hover{color:var(--text)}
.topbar .links a svg{width:15px;height:15px}

/* ---- pills (key/prekeys/ADMIN) ---- */
.pill{font-family:'Fira Code',monospace;font-size:11px;color:var(--accent-br);background:rgba(16,185,129,.10);
  border:1px solid rgba(16,185,129,.30);border-radius:20px;padding:4px 11px;display:inline-flex;align-items:center;gap:7px;letter-spacing:.2px}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}

/* ---- inputs ---- */
label{display:block;font-size:12px;font-weight:500;color:var(--muted);margin:16px 0 7px;letter-spacing:.3px}
input,select,textarea{width:100%;background:var(--panel2);border:1px solid var(--border);color:var(--text);
  border-radius:var(--r-xs);padding:12px 13px;font-size:14px;font-family:inherit;transition:border-color .15s,box-shadow .15s}
input::placeholder,textarea::placeholder{color:var(--faint)}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-deep);box-shadow:0 0 0 3px var(--ring)}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%2393a3bd' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}

/* ---- buttons ---- */
button{font-family:inherit;background:linear-gradient(180deg,var(--accent-br),var(--accent-deep));color:var(--accent-ink);
  border:none;border-radius:var(--r-xs);padding:12px 18px;font-size:14px;font-weight:600;cursor:pointer;margin-top:18px;width:100%;
  box-shadow:0 0 0 1px rgba(16,185,129,.35), 0 8px 20px rgba(16,185,129,.16), inset 0 1px 0 rgba(255,255,255,.25);
  transition:filter .15s,transform .05s,box-shadow .15s;letter-spacing:.2px}
button:hover{filter:brightness(1.07)}
button:active{transform:translateY(1px)}
button:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}
button.sm{width:auto;margin:0;padding:9px 14px;font-size:13px}
button.ghost,button.callbtn{background:transparent;border:1px solid var(--border2);color:var(--text2);box-shadow:none;font-weight:500}
button.ghost:hover,button.callbtn:hover{border-color:var(--accent-deep);color:var(--text);background:rgba(16,185,129,.07);filter:none}
button.danger{background:linear-gradient(180deg,#ff7385,#e23b50);color:#fff;box-shadow:0 0 0 1px rgba(240,85,106,.4),0 8px 20px rgba(240,85,106,.18)}
button.ok{background:linear-gradient(180deg,var(--accent-br),var(--accent-deep))}

.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* ---- stats grid (admin) ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:14px;margin:0 0 22px}
.stat{background:linear-gradient(180deg,rgba(255,255,255,.02),transparent),var(--panel2);border:1px solid var(--border);
  border-radius:var(--r-sm);padding:18px}
.stat .n{font-size:30px;font-weight:700;font-family:'Fira Code',monospace;color:var(--text);text-shadow:0 0 18px rgba(16,185,129,.12)}
.stat .l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-top:4px}

/* ---- tables ---- */
table{width:100%;border-collapse:collapse;font-size:13.5px;margin-top:6px}
th,td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--border)}
thead th{color:var(--faint);font-weight:600;font-size:10.5px;text-transform:uppercase;letter-spacing:.9px;
  border-bottom:1px solid var(--border2);padding-bottom:9px}
tbody tr{transition:background .12s}
tbody tr:hover{background:rgba(255,255,255,.022)}
tbody tr:last-child td{border-bottom:none}
td .mono{font-size:11px}

/* ---- badges / sectags ---- */
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.2px}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 7px currentColor}
.badge.active{background:rgba(16,185,129,.12);color:#41dca0;border:1px solid rgba(16,185,129,.28)}
.badge.pending{background:rgba(245,177,59,.12);color:var(--warn);border:1px solid rgba(245,177,59,.28)}
.badge.rejected,.badge.revoked{background:rgba(240,85,106,.12);color:var(--bad);border:1px solid rgba(240,85,106,.28)}
.sectag{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;white-space:nowrap}
.sectag::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;box-shadow:0 0 6px currentColor}
.sectag.fs{background:rgba(16,185,129,.12);color:#41dca0}
.sectag.static{background:rgba(245,177,59,.12);color:var(--warn)}

/* ---- messages ---- */
.err{color:var(--bad);font-size:13px;margin-top:12px;min-height:18px}
.ok-msg{color:#41dca0;font-size:13px;margin-top:12px;min-height:18px}
.note{background:linear-gradient(90deg,rgba(16,185,129,.06),transparent);border:1px solid var(--border);
  border-left:2px solid var(--accent-deep);padding:13px 16px;border-radius:var(--r-xs);font-size:13px;color:var(--muted);margin:0 0 22px}
.note strong{color:var(--text2)}

/* ledger (admin) */
.ledger-entry{font-family:'Fira Code',monospace;font-size:11px;padding:9px 12px;border-bottom:1px solid var(--border);color:var(--muted)}
.ledger-entry b{color:var(--accent-br);font-weight:600}

/* ============================ PORTAL-SPECIFIC ============================ */
.portal .topbar .pill{margin-left:0}
.portal .compose-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:18px;align-items:start}
.portal .compose-grid>.card{min-width:0}

/* self-host download row */
.dl-row{display:flex;gap:10px;flex-wrap:wrap;margin:2px 0 0}
.dl-row button{display:inline-flex;align-items:center;gap:8px}
.dl-row button svg{width:15px;height:15px}

/* prominent attach dropzone */
.portal .attach{margin-top:18px;border:1.5px dashed var(--border2);border-radius:var(--r-sm);
  background:linear-gradient(180deg,rgba(16,185,129,.04),transparent),var(--panel2);padding:18px;transition:border-color .15s,background .15s}
.portal .attach:hover{border-color:var(--accent-deep);background:rgba(16,185,129,.06)}
.portal .attach-head{display:flex;align-items:center;gap:10px;margin-bottom:5px}
.portal .attach-ico{width:34px;height:34px;flex:0 0 34px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  background:rgba(16,185,129,.13);color:var(--accent);border:1px solid rgba(16,185,129,.25)}
.portal .attach-ico svg{width:18px;height:18px}
.portal .attach-title{font-size:14px;font-weight:600;color:var(--text)}
.portal .attach-help{font-size:12px;color:var(--muted);margin:0 0 12px}
.portal .filebtn{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--border2);
  color:var(--text2);border-radius:var(--r-xs);padding:10px 16px;font-size:13px;font-weight:500;cursor:pointer;margin:0;width:auto;transition:border-color .15s,background .15s}
.portal .filebtn:hover{border-color:var(--accent-deep);background:rgba(16,185,129,.08);color:var(--text)}
.portal .filebtn svg{width:16px;height:16px;color:var(--accent)}
.portal #fileState{display:inline-block;margin-left:12px;color:var(--muted)}
.portal #fileState.active{color:var(--accent-br)}
.portal .compose-actions{display:flex;gap:12px;align-items:center;margin-top:16px;flex-wrap:wrap}
.portal .compose-actions button{margin:0;display:inline-flex;align-items:center;gap:8px}
.portal .compose-actions button svg{width:16px;height:16px}
.callbtn{padding:5px 11px !important;font-size:12px !important;margin:0 2px 0 0 !important;display:inline-flex;align-items:center;gap:5px}
.callbtn svg{width:13px;height:13px}

/* call overlay */
.portal #callOverlay{position:fixed;inset:0;background:rgba(4,7,14,.86);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:9500}
.portal #callCard{background:var(--panel);border:1px solid var(--border2);border-radius:16px;padding:26px;width:min(680px,92vw);box-shadow:var(--sh)}
.portal #callTitle{font-size:18px;font-weight:600;margin-bottom:4px}
.portal #videos{position:relative;margin-top:14px;background:#05080f;border-radius:12px;overflow:hidden;aspect-ratio:16/9;border:1px solid var(--border)}
.portal #remoteVid{width:100%;height:100%;object-fit:cover;display:block}
.portal #localVid{position:absolute;right:12px;bottom:12px;width:26%;border-radius:9px;border:1px solid var(--border2)}

@media(max-width:820px){
  .portal .compose-grid{grid-template-columns:1fr}
  .topbar{flex-direction:column;align-items:flex-start}
}
@media(prefers-reduced-motion:reduce){*{transition:none !important}}
