:root{--marketing-cream:#f7ecdc;--marketing-brown:#3d2914}.auth-page{isolation:isolate;min-height:100dvh;padding:1.25rem;padding-top:max(1.25rem, env(safe-area-inset-top));box-sizing:border-box;font-family:var(--editor-font-ui,system-ui);margin:0;position:relative}.auth-page.auth-page--hero{background:#1a1410}.auth-page.auth-page--hero:before{content:"";z-index:0;pointer-events:none;background-color:#1a1410;background-image:linear-gradient(#0a080659 0%,#0a080633 45%,#0a080666 100%),url(../../../branding/hex-map-hero-terrain.png);background-position:50%,50%;background-repeat:no-repeat;background-size:cover,cover;position:fixed;inset:0}.auth-page__content{z-index:1;flex-direction:column;align-items:stretch;gap:1rem;width:100%;max-width:420px;margin-inline:auto;display:flex;position:relative}.auth-home-chip{z-index:20;width:fit-content;max-width:100%;box-shadow:var(--editor-inset-highlight,inset 0 1px 0 #fff8dc1f), 0 4px 14px #00000059;font:600 .72rem/1 var(--editor-font-ui,system-ui);letter-spacing:.02em;text-transform:uppercase;color:var(--editor-gold,#d4af37);cursor:pointer;background:#121820;border:1px solid #d4af3759;border-radius:8px;align-self:flex-start;align-items:center;gap:.35rem;margin:0;padding:6px 12px;text-decoration:none;display:inline-flex;position:relative}.auth-home-chip:hover{color:var(--editor-text,#f5f0e6);background:#161d26;border-color:#d4af378c}.auth-home-chip:focus-visible{outline-offset:2px;outline:2px solid #d4af378c}.auth-card{z-index:1;border-radius:var(--editor-radius,12px);border:1px solid var(--editor-border,#d4af3747);background:linear-gradient(165deg, var(--editor-panel-elevated,#201a14f2) 0%, var(--editor-bg-deep,#0d0a08) 100%);width:100%;color:var(--editor-text,#f5f0e6);box-shadow:var(--editor-shadow-raised,0 8px 32px #00000073);padding:1.25rem;position:relative}.auth-logo{border:1px solid var(--editor-border-strong,#d4af3773);border-radius:16px;width:96px;height:96px;margin:0 auto .75rem;display:block}.auth-card h1{font-family:var(--editor-font-display,serif);color:var(--editor-gold,#d4af37);letter-spacing:.02em;margin:0;font-size:1.35rem;font-weight:600}.auth-card>p:not(.auth-error):not(.auth-success):not(.auth-plan-badge){color:var(--editor-text-muted,#f5f0e6b8);margin:.5rem 0 1rem;font-size:.92rem;line-height:1.45}.auth-error{color:#fca5a5;margin:0 0 .75rem;font-size:.9rem}.auth-success{color:#86efac;margin:0 0 .75rem;font-size:.9rem}.auth-google{border-radius:var(--editor-radius-sm,8px);border:1px solid var(--editor-border,#d4af3747);min-height:42px;color:var(--editor-bg-deep,#0d0a08);background:#fffffff5;justify-content:center;align-items:center;gap:.55rem;margin-bottom:1rem;font-size:.92rem;font-weight:600;text-decoration:none;display:flex}.auth-google img{flex-shrink:0;width:18px;height:18px}.auth-google:hover{border-color:var(--editor-border-strong,#d4af3773)}.auth-form{gap:.75rem;display:grid}.auth-form label{color:var(--editor-text-muted,#f5f0e6bf);gap:.35rem;font-size:.88rem;display:grid}.auth-form input{border-radius:var(--editor-radius-sm,8px);background:var(--editor-panel-inset,#0a08068c);color:var(--editor-text,#f5f0e6);font-family:var(--editor-font-ui,system-ui);border:1px solid #d4af3738;padding:.55rem .65rem}.auth-form input:focus{outline-offset:1px;outline:2px solid #d4af3773}.auth-form input[aria-invalid=true]{border-color:#f87171}.auth-hint{color:var(--editor-text-muted,#f5f0e69e);font-size:.78rem;line-height:1.4}.auth-inline-error{color:#fca5a5;font-size:.8rem;line-height:1.4}.auth-password-row{display:block;position:relative}.auth-password-row input{width:100%;padding-right:60px}.auth-password-toggle{appearance:none;color:var(--editor-gold-muted,#9a7b2c);cursor:pointer;background:0 0;border:1px solid #d4af3747;border-radius:6px;padding:4px 8px;font-size:.78rem;font-weight:600;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.auth-password-toggle:hover{border-color:var(--editor-gold,#d4af37);color:var(--editor-text,#f5f0e6)}.auth-form button[type=submit]{border-radius:var(--editor-radius-sm,8px);border:1px solid var(--editor-border-strong,#d4af3773);color:#fff;min-height:42px;font-weight:600;font-family:var(--editor-font-ui,system-ui);cursor:pointer;background:linear-gradient(#6b5420,#4a3a18);margin-top:.25rem}.auth-form button[type=submit]:hover{filter:brightness(1.06)}.auth-strength{gap:4px;margin-top:.4rem;display:grid}.auth-strength__bar{grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;display:grid}.auth-strength__bar span{background:#ffffff1f;border-radius:999px;height:5px}.auth-strength__bar[data-score="1"] span:nth-child(-n+1),.auth-strength__bar[data-score="2"] span:nth-child(-n+2),.auth-strength__bar[data-score="3"] span:nth-child(-n+3),.auth-strength__bar[data-score="4"] span:nth-child(-n+4){background:var(--strength-color,#d4af37b3)}.auth-strength--weak{--strength-color:#fca5a5}.auth-strength--okay{--strength-color:#fbbf24}.auth-strength--good{--strength-color:#facc15}.auth-strength--strong{--strength-color:#86efac}.auth-strength__label{color:var(--editor-text-muted,#f5f0e6b8);font-size:.78rem}.auth-plan-badge{border:1px solid var(--editor-border-strong,#d4af3773);color:var(--editor-gold,#d4af37);text-align:center;letter-spacing:.02em;background:#d4af371f;border-radius:999px;margin:0 0 .85rem;padding:.45rem .7rem;font-size:.82rem;font-weight:700}.auth-turnstile{justify-content:center;margin-top:.2rem;display:flex}.auth-legal{color:var(--editor-text-muted,#f5f0e69e);margin:.8rem 0 0;font-size:.82rem;line-height:1.4}.auth-legal a{color:var(--editor-gold,#d4af37);font-weight:600}.auth-legal a:hover{color:var(--editor-text,#f5f0e6)}.auth-links{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-top:.8rem;display:flex}.auth-links a{color:var(--editor-gold,#d4af37);font-size:.85rem;font-weight:600;text-decoration:none}.auth-links a:hover{color:var(--editor-text,#f5f0e6);text-decoration:underline}.auth-mode-switch{border:1px solid var(--editor-border,#d4af3747);background:var(--editor-panel-inset,#0a08068c);border-radius:999px;grid-template-columns:1fr 1fr;gap:4px;margin:0 0 1rem;padding:4px;display:grid}.auth-mode-switch__tab{text-align:center;font-size:.88rem;font-weight:600;font-family:var(--editor-font-ui,system-ui);color:var(--editor-text-muted,#f5f0e68c);transition:color var(--editor-duration,.22s) var(--editor-ease,ease), background var(--editor-duration,.22s) var(--editor-ease,ease);border:1px solid #0000;border-radius:999px;padding:.5rem .65rem;text-decoration:none}.auth-mode-switch__tab:hover{color:var(--editor-text,#f5f0e6)}.auth-mode-switch__tab--active{box-shadow:var(--editor-inset-highlight,inset 0 1px 0 #fff8dc1f);background:linear-gradient(#6b5420,#4a3a18);border-color:#d4af3773;color:#fff!important}
