:root{
  --ground:#f8f1ef;
  --ground-2:#f0e5e3;
  --ground-3:#e8d9d7;
  --hairline:rgba(58,46,53,.13);
  --ink:#3c2f36;
  --ink-dim:#8a747b;
  --ink-faint:#b7a5aa;
  --rose:#b9778a;
  --rose-deep:#96566a;
  --sage:#899a7d;
  --sage-deep:#62735a;
  --gold:#bd9450;
  --shadow-veil:rgba(58,46,53,.10);
  --card-1:#fdf8f3;
  --card-2:#f3e6de;
  --radius:20px;
  --radius-sm:12px;
}
:root[data-theme="dark"]{
  --ground:#241d25;
  --ground-2:#2e2530;
  --ground-3:#392e3b;
  --hairline:rgba(247,241,239,.10);
  --ink:#f3e9e6;
  --ink-dim:#bfa6ac;
  --ink-faint:#8a747b;
  --rose:#d99cae;
  --rose-deep:#b9778a;
  --sage:#a3b596;
  --sage-deep:#899a7d;
  --gold:#d3ac6c;
  --shadow-veil:rgba(0,0,0,.30);
  --card-1:#352832;
  --card-2:#2b2029;
}
@media (prefers-color-scheme:dark){
  :root:not([data-theme="light"]){
    --ground:#241d25;
    --ground-2:#2e2530;
    --ground-3:#392e3b;
    --hairline:rgba(247,241,239,.10);
    --ink:#f3e9e6;
    --ink-dim:#bfa6ac;
    --ink-faint:#8a747b;
    --rose:#d99cae;
    --rose-deep:#b9778a;
    --sage:#a3b596;
    --sage-deep:#899a7d;
    --gold:#d3ac6c;
    --shadow-veil:rgba(0,0,0,.30);
    --card-1:#352832;
    --card-2:#2b2029;
  }
}

*{box-sizing:border-box;}
body{
  margin:0;background:var(--ground);color:var(--ink);
  font-family:"Jost Var","Jost",ui-sans-serif,system-ui,sans-serif;font-weight:300;
  line-height:1.6;overflow-x:hidden;transition:background .4s ease,color .4s ease;
  font-size:16px;
}
::selection{background:var(--rose);color:var(--ground);}
h1,h2,h3{font-family:"Cormorant Var","Cormorant Garamond",serif;font-weight:500;margin:0;text-wrap:balance;}
p{margin:0;}
.tabular{font-variant-numeric:tabular-nums;}
.wrap{max-width:1120px;margin:0 auto;padding:0 28px;position:relative;z-index:1;}
.motes{position:fixed;inset:0;z-index:0;pointer-events:none;}

/* ---------- NAV + TABS ---------- */
.nav{display:flex;align-items:center;justify-content:space-between;padding:26px 0 20px;}
.brand{display:flex;align-items:center;gap:11px;font-family:"Cormorant Var",serif;font-weight:600;font-size:1.35rem;font-style:italic;color:var(--ink);}
.brand-mark{width:24px;height:24px;border-radius:50%;background:radial-gradient(circle at 35% 30%, var(--gold), var(--rose) 70%);box-shadow:0 0 16px color-mix(in srgb, var(--rose) 35%, transparent);}
.tabs{display:flex;gap:6px;background:var(--ground-2);padding:6px;border-radius:999px;border:1px solid var(--hairline);flex-wrap:wrap;}
.tab-btn{
  font-family:"Jost Var",sans-serif;font-weight:500;font-size:.82rem;color:var(--ink-dim);
  background:none;border:none;padding:10px 18px;border-radius:999px;cursor:pointer;
  transition:background .2s ease,color .2s ease;letter-spacing:.01em;
}
.tab-btn:hover{color:var(--ink);}
.tab-btn.active{background:var(--rose);color:#fff8f5;}
.tab-btn:focus-visible{outline:2px solid var(--sage-deep);outline-offset:2px;}
.tab-panel{display:none;animation:fadein .5s ease;}
.tab-panel.active{display:block;}
@keyframes fadein{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}

/* ---------- HERO ---------- */
.hero{padding:56px 0 60px;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;}
.eyebrow{font-family:"Jost Var",sans-serif;font-weight:500;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--rose-deep);display:flex;align-items:center;gap:10px;margin-bottom:20px;}
.eyebrow::before{content:"";width:20px;height:1px;background:var(--rose-deep);}
h1.hero-title{font-size:clamp(2.1rem,4vw,3.1rem);line-height:1.1;letter-spacing:.002em;margin-bottom:22px;}
h1.hero-title em{font-style:italic;font-weight:500;color:var(--rose-deep);}
.hero-sub{max-width:46ch;color:var(--ink-dim);font-size:1.05rem;margin-bottom:32px;font-weight:300;}
.hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;}
.btn-primary{font-family:"Jost Var",sans-serif;font-weight:600;font-size:.86rem;padding:15px 28px;border-radius:999px;background:var(--rose);color:#fff8f5;border:1px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;letter-spacing:.01em;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px color-mix(in srgb, var(--rose) 40%, transparent);}
.btn-primary:focus-visible{outline:2px solid var(--sage-deep);outline-offset:3px;}
.btn-ghost{font-family:"Jost Var",sans-serif;font-weight:500;font-size:.85rem;color:var(--ink-dim);display:flex;align-items:center;gap:8px;cursor:pointer;background:none;border:none;padding:8px;}
.btn-ghost:hover{color:var(--ink);}

/* ---------- FLIP CARD ---------- */
.card-stage{display:flex;justify-content:center;perspective:1400px;}
.flipcard{width:240px;height:378px;position:relative;cursor:pointer;transform-style:preserve-3d;transition:transform .7s cubic-bezier(.2,.9,.25,1.05);}
.flipcard.is-flipped{transform:rotateY(180deg);}
.flipcard:hover{transform:rotateY(6deg) translateY(-4px);}
.flipcard.is-flipped:hover{transform:rotateY(186deg) translateY(-4px);}
.face{position:absolute;inset:0;border-radius:var(--radius);backface-visibility:hidden;display:flex;flex-direction:column;box-shadow:0 22px 50px -18px var(--shadow-veil),0 0 0 1px var(--hairline);}
.face-front{background:linear-gradient(160deg,var(--card-1),var(--card-2));align-items:stretch;justify-content:flex-end;padding:0;overflow:hidden;}
.face-front .art{position:absolute;inset:0;background-size:cover;background-position:center top;}
.face-front .scrim{position:relative;z-index:1;width:100%;padding:34px 16px 16px;display:flex;flex-direction:column;gap:5px;background:linear-gradient(180deg, rgba(20,10,15,0) 0%, rgba(20,10,15,.78) 78%, rgba(20,10,15,.92) 100%);}
.roman{font-family:"Jost Var",sans-serif;font-weight:500;font-size:.68rem;letter-spacing:.14em;color:var(--gold);}
.card-name-front{font-family:"Cormorant Var",serif;font-weight:500;font-style:italic;color:#fbf3ee;font-size:1.15rem;text-align:left;}
.face-back{background:linear-gradient(160deg,var(--ground-3),var(--ground-2));transform:rotateY(180deg);padding:24px 20px;justify-content:flex-start;}
.face-back .tag{font-family:"Jost Var",sans-serif;font-weight:500;font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sage-deep);}
.face-back h3{font-family:"Cormorant Var",serif;font-weight:600;font-size:1.5rem;margin:8px 0 2px;}
.face-back .archetype{color:var(--rose-deep);font-size:.85rem;font-style:italic;font-family:"Cormorant Var",serif;margin-bottom:12px;}
.face-back p{font-size:.83rem;color:var(--ink-dim);margin-bottom:12px;}
.face-back .stat-row{display:flex;justify-content:space-between;font-size:.68rem;color:var(--ink-faint);border-top:1px solid var(--hairline);padding-top:10px;margin-top:auto;font-family:"Jost Var",sans-serif;}
.hint{text-align:center;font-size:.75rem;color:var(--ink-faint);margin-top:16px;font-family:"Jost Var",sans-serif;letter-spacing:.02em;}

/* ---------- HUD ---------- */
.hud{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline);border-radius:18px;overflow:hidden;margin:8px 0 70px;}
.hud-cell{background:var(--ground-2);padding:22px 24px;}
.hud-label{font-family:"Jost Var",sans-serif;font-weight:500;font-size:.66rem;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:10px;}
.hud-value{font-family:"Cormorant Var",serif;font-weight:600;font-size:1.7rem;}
.hud-value.accent{color:var(--rose-deep);}
.hud-bar{height:5px;border-radius:3px;background:var(--ground-3);margin-top:12px;overflow:hidden;}
.hud-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--rose));border-radius:3px;width:64%;}
.streak-dots{display:flex;gap:5px;margin-top:12px;}
.streak-dots span{width:9px;height:9px;border-radius:50%;background:var(--ground-3);}
.streak-dots span.lit{background:var(--gold);}

/* ---------- SECTION HEAD ---------- */
.section-head{margin:0 0 38px;max-width:62ch;}
.section-head h2{font-size:clamp(1.6rem,2.4vw,2.15rem);margin-bottom:12px;}
.section-head p{color:var(--ink-dim);font-size:.98rem;}

/* ---------- FEATURES ---------- */
.features{padding:10px 0 80px;}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline);border-radius:18px;overflow:hidden;}
.feature{background:var(--ground-2);padding:28px 26px;transition:background .2s ease;}
.feature:hover{background:var(--ground-3);}
.feature-icon{width:34px;height:34px;margin-bottom:16px;color:var(--sage-deep);}
.feature h3{font-size:1.15rem;margin-bottom:9px;}
.feature p{font-size:.85rem;color:var(--ink-dim);}

.cta{padding:60px 0 90px;text-align:center;}
.cta h2{font-size:clamp(1.6rem,3vw,2.3rem);margin-bottom:16px;}
.cta p{color:var(--ink-dim);max-width:52ch;margin:0 auto 28px;}

footer{border-top:1px solid var(--hairline);padding:24px 0;font-size:.76rem;color:var(--ink-faint);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-family:"Jost Var",sans-serif;}

/* ---------- ARCANA GRID ---------- */
.library-section-title{font-family:"Cormorant Var",serif;font-weight:600;font-style:italic;font-size:1.3rem;margin:36px 0 16px;color:var(--ink);}
.library-section-title:first-of-type{margin-top:0;}
.arcana-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:22px;padding-bottom:20px;}
.mini-flip{width:100%;height:290px;perspective:1200px;cursor:pointer;}
.mini-flip .flipcard{width:100%;height:100%;}
.mini-flip .card-name-front{font-size:.98rem;}
.mini-flip .face-front .scrim{padding:26px 13px 13px;}
.mini-flip .face-back h3{font-size:1.2rem;}
.mini-flip .face-back p{font-size:.76rem;}

/* ---------- SUITS ---------- */
.suits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-bottom:60px;}
.suit-card{background:var(--ground-2);border:1px solid var(--hairline);border-radius:var(--radius);padding:30px;}
.suit-head{display:flex;align-items:center;gap:16px;margin-bottom:16px;}
.suit-icon{width:42px;height:42px;color:var(--rose-deep);flex:none;}
.suit-head h3{font-size:1.5rem;}
.suit-meta{font-family:"Jost Var",sans-serif;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--sage-deep);}
.suit-card p.suit-text{color:var(--ink-dim);font-size:.9rem;margin:12px 0 18px;}
.court-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;border-top:1px solid var(--hairline);padding-top:16px;}
.court-item b{font-family:"Cormorant Var",serif;font-style:italic;font-weight:500;color:var(--ink);font-size:.92rem;display:block;margin-bottom:3px;}
.court-item span{font-size:.78rem;color:var(--ink-dim);}

/* ---------- NUMBERS ---------- */
.numbers-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;}
.number-card{background:var(--ground-2);border:1px solid var(--hairline);border-radius:var(--radius-sm);padding:22px 18px;text-align:center;transition:transform .2s ease,background .2s ease;}
.number-card:hover{transform:translateY(-5px);background:var(--ground-3);}
.number-num{font-family:"Cormorant Var",serif;font-weight:600;font-size:2.4rem;color:var(--gold);line-height:1;}
.number-title{font-family:"Jost Var",sans-serif;font-weight:500;font-size:.82rem;margin:10px 0 8px;color:var(--ink);}
.number-text{font-size:.78rem;color:var(--ink-dim);}

/* ---------- PATH ---------- */
.path-scroll{overflow-x:auto;padding:30px 4px 10px;margin:0 -4px;}
.path{position:relative;display:flex;align-items:flex-end;gap:0;min-width:920px;height:250px;padding:0 20px;}
.path-line{position:absolute;left:40px;right:40px;top:132px;height:2px;background:repeating-linear-gradient(90deg,var(--hairline) 0 8px,transparent 8px 14px);z-index:0;}
.node-wrap{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1;}
.node{width:56px;height:56px;border-radius:50%;border:1px solid var(--hairline);background:var(--ground-2);display:flex;align-items:center;justify-content:center;font-family:"Jost Var",sans-serif;font-weight:500;font-size:.78rem;color:var(--ink-faint);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;position:relative;top:calc(var(--lift,0px));}
.node:hover{transform:translateY(-4px);}
.node-wrap.done .node{background:var(--sage);border-color:var(--sage-deep);color:#fff;}
.node-wrap.current .node{background:var(--rose);border-color:var(--rose-deep);color:#fff8f5;box-shadow:0 0 0 5px color-mix(in srgb, var(--rose) 22%, transparent);animation:pulse 2.4s ease-in-out infinite;}
.node-wrap.locked .node{opacity:.45;}
@keyframes pulse{0%,100%{box-shadow:0 0 0 5px color-mix(in srgb, var(--rose) 22%, transparent);}50%{box-shadow:0 0 0 9px color-mix(in srgb, var(--rose) 8%, transparent);}}
.node-label{font-size:.72rem;color:var(--ink-dim);margin-top:10px;text-align:center;max-width:92px;}
.node-arcana{font-family:"Cormorant Var",serif;font-style:italic;font-size:.82rem;color:var(--ink-faint);margin-top:2px;}
.node-pop{position:absolute;bottom:100%;margin-bottom:14px;width:200px;background:var(--ground-3);border:1px solid var(--hairline);border-radius:10px;padding:14px 16px;font-size:.78rem;color:var(--ink-dim);opacity:0;pointer-events:none;transform:translateY(6px);transition:opacity .18s ease,transform .18s ease;box-shadow:0 14px 30px var(--shadow-veil);left:50%;translate:-50% 0;}
.node-wrap:hover .node-pop,.node-wrap.pop-open .node-pop{opacity:1;transform:translateY(0);pointer-events:auto;}
.node{outline-offset:2px;}
.node:focus-visible{outline:2px solid var(--sage-deep);}
.node-pop b{color:var(--ink);display:block;margin-bottom:4px;font-family:"Cormorant Var",serif;font-weight:600;}

/* ---------- DRAW WIDGET ---------- */
.draw-section{padding:10px 0 80px;display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:center;}
.draw-widget{background:var(--ground-2);border:1px solid var(--hairline);border-radius:18px;padding:30px;}
.draw-widget .head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;}
.draw-widget .head span{font-family:"Jost Var",sans-serif;font-weight:500;font-size:.68rem;letter-spacing:.06em;color:var(--ink-faint);text-transform:uppercase;}
.mini-cards{display:flex;gap:12px;justify-content:center;padding:10px 0 22px;}
.mini-card{width:62px;height:94px;border-radius:8px;background:linear-gradient(160deg,var(--card-1),var(--card-2));border:1px solid color-mix(in srgb, var(--gold) 50%, transparent);cursor:pointer;transition:transform .25s ease;}
.mini-card:hover{transform:translateY(-8px) rotate(var(--r,0deg));}
.mini-card.chosen{outline:2px solid var(--sage-deep);outline-offset:3px;}
.draw-result{font-size:.86rem;color:var(--ink-dim);text-align:center;min-height:40px;}
.draw-result b{color:var(--rose-deep);font-family:"Cormorant Var",serif;font-style:italic;font-weight:500;}

@media (max-width:860px){
  .hero{grid-template-columns:1fr;}
  .card-stage{order:-1;}
  .hud{grid-template-columns:repeat(2,1fr);}
  .feature-grid,.suits-grid{grid-template-columns:1fr;}
  .draw-section{grid-template-columns:1fr;}
  .numbers-grid{grid-template-columns:repeat(2,1fr);}
  .nav{flex-direction:column;align-items:stretch;gap:16px;}
  .tab-btn{padding:9px 13px;font-size:.76rem;}
}
@media (max-width:420px){
  .numbers-grid{grid-template-columns:repeat(2,1fr);}
  .flipcard{width:210px;height:330px;}
  .mini-flip{height:260px;}
}
@media (prefers-reduced-motion:reduce){*{animation-duration:.001s !important;transition-duration:.001s !important;}}
