/* ═══ READING ENGINE ═══ */
#readingScreen{padding-top:68px;background:var(--bg)}

/* Oracle picker */
.oracle-picks{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:28px}
.oracle-pick{padding:20px;border-radius:var(--r2);background:var(--surface);border:1.5px solid var(--border);cursor:pointer;transition:all .35s var(--ease);text-align:center}
.oracle-pick:hover{border-color:var(--gold-border);transform:translateY(-3px);box-shadow:0 12px 40px rgba(14,27,61,.06)}
.oracle-pick.sel{border-color:var(--gold);background:var(--gold-glow);box-shadow:0 0 0 3px rgba(232,119,26,.08)}
.op-icon{font-size:1.8rem;margin-bottom:8px;color:var(--navy)}
.oracle-pick.sel .op-icon{color:var(--gold)}
.op-name{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:3px;letter-spacing:-.02em}
.op-desc{font-size:.72rem;color:var(--text3)}

/* Spread picker */
.spread-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px}
@media(max-width:768px){.spread-grid{grid-template-columns:1fr;max-width:400px;margin-left:auto;margin-right:auto}}
.sp-card{padding:28px 24px;border-radius:var(--r2);background:var(--surface);border:1.5px solid var(--border);cursor:pointer;transition:all .35s var(--ease);position:relative;overflow:hidden;text-align:center}
.sp-card:hover{border-color:var(--gold-border);transform:translateY(-4px);box-shadow:0 16px 48px rgba(14,27,61,.08)}
.sp-card.sel{border-color:var(--gold);background:var(--gold-glow);box-shadow:0 0 0 3px rgba(232,119,26,.1)}
.sp-free{position:absolute;top:14px;left:14px;padding:3px 11px;border-radius:100px;background:linear-gradient(135deg,var(--gold),var(--ember));color:#fff;font-size:.6rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.sp-cnt{position:absolute;top:14px;right:14px;padding:3px 11px;border-radius:100px;background:var(--navy);color:#fff;font-size:.62rem;font-weight:700}
.sp-dots{display:flex;gap:6px;justify-content:center;margin:18px 0 14px;min-height:30px}
.sp-dot{width:20px;height:30px;border-radius:4px;background:linear-gradient(145deg,var(--navy),var(--navy-mid));opacity:.15}
.sp-card.sel .sp-dot{opacity:.35}
.sp-name{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:4px;letter-spacing:-.02em}
.sp-desc{font-size:.78rem;color:var(--text2);line-height:1.55}

/* Topic picker */
.topic-pick-wrap{text-align:center;margin-bottom:28px}
.topic-picks{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.topic-pick{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:100px;background:var(--surface);border:1.5px solid var(--border);cursor:pointer;transition:all .3s var(--ease);font-family:var(--font)}
.topic-pick:hover{border-color:var(--gold-border);transform:translateY(-2px)}
.topic-pick.sel{border-color:var(--gold);background:var(--gold-glow);box-shadow:0 0 0 3px rgba(232,119,26,.08)}
.tp-icon{font-size:1.1rem;line-height:1}
.topic-pick.sel .tp-icon{color:var(--gold)}
.tp-name{font-size:.86rem;font-weight:700;color:var(--navy);letter-spacing:-.01em}
.topic-pick.sel .tp-name{color:var(--gold)}

.draw-row{text-align:center;padding:28px 0 20px}
.btn-draw{padding:17px 52px;border-radius:14px;font-size:.98rem;font-weight:700;font-family:var(--font);
background:linear-gradient(135deg,#f59130,var(--gold),var(--ember));color:#fff;border:none;cursor:pointer;
transition:all .35s var(--ease);box-shadow:0 4px 24px rgba(232,119,26,.3),inset 0 1px 0 rgba(255,255,255,.12);
position:relative;overflow:hidden;text-shadow:0 1px 2px rgba(0,0,0,.15);letter-spacing:.01em}
.btn-draw::before{content:'';position:absolute;top:-50%;left:-60%;width:40%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transform:rotate(25deg);transition:left .6s var(--ease)}
.btn-draw:hover::before{left:120%}
.btn-draw:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 36px rgba(232,119,26,.4),inset 0 1px 0 rgba(255,255,255,.15)}
.btn-draw:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.btn-draw:disabled::before{display:none}

/* ═══ CARD FAN — base (used inside hero) ═══ */
.fan-hero{text-align:center;margin-bottom:48px;position:relative;padding:32px 0 0}
.fan-glow{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);width:600px;height:350px;background:radial-gradient(ellipse,rgba(232,119,26,.1) 0%,rgba(232,119,26,.03) 40%,transparent 65%);pointer-events:none;filter:blur(50px);animation:fanGlowPulse 6s ease-in-out infinite}
@keyframes fanGlowPulse{0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}}
.fan-wrap{display:flex;justify-content:center;align-items:flex-end;height:220px;position:relative;margin-bottom:52px;perspective:800px}
.fan-card{width:90px;height:140px;border-radius:10px;background:linear-gradient(160deg,var(--navy) 0%,var(--navy-mid) 50%,var(--navy-light) 100%);border:2px solid rgba(255,255,255,.08);box-shadow:0 8px 32px rgba(14,27,61,.2);position:absolute;bottom:0;transform-origin:50% 140%;transition:all .7s cubic-bezier(.25,.8,.25,1);cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden}
.fan-card::before{content:'';position:absolute;inset:6px;border-radius:6px;border:1px solid rgba(255,255,255,.06)}
.fan-card::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;opacity:.15;color:#fff;pointer-events:none}
.fan-card .fan-sym{font-size:1.4rem;color:rgba(255,255,255,.12);position:relative;z-index:1;transition:all .7s cubic-bezier(.25,.8,.25,1)}
.fan-card:hover{transform:var(--rot) translateY(-20px) scale(1.08)!important;box-shadow:0 20px 48px rgba(14,27,61,.3),0 0 32px rgba(232,119,26,.1);border-color:rgba(232,119,26,.2);z-index:10!important}
.fan-card:hover .fan-sym{color:rgba(232,119,26,.4);transform:scale(1.12)}
.fan-card .fan-shine{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.04) 50%,transparent 60%);transform:rotate(25deg);pointer-events:none;transition:all .6s}
.fan-card:hover .fan-shine{background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%)}
.fan-cta{position:relative;z-index:2}

@media(max-width:520px){
  .fan-wrap{height:180px}
  .fan-card{width:70px;height:110px}
}

/* ═══ WIZARD STEP SYSTEM ═══ */
.wiz-wrap{max-width:640px;margin:0 auto;position:relative;overflow:hidden;min-height:340px}
.wiz-step{position:absolute;top:0;left:0;right:0;opacity:0;transform:scale(.96) translateY(12px);transition:opacity .5s cubic-bezier(.25,.8,.25,1),transform .5s cubic-bezier(.25,.8,.25,1),visibility 0s .5s;pointer-events:none;visibility:hidden}
.wiz-step.active{opacity:1;transform:scale(1) translateY(0);pointer-events:auto;position:relative;visibility:visible;transition:opacity .5s cubic-bezier(.25,.8,.25,1) .1s,transform .5s cubic-bezier(.25,.8,.25,1) .1s,visibility 0s 0s}
.wiz-step.exit-left{opacity:0;transform:scale(.96) translateY(-8px)}

.wiz-progress{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:32px}
.wiz-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .3s}
.wiz-dot.done{background:var(--gold)}
.wiz-dot.on{background:var(--gold);width:24px;border-radius:4px}
.wiz-step-label{text-align:center;margin-bottom:24px}
.wiz-step-num{font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:6px}
.wiz-step-title{font-size:clamp(1.2rem,3vw,1.6rem);font-weight:800;color:var(--navy);letter-spacing:-.03em}

.wiz-options{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;max-width:460px;margin:0 auto}
.wiz-opt{padding:16px 14px;border-radius:var(--r2);background:var(--surface);border:1.5px solid var(--border);cursor:pointer;transition:all .4s var(--ease);text-align:center;position:relative;overflow:hidden}
.wiz-opt::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(232,119,26,.04),transparent 60%);opacity:0;transition:opacity .4s}
.wiz-opt:hover{border-color:var(--gold-border);transform:translateY(-4px);box-shadow:0 14px 40px rgba(14,27,61,.08)}
.wiz-opt:hover::after{opacity:1}
.wiz-opt.sel{border-color:var(--gold);background:var(--gold-glow);box-shadow:0 0 0 3px rgba(232,119,26,.08),0 8px 28px rgba(232,119,26,.06)}
.wiz-opt.sel::after{opacity:1}
.wiz-opt-icon{font-size:1.3rem;margin-bottom:6px}
.wiz-opt.sel .wiz-opt-icon{color:var(--gold)}
.wiz-opt-name{font-size:.82rem;font-weight:700;color:var(--navy);margin-bottom:2px}
.wiz-opt.sel .wiz-opt-name{color:var(--gold)}
.wiz-opt-desc{font-size:.64rem;color:var(--text3);line-height:1.45}

/* Spread grid v2 */
.spread-filters{display:flex;gap:6px;justify-content:center;margin-bottom:18px;flex-wrap:wrap}
.sf-btn{padding:6px 16px;border-radius:100px;font-size:.68rem;font-weight:600;font-family:var(--font);background:var(--surface);color:var(--text3);border:1px solid var(--border);cursor:pointer;transition:all .25s}
.sf-btn:hover{border-color:var(--gold-border);color:var(--text2)}
.sf-btn.on{background:var(--navy);color:#fff;border-color:var(--navy)}

.spread-grid-v2{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-height:360px;overflow-y:auto;padding:4px;scrollbar-width:thin;scrollbar-color:rgba(14,27,61,.08) transparent}
.spread-grid-v2::-webkit-scrollbar{width:4px}
.spread-grid-v2::-webkit-scrollbar-track{background:transparent}
.spread-grid-v2::-webkit-scrollbar-thumb{background:rgba(14,27,61,.1);border-radius:4px}

.wiz-sp{padding:18px 14px;border-radius:var(--r2);background:var(--surface);border:1.5px solid var(--border);cursor:pointer;transition:all .35s cubic-bezier(.25,.8,.25,1);text-align:center;position:relative}
.wiz-sp:hover{border-color:var(--gold-border);transform:translateY(-3px);box-shadow:0 10px 32px rgba(14,27,61,.06)}
.wiz-sp.sel{border-color:var(--gold);background:var(--gold-glow);box-shadow:0 0 0 3px rgba(232,119,26,.08)}
.wiz-sp.hidden{display:none}
.wiz-sp-cnt{display:inline-block;padding:2px 8px;border-radius:100px;background:var(--navy);color:#fff;font-size:.56rem;font-weight:700;margin-bottom:8px}
.wiz-sp-dots{display:flex;gap:3px;justify-content:center;margin-bottom:8px;min-height:20px;flex-wrap:wrap}
.wiz-sp-dot{width:10px;height:16px;border-radius:2px;background:linear-gradient(145deg,var(--navy),var(--navy-mid));opacity:.1}
.wiz-sp.sel .wiz-sp-dot{opacity:.25}
.wiz-sp-name{font-size:.74rem;font-weight:700;color:var(--navy);margin-bottom:2px;letter-spacing:-.01em;line-height:1.3}
.wiz-sp.sel .wiz-sp-name{color:var(--gold)}
.wiz-sp-desc{font-size:.6rem;color:var(--text3);line-height:1.4}

/* Help me choose */
.spread-help{text-align:center;margin-top:20px}
.spread-help-btn{padding:14px 32px;border-radius:14px;font-size:.82rem;font-family:var(--font);background:linear-gradient(135deg,rgba(14,27,61,.03),rgba(232,119,26,.06));border:1.5px solid rgba(232,119,26,.18);color:var(--text2);cursor:pointer;transition:all .35s var(--ease);position:relative;overflow:hidden}
.spread-help-btn::before{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(232,119,26,.06),transparent);animation:helpShimmer 3s ease-in-out infinite}
@keyframes helpShimmer{0%{left:-100%}50%{left:150%}100%{left:150%}}
.spread-help-btn:hover{border-color:var(--gold);background:linear-gradient(135deg,rgba(232,119,26,.08),rgba(232,119,26,.12));transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,119,26,.1)}
.spread-help-btn .spread-help-icon{color:var(--gold);margin-right:6px;font-size:1rem;vertical-align:middle}
.spread-help-btn strong{color:var(--gold);font-weight:700}

/* Spread helper chat */
.spread-chat{position:fixed;bottom:24px;right:24px;width:340px;max-height:480px;background:var(--surface);border-radius:20px;border:1px solid var(--border);box-shadow:0 20px 60px rgba(14,27,61,.15);z-index:200;display:flex;flex-direction:column;overflow:hidden;animation:chatIn .4s cubic-bezier(.25,.8,.25,1)}
@keyframes chatIn{from{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
.spread-chat-hdr{padding:16px 20px;background:var(--navy);display:flex;align-items:center;justify-content:space-between}
.spread-chat-title{font-size:.78rem;font-weight:700;color:#fff}
.spread-chat-close{background:none;border:none;color:rgba(255,255,255,.4);font-size:1.2rem;cursor:pointer;padding:0;line-height:1;transition:color .2s}
.spread-chat-close:hover{color:#fff}
.spread-chat-body{flex:1;padding:16px 20px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}
.spread-chat-msg{padding:10px 14px;border-radius:12px;font-size:.78rem;line-height:1.55;max-width:85%;animation:msgIn .3s cubic-bezier(.25,.8,.25,1)}
@keyframes msgIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.spread-chat-msg.bot{background:var(--gold-glow);border:1px solid rgba(232,119,26,.08);color:var(--text2);align-self:flex-start;border-bottom-left-radius:4px}
.spread-chat-msg.user{background:var(--navy);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.spread-chat-options{padding:12px 16px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:6px}
.spread-chat-opt{padding:7px 14px;border-radius:100px;font-size:.72rem;font-weight:600;font-family:var(--font);background:var(--surface);border:1px solid var(--border);color:var(--text2);cursor:pointer;transition:all .2s}
.spread-chat-opt:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-glow)}

@media(max-width:520px){
  .spread-grid-v2{grid-template-columns:repeat(2,1fr)}
  .spread-chat{left:12px;right:12px;bottom:12px;width:auto}
}

/* Wizard nav buttons */
.wiz-nav{display:flex;justify-content:center;gap:12px;margin-top:28px}
.wiz-back{padding:12px 28px;border-radius:100px;font-size:.82rem;font-weight:600;font-family:var(--font);background:var(--surface);color:var(--text2);border:1.5px solid var(--border);cursor:pointer;transition:all .25s}
.wiz-back:hover{border-color:var(--gold-border);color:var(--gold)}
.wiz-next{padding:13px 36px;border-radius:12px;font-size:.82rem;font-weight:700;font-family:var(--font);
background:linear-gradient(135deg,#f59130,var(--gold),var(--ember));color:#fff;border:none;cursor:pointer;
transition:all .3s var(--ease);box-shadow:0 4px 20px rgba(232,119,26,.25),inset 0 1px 0 rgba(255,255,255,.1);
position:relative;overflow:hidden;text-shadow:0 1px 2px rgba(0,0,0,.1);letter-spacing:.01em}
.wiz-next::before{content:'';position:absolute;top:-50%;left:-60%;width:40%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);transform:rotate(25deg);transition:left .5s var(--ease)}
.wiz-next:hover::before{left:120%}
.wiz-next:hover{transform:translateY(-2px);box-shadow:0 6px 28px rgba(232,119,26,.35),inset 0 1px 0 rgba(255,255,255,.12)}

/* Confirmation step */
.wiz-confirm{text-align:center;padding:20px 0}
.wiz-confirm-summary{display:inline-flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:24px}
.wiz-confirm-pill{padding:7px 16px;border-radius:100px;background:var(--gold-glow);border:1px solid rgba(232,119,26,.12);font-size:.74rem;font-weight:600;color:var(--navy)}
.wiz-confirm-pill span{color:var(--gold)}

@media(max-width:520px){
  .wiz-options{grid-template-columns:1fr 1fr}
  .wiz-sp{flex:0 0 170px}
}

/* ═══ READING HERO ═══ */
.r-hero{min-height:50vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:100px 24px 100px;
background:linear-gradient(170deg,#030610 0%,var(--navy) 30%,var(--navy-mid) 55%,var(--navy-light) 85%,#2a4a78 100%)}
.r-hero::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:120px;background:linear-gradient(to top,var(--bg),rgba(247,245,241,.3) 40%,transparent);pointer-events:none;z-index:1}
/* Orbs */
.r-hero .rh-orb1{position:absolute;top:-10%;right:-5%;width:600px;height:600px;background:radial-gradient(circle,rgba(232,119,26,.09) 0%,transparent 50%);border-radius:50%;pointer-events:none;animation:drift 20s ease-in-out infinite}
.r-hero .rh-orb2{position:absolute;bottom:-15%;left:-8%;width:500px;height:500px;background:radial-gradient(circle,rgba(107,91,167,.06) 0%,transparent 50%);border-radius:50%;pointer-events:none;animation:drift 24s ease-in-out infinite reverse}
/* Vertical line */
.r-hero .rh-line{position:absolute;top:0;left:50%;width:1px;height:100%;background:linear-gradient(to bottom,transparent,rgba(232,119,26,.06) 30%,rgba(232,119,26,.03) 70%,transparent);pointer-events:none}
/* Stars */
.r-hero .rh-stars{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.rh-star{position:absolute;width:2px;height:2px;background:rgba(255,255,255,.15);border-radius:50%;animation:starTwinkle 4s ease-in-out infinite}
@keyframes starTwinkle{0%,100%{opacity:.1;transform:scale(.8)}50%{opacity:.5;transform:scale(1.2)}}
/* Content */
.r-hero-inner{position:relative;z-index:2;text-align:center;max-width:600px}
.r-spread-tag{display:inline-flex;align-items:center;gap:8px;padding:10px 26px;border-radius:100px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.7);font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:28px;animation:fu .7s var(--ease) both;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 4px 20px rgba(0,0,0,.12),inset 0 1px 0 rgba(255,255,255,.06)}
.r-spread-tag::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--gold);animation:pulse 2.5s ease infinite}
.r-hero h2{font-size:clamp(2.2rem,6vw,3.8rem);font-weight:800;line-height:.95;letter-spacing:-.05em;color:#fff;margin-bottom:16px;animation:fu .7s .1s var(--ease) both}
.r-hero h2 em{font-style:normal;display:block;background:linear-gradient(135deg,var(--gold),var(--ember));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.r-hero-p{font-size:clamp(.92rem,1.6vw,1.05rem);color:rgba(255,255,255,.4);max-width:440px;margin:0 auto 28px;line-height:1.75;animation:fu .7s .2s var(--ease) both}
.tap-hint{display:inline-flex;align-items:center;gap:8px;padding:11px 28px;border-radius:100px;background:rgba(232,119,26,.08);border:1px solid rgba(232,119,26,.12);color:var(--gold);font-size:.78rem;font-weight:700;animation:fu .7s .3s var(--ease) both,hintPulse 2.5s 1s ease-in-out infinite;position:relative;z-index:2}
@keyframes hintPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.97)}}
.r-back{position:absolute;top:24px;left:24px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.06);color:rgba(255,255,255,.45);font-size:.76rem;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .25s;padding:9px 20px;border-radius:100px;z-index:3}
.r-back:hover{background:rgba(255,255,255,.1);color:#fff}

/* Card progress tracker */
.card-progress{display:flex;justify-content:center;gap:8px;padding:20px 24px 0;max-width:400px;margin:0 auto}
.cp-dot{width:100%;height:3px;border-radius:3px;background:var(--border);transition:all .5s var(--ease)}
.cp-dot.done{background:linear-gradient(90deg,var(--gold),var(--ember))}

/* Card spread */
.card-area{display:flex;justify-content:center;gap:clamp(16px,3.5vw,32px);padding:32px 24px 44px;flex-wrap:wrap;max-width:960px;margin:0 auto}
.card-slot{text-align:center;transition:transform .4s var(--ease)}
.card-slot .pos-lbl{font-size:.66rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;transition:color .4s}
.card-slot.revealed-slot .pos-lbl{color:var(--gold)}
.cc{width:clamp(105px,20vw,140px);aspect-ratio:2/3;perspective:900px;cursor:pointer;position:relative;transition:transform .3s var(--ease)}
.cc.revealed{cursor:pointer}
.cc.selected{transform:translateY(-6px)}
.selected-slot .pos-lbl{color:var(--gold)!important}
.cc.selected .cc-face{box-shadow:0 12px 40px rgba(232,119,26,.2)!important}
.cc-inner{width:100%;height:100%;position:relative;transition:transform .9s var(--ease);transform-style:preserve-3d}
.cc-inner.flipped{transform:rotateY(180deg)}
.cc:not(.revealed){animation:cardGlow 2.5s ease-in-out infinite}
@keyframes cardGlow{0%,100%{filter:drop-shadow(0 4px 16px rgba(232,119,26,.08))}50%{filter:drop-shadow(0 6px 32px rgba(232,119,26,.22))}}
.cc-face{position:absolute;inset:0;border-radius:13px;backface-visibility:hidden;overflow:hidden;box-shadow:0 8px 36px rgba(14,27,61,.12)}
.cc-back{background:linear-gradient(155deg,#1a2a52 0%,#12203e 50%,#0e1830 100%);display:flex;align-items:center;justify-content:center;border:1.5px solid rgba(232,119,26,.12)}
.cc-back-i{width:76%;height:76%;border:1px solid rgba(232,119,26,.08);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:rgba(232,119,26,.15);background:radial-gradient(circle at 50% 50%,rgba(232,119,26,.03),transparent 70%)}
.cc-front{transform:rotateY(180deg);background:#fff;overflow:hidden;padding:4px}
.cc-front img{width:100%;height:100%;object-fit:cover;border-radius:10px}
.cc-front .cc-sym{font-size:2.6rem;color:var(--navy)}
.card-name{font-size:.76rem;font-weight:700;color:var(--navy);margin-top:12px;opacity:0;transition:all .5s var(--ease);min-height:20px;transform:translateY(4px)}
.card-name.show{opacity:1;transform:translateY(0)}

/* Shuffle */
@keyframes cardBob{0%{transform:translateY(0) rotate(0)}25%{transform:translateY(-10px) rotate(-1.5deg)}50%{transform:translateY(-4px) rotate(1deg)}75%{transform:translateY(-12px) rotate(-.5deg)}100%{transform:translateY(0) rotate(0)}}
.shuffling .cc-inner{animation:cardBob 1.3s ease-in-out infinite}
.shuffling .cc::after{opacity:0!important}
.shuffling .cc{animation:none!important}
.shuffling .card-slot:nth-child(2) .cc-inner{animation-delay:.18s}
.shuffling .card-slot:nth-child(3) .cc-inner{animation-delay:.32s}
.shuffling .card-slot:nth-child(4) .cc-inner{animation-delay:.12s}
.shuffling .card-slot:nth-child(5) .cc-inner{animation-delay:.26s}

/* Reading content */
.r-content{max-width:760px;margin:0 auto;padding:0 24px 20px}

/* ═══ CARD TAB BAR ═══ */
.card-tabs{display:flex;gap:8px;justify-content:center;padding:12px 24px 0;flex-wrap:wrap;max-width:760px;margin:0 auto}
.card-tab{display:flex;align-items:center;gap:10px;padding:12px 22px;border-radius:100px;background:var(--surface);border:1.5px solid var(--border);cursor:pointer;transition:all .35s var(--ease);opacity:0;transform:translateY(8px);font-family:var(--font)}
.card-tab.show{opacity:1;transform:translateY(0)}
.card-tab:hover{border-color:var(--gold-border);background:var(--gold-glow)}
.card-tab.active{border-color:var(--gold);background:var(--gold-glow);box-shadow:0 2px 16px rgba(232,119,26,.1)}
.ct-num{width:24px;height:24px;border-radius:8px;background:var(--navy);color:rgba(255,255,255,.5);font-size:.62rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s}
.card-tab.active .ct-num{background:var(--gold);color:#fff}
.ct-pos{font-size:.58rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text3);transition:color .3s}
.card-tab.active .ct-pos{color:var(--gold)}
.ct-name{font-size:.84rem;font-weight:700;color:var(--navy);letter-spacing:-.01em;transition:color .3s}
.card-tab.active .ct-name{color:var(--navy)}
.ct-info{display:flex;flex-direction:column;gap:1px;text-align:left}

/* ═══ READING PANEL ═══ */
.rd-panel{display:none;padding:40px 0 20px;animation:rdFadeIn .5s var(--ease) both}
.rd-panel.active{display:block}
@keyframes rdFadeIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* Card header */
.rd-head{text-align:center;margin-bottom:32px;position:relative}
.rd-head::after{content:'';display:block;width:40px;height:2px;background:linear-gradient(90deg,var(--gold),var(--ember));margin:20px auto 0;border-radius:2px}
.rd-card-name{font-size:clamp(1.6rem,4vw,2.2rem);font-weight:800;color:var(--navy);letter-spacing:-.04em;line-height:1.05;margin-bottom:6px}
.rd-card-sub{font-size:.8rem;color:var(--text3);font-weight:500}
.rd-kw{display:flex;gap:7px;flex-wrap:wrap;justify-content:center;margin-top:16px}
.rd-kw .kw{padding:5px 16px;border-radius:100px;background:var(--gold-glow);color:var(--gold);font-size:.64rem;font-weight:600;border:1px solid var(--gold-border)}

/* Reading text */
.rd-text{margin-top:32px;font-size:clamp(.92rem,1.4vw,1rem);color:var(--text2);line-height:2;letter-spacing:.005em}

/* Context tabs (general/love/career/health) */
.ctx-section{margin-top:20px}
.ctx-tabs{display:flex;gap:6px;justify-content:center;margin-bottom:24px;flex-wrap:wrap}
.ctx-tab{padding:9px 22px;border-radius:100px;font-size:.78rem;font-weight:700;background:var(--surface);color:var(--text3);border:1.5px solid var(--border);cursor:pointer;font-family:var(--font);transition:all .25s var(--ease)}
.ctx-tab:hover{border-color:var(--gold-border);color:var(--gold)}
.ctx-tab.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.ctx-panel{display:none;animation:ctxFade .4s var(--ease) both}
.ctx-panel.active{display:block}
@keyframes ctxFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.ctx-panel .ctx-text{font-size:.9rem;color:var(--text2);line-height:1.9}
.ctx-panel .ctx-text p{margin-bottom:14px}
.ctx-panel .ctx-text strong{color:var(--navy);font-weight:700}
.ctx-panel .ctx-text em{color:var(--gold);font-style:italic}
.rd-text p{margin-bottom:20px;max-width:640px}
.rd-text p:first-child{font-size:clamp(.95rem,1.5vw,1.04rem);color:var(--text);line-height:1.95}
.rd-text p:first-child::first-letter{font-size:2.2em;font-weight:800;color:var(--navy);float:left;line-height:.8;padding-right:8px;padding-top:5px}
.rd-text strong{color:var(--navy);font-weight:700}
.rd-text em{color:var(--gold);font-style:italic}
.rd-text p:last-child{position:relative;margin-top:24px;padding:22px 26px;border-radius:var(--r2);background:linear-gradient(135deg,rgba(14,27,61,.03),rgba(14,27,61,.01));border-left:3px solid var(--gold);max-width:640px}
.rd-text p:last-child em{font-size:.92rem;line-height:1.85;color:var(--gold)}

/* All cards revealed */
.all-revealed-msg{text-align:center;padding:36px 24px 8px;opacity:0;transform:translateY(16px);transition:all .7s var(--ease)}
.all-revealed-msg.vis{opacity:1;transform:translateY(0)}
.all-revealed-msg .arm-line{font-size:.78rem;color:var(--text3);margin-bottom:4px}
.all-revealed-msg .arm-title{font-size:1.3rem;font-weight:800;color:var(--navy);letter-spacing:-.03em}

@media(max-width:600px){
  .card-tabs{gap:6px;padding:8px 16px 0}
  .card-tab{padding:10px 16px;gap:8px}
  .ct-name{font-size:.78rem}
  .rd-head{margin-bottom:24px}
  .rd-text p:first-child::first-letter{font-size:1.7em;padding-right:5px;padding-top:4px}
  .rd-text p:last-child{padding:18px 20px}
  .rd-head{margin-bottom:24px}
}

/* ═══ Synthesis upsell - premium ═══ */
.syn-wrap{max-width:740px;margin:24px auto 20px;padding:0 24px;opacity:0;transform:translateY(24px);transition:all .8s var(--ease)}
.syn-wrap.vis{opacity:1;transform:translateY(0)}
.syn-box{border-radius:var(--r3);padding:48px 44px;text-align:center;position:relative;background:linear-gradient(150deg,#050b1e 0%,var(--navy) 25%,var(--navy-mid) 55%,var(--navy-light) 100%);border:1px solid rgba(255,255,255,.06);box-shadow:0 24px 80px rgba(14,27,61,.25)}
.syn-box::before{content:'';position:absolute;top:-35%;right:-12%;width:450px;height:450px;background:radial-gradient(circle,rgba(232,119,26,.08),transparent 50%);border-radius:50%;pointer-events:none;animation:drift 16s ease-in-out infinite}
.syn-box::after{content:'';position:absolute;bottom:-25%;left:-8%;width:350px;height:350px;background:radial-gradient(circle,rgba(107,91,167,.05),transparent 50%);border-radius:50%;pointer-events:none;animation:drift 20s ease-in-out infinite reverse}
.syn-tag{display:inline-flex;align-items:center;gap:6px;padding:9px 24px;border-radius:100px;background:rgba(255,255,255,.04);color:rgba(255,255,255,.7);font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:20px;border:1px solid rgba(255,255,255,.12);position:relative;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 4px 20px rgba(0,0,0,.12),inset 0 1px 0 rgba(255,255,255,.06)}
.syn-tag::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--gold);animation:tagPulse 2s ease infinite}
@keyframes tagPulse{0%,100%{opacity:1}50%{opacity:.3}}
.syn-box h3{font-size:clamp(1.3rem,3vw,1.9rem);font-weight:800;color:#fff;letter-spacing:-.03em;line-height:1.15;margin-bottom:14px;position:relative}
.syn-box h3 em{font-style:normal;background:linear-gradient(135deg,var(--gold),var(--ember));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.syn-desc{color:rgba(255,255,255,.4);font-size:.86rem;line-height:1.7;max-width:500px;margin:0 auto 28px;position:relative}
.syn-features{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:28px;position:relative}
.syn-feat{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:100px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);font-size:.7rem;color:rgba(255,255,255,.5);font-weight:500}
.syn-feat-icon{color:var(--gold);font-size:.8rem}
.syn-pr{display:flex;justify-content:center;gap:16px;margin-bottom:28px;flex-wrap:wrap;position:relative}
.syn-pr-i{padding:14px 28px;border-radius:var(--r2);background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.08);text-align:center;transition:all .3s}
.syn-pr-i:hover{border-color:rgba(232,119,26,.2);background:rgba(232,119,26,.04)}
.syn-pr-t{font-size:.66rem;color:rgba(255,255,255,.3);font-weight:600;margin-bottom:4px}
.syn-pr-v{font-size:1.4rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.syn-form{max-width:500px;margin:0 auto;position:relative}
.syn-form textarea,.syn-form input[type=email]{width:100%;padding:15px 18px;border-radius:var(--r2);background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.08);color:#fff;font-family:var(--font);font-size:.86rem;outline:none;transition:all .3s;margin-bottom:12px}
.syn-form textarea{resize:vertical;min-height:110px;line-height:1.65}
.syn-form textarea::placeholder,.syn-form input::placeholder{color:rgba(255,255,255,.2)}
.syn-form textarea:focus,.syn-form input:focus{border-color:rgba(232,119,26,.4);box-shadow:0 0 0 4px rgba(232,119,26,.08);background:rgba(255,255,255,.08)}
.syn-hint{font-size:.66rem;color:rgba(255,255,255,.2);margin-bottom:22px;text-align:left}
.btn-syn{width:100%;padding:18px;border-radius:14px;font-size:.95rem;font-weight:700;font-family:var(--font);
background:linear-gradient(135deg,#f59130,var(--gold),var(--ember));color:#fff;border:none;cursor:pointer;
transition:all .4s var(--ease);box-shadow:0 4px 28px rgba(232,119,26,.3),inset 0 1px 0 rgba(255,255,255,.12);
letter-spacing:.01em;position:relative;overflow:hidden;text-shadow:0 1px 2px rgba(0,0,0,.15)}
.btn-syn::before{content:'';position:absolute;top:-50%;left:-60%;width:40%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transform:rotate(25deg);transition:left .6s var(--ease)}
.btn-syn:hover::before{left:120%}
.btn-syn:hover{transform:translateY(-2px);box-shadow:0 8px 40px rgba(232,119,26,.4),inset 0 1px 0 rgba(255,255,255,.15)}
.btn-syn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* Synthesis loading state */
.syn-loading{text-align:center;padding:40px 0}
.syn-loading .syn-spinner{width:48px;height:48px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--gold);border-radius:50%;animation:synSpin 1s linear infinite;margin:0 auto 20px}
@keyframes synSpin{to{transform:rotate(360deg)}}
.syn-loading .syn-load-msg{color:rgba(255,255,255,.5);font-size:.82rem;font-weight:500;animation:synPulse 2s ease-in-out infinite}
@keyframes synPulse{0%,100%{opacity:1}50%{opacity:.4}}
.syn-loading .syn-load-dots{display:flex;gap:6px;justify-content:center;margin-top:16px}
.syn-loading .syn-load-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);opacity:.2;animation:synDotPulse 1.5s ease-in-out infinite}
.syn-loading .syn-load-dot:nth-child(2){animation-delay:.3s}
.syn-loading .syn-load-dot:nth-child(3){animation-delay:.6s}
@keyframes synDotPulse{0%,100%{opacity:.2;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}

/* Synthesis result display */
.syn-result{max-width:740px;margin:0 auto 40px;padding:0 24px;opacity:0;transform:translateY(20px);transition:all .8s var(--ease)}
.syn-result.vis{opacity:1;transform:translateY(0)}
.syn-result-box{border-radius:var(--r3);overflow:hidden;border:1px solid var(--border);box-shadow:0 8px 48px rgba(14,27,61,.06)}
.syn-result-hdr{padding:36px 36px 28px;background:linear-gradient(150deg,var(--navy) 0%,var(--navy-mid) 60%,var(--navy-light) 100%);text-align:center;position:relative;overflow:hidden}
.syn-result-hdr::before{content:'';position:absolute;top:-30%;right:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(232,119,26,.08),transparent 50%);border-radius:50%;pointer-events:none}
.syn-result-badge{display:inline-flex;align-items:center;gap:6px;padding:8px 22px;border-radius:100px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.7);font-size:.6rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px;position:relative;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 4px 20px rgba(0,0,0,.12),inset 0 1px 0 rgba(255,255,255,.06)}
.syn-result-badge::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--gold)}
.syn-result-title{font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:800;color:#fff;letter-spacing:-.03em;margin-bottom:6px;position:relative}
.syn-result-meta{font-size:.72rem;color:rgba(255,255,255,.35);position:relative}
.syn-result-body{padding:36px;background:var(--surface)}
.syn-result-body .interp{font-size:.92rem;color:var(--text2);line-height:1.9}
.syn-result-body .interp p{margin-bottom:16px}
.syn-result-body .interp p:last-child{margin-bottom:0}
.syn-result-body .interp strong{color:var(--navy);font-weight:700}
.syn-result-body .interp em{color:var(--gold);font-style:italic}
.syn-result-body .interp p:last-child em{display:block;margin-top:16px;padding:16px 20px;border-radius:var(--r2);background:linear-gradient(135deg,rgba(232,119,26,.04),rgba(232,90,48,.02));border-left:3px solid var(--gold);font-size:.88rem;line-height:1.75}
.syn-result-footer{padding:20px 36px;background:var(--bg);border-top:1px solid var(--border);display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.syn-result-footer button{padding:10px 24px;border-radius:100px;font-size:.78rem;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .25s}
.syn-save-btn{background:linear-gradient(135deg,var(--gold),var(--ember));color:#fff;border:none;box-shadow:0 2px 12px rgba(232,119,26,.2)}
.syn-save-btn:hover{transform:translateY(-2px)}
.syn-new-btn{background:var(--surface);color:var(--text2);border:1.5px solid var(--border)}
.syn-new-btn:hover{border-color:var(--gold-border);color:var(--gold)}

.new-row{text-align:center;padding:20px 24px 80px}
.btn-new{padding:14px 36px;border-radius:100px;font-size:.82rem;font-weight:600;background:var(--surface);color:var(--text2);border:1.5px solid var(--border);cursor:pointer;font-family:var(--font);transition:all .25s var(--ease)}
.btn-new:hover{border-color:var(--gold-border);color:var(--gold)}

@media(max-width:600px){
  .cc{width:88px}
  .syn-box{padding:32px 22px}
  .card-area{gap:10px;padding:28px 16px 36px}
  .r-hero{min-height:42vh;padding:88px 20px 80px}
  .r-hero h2{font-size:clamp(1.8rem,8vw,2.6rem)}
}
