/* Candle Onboarding V5 — unified stylesheet */
/* Inherits all tokens from landing-tokens.css via HTML <link> */

/* ── Reset + base ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{background:var(--bg-void);color:var(--text-primary);font-family:var(--font-display);min-height:100vh;overflow-x:hidden;line-height:1.6}

/* ── Progress dots ── */
.ob-progress{position:fixed;top:40px;left:50%;transform:translateX(-50%);z-index:100;display:flex;gap:8px;align-items:center}
.ob-dot{width:6px;height:6px;border-radius:100px;background:rgba(255,255,255,0.2);transition:all var(--duration-base) var(--ease-out)}
.ob-dot.past{background:rgba(255,255,255,0.6)}
.ob-dot.active{width:20px;background:var(--accent-ice)}

/* ── Back button ── */
.ob-back{position:fixed;top:36px;left:24px;z-index:100;width:40px;height:40px;border-radius:var(--radius-md);background:var(--glass-subtle);border:1px solid rgba(255,255,255,0.06);color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--duration-fast) var(--ease-standard);backdrop-filter:var(--blur-subtle);opacity:0;pointer-events:none}
.ob-back.visible{opacity:1;pointer-events:auto}
.ob-back:hover{color:var(--text-secondary);background:var(--glass-regular);border-color:rgba(255,255,255,0.1);transform:translateX(-2px)}
.ob-back svg{width:16px;height:16px}

/* ── Screen container ── */
.ob-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity var(--duration-slow) var(--ease-out);z-index:10;padding:24px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.ob-screen.active{opacity:1;pointer-events:auto}

/* ══════════════════════════════════════════
   AURORA TREATMENT (Q1 + Reveal)
   ══════════════════════════════════════════ */

.ob-aurora-bg{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.ob-aurora-gradient{position:absolute;width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(0,212,255,0.08),transparent 70%);filter:blur(60px);transform:translate(-50%,-50%);transition:left 400ms ease-out,top 400ms ease-out;will-change:left,top}

/* Aurora layout: two-column editorial */
.ob-aurora-layout{display:grid;grid-template-columns:1.1fr 1fr;gap:var(--space-8);max-width:960px;width:100%;align-items:center;min-height:60vh}
.ob-aurora-prompt{padding-right:var(--space-6)}
.ob-aurora-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:0.25em;text-transform:uppercase;color:var(--accent-ice);margin-bottom:var(--space-5)}
.ob-aurora-text{font-family:var(--font-display);font-size:60px;font-weight:400;line-height:1.02;letter-spacing:-0.02em;color:var(--text-primary)}

/* Aurora answer pills */
.ob-aurora-options{display:flex;flex-direction:column;gap:var(--space-3)}
.ob-aurora-pill{display:flex;align-items:center;gap:var(--space-3);padding:18px 32px;border-radius:100px;background:rgba(255,255,255,0.03);backdrop-filter:var(--blur-regular);border:1px solid rgba(255,255,255,0.08);font-family:var(--font-display);font-size:17px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-standard);text-align:left;position:relative;opacity:0;transform:translateY(20px)}
.ob-aurora-pill.show{opacity:1;transform:translateY(0)}
.ob-aurora-pill:hover{transform:translateX(4px);border-color:rgba(0,212,255,0.2)}
.ob-aurora-pill.selected{background:linear-gradient(135deg,rgba(0,212,255,0.08),rgba(0,212,255,0.03));border-color:rgba(0,212,255,0.35);box-shadow:0 0 40px rgba(0,212,255,0.15)}
.ob-aurora-pill .ob-pill-check{width:20px;height:20px;border-radius:50%;border:1.5px solid rgba(255,255,255,0.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-left:auto;transition:all var(--duration-fast) var(--ease-standard)}
.ob-aurora-pill.selected .ob-pill-check{background:var(--accent-ice);border-color:var(--accent-ice)}
.ob-aurora-pill.selected .ob-pill-check svg{opacity:1}
.ob-pill-check svg{width:12px;height:12px;opacity:0;transition:opacity var(--duration-fast) var(--ease-standard)}

/* ══════════════════════════════════════════
   QUIET TREATMENT (Q2-Q6)
   ══════════════════════════════════════════ */

.ob-quiet-layout{max-width:640px;width:100%;text-align:left}
.ob-quiet-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:var(--space-5)}
.ob-quiet-text{font-family:var(--font-display);font-size:44px;font-weight:500;line-height:1.1;letter-spacing:-0.02em;color:var(--text-primary);margin-bottom:var(--space-3)}
.ob-quiet-helper{font-family:var(--font-display);font-size:17px;font-weight:400;line-height:1.5;color:var(--text-secondary);margin-bottom:var(--space-6)}

/* Quiet answer rows */
.ob-quiet-options{display:flex;flex-direction:column}
.ob-quiet-row{display:flex;align-items:center;gap:var(--space-4);padding:20px 0;border-bottom:1px solid rgba(255,255,255,0.06);cursor:pointer;transition:all var(--duration-fast) var(--ease-standard);opacity:0;transform:translateY(16px)}
.ob-quiet-row.show{opacity:1;transform:translateY(0)}
.ob-quiet-row:last-child{border-bottom:none}
.ob-quiet-row:hover .ob-radio{border-color:rgba(0,212,255,0.3)}

.ob-radio{width:14px;height:14px;border-radius:50%;border:1.5px solid rgba(255,255,255,0.15);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast) var(--ease-standard)}
.ob-quiet-row.selected .ob-radio{border-color:var(--accent-ice);box-shadow:0 0 10px rgba(0,212,255,0.4)}
.ob-quiet-row.selected .ob-radio::after{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent-ice)}
.ob-quiet-label{font-family:var(--font-display);font-size:18px;font-weight:400;color:var(--text-primary)}

/* Checkbox variant for multi-select */
.ob-checkbox{width:14px;height:14px;border-radius:4px;border:1.5px solid rgba(255,255,255,0.15);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast) var(--ease-standard)}
.ob-quiet-row.selected .ob-checkbox{background:var(--accent-ice);border-color:var(--accent-ice);box-shadow:0 0 10px rgba(0,212,255,0.4)}
.ob-quiet-row.selected .ob-checkbox svg{opacity:1}
.ob-checkbox svg{width:10px;height:10px;opacity:0;stroke:#06060a;stroke-width:2.5;transition:opacity var(--duration-fast) var(--ease-standard)}

/* Continue button (quiet screens) */
.ob-continue{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-display);font-size:1.0625rem;font-weight:600;color:#06060a;background:linear-gradient(180deg,#ffffff 0%,#e2e2ea 100%);border:none;border-radius:100px;padding:16px 32px;cursor:pointer;position:relative;box-shadow:0 0 0 1px rgba(255,255,255,0.4),0 8px 24px rgba(255,255,255,0.1),0 0 40px rgba(0,212,255,0.25),inset 0 1px 0 rgba(255,255,255,0.5);transition:all var(--duration-base) var(--ease-standard);margin-top:var(--space-6);opacity:0;transform:translateY(8px);pointer-events:none;text-decoration:none}
.ob-continue::before{content:'';position:absolute;inset:-2px;border-radius:100px;background:linear-gradient(135deg,rgba(0,212,255,0.4) 0%,transparent 50%,rgba(0,212,255,0.2) 100%);z-index:-1;opacity:0.6;filter:blur(8px);transition:all var(--duration-base) var(--ease-standard)}
.ob-continue.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.ob-continue:hover{transform:translateY(-2px);box-shadow:0 0 0 1px rgba(255,255,255,0.5),0 12px 32px rgba(255,255,255,0.15),0 0 60px rgba(0,212,255,0.4),inset 0 1px 0 rgba(255,255,255,0.6)}
.ob-continue:hover::before{opacity:1;filter:blur(12px)}
.ob-continue svg{width:14px;height:14px;transition:transform var(--duration-base) var(--ease-standard)}
.ob-continue:hover svg{transform:translateX(3px)}

/* ══════════════════════════════════════════
   STAGED REVEAL (4 beats)
   ══════════════════════════════════════════ */

.ob-reveal-beat{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:100vh;padding:var(--space-8) var(--space-5)}

/* Beat 1: Analyzing */
.ob-analyzing-logo{width:48px;height:48px;opacity:0.9;margin-bottom:var(--space-5);animation:obPulse 2s ease-in-out infinite}
.ob-analyzing-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:0.25em;text-transform:uppercase;color:var(--accent-ice);margin-bottom:var(--space-3)}
.ob-analyzing-text{font-family:var(--font-display);font-size:22px;font-weight:400;color:var(--text-secondary)}
.ob-analyzing-dots{display:flex;gap:6px;justify-content:center;margin-top:var(--space-4)}
.ob-analyzing-dots span{width:4px;height:4px;border-radius:50%;background:var(--text-tertiary);animation:obDotPulse 1.4s ease-in-out infinite}
.ob-analyzing-dots span:nth-child(2){animation-delay:0.2s}
.ob-analyzing-dots span:nth-child(3){animation-delay:0.4s}

@keyframes obPulse{0%,100%{opacity:0.9;transform:scale(1)}50%{opacity:0.5;transform:scale(0.92)}}
@keyframes obDotPulse{0%,100%{opacity:0.3;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}

/* Beat 2: Sentence reveal */
.ob-sentence-wrap{max-width:760px;width:100%;text-align:left}
.ob-sentence-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:0.25em;text-transform:uppercase;color:var(--accent-ice);margin-bottom:var(--space-6);opacity:0;transition:opacity 400ms var(--ease-out)}
.ob-sentence-eyebrow.show{opacity:1}
.ob-sentence{margin-bottom:var(--space-6)}
.ob-sentence-line{font-family:var(--font-display);font-size:32px;font-weight:400;line-height:1.5;letter-spacing:-0.01em;color:var(--text-secondary);opacity:0;transform:translateY(12px);transition:opacity 600ms var(--ease-out),transform 600ms var(--ease-out)}
.ob-sentence-line.show{opacity:1;transform:translateY(0)}
.ob-sentence-line .ob-highlight{color:var(--text-primary);font-weight:500;transition:text-shadow 800ms var(--ease-out)}
.ob-sentence-line .ob-highlight.glow{text-shadow:0 0 20px rgba(0,212,255,0.3)}

/* Beat 3: Doughnut chart */
.ob-chart-card{max-width:480px;width:100%;text-align:left}
.ob-chart-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:0.25em;text-transform:uppercase;color:var(--accent-ice);margin-bottom:var(--space-5);text-align:center}
.ob-doughnut-wrap{width:220px;height:220px;margin:0 auto var(--space-5);position:relative}
.ob-doughnut-wrap svg{width:100%;height:100%;transform:rotate(-90deg)}
.ob-doughnut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ob-doughnut-center-label{font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-tertiary)}
.ob-doughnut-center-value{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--text-primary)}
.ob-legend{display:grid;grid-template-columns:1fr 1fr;gap:6px var(--space-5);margin-top:var(--space-4)}
.ob-legend-item{display:flex;align-items:center;gap:8px;padding:4px 0}
.ob-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ob-legend-name{font-family:var(--font-display);font-size:13px;color:var(--text-secondary);flex:1}
.ob-legend-pct{font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary)}

/* Beat 4: Welcome */
.ob-welcome-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:0.25em;text-transform:uppercase;color:var(--accent-ice);margin-bottom:var(--space-5)}
.ob-welcome-headline{font-family:var(--font-display);font-size:clamp(36px,6vw,52px);font-weight:400;line-height:1.08;letter-spacing:-0.02em;color:var(--text-primary);margin-bottom:var(--space-4)}
.ob-welcome-sub{font-family:var(--font-display);font-size:17px;font-weight:400;line-height:1.5;color:var(--text-secondary);max-width:420px;margin-bottom:var(--space-6)}
.ob-welcome-signin{font-family:var(--font-display);font-size:14px;color:var(--text-tertiary);margin-top:var(--space-4)}
.ob-welcome-signin a{color:var(--accent-ice);text-decoration:none;font-weight:500}
.ob-welcome-signin a:hover{text-decoration:underline}

/* ══════════════════════════════════════════
   AUTH OVERLAY
   ══════════════════════════════════════════ */

.ob-auth-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;visibility:hidden;transition:opacity 300ms ease}
.ob-auth-overlay.visible{opacity:1;pointer-events:auto;visibility:visible}
.ob-auth-backdrop{position:absolute;inset:0;background:rgba(6,6,10,0.7);backdrop-filter:var(--blur-heavy)}
.ob-auth-card{position:relative;z-index:1;max-width:480px;width:calc(100% - 40px);background:rgba(10,10,14,0.95);backdrop-filter:var(--blur-heavy);border:1px solid rgba(255,255,255,0.08);border-radius:24px;padding:48px 40px;text-align:center;transform:scale(0.96);opacity:0;transition:transform 400ms var(--ease-out),opacity 400ms var(--ease-out)}
.ob-auth-overlay.visible .ob-auth-card{transform:scale(1);opacity:1}
.ob-auth-logo{display:block;margin:0 auto 24px;width:48px;height:48px}
.ob-auth-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;background:none;border:none;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--duration-fast)}
.ob-auth-close:hover{background:rgba(255,255,255,0.05);color:var(--text-primary)}
.ob-auth-headline{font-family:var(--font-display);font-size:28px;font-weight:500;letter-spacing:-0.01em;color:var(--text-primary);margin-bottom:12px}
.ob-auth-sub{font-family:var(--font-display);font-size:15px;font-weight:400;color:var(--text-secondary);margin-bottom:32px;line-height:1.5;max-width:360px;margin-left:auto;margin-right:auto}
.ob-auth-google{width:100%;height:52px;display:flex;align-items:center;justify-content:center;gap:12px;border-radius:100px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.05);color:var(--text-primary);font-family:var(--font-display);font-size:15px;font-weight:500;cursor:pointer;transition:all var(--duration-fast)}
.ob-auth-google:hover{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.2)}
.ob-auth-google svg{flex-shrink:0}
.ob-auth-divider{display:flex;align-items:center;gap:14px;margin:24px 0;font-family:var(--font-mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-tertiary)}
.ob-auth-divider span{flex:1;height:1px;background:rgba(255,255,255,0.08)}
.ob-auth-input{width:100%;height:52px;padding:0 20px;border-radius:100px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.03);color:var(--text-primary);font-family:var(--font-display);font-size:15px;font-weight:400;outline:none;margin-bottom:12px;transition:all var(--duration-fast)}
.ob-auth-input:focus{border-color:var(--accent-ice);box-shadow:0 0 0 3px rgba(0,212,255,0.15)}
.ob-auth-input::placeholder{color:var(--text-tertiary)}
.ob-auth-submit{width:100%;height:56px;border-radius:100px;font-family:var(--font-display);font-size:15px;font-weight:600;cursor:pointer;margin-top:24px;color:#06060a;background:linear-gradient(180deg,#ffffff 0%,#f0f0f0 100%);border:none;position:relative;box-shadow:0 0 60px rgba(0,212,255,0.25),0 4px 16px rgba(0,0,0,0.3);transition:all var(--duration-fast)}
.ob-auth-submit:hover{box-shadow:0 0 80px rgba(0,212,255,0.35),0 8px 24px rgba(0,0,0,0.3);transform:translateY(-1px)}
.ob-auth-toggle{font-family:var(--font-display);font-size:14px;font-weight:400;color:var(--text-secondary);margin-top:20px}
.ob-auth-toggle a{color:var(--accent-ice);font-weight:500;text-decoration:none}
.ob-auth-toggle a:hover{text-decoration:underline}
.ob-auth-message{font-size:12px;margin-top:12px;min-height:16px;color:var(--text-secondary);text-align:center}

/* ══════════════════════════════════════════
   RESUME CARD (returning users)
   ══════════════════════════════════════════ */

.ob-resume-card{max-width:400px;width:100%;background:var(--glass-regular);border:1px solid rgba(255,255,255,0.09);border-radius:var(--radius-lg);padding:32px;text-align:center}
.ob-resume-title{font-family:var(--font-display);font-size:20px;font-weight:600;margin-bottom:var(--space-3)}
.ob-resume-sub{font-size:14px;color:var(--text-secondary);margin-bottom:var(--space-5);line-height:1.5}
.ob-resume-actions{display:flex;flex-direction:column;gap:var(--space-3)}
.ob-resume-continue{font-family:var(--font-display);font-size:15px;font-weight:600;color:#06060a;background:linear-gradient(180deg,#ffffff 0%,#e2e2ea 100%);border:none;border-radius:100px;padding:14px 32px;cursor:pointer;box-shadow:0 0 0 1px rgba(255,255,255,0.4),0 8px 24px rgba(255,255,255,0.1),0 0 40px rgba(0,212,255,0.25);transition:all var(--duration-base) var(--ease-standard)}
.ob-resume-continue:hover{transform:translateY(-2px);box-shadow:0 0 0 1px rgba(255,255,255,0.5),0 12px 32px rgba(255,255,255,0.15),0 0 60px rgba(0,212,255,0.4)}
.ob-resume-restart{font-family:var(--font-display);font-size:14px;font-weight:500;color:var(--text-tertiary);background:none;border:none;cursor:pointer;padding:8px;transition:color var(--duration-fast)}
.ob-resume-restart:hover{color:var(--text-secondary)}

/* ══════════════════════════════════════════
   ROUTE GATE
   ══════════════════════════════════════════ */

.ob-gate{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;background:var(--bg-void);transition:opacity 0.35s ease,visibility 0.35s}
.ob-gate.hidden{opacity:0;visibility:hidden;pointer-events:none}
.ob-gate-inner{text-align:center}
.ob-gate-logo{width:40px;height:auto;opacity:0.9;margin-bottom:var(--space-4)}
.ob-gate-text{font-size:13px;color:var(--text-tertiary);letter-spacing:0.04em}

/* ══════════════════════════════════════════
   MOBILE (max-width: 768px)
   ══════════════════════════════════════════ */

@media(max-width:768px){
  /* Aurora */
  .ob-aurora-layout{grid-template-columns:1fr;gap:var(--space-5);text-align:center}
  .ob-aurora-prompt{padding-right:0}
  .ob-aurora-text{font-size:38px}
  .ob-aurora-pill{padding:16px 24px;font-size:15px}

  /* Quiet */
  .ob-quiet-text{font-size:32px}
  .ob-quiet-helper{font-size:15px}
  .ob-quiet-label{font-size:16px}

  /* Progress */
  .ob-dot{width:4px;height:4px}
  .ob-dot.active{width:16px}

  /* Reveal */
  .ob-sentence-line{font-size:22px}
  .ob-sentence-wrap{max-width:320px}
  .ob-chart-card{max-width:100%}
  .ob-doughnut-wrap{width:180px;height:180px}
  .ob-legend{grid-template-columns:1fr}
  .ob-welcome-headline{font-size:32px}

  /* Auth */
  .ob-auth-card{padding:36px 24px;border-radius:20px}
  .ob-auth-headline{font-size:24px}

  /* Resume */
  .ob-resume-card{padding:24px}
}

@media(max-width:480px){
  .ob-aurora-text{font-size:32px}
  .ob-quiet-text{font-size:28px}
}
