/* ============================================================
   Lex Platform — Login HUD Theme
   ============================================================ */

:root {
  --g:         #2ee8a5;
  --g-dim:     rgba(46,232,165,0.5);
  --g-glow:    rgba(46,232,165,0.18);
  --bg:        #050b11;
  --bg-panel:  #080f18;
  --bg-input:  #060d16;
  --border:    rgba(46,232,165,0.1);
  --border-hi: rgba(46,232,165,0.45);
  --text:      #e8f0f8;
  --muted:     #5a7080;
  --dim:       #243040;
  --amber:     #f0a020;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

html, body {
  width:100%; height:100%;
  overflow:hidden;
  background:var(--bg);
  color:var(--text);
  font-family:'DM Sans',sans-serif;
}

.lex-auth-root {
  cursor: none;
}

#cursor {
  position:fixed; width:7px; height:7px;
  background:var(--g); border-radius:50%;
  pointer-events:none; z-index:99999;
  transform:translate(-50%,-50%);
  will-change:left,top;
}
#cursor-ring {
  position:fixed; width:28px; height:28px;
  border:1px solid rgba(46,232,165,0.4); border-radius:50%;
  pointer-events:none; z-index:99998;
  transform:translate(-50%,-50%);
  transition:width .2s,height .2s,border-color .2s;
  will-change:left,top;
}

.root { display:flex; width:100vw; height:100vh; }

/* ── LEFT HUD ──────────────────────────────────────────── */
.hud {
  flex:1; position:relative; overflow:hidden;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  background:#050b11;
}

#c {
  position:absolute; inset:0; width:100%; height:100%;
  will-change:contents;
}

.glyph-layer {
  position:absolute; inset:0; width:100%; height:100%;
  pointer-events:none; z-index:1;
}

.auth-mesh {
  position:absolute; inset:0; width:100%; height:100%;
  pointer-events:none; z-index:0; opacity:.55;
}

.hud-top {
  position:absolute; top:0; left:0; right:0; height:46px;
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; padding:0 22px; gap:14px;
  background:rgba(5,11,17,0.8); backdrop-filter:blur(6px); z-index:2;
}
.hud-dot { width:6px; height:6px; border-radius:50%; }
.hud-dot.g { background:var(--g);     animation:blink 2s    ease-in-out infinite; }
.hud-dot.a { background:var(--amber); animation:blink 2s    ease-in-out infinite .4s; }
.hud-dot.r { background:#ff4060;      animation:blink 2s    ease-in-out infinite .8s; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.25} }

.hud-top-label {
  font-family:'JetBrains Mono',monospace;
  font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); flex:1;
}
.hud-top-time {
  font-family:'JetBrains Mono',monospace;
  font-size:11px; color:var(--g-dim); letter-spacing:.1em;
}

.hud-corner {
  position:absolute; width:24px; height:24px;
  z-index:2; pointer-events:none;
  animation:cpulse 3s ease-in-out infinite;
}
@keyframes cpulse { 0%,100%{opacity:.4} 50%{opacity:1} }
.hud-corner.tl { top:54px;   left:14px;  border-top:1.5px solid var(--g); border-left:1.5px solid var(--g); }
.hud-corner.tr { top:54px;   right:14px; border-top:1.5px solid var(--g); border-right:1.5px solid var(--g); }
.hud-corner.bl { bottom:38px;left:14px;  border-bottom:1.5px solid var(--g); border-left:1.5px solid var(--g); }
.hud-corner.br { bottom:38px;right:14px; border-bottom:1.5px solid var(--g); border-right:1.5px solid var(--g); }

.hud-centre { position:relative; z-index:2; text-align:center; user-select:none; }

.hud-avatar-canvas {
  width:220px; height:220px;
  display:block; margin:0 auto 4px;
}

.hud-tagline {
  font-family:'JetBrains Mono',monospace;
  font-size:10.5px; letter-spacing:.33em; text-transform:uppercase;
  color:rgba(46,232,165,.38); margin-top:14px;
}

.hud-readout { position:absolute; z-index:2; font-family:'JetBrains Mono',monospace; }
.hud-readout.l { left:22px;  bottom:52px; }
.hud-readout.r { right:22px; bottom:52px; text-align:right; }
.r-label { font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:4px; }
.r-val   { font-size:20px; font-weight:500; color:var(--g); letter-spacing:-.02em; line-height:1; }
.r-sub   { font-size:9px; color:var(--muted); letter-spacing:.07em; margin-top:2px; }

.mini-bars { display:flex; align-items:flex-end; gap:3px; height:22px; margin-top:8px; }
.mb { width:4px; background:var(--g); border-radius:1px; opacity:.6; animation:ba 2s ease-in-out infinite; }
@keyframes ba { 0%,100%{height:var(--h);opacity:.45} 50%{height:calc(var(--h)*1.45);opacity:1} }

.hud-strip {
  position:absolute; bottom:0; left:0; right:0; height:34px;
  border-top:1px solid var(--border);
  background:rgba(5,11,17,.85); backdrop-filter:blur(6px);
  display:flex; align-items:center; padding:0 22px; gap:20px;
  z-index:2; overflow:hidden;
}
.s-item { display:flex; align-items:center; gap:6px;
  font-family:'JetBrains Mono',monospace; font-size:9.5px;
  color:var(--muted); letter-spacing:.07em; white-space:nowrap; }
.s-dot  { width:5px; height:5px; border-radius:50%; background:var(--g); animation:blink 1.8s ease-in-out infinite; }
.s-dot.a{ background:var(--amber); }
.ticker { flex:1; overflow:hidden; }
.ticker-inner { display:flex; gap:48px; white-space:nowrap; animation:tick 30s linear infinite; }
@keyframes tick { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.hud-ticker-item { font-family:'JetBrains Mono',monospace; font-size:9px; color:var(--dim); letter-spacing:.1em; text-transform:uppercase; }
.hud-ticker-item span { color:var(--g); opacity:.55; }

/* ── RIGHT: AUTH PANEL ─────────────────────────────────── */
.auth-panel {
  width:480px; min-height:100vh;
  background:var(--bg-panel); border-left:1px solid var(--border);
  display:flex; flex-direction:column; justify-content:center;
  padding:0 52px; position:relative; overflow-y:auto; overflow-x:hidden;
  opacity:1;
  animation:panelIn .9s cubic-bezier(.16,1,.3,1) both;
}
@keyframes panelIn { from{transform:translateX(70px)} to{transform:translateX(0)} }

.auth-panel::before {
  content:''; position:absolute; top:0; left:-1px;
  width:1px; height:100%;
  background:linear-gradient(to bottom,
    transparent 0%,var(--g-dim) 25%,var(--g) 50%,var(--g-dim) 75%,transparent 100%);
  animation:seam 4s ease-in-out infinite;
}
@keyframes seam { 0%,100%{opacity:.25} 50%{opacity:1} }

.auth-panel::after {
  content:''; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    repeating-linear-gradient(to bottom,
      transparent 0px,transparent 3px,rgba(0,0,0,.045) 3px,rgba(0,0,0,.045) 4px),
    radial-gradient(ellipse at 50% 40%, rgba(46,232,165,.04) 0%, transparent 60%);
  animation:panelGlow 8s ease-in-out infinite;
}
@keyframes panelGlow {
  0%,100% { opacity:.6; }
  50% { opacity:1; }
}

/* Floating dots on auth panel */
.auth-panel-dots {
  position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:0;
}
.auth-panel-dots span {
  position:absolute; width:2px; height:2px; border-radius:50%;
  background:var(--g); opacity:0;
  animation:dotFloat linear infinite;
}
@keyframes dotFloat {
  0%   { transform:translateY(100vh); opacity:0; }
  10%  { opacity:.25; }
  90%  { opacity:.25; }
  100% { transform:translateY(-20px); opacity:0; }
}

.auth-inner { position:relative; z-index:2; }

.auth-deco { display:flex; align-items:center; gap:10px; margin-bottom:36px; }
.deco-dot  { width:5px; height:5px; background:var(--g); border-radius:50%; box-shadow:0 0 8px var(--g); }
.deco-label{ font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); }
.deco-line { flex:1; height:1px; background:linear-gradient(to right,var(--border-hi),transparent); }
.auth-deco--alert .deco-line { background:linear-gradient(to right, rgba(255,64,96,.45), transparent); }
.auth-deco--alert .deco-label { color:rgba(255,255,255,.48); }

.auth-logo {
  height:120px; width:auto; max-width:100%; margin-bottom:10px;
  filter:drop-shadow(0 0 20px rgba(46,232,165,.3));
}
.auth-title {
  font-family:'Syne',sans-serif; font-weight:700;
  font-size:24px; letter-spacing:-.02em; color:var(--text); margin-bottom:4px;
}
.auth-sub { font-size:13px; color:var(--muted); margin-bottom:32px; letter-spacing:.01em; }

.field { margin-bottom:16px; }
.field-lbl { display:flex; align-items:center; gap:8px; margin-bottom:7px; }
.lbl-txt {
  font-family:'JetBrains Mono',monospace; font-size:10px;
  letter-spacing:.14em; text-transform:uppercase; color:var(--muted);
}
.lbl-line { flex:1; height:1px; background:var(--border); }

.field-wrap { position:relative; }
.field-wrap::before {
  content:''; position:absolute; left:0; top:0; bottom:0;
  width:2px; border-radius:2px; background:var(--border);
  transition:background .3s,box-shadow .3s;
}
.field-wrap:focus-within::before {
  background:var(--g); box-shadow:0 0 10px var(--g-glow),2px 0 6px var(--g-glow);
}

.field-input {
  width:100%; padding:12px 38px 12px 16px;
  background:var(--bg-input);
  border:1px solid var(--border); border-left:none;
  border-radius:0 8px 8px 0; color:var(--text);
  font-family:'JetBrains Mono',monospace; font-size:13px; letter-spacing:.03em;
  transition:border-color .25s,background .25s,box-shadow .25s; outline:none;
}
.field-input::placeholder { color:var(--dim); font-family:'DM Sans',sans-serif; font-size:13px; }
.field-input:focus {
  border-color:var(--border-hi); background:#060e18;
  box-shadow:0 0 0 1px rgba(46,232,165,.07);
}
.field-badge {
  position:absolute; right:11px; top:50%; transform:translateY(-50%);
  font-family:'JetBrains Mono',monospace; font-size:8px;
  letter-spacing:.1em; text-transform:uppercase; color:var(--dim);
  transition:color .25s; pointer-events:none;
}
.field-wrap:focus-within .field-badge { color:var(--g); opacity:.4; }

.row-inline {
  display:flex; align-items:center; justify-content:space-between;
  margin:10px 0 24px;
}
.cb-wrap { display:flex; align-items:center; gap:9px; cursor:pointer; }
.cb-wrap input { display:none; }
.cb-box {
  width:16px; height:16px; border:1px solid var(--border-hi); border-radius:3px;
  background:var(--bg-input); position:relative; transition:all .2s; flex-shrink:0;
}
.cb-wrap input:checked + .cb-box { background:var(--g); border-color:var(--g); box-shadow:0 0 9px var(--g-glow); }
.cb-wrap input:checked + .cb-box::after {
  content:'\2713'; position:absolute; inset:0; display:flex;
  align-items:center; justify-content:center; font-size:10px; color:#050b11; font-weight:700;
}
.cb-text { font-family:'JetBrains Mono',monospace; font-size:10.5px; color:var(--muted); letter-spacing:.05em; }
.forgot {
  font-family:'JetBrains Mono',monospace; font-size:10.5px; color:var(--g);
  text-decoration:none; opacity:.65; letter-spacing:.04em; transition:opacity .2s;
}
.forgot:hover { opacity:1; }

.btn-signin {
  width:100%; padding:14px 24px;
  background:var(--g); border:none; border-radius:8px;
  color:#050b11; font-family:'Syne',sans-serif; font-weight:700;
  font-size:15px; letter-spacing:.05em; cursor:pointer;
  position:relative; overflow:hidden;
  transition:transform .25s,box-shadow .25s;
}
.btn-signin::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(105deg,transparent 20%,rgba(255,255,255,.28) 50%,transparent 80%);
  transform:translateX(-100%); transition:transform .5s ease;
}
.btn-signin:hover { transform:translateY(-2px); box-shadow:0 10px 34px rgba(46,232,165,.36); }
.btn-signin:hover::before { transform:translateX(100%); }
.btn-signin:active { transform:translateY(0); transition-duration:.1s; }
.btn-inner {
  position:relative; z-index:1; display:flex; align-items:center; justify-content:center; gap:10px;
}
.btn-arrow {
  width:17px; height:17px; border:1.5px solid #050b11; border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-size:10px;
  flex-shrink:0; transition:transform .25s;
}
.btn-signin:hover .btn-arrow { transform:translateX(3px); }

.divider { display:flex; align-items:center; gap:10px; margin:22px 0; }
.divider::before,.divider::after { content:''; flex:1; height:1px; background:var(--border); }
.div-lbl {
  font-family:'JetBrains Mono',monospace; font-size:9px;
  color:var(--dim); letter-spacing:.16em; text-transform:uppercase;
}

.btn-sso {
  width:100%; padding:12px 16px; margin-bottom:9px;
  background:transparent; border:1px solid var(--border); border-radius:8px;
  color:var(--muted); font-family:'DM Sans',sans-serif; font-size:13px;
  cursor:pointer; transition:all .22s;
  text-align:left; display:flex; align-items:center; gap:11px;
  position:relative; overflow:hidden;
}
.btn-sso::after {
  content:'\2192'; position:absolute; right:14px;
  opacity:0; transform:translateX(-5px); transition:all .22s; color:var(--g); font-size:13px;
}
.btn-sso:hover { border-color:var(--border-hi); color:var(--text); background:rgba(46,232,165,.04); }
.btn-sso:hover::after { opacity:1; transform:translateX(0); }
.sso-ic {
  width:19px; height:19px; border-radius:4px; flex-shrink:0;
  background:var(--border); display:flex; align-items:center; justify-content:center;
  font-family:'JetBrains Mono',monospace; font-size:8px; color:var(--muted);
}

.auth-footer {
  margin-top:24px; padding-top:18px; border-top:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
}
.af-left  { font-family:'JetBrains Mono',monospace; font-size:9px; color:var(--dim); letter-spacing:.1em; }
.af-right { display:flex; align-items:center; gap:6px; }
.af-dot   { width:5px; height:5px; background:var(--g); border-radius:50%; box-shadow:0 0 6px var(--g); animation:blink 2.5s ease-in-out infinite; }
.af-lbl   { font-family:'JetBrains Mono',monospace; font-size:9px; color:var(--g); opacity:.5; letter-spacing:.1em; text-transform:uppercase; }

.reveal > * { opacity:1; animation:fadeUp .65s cubic-bezier(.16,1,.3,1) both; }
.reveal > *:nth-child(1)  { animation-delay:.35s }
.reveal > *:nth-child(2)  { animation-delay:.44s }
.reveal > *:nth-child(3)  { animation-delay:.51s }
.reveal > *:nth-child(4)  { animation-delay:.58s }
.reveal > *:nth-child(5)  { animation-delay:.64s }
.reveal > *:nth-child(6)  { animation-delay:.70s }
.reveal > *:nth-child(7)  { animation-delay:.76s }
.reveal > *:nth-child(8)  { animation-delay:.81s }
.reveal > *:nth-child(9)  { animation-delay:.86s }
.reveal > *:nth-child(10) { animation-delay:.90s }
.reveal > *:nth-child(11) { animation-delay:.94s }
.reveal > *:nth-child(12) { animation-delay:.98s }
.reveal > *:nth-child(13) { animation-delay:1.02s }
@keyframes fadeUp { from{transform:translateY(12px)} to{transform:translateY(0)} }
@media (prefers-reduced-motion: reduce) {
  .auth-panel, .reveal > * { animation: none !important; transform: none !important; }
}

/* ── Error / Success messages ────────────────────────── */
.auth-error {
  padding:12px 16px;
  background:rgba(255,64,96,0.08);
  border:1px solid rgba(255,64,96,0.25);
  border-left:2px solid #ff4060;
  border-radius:0 8px 8px 0;
  color:#ff4060;
  font-family:'JetBrains Mono',monospace;
  font-size:12px;
  letter-spacing:.03em;
  margin-bottom:16px;
}

.auth-success {
  padding:12px 16px;
  background:rgba(46,232,165,0.08);
  border:1px solid rgba(46,232,165,0.25);
  border-left:2px solid var(--g);
  border-radius:0 8px 8px 0;
  color:var(--g);
  font-family:'JetBrains Mono',monospace;
  font-size:12px;
  letter-spacing:.03em;
  margin-bottom:16px;
}

.auth-hint {
  font-family:'JetBrains Mono',monospace;
  font-size:9px;
  color:var(--dim);
  letter-spacing:.08em;
  text-align:center;
  margin-bottom:14px;
}

/* ── Error modal ─────────────────────────────────────── */
.error-scene {
  display:grid;
  gap:18px;
  width:100%;
}

.error-scene__shell {
  position:relative;
}

.error-scene__shell::before {
  content:'';
  position:absolute;
  inset:-18px;
  background:radial-gradient(circle at 50% 0%, rgba(255,64,96,.16), transparent 55%);
  filter:blur(20px);
  opacity:.9;
  pointer-events:none;
}

.error-modal {
  position:relative;
  display:grid;
  gap:16px;
  background:
    linear-gradient(180deg, rgba(255,64,96,0.08), transparent 26%),
    linear-gradient(180deg, rgba(8,15,24,.98), rgba(11,18,29,.98));
  border:1px solid rgba(255,64,96,0.22);
  border-radius:18px;
  padding:24px 22px 22px;
  box-shadow:0 24px 56px rgba(0,0,0,.34), 0 0 0 1px rgba(255,64,96,.08);
  animation:fadeUp .5s ease both;
  overflow:hidden;
}
.error-modal::before {
  content:'';
  position:absolute;
  inset:0 0 auto 0;
  height:1px;
  background:linear-gradient(to right, transparent, rgba(255,64,96,.92), transparent);
}
.error-modal__brand {
  display:grid;
  gap:10px;
}
.error-modal__logo {
  height:72px;
  width:auto;
  max-width:100%;
  filter:drop-shadow(0 0 16px rgba(46,232,165,.18));
}
.error-modal__status {
  font-family:'JetBrains Mono',monospace;
  font-size:9px;
  font-weight:700;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:rgba(255,64,96,.72);
}
.error-modal__header {
  display:flex;
  align-items:center;
  gap:10px;
}
.error-modal__icon { flex-shrink:0; }
.error-modal__title {
  font-family:'JetBrains Mono',monospace;
  font-size:14px;
  font-weight:700;
  color:#ff4060;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.error-modal__body {
  font-size:13px;
  color:#93a4b4;
  line-height:1.72;
}
.error-modal__meta {
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:6px;
  padding:12px 14px;
  background:rgba(255,64,96,0.05);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:10px;
}
.error-modal__label {
  font-family:'JetBrains Mono',monospace;
  font-size:9px;
  font-weight:700;
  color:#ff7b91;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.error-modal__code {
  font-family:'JetBrains Mono',monospace;
  font-size:10px;
  color:#d6deea;
  word-break:break-all;
}
.error-modal__actions {
  margin-top:2px;
}
.error-modal__action {
  display:block;
  text-decoration:none;
}
.error-modal__hint {
  font-family:'JetBrains Mono',monospace;
  font-size:10px;
  color:var(--dim);
  letter-spacing:.05em;
  line-height:1.55;
}
.error-footer {
  margin-top:4px;
}

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 760px) {
  .hud { display:none; }
  .root { flex-direction:column; }
  .auth-panel { width:100%; min-height:100vh; padding:0 28px; }
  .error-modal { padding:22px 18px 18px; }
}
@media (max-width: 960px) and (min-width: 761px) {
  .hud { display:flex; }
  .root { flex-direction:row; }
  .auth-panel { width:380px; }
}

@media (max-width: 360px) {
  .auth-panel {
    padding: 0 16px !important;
  }
  .auth-title {
    font-size: 20px !important;
  }
  .auth-sub {
    font-size: 12px !important;
    margin-bottom: 24px !important;
  }
  .btn-signin {
    padding: 12px 16px !important;
    font-size: 14px !important;
  }
  .btn-sso {
    font-size: 12px !important;
    padding: 10px 14px !important;
  }
}
