/* Editorial Numbered chrome — shared by /login/, /signup/, /forgot-password/.
   Matches the home page background (gradient + orbs + animated stars via
   main.js) and the OTP email's typography (Inter + Instrument Serif italic). */

:root{
    --bg:#08060f; --bg2:#0c0918; --bg-c:#0d0d18;
    --bdr:rgba(124,58,237,.12); --bdr-h:rgba(124,58,237,.3);
    --t1:#f4f4fb; --t2:#9494b8; --t3:#5e5e7e;
    --ac:#7c3aed; --acl:#a78bfa; --acd:#5b21b6;
    --grad:linear-gradient(135deg,#c4b5fd,#7c3aed 40%,#a78bfa 70%,#ddd6fe);
    --gbtn:linear-gradient(135deg,#7c3aed,#6d28d9);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;overflow-x:hidden;width:100%;max-width:100vw;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%}
body{
    font-family:'Inter',system-ui,-apple-system,sans-serif;
    background:linear-gradient(180deg,#0c0818 0%,#08060f 40%,#08060f 60%,#0c0818 100%) fixed;
    color:var(--t1);
    overflow-x:hidden;
    line-height:1.6;
    min-height:100vh;min-height:100dvh;
    display:flex;flex-direction:column;
    touch-action:pan-y;
}
a{text-decoration:none;color:inherit}
::selection{background:rgba(124,58,237,.3)}

/* Stars canvas + orbs (matches home) */
#stars{position:fixed;inset:0;pointer-events:none;z-index:0;width:100%;height:100%}
.orb{position:fixed;border-radius:50%;pointer-events:none;filter:blur(140px);z-index:-1}
.orb-h{width:min(700px,100vw);height:700px;top:-300px;left:50%;transform:translateX(-50%);background:radial-gradient(circle,rgba(124,58,237,.2),transparent 70%)}
.orb-m{width:min(500px,100vw);height:500px;top:50%;right:0;transform:translateX(50%);background:radial-gradient(circle,rgba(99,102,241,.08),transparent 70%)}

/* Subtle noise — same as home */
body::before{
    content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
    opacity:.025;mix-blend-mode:overlay;
}

/* Header */
.hd{padding:28px 32px;position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between}
/* "Yvor" in Instrument Serif italic (matches the home .nav-logo and the
   .stat-v "24/7" treatment) with a subtle violet glow halo. "AIO" stays
   Inter 800 in violet, solid (text-shadow:none override). */
.hd-logo{display:flex;align-items:baseline;gap:8px;font-family:'Instrument Serif',Georgia,serif;font-style:italic;font-weight:400;font-size:24px;letter-spacing:-.5px;color:#fff;line-height:1;text-shadow:0 0 16px rgba(167,139,250,.5),0 0 36px rgba(124,58,237,.28)}
.hd-logo:hover{color:#fff}
.hd-logo img{width:32px;height:32px;border-radius:8px;align-self:center}
.hd-logo span{font-family:'Inter',system-ui,sans-serif;font-style:normal;font-weight:800;font-size:17px;color:var(--acl);margin-left:-4px;letter-spacing:-.3px;text-shadow:none}

/* Back link */
.back{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--t2);padding:8px 12px;margin:0 24px 16px;border-radius:100px;transition:color .2s,background .2s;align-self:flex-start;position:relative;z-index:2;font-family:'Instrument Serif',Georgia,serif;font-style:italic;font-size:14px}
.back:hover{color:var(--t1);background:rgba(124,58,237,.06)}
.back svg{width:14px;height:14px}

/* Main + card */
.main{flex:1;display:flex;align-items:center;justify-content:center;padding:24px 24px 80px;position:relative;z-index:2}
.card{
    width:100%;max-width:520px;
    background:rgba(13,9,24,.55);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(167,139,250,.12);
    border-radius:24px;
    padding:52px 48px;
    position:relative;
    box-shadow:0 24px 80px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.04);
    animation:cardIn .7s cubic-bezier(.16,1,.3,1) both;
}
@keyframes cardIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* Editorial badge — "welcome back", "join the beta", "reset" */
.kicker{
    display:inline-flex;align-items:center;gap:10px;
    font-family:'Instrument Serif',Georgia,serif;
    font-style:italic;font-size:14px;color:var(--acl);
    margin-bottom:24px;text-transform:lowercase;letter-spacing:.2px;
}
.kicker::before{content:'';width:28px;height:1px;background:linear-gradient(90deg,transparent,var(--acl))}

/* Big serif title */
.title{
    font-family:'Instrument Serif',Georgia,serif;
    font-size:44px;font-weight:400;line-height:1.02;letter-spacing:-1.2px;
    margin-bottom:14px;
    color:var(--t1);
}
.title em{font-style:italic;color:var(--acl)}
@media (max-width:520px){.title{font-size:36px;letter-spacing:-1px}}

.lede{font-size:14px;color:var(--t2);margin-bottom:36px;line-height:1.65;max-width:380px}
.lede strong{color:var(--t1);font-weight:600}

/* Form fields — underline minimal style */
.field{margin-bottom:18px}
.field label{
    display:block;
    font-size:10.5px;letter-spacing:1.6px;text-transform:uppercase;
    color:var(--t3);font-weight:600;margin-bottom:8px;
}
.field input{
    width:100%;background:transparent;border:none;
    border-bottom:1px solid rgba(167,139,250,.18);
    padding:8px 0 10px;
    color:var(--t1);font-family:inherit;font-size:15.5px;
    outline:none;transition:border-color .25s ease;
}
.field input::placeholder{color:var(--t3)}
.field input:focus{border-bottom-color:var(--ac)}
.field input:-webkit-autofill,.field input:-webkit-autofill:hover,.field input:-webkit-autofill:focus{
    -webkit-text-fill-color:var(--t1);
    -webkit-box-shadow:0 0 0 1000px rgba(13,9,24,.95) inset;
    caret-color:var(--t1);
    transition:background-color 9999s ease-in-out 0s;
}

/* Row with checkbox + forgot link */
.row{display:flex;align-items:center;justify-content:space-between;margin:20px 0 24px;font-size:13px;flex-wrap:wrap;gap:12px}
.remember{display:inline-flex;align-items:center;gap:8px;color:var(--t2);cursor:pointer;user-select:none}
.remember input{display:none}
.remember .check{
    width:16px;height:16px;border-radius:4px;
    border:1px solid rgba(167,139,250,.25);
    background:rgba(8,6,15,.6);
    display:flex;align-items:center;justify-content:center;
    transition:all .2s;flex-shrink:0;
}
.remember input:checked+.check{background:var(--ac);border-color:var(--ac)}
.remember input:checked+.check svg{opacity:1}
.remember .check svg{width:10px;height:10px;stroke:#fff;opacity:0;transition:opacity .2s}
.row .link{
    font-family:'Instrument Serif',Georgia,serif;
    font-style:italic;font-size:14.5px;color:var(--acl);
    transition:color .2s;cursor:pointer;
}
.row .link:hover{color:#c4b5fd}

/* Turnstile (Cloudflare widget) */
.turnstile-wrap{margin:0 -8px 22px;display:flex;justify-content:center}

/* 2FA collapsible */
.totp-group{display:none;margin:0 0 18px;animation:totpIn .35s cubic-bezier(.16,1,.3,1)}
.totp-group.show{display:block}
@keyframes totpIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.totp-group input{
    text-align:center;letter-spacing:10px;font-size:22px;font-weight:600;
    padding:10px 0;font-variant-numeric:tabular-nums;
}

/* Submit button — gradient pill */
.btn{
    width:100%;padding:15px 24px;border:none;border-radius:14px;
    background:var(--gbtn);color:#fff;
    font-family:inherit;font-size:14.5px;font-weight:600;letter-spacing:.3px;
    cursor:pointer;
    display:inline-flex;align-items:center;justify-content:center;gap:10px;
    transition:transform .2s,box-shadow .2s,filter .2s;
    box-shadow:0 12px 32px rgba(124,58,237,.25);
}
.btn:hover{transform:translateY(-1px);box-shadow:0 16px 40px rgba(124,58,237,.35);filter:brightness(1.08)}
.btn:active{transform:translateY(0);box-shadow:0 8px 24px rgba(124,58,237,.2)}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:0 4px 16px rgba(124,58,237,.15);filter:none}
.btn .arr{width:16px;height:16px;transition:transform .2s}
.btn:hover .arr{transform:translateX(3px)}

/* Editorial footer link (signup/login/back) */
.swap{
    text-align:center;margin-top:24px;font-size:13px;color:var(--t3);
    font-family:'Instrument Serif',Georgia,serif;font-style:italic;
}
.swap a{
    margin-left:6px;color:var(--t1);font-style:normal;font-family:'Inter',sans-serif;
    font-weight:600;transition:color .2s;
}
.swap a:hover{color:var(--acl)}

/* Terms note — only on signup */
.terms{text-align:center;margin-top:16px;font-size:11.5px;color:var(--t3);line-height:1.7}
.terms a{color:var(--acl);transition:color .2s}
.terms a:hover{color:#c4b5fd}

/* Msg banner (success / error) */
.msg{padding:11px 14px;border-radius:10px;font-size:13px;font-weight:500;margin-bottom:18px;display:none;line-height:1.5}
.msg.show{display:block}
.msg-ok{background:rgba(34,197,94,.06);color:#86efac;border:1px solid rgba(34,197,94,.18)}
.msg-err{background:rgba(239,68,68,.06);color:#fca5a5;border:1px solid rgba(239,68,68,.18)}

/* OTP code boxes (signup step 2) — keep grid layout but editorial colors */
.code-step{display:none;animation:cardIn .5s cubic-bezier(.16,1,.3,1)}
.code-step.show{display:block}
.code-boxes{display:flex;gap:10px;justify-content:center;margin-bottom:28px;margin-top:8px}
.code-box{
    width:54px;height:64px;
    border:1px solid rgba(167,139,250,.18);
    border-radius:12px;
    background:rgba(8,6,15,.55);
    color:var(--t1);font-size:28px;font-weight:700;
    text-align:center;outline:none;
    transition:border-color .2s,box-shadow .2s,background .2s;
    -webkit-appearance:none;appearance:none;caret-color:transparent;
    /* Match the "Confirm your email" title font (beta bug 3.6) */
    font-family:'Instrument Serif',Georgia,serif;font-variant-numeric:tabular-nums;
}
.code-box:focus{border-color:var(--ac);box-shadow:0 0 0 3px rgba(124,58,237,.18);background:rgba(124,58,237,.04)}
.code-box.filled{border-color:rgba(167,139,250,.45);background:rgba(124,58,237,.06)}

.resend-row{
    text-align:center;margin-top:18px;font-size:12.5px;color:var(--t3);
    font-family:'Instrument Serif',Georgia,serif;font-style:italic;
}
.resend-row a{color:var(--acl);cursor:pointer;font-weight:500;font-family:inherit}
.resend-row a:hover{color:#c4b5fd}

/* Footer disclaimer at the very bottom of the page */
.foot{text-align:center;padding:24px;font-size:11.5px;color:var(--t3);position:relative;z-index:2;font-family:'Instrument Serif',Georgia,serif;font-style:italic}
.foot a{color:var(--t2);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}
.foot a:hover{border-color:var(--t2)}

/* Mobile */
@media (max-width:768px){
    body::before{display:none}
    .orb{filter:blur(80px)}
    .orb-h{width:min(500px,100vw);height:500px;top:-220px}
    .orb-m{width:min(380px,100vw);height:380px}
    .hd{padding:20px 20px}
    .hd-logo{font-size:22px}
    .hd-logo span{font-size:15.5px}
    .hd-logo img{width:28px;height:28px}
    .back{margin:0 16px 12px;font-size:13px}
    .main{padding:8px 16px 60px;align-items:flex-start}
    .card{padding:36px 28px;border-radius:20px}
    .title{font-size:32px}
    .lede{font-size:13.5px;margin-bottom:30px}
    .field input{font-size:15px}
    .code-box{width:44px;height:54px;font-size:22px;border-radius:10px}
    .code-boxes{gap:7px}
}
@media (max-width:380px){
    .card{padding:32px 22px}
    .title{font-size:28px}
    .code-box{width:38px;height:48px;font-size:20px}
}
