/* Think North — shared "motion-graphics login" chrome.
   Used by templates/accounts/login.html, signup.html, clerk_auth.html and
   templates/access/redeem.html so the four login-adjacent surfaces stop
   redeclaring four near-duplicate inline token sets. Token values mirror
   static/site/tnc.css (kept as a standalone file, not an import, so these
   pages don't have to pull in the full marketing-site stylesheet). */
:root{
  --bg:#070A12;
  --panel:#0D1424;
  --panel-2:#101A2E;
  --ink:#F1F4FA;
  --soft:#B6C0D2;
  --dim:#8794AE;
  --accent:#3FA9FF;
  --accent-2:#6E8BFF;
  --blue:#019DF8;
  --indigo:#3850CD;
  --line:rgba(255,255,255,.10);
  --line-2:rgba(255,255,255,.06);
  --glow:rgba(31,150,255,.5);
  --disp:"Schibsted Grotesk",system-ui,sans-serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--body);background:var(--bg);color:var(--ink);
  min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:32px;position:relative;overflow:hidden;font-size:1rem;line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
#bg{position:fixed;inset:0;z-index:0;display:block}
.glow{position:fixed;border-radius:50%;filter:blur(90px);z-index:0;pointer-events:none}
.g1{width:560px;height:560px;background:radial-gradient(circle,rgba(31,150,255,.4),transparent 70%);top:-180px;left:-140px;animation:auth-f1 18s ease-in-out infinite}
.g2{width:480px;height:480px;background:radial-gradient(circle,rgba(110,139,255,.35),transparent 70%);bottom:-180px;right:-120px;animation:auth-f2 22s ease-in-out infinite}
@keyframes auth-f1{0%,100%{transform:translate(0,0)}50%{transform:translate(90px,70px)}}
@keyframes auth-f2{0%,100%{transform:translate(0,0)}50%{transform:translate(-80px,-60px)}}
@media(prefers-reduced-motion:reduce){.glow{animation:none}}

.shell{position:relative;z-index:2;width:100%;max-width:440px}
.top{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-weight:600;
  font-size:1.05rem;justify-content:center;margin-bottom:22px}
.top .logo{filter:drop-shadow(0 0 10px rgba(1,157,248,.55))}
.top b{color:var(--accent);font-weight:600}

.card{background:rgba(13,20,36,.72);backdrop-filter:blur(16px);border:1px solid var(--line);
  border-radius:20px;padding:34px 30px;box-shadow:0 36px 90px -28px rgba(0,0,0,.85)}
.card h1{font-family:var(--disp);font-weight:600;font-size:1.5rem;letter-spacing:-.02em;
  line-height:1.15;text-align:center}
.card .sub{color:var(--soft);font-size:.92rem;text-align:center;margin:8px 0 22px;line-height:1.6}

.field{margin-top:14px}
.field label{display:block;font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--dim);margin-bottom:7px}
.field label .opt{text-transform:none;letter-spacing:0}
.field input{width:100%;font-family:var(--body);font-size:.96rem;color:var(--ink);
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:10px;padding:12px 14px;
  transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}
.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(63,169,255,.16);
  background:rgba(255,255,255,.05)}
.field:focus-within label{color:var(--accent)}

.err{border:1px solid rgba(255,133,133,.4);background:rgba(255,133,133,.08);color:#ffc1c1;
  border-radius:10px;padding:10px 13px;font-size:.86rem;margin-bottom:6px}
.err.inline{border:0;background:none;padding:0;margin-top:7px;margin-bottom:0}

.btn{width:100%;margin-top:20px;font-family:var(--body);font-weight:600;font-size:.94rem;
  color:#04101f;background:var(--blue);border:0;border-radius:10px;padding:13px 18px;cursor:pointer;
  box-shadow:0 0 0 1px rgba(63,169,255,.4),0 12px 40px -14px rgba(31,150,255,.8);transition:background .2s ease}
.btn:hover{background:#27AEFF}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

.alt{margin-top:18px;text-align:center;font-size:.86rem;color:var(--soft)}
.alt a{color:var(--accent);text-decoration:none}
.alt a:hover{text-decoration:underline}
.consent{margin-top:14px;font-size:.76rem;color:var(--dim);text-align:center}
.refrain{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;color:var(--dim);
  text-align:center;margin-top:16px;text-transform:uppercase}
.back{margin-top:22px;text-align:center;font-size:.82rem;color:var(--dim)}
.back a{color:var(--accent);text-decoration:none}
.back a:hover{text-decoration:underline}

.spin{margin:10px auto;width:26px;height:26px;border:3px solid rgba(255,255,255,.15);
  border-top-color:var(--accent);border-radius:50%;animation:auth-sp .8s linear infinite}
@keyframes auth-sp{to{transform:rotate(360deg)}}
#clerk-auth{display:flex;justify-content:center;min-height:90px}
#clerk-fallback{display:none;margin-top:16px;text-align:center;color:var(--soft);font-size:.9rem}
#clerk-fallback a{color:var(--accent)}

/* access/redeem: same shell, plus a small "who" / link-row footer */
.who{font-family:var(--mono);font-size:.78rem;color:var(--dim);margin-top:10px}
.links{margin-top:18px;font-size:.82rem;color:var(--dim);display:flex;justify-content:space-between}
.links a{color:var(--accent);text-decoration:none}
.links a:hover{text-decoration:underline}
