/* Tao Arcana — 门户 / Two Worlds : portal entry + warm parchment content world */
:root{
  --bone:#0c0a12; --bone2:#14111c; --paper:#17131f; --paper2:#1d1828;
  --ink:#E9DCBF; --ink2:#F3E8C9; --soft:#b6a883; --faint:#877c64;
  --jade:#7ec2ab; --jade2:#0e2a24; --jade-soft:#6f9488;
  --cin:#d6553f; --cin-deep:#E0613F; --gold:#C9A24E; --gold-bright:#E8C877;
  --line:rgba(201,162,78,.2); --line-soft:rgba(201,162,78,.1);
  --disp:"Cormorant Garamond",Georgia,serif; --label:"Cinzel",serif;
  --body:"EB Garamond",Georgia,serif; --cjk:"Noto Serif SC",serif; --mono:"Space Mono",ui-monospace,monospace; --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{background:var(--bone);color:var(--ink);font-family:var(--body);font-size:18.5px;line-height:1.66;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
  background-attachment:fixed;
  background-image:radial-gradient(120% 78% at 50% -8%, rgba(201,162,78,.07), transparent 52%),
                   radial-gradient(95% 70% at 88% 108%, rgba(78,62,140,.16), transparent 60%),
                   radial-gradient(80% 60% at 8% 40%, rgba(126,62,42,.08), transparent 58%);}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 44px;position:relative}
.serif{font-family:var(--disp)} .cjk{font-family:var(--cjk)}
a{color:var(--gold-bright)}
img{max-width:100%;height:auto;display:block}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip-link{position:absolute;left:-999px;top:0;background:var(--ink);color:var(--bone);padding:8px 14px;z-index:50}
.skip-link:focus{left:8px;top:8px}
.eyebrow{font-family:var(--label);font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:var(--cin);
  display:flex;gap:14px;align-items:center;justify-content:center}
.eyebrow .dot{width:4px;height:4px;background:var(--gold);transform:rotate(45deg);flex:none}

/* ---------- HERO (bright editorial — the two traditions, reborn light) ---------- */
.hero{position:relative;z-index:2;overflow:hidden;
  background:radial-gradient(56% 62% at 86% 26%, rgba(22,67,58,.07), transparent 62%),
             radial-gradient(52% 56% at 10% 84%, rgba(96,72,150,.06), transparent 62%)}
.hero-wrap{display:grid;grid-template-columns:1.04fr .96fr;gap:54px;align-items:center;padding-top:74px;padding-bottom:82px}
.hero-copy .eyebrow{justify-content:flex-start}
.hero h1{font-family:var(--disp);font-weight:500;font-size:66px;line-height:1.03;letter-spacing:-.012em;color:var(--ink);margin:18px 0 20px}
.hero h1 em{font-style:italic;color:var(--cin-deep)}
.hero .lede{font-size:20px;line-height:1.64;color:var(--soft);max-width:31em}
.hero .lede b{color:var(--ink);font-weight:500}
.hero-cta{margin-top:30px;display:flex;flex-direction:column;gap:15px;align-items:flex-start}
.hero-cta .btn-fill{padding:15px 30px;font-size:12px}
.hero-or{font-family:var(--disp);font-style:italic;font-size:17px;color:var(--faint)}
.hero-or a{color:var(--gold-bright)}
/* the two panels meeting at the seal — left Tarot (violet), right I Ching (jade) */
.hero-art{position:relative;display:flex;align-items:center;justify-content:center;min-height:420px}
.ha-tarot,.ha-hex{border-radius:15px;display:flex;align-items:center;justify-content:center;box-shadow:0 28px 58px rgba(42,36,24,.14)}
.ha-tarot{width:212px;height:364px;overflow:hidden;border:1px solid rgba(96,72,150,.28);
  background:radial-gradient(120% 92% at 38% 28%,#EFE9F5,#E5DDEB);transform:rotate(-5deg) translateX(26px)}
.ha-tarot img{width:100%;height:100%;object-fit:cover;border-radius:14px}
.ha-hex{width:182px;height:298px;border:1px solid rgba(22,67,58,.26);
  background:radial-gradient(120% 92% at 62% 30%,#E9F1ED,#DCE8E1);transform:rotate(4.5deg) translateX(-26px)}
.ha-hex svg{display:block}
.ha-seal{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:76px;height:76px;border-radius:50%;
  background:var(--cin);color:#F6ECDD;display:flex;align-items:center;justify-content:center;font-family:var(--cjk);font-size:38px;z-index:3;text-decoration:none;
  box-shadow:0 16px 34px rgba(197,64,46,.32),0 0 0 7px rgba(246,239,222,.9),inset 0 0 0 1.5px rgba(246,236,221,.5);
  transition:transform .2s,box-shadow .2s}
.ha-seal:hover{transform:translate(-50%,-50%) scale(1.06);box-shadow:0 20px 40px rgba(197,64,46,.4),0 0 0 7px rgba(246,239,222,.9),inset 0 0 0 1.5px rgba(246,236,221,.5)}
.ha-cap{position:absolute;left:0;right:0;bottom:-2px;text-align:center;font-family:var(--label);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--faint)}

/* ---------- inner-page header ---------- */
.site-head{border-bottom:1px solid var(--line);position:relative;z-index:3;background:var(--bone)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;padding:24px 44px 20px}
.brand{display:flex;align-items:center;gap:13px;text-decoration:none;color:var(--ink)}
.seal{width:46px;height:46px;flex:none;border-radius:50%;border:1.5px solid var(--ink);display:flex;align-items:center;justify-content:center;
  font-size:24px;font-weight:500;font-family:var(--cjk);color:var(--ink);position:relative}
.seal::after{content:"";position:absolute;inset:4px;border-radius:50%;border:.5px solid rgba(42,36,24,.3)}
.brand b{font-family:var(--label);font-weight:600;font-size:19px;letter-spacing:.2em;display:block;line-height:1;color:var(--ink)}
.brand span{font-size:9.5px;letter-spacing:.36em;text-transform:uppercase;color:var(--faint)}
.nav{display:flex;gap:28px;align-items:center}
.nav a{color:var(--soft);text-decoration:none;font-size:15px;letter-spacing:.01em}
.nav a:hover,.nav a[aria-current=page]{color:var(--cin)}
.nav-toggle,.nav-toggle-cb{display:none}
.btn{display:inline-block;font-family:var(--label);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;
  border:none;cursor:pointer;border-radius:30px;padding:12px 24px;text-decoration:none;text-align:center;transition:background .15s,color .15s}
.btn-fill{background:var(--cin);color:#FBF1E6}.btn-fill:hover{background:var(--cin-deep)}
.btn-ghost,.btn-gold{background:transparent;color:var(--ink);border:1.5px solid var(--ink);padding:11px 24px;border-radius:30px}
.btn-ghost:hover,.btn-gold:hover{background:var(--ink);color:var(--bone)}
.nav a.btn-fill{color:#FBF1E6}.nav a.btn-ghost,.nav a.btn-gold{color:var(--ink)}

/* ---------- ornament + headings ---------- */
.orn{display:flex;align-items:center;justify-content:center;gap:16px;margin:0 auto}
.orn .l{height:1px;width:86px;background:linear-gradient(90deg,transparent,var(--gold))}
.orn .r{background:linear-gradient(90deg,var(--gold),transparent)}
.orn .d{width:7px;height:7px;flex:none;background:var(--cin);transform:rotate(45deg)}
.section{padding:64px 0;position:relative;z-index:2}
.band-head,.section-head{text-align:center;margin-bottom:38px}
.section-head p{color:var(--soft);max-width:34em;margin:12px auto 0;font-size:17px}
.ritual h2,.fusion h2,.section-head h2,.reveal h2{font-family:var(--disp);font-weight:500;font-size:46px;color:var(--ink);margin-top:12px}

/* ---------- reveal / dual reading ---------- */
.ritual,.reveal{position:relative;z-index:2;background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ritual .wrap,.reveal .wrap{padding-top:64px;padding-bottom:66px}
.ritual .q,.reveal .q,.q{text-align:center;font-family:var(--disp);font-style:italic;font-size:23px;color:var(--soft);margin:14px 0 38px}
.ritual .q b,.reveal .q b,.q b{color:var(--ink);font-style:normal;font-weight:500}
.duo{display:flex;gap:34px;justify-content:center;flex-wrap:wrap;max-width:760px;margin:0 auto;align-items:flex-start}
.read{flex:1 1 300px;max-width:330px;text-align:center}
.read .tag{font-family:var(--label);font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--cin);margin-bottom:16px}
.read .glyph{height:120px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.read .read-card{width:150px;height:auto;margin:0 auto 8px;border-radius:8px;border:4px solid #fff;box-shadow:0 18px 40px rgba(42,36,24,.3)}
.read .name{font-family:var(--disp);font-size:27px;font-weight:600;color:var(--ink)}
.read .name .cjk{color:var(--cin)}
.read .pos{font-size:14px;color:var(--soft);margin-top:4px;font-style:italic;font-family:var(--disp)}
.synth{text-align:center;max-width:640px;margin:36px auto 0;color:var(--soft);font-size:17px;line-height:1.75}
.synth b{color:var(--cin-deep);font-weight:500}

/* ---------- fusion strip ---------- */
.fusion{border-bottom:1px solid var(--line);padding:60px 0;position:relative;z-index:2}
.triad{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.fitem{text-align:center;padding:0 6px}
.fitem .map{font-family:var(--cjk);font-size:18px;color:var(--ink);letter-spacing:.04em;margin-bottom:10px;white-space:nowrap}
.fitem .map .v{color:var(--cin);margin:0 5px}
.fitem .name{font-family:var(--disp);font-size:22px;font-weight:600;color:var(--ink2)}
.fitem .desc{font-size:15px;color:var(--soft);margin-top:5px}

/* ---------- tiles ---------- */
.grid{display:grid;gap:18px}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}
.tile{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:24px;text-decoration:none;color:var(--ink);
  transition:transform .16s,border-color .16s,box-shadow .16s}
.tile:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:0 14px 30px rgba(42,36,24,.08)}
.tile h3{font-family:var(--disp);font-size:23px;font-weight:600;margin-bottom:4px;color:var(--ink2)}
.tile p{font-size:15px;color:var(--soft)}
.tile .kicker{font-family:var(--label);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--cin);margin-bottom:10px}

/* ---------- engines (used on some pages) ---------- */
.engines{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.ecard{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:30px 24px 24px;text-decoration:none;color:var(--ink);display:block;transition:transform .18s,border-color .18s,box-shadow .18s}
.ecard:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:0 14px 30px rgba(42,36,24,.08)}
.ecard .glyph{height:96px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.ecard h3{font-family:var(--disp);font-weight:600;font-size:27px;color:var(--ink2)}
.ecard .sub{font-size:14.5px;color:var(--soft);margin-top:4px;min-height:36px;font-style:italic;font-family:var(--disp)}
.ecard .go{margin-top:14px;font-family:var(--label);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--cin)}
.corner{position:absolute;top:13px;right:15px;font-size:13px;color:var(--gold);font-family:var(--cjk)}

/* ---------- article / prose ---------- */
.article{max-width:700px;margin:0 auto;padding:56px 0 20px;position:relative;z-index:2}
.article .kicker{font-family:var(--label);font-size:11.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--cin)}
.article h1{font-family:var(--disp);font-weight:500;font-size:54px;line-height:1.05;margin:14px 0 10px;color:var(--ink)}
.article .byline{font-size:15px;color:var(--faint);font-style:italic;font-family:var(--disp);margin-bottom:30px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.article h2{font-family:var(--disp);font-weight:600;font-size:33px;margin:38px 0 12px;color:var(--jade)}
.article h3{font-family:var(--disp);font-weight:600;font-size:25px;margin:28px 0 8px;color:var(--jade)}
.article p{font-size:18.5px;color:var(--ink);margin:0 0 18px;line-height:1.78}
.article a{color:var(--cin-deep);text-underline-offset:2px}
.article ul,.article ol{margin:0 0 18px 1.2em}
.article li{font-size:18.5px;color:var(--ink);margin:0 0 8px;line-height:1.72}
.article blockquote{border-left:3px solid var(--cin);background:var(--paper);padding:14px 24px;margin:24px 0;font-family:var(--disp);font-style:italic;font-size:24px;color:var(--jade);border-radius:0}
.article figure{margin:26px 0}
.article figcaption{font-size:14px;color:var(--faint);text-align:center;margin-top:8px}
.card-figure{max-width:266px;margin:6px auto 32px;border-radius:8px;overflow:hidden;border:4px solid #fff;box-shadow:0 18px 44px rgba(42,36,24,.28)}
.card-figure img{width:100%;display:block}
.read-card{display:block}
.callout{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:20px 24px;margin:26px 0}
.callout .h{font-family:var(--disp);font-size:21px;font-weight:600;margin-bottom:4px;color:var(--cin)}

/* ---------- footer ---------- */
.site-foot{border-top:1px solid var(--line);margin-top:10px;position:relative;z-index:2;background:rgba(8,6,14,.55);color:var(--soft)}
.site-foot .wrap{display:flex;justify-content:space-between;align-items:flex-start;gap:30px;padding:46px 44px 46px;flex-wrap:wrap}
.foot-col h4{font-family:var(--disp);font-size:20px;font-weight:600;margin-bottom:10px;color:var(--gold-bright)}
.foot-col a{display:block;color:var(--jade-soft);text-decoration:none;font-size:15px;margin-bottom:7px}
.foot-col a:hover{color:var(--gold-bright)}
.foot-base{border-top:1px solid rgba(201,162,78,.2)}
.foot-base .wrap{display:flex;justify-content:space-between;align-items:center;padding:18px 44px;color:var(--jade-soft);font-size:13px;flex-wrap:wrap;gap:10px}
.foot-base .tri{letter-spacing:.5em;color:var(--gold);font-size:15px}

/* ---------- tools ---------- */
.tool-head{max-width:720px;margin:0 auto;text-align:center;padding:56px 0 8px;position:relative;z-index:2}
.tool-head .kicker{font-family:var(--label);font-size:11.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--cin)}
.tool-head h1{font-family:var(--disp);font-weight:500;font-size:56px;line-height:1.05;margin:12px 0 12px;color:var(--ink)}
.tool-head p{font-size:18px;color:var(--soft)}
.tool-panel{position:relative;max-width:620px;margin:28px auto 0;z-index:2;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:26px}
.tool-panel label{display:block;font-family:var(--label);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--soft);margin-bottom:10px}
.tool-panel input[type=text]{width:100%;font-family:var(--disp);font-size:21px;color:var(--ink);background:var(--bone);border:1px solid var(--line);border-radius:6px;padding:13px 15px;margin-bottom:16px}
.tool-panel input[type=text]::placeholder{color:var(--faint)}
.tool-panel input[type=text]:focus{outline:none;border-color:var(--cin)}
.tool-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.tool-out{max-width:920px;margin:38px auto 0;min-height:20px;position:relative;z-index:2}
.tool-q{text-align:center;font-family:var(--disp);font-style:italic;font-size:23px;color:var(--soft);margin-bottom:26px}
.tool-err{text-align:center;color:var(--cin)}
.tool-note{max-width:620px;margin:40px auto 0;text-align:center;font-size:15px;color:var(--faint);position:relative;z-index:2}
.tool-note a{color:var(--gold-bright)}

/* tarot result cards — real RWS art with flip reveal */
.tool-cards{display:flex;gap:30px;justify-content:center;flex-wrap:wrap}
.tcard{flex:1 1 250px;max-width:288px}
.tool-cards.compact{gap:18px;max-width:920px}
.tool-cards.compact .tcard{flex:0 1 152px;max-width:160px}
.tool-cards.compact .tcard-pos{font-size:9.5px;letter-spacing:.16em;margin-bottom:9px}
.tool-cards.compact .tcard-name{font-size:18px;margin-bottom:3px}
.tool-cards.compact .tcard-kw{font-size:13.5px;margin-bottom:5px}
.tool-cards.compact .tcard-read{font-size:13px;line-height:1.5}
.tool-cards.compact .orient{font-size:9px;padding:3px 10px;margin-bottom:6px}
.tcard-pos{text-align:center;font-family:var(--label);font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--cin);margin-bottom:14px}
.tcard-flip{perspective:1500px}
.tcard-inner{position:relative;width:100%;aspect-ratio:350/600;transform-style:preserve-3d;animation:dealflip .9s cubic-bezier(.3,.7,.25,1) both}
@keyframes dealflip{0%{transform:rotateY(0deg) translateY(10px)}45%{transform:rotateY(0deg) translateY(0)}100%{transform:rotateY(180deg)}}
.tcard-back,.tcard-front{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:9px;overflow:hidden;border:4px solid #fff;box-shadow:0 14px 34px rgba(42,36,24,.3)}
.tcard-back{background:radial-gradient(circle at 50% 38%,#1c4a40,#0e2b25 74%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;border-color:var(--jade)}
.cb-seal{width:54px;height:54px;border-radius:50%;border:1px solid var(--gold-bright);display:flex;align-items:center;justify-content:center;color:var(--gold-bright);font-size:28px}
.cb-orn{width:7px;height:7px;background:var(--gold-bright);transform:rotate(45deg)}
.tcard-front{transform:rotateY(180deg);background:#fff}
.tcard-front img{width:100%;height:100%;object-fit:cover;display:block}
.tcard-front.rev img{transform:rotate(180deg)}
@media (prefers-reduced-motion:reduce){.tcard-inner{animation:none;transform:rotateY(180deg)}}
.tcard-body{text-align:center;padding:18px 6px 0;opacity:0;animation:fadeup .5s ease both}
@keyframes fadeup{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.orient{display:inline-block;font-family:var(--label);font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:4px 14px;border-radius:20px;margin-bottom:8px;border:1px solid}
.o-up{border-color:var(--gold);color:var(--gold)}.o-rev{border-color:var(--cin);color:var(--cin)}
.tcard-name{font-family:var(--disp);font-size:25px;font-weight:600;color:var(--ink);margin-bottom:5px}
.tcard-kw{font-family:var(--disp);font-style:italic;font-size:18px;color:var(--soft);margin-bottom:8px}
.tcard-read{font-size:16px;color:var(--soft);line-height:1.62}
.tcard-link{display:inline-block;margin-top:10px;font-family:var(--label);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--cin);text-decoration:none}
.tcard-link:hover{text-decoration:underline}
@media (prefers-reduced-motion:reduce){.tcard-body{opacity:1;animation:none}}

/* optional ambient-sound toggle */
#sound-toggle{position:fixed;right:18px;bottom:18px;z-index:60;width:42px;height:42px;border-radius:50%;
  border:1px solid var(--line);background:var(--paper);color:var(--faint);cursor:pointer;font-size:16px;line-height:1;
  display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(42,36,24,.14);transition:color .15s,border-color .15s,transform .15s}
#sound-toggle:hover{color:var(--cin);transform:translateY(-1px)}
#sound-toggle.on{color:var(--cin);border-color:var(--cin)}

/* combined reading (ask once, read twice) */
.reading-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;max-width:880px;margin:0 auto;align-items:start}
.reading-col{text-align:center}
.reading-col .tool-cards{margin-top:0}
.reading-tag{font-family:var(--label);font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--cin);margin-bottom:18px}
.reading-hextext{max-width:none;margin:16px auto 0}
.reading-hextext p{font-size:16px;color:var(--ink);line-height:1.7}
.reading-synth{max-width:680px;margin:40px auto 0;text-align:center;font-family:var(--disp);font-size:21px;font-style:italic;color:var(--soft);line-height:1.68;
  padding-top:30px;border-top:1px solid var(--line)}
.reading-synth b{color:var(--cin-deep);font-style:normal;font-weight:500}
@media (max-width:740px){.reading-grid{grid-template-columns:1fr;gap:34px}}

/* the 64 hexagrams reference grid */
.hex-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:9px;max-width:780px;margin:0 auto}
.hex-cell{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:11px 4px 9px;cursor:pointer;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:3px;font-family:inherit;transition:border-color .15s,transform .15s,background .15s}
.hex-cell:hover{border-color:var(--gold);transform:translateY(-2px)}
.hex-cell.active{border-color:var(--cin);background:var(--jade2);box-shadow:0 6px 16px rgba(0,0,0,.4)}
.hex-cell .hn{font-family:var(--label);font-size:9px;letter-spacing:.06em;color:var(--faint)}
.hex-cell .hh{font-family:var(--cjk);font-size:13px;color:var(--ink2)}
.hex-cell .he{font-size:10px;color:var(--soft);line-height:1.12;min-height:24px}
.minihex{display:flex;flex-direction:column;gap:2.5px;width:24px;margin-bottom:2px}
.minihex.big{width:46px;gap:4px}
.minihex .ml{height:3px;border-radius:1px;background:var(--ink);display:block}
.minihex.big .ml{height:5px;border-radius:2px}
.minihex .ml.yin{background:linear-gradient(90deg,var(--ink) 0 40%,transparent 40% 60%,var(--ink) 60% 100%)}
.hex-cell.active .minihex .ml{background:var(--cin)}
.hex-cell.active .minihex .ml.yin{background:linear-gradient(90deg,#C5402E 0 40%,transparent 40% 60%,#C5402E 60% 100%)}
.hex-detail{max-width:640px;margin:38px auto 0;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:28px 30px}
.hex-detail .hd-head{display:flex;align-items:center;gap:20px;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:4px}
.hex-detail .hd-head .minihex.big .ml{background:var(--cin)}
.hex-detail .hd-head .minihex.big .ml.yin{background:linear-gradient(90deg,#C5402E 0 40%,transparent 40% 60%,#C5402E 60% 100%)}
.hex-detail .hd-no{font-family:var(--label);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.hex-detail .hd-name{font-family:var(--disp);font-size:27px;font-weight:600;color:var(--ink)}
.hex-detail .hd-name .cjk{color:var(--cin)}
.hex-detail .hd-tri{font-size:14px;color:var(--soft);font-style:italic;font-family:var(--disp)}
.hex-detail h3{font-family:var(--disp);font-size:20px;font-weight:600;margin:20px 0 4px;color:var(--jade)}
.hex-detail p{font-size:16.5px;color:var(--ink);line-height:1.7}
.hex-detail .hd-kin{margin-top:14px;padding-top:12px;border-top:1px solid var(--line);font-size:15px;color:var(--soft)}
.hex-detail .hd-kin b{color:var(--cin-deep)}
.hex-detail .hd-cast{margin-top:16px;font-family:var(--label);font-size:12px;letter-spacing:.04em;text-transform:uppercase}
@media (max-width:680px){.hex-grid{grid-template-columns:repeat(4,1fr)}}

/* iching result */
.hex-duo{display:flex;gap:44px;justify-content:center;flex-wrap:wrap;margin-bottom:30px}
.hexblock{text-align:center;max-width:260px}
.hex-label{font-family:var(--label);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--cin);margin-bottom:14px}
.hexsvg{margin:0 auto 14px;display:block}
.hex-no{font-family:var(--label);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.hex-name{font-family:var(--disp);font-size:26px;font-weight:600;margin-top:3px;color:var(--ink)}
.hex-name .cjk{color:var(--cin)}
.hex-tri{font-size:14px;color:var(--soft);margin-top:4px;font-style:italic;font-family:var(--disp)}
.hex-text{max-width:620px;margin:0 auto;text-align:left}
.hex-text h3{font-family:var(--disp);font-size:23px;font-weight:600;margin:22px 0 6px;color:var(--jade)}
.hex-text p{font-size:17px;color:var(--ink);line-height:1.75}
.hex-bridge{margin-top:18px;padding-top:14px;border-top:1px solid var(--line);font-size:15px;color:var(--soft)}
.hex-bridge b{color:var(--cin-deep)}
/* recolor the engine's hard-coded gold hex strokes via filter is not possible; lines stay gold-bright on the parchment which still reads */

/* responsive */
@media (max-width:900px){
  .ritual h2,.fusion h2,.section-head h2,.reveal h2{font-size:36px}
  .triad{grid-template-columns:1fr;gap:22px}.grid-3,.grid-4{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .hero-wrap{grid-template-columns:1fr;gap:38px;padding-top:48px;padding-bottom:56px;text-align:center}
  .hero-copy .eyebrow{justify-content:center}
  .hero h1{font-size:42px}
  .hero .lede{margin:0 auto;font-size:18px}
  .hero-cta{align-items:center}
  .hero-art{min-height:360px;order:-1}
  .ha-tarot{width:174px;height:300px;transform:rotate(-5deg) translateX(22px)}
  .ha-hex{width:150px;height:246px;transform:rotate(4.5deg) translateX(-22px)}
  .ha-seal{width:64px;height:64px;font-size:32px}
  .wrap,.site-head .wrap,.site-foot .wrap,.foot-base .wrap{padding-left:22px;padding-right:22px}
  .nav-toggle{display:inline-flex;align-items:center;gap:7px;background:none;border:1px solid var(--line);border-radius:30px;padding:8px 14px;font-family:var(--label);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);cursor:pointer}
  .nav{display:none;position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:flex-start;gap:0;background:var(--bone);border-bottom:1px solid var(--line);padding:8px 22px 16px;z-index:40}
  .nav a{padding:12px 0;width:100%;border-bottom:1px solid var(--line-soft)}.nav .btn{margin-top:12px}
  .site-head .wrap{position:relative;flex-wrap:wrap}.nav-toggle-cb:checked ~ .nav{display:flex}
}
@media (max-width:560px){
  .article h1{font-size:36px}.tool-head h1{font-size:34px}.engines{grid-template-columns:1fr}.grid-3,.grid-4{grid-template-columns:1fr}
}

/* card of the day */
.daily-note{text-align:center;font-family:var(--disp);font-style:italic;font-size:18px;color:var(--faint);margin:26px 0 0}

/* yes / no verdict */
.verdict{display:flex;flex-direction:column;align-items:center;gap:6px;margin:0 auto 30px;text-align:center}
.verdict-word{font-family:var(--disp);font-weight:600;font-size:52px;line-height:1;letter-spacing:.01em}
.verdict.v-yes .verdict-word{color:var(--jade)}
.verdict.v-no .verdict-word{color:var(--cin)}
.verdict-tally{font-family:var(--label);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--soft)}
.verdict-nuance{max-width:600px;margin:26px auto 0;text-align:center;font-size:17px;line-height:1.66;color:var(--soft)}
@media (max-width:560px){.verdict-word{font-size:40px}}

/* ============================================================
   THE DESCENT — scroll-journey homepage (its own vocabulary)
   ============================================================ */
html{scroll-behavior:smooth}
.dsc-brand{position:fixed;left:24px;top:20px;z-index:45;display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink)}
.dsc-brand .s{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--cjk);font-size:21px;color:var(--ink);background:rgba(246,239,222,.72);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}
.dsc-brand b{font-family:var(--label);font-size:13px;letter-spacing:.32em;font-weight:600}
@media (max-width:680px){.dsc-brand b{display:none}}

.descent{position:relative;max-width:1040px;margin:0 auto;padding:0 44px}
/* entry / threshold */
.threshold{min-height:96vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative}
.dsc-seal{width:86px;height:86px;border-radius:50%;border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--cjk);font-size:43px;color:var(--cin);margin-bottom:30px;position:relative}
.dsc-seal::after{content:"";position:absolute;inset:6px;border-radius:50%;border:.5px solid rgba(168,132,58,.55)}
.threshold .tk{font-family:var(--label);font-size:12px;letter-spacing:.42em;text-transform:uppercase;color:var(--cin);margin-bottom:22px}
.threshold h1{font-family:var(--disp);font-weight:500;font-size:74px;line-height:1.02;letter-spacing:-.012em;color:var(--ink);max-width:13ch}
.threshold h1 em{font-style:italic;color:var(--cin-deep)}
.threshold .lede{font-size:20px;color:var(--soft);max-width:36ch;margin:24px auto 0;line-height:1.6}
.dsc-links{margin-top:32px;display:flex;gap:10px 22px;flex-wrap:wrap;justify-content:center;font-family:var(--label);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.dsc-links a{color:var(--soft);text-decoration:none}.dsc-links a:hover{color:var(--cin)}
.dsc-cue{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);font-family:var(--label);font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--faint);display:flex;flex-direction:column;align-items:center;gap:9px;text-decoration:none}
.dsc-cue .ar{font-size:19px;animation:cuebob 2.4s ease-in-out infinite}
@keyframes cuebob{0%,100%{transform:translateY(0);opacity:.45}50%{transform:translateY(7px);opacity:1}}

/* the journey + descending spine */
.journey{position:relative;padding:10px 0 50px}
.spine{position:absolute;left:50%;top:0;bottom:0;width:2px;transform:translateX(-1px);background:var(--line-soft);z-index:0;overflow:hidden}
.spine-fill{position:absolute;left:0;top:0;width:100%;height:0;background:linear-gradient(180deg,var(--gold),var(--cin))}

/* stations along the path */
.station{position:relative;z-index:1;min-height:72vh;display:flex;align-items:center;padding:40px 0}
.station.left{justify-content:flex-start}
.station.right{justify-content:flex-end}
.station.full{justify-content:center}
.st-inner{width:43%;position:relative}
.station.right .st-inner{text-align:left}
.station.full .st-inner{width:100%;max-width:720px;text-align:center}
.node{position:absolute;left:50%;top:50%;width:15px;height:15px;border-radius:50%;background:var(--paper);border:2px solid var(--cin);transform:translate(-50%,-50%);z-index:2}
.node::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--cin);opacity:0;transform:scale(.4);transition:opacity .55s,transform .55s}
.station.in .node::after{opacity:1;transform:scale(1)}
.st-num{font-family:var(--disp);font-size:122px;line-height:.8;font-weight:500;color:rgba(197,64,46,.11);position:absolute;top:-60px;pointer-events:none;z-index:-1}
.station.left .st-num{left:-8px}.station.right .st-num{right:-8px}
.station.full .st-num{left:50%;transform:translateX(-50%);top:-74px}
.st-kicker{font-family:var(--label);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--cin);margin-bottom:13px}
.st-kicker .cjk{font-size:13px}
.st-h{font-family:var(--disp);font-weight:500;font-size:39px;line-height:1.08;color:var(--ink);margin-bottom:14px}
.st-h em{font-style:italic;color:var(--cin-deep)}
.st-p{font-size:18px;color:var(--soft);line-height:1.66;max-width:36ch}
.station.full .st-p{margin-left:auto;margin-right:auto}
.st-quote{font-family:var(--disp);font-style:italic;font-size:25px;color:var(--ink);line-height:1.4;margin:6px 0 0}
.st-cta{display:inline-block;margin-top:22px;font-family:var(--label);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--cin);text-decoration:none;border-bottom:1px solid rgba(197,64,46,.4);padding-bottom:3px}
.st-cta:hover{color:var(--cin-deep);border-color:var(--cin-deep)}
.st-card{width:206px;border-radius:10px;overflow:hidden;border:5px solid #fff;box-shadow:0 26px 54px rgba(42,36,24,.22);margin-bottom:8px}
.station.right .st-card{margin-left:auto}
.st-hex{margin-bottom:10px}

/* reveal on enter */
.reveal-up{opacity:0;transform:translateY(30px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.station.in .reveal-up{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal-up{opacity:1;transform:none}.dsc-cue .ar{animation:none}.dsc-seal{animation:none}}

/* fixed dot navigation (replaces the header nav) */
.dotnav{position:fixed;right:26px;top:50%;transform:translateY(-50%);z-index:44;display:flex;flex-direction:column;gap:17px}
.dotnav a{position:relative;width:9px;height:9px;border-radius:50%;border:1.5px solid var(--faint);transition:background .2s,border-color .2s,transform .2s}
.dotnav a:hover{transform:scale(1.35)}
.dotnav a.active{background:var(--cin);border-color:var(--cin)}
.dotnav a .lbl{position:absolute;right:20px;top:50%;transform:translateY(-50%);white-space:nowrap;font-family:var(--label);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--soft);background:var(--paper);padding:4px 10px;border:1px solid var(--line);border-radius:20px;opacity:0;pointer-events:none;transition:opacity .2s}
.dotnav a:hover .lbl{opacity:1}
@media (max-width:860px){.dotnav{display:none}}

/* meeting + bridge reuse the existing .duo/.read/.synth/.triad/.fitem */
.station.full .duo{margin-top:26px}
.station.full .synth{margin-top:28px}
.station.full .triad{margin-top:8px;text-align:left}

/* go-deeper branches (not a card grid) */
.branches{margin-top:8px}
.branches a{display:flex;align-items:baseline;gap:14px;padding:15px 0;border-top:1px solid var(--line);text-decoration:none;color:var(--ink);transition:color .15s,padding-left .15s}
.branches a:last-child{border-bottom:1px solid var(--line)}
.branches a:hover{color:var(--cin);padding-left:8px}
.branches a .bk{font-family:var(--label);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);flex:none;width:80px;padding-top:6px}
.branches a .bt{font-family:var(--disp);font-size:22px;font-weight:600}
.branches a .bd{font-size:14px;color:var(--soft);display:block;margin-top:2px}

@media (max-width:760px){
  .descent{padding:0 22px}
  .threshold{min-height:90vh}.threshold h1{font-size:43px}.threshold .lede{font-size:18px}
  .spine{left:15px;transform:none}
  .station{min-height:auto;padding:46px 0}
  .station.left,.station.right,.station.full{justify-content:flex-start}
  .st-inner,.station.full .st-inner{width:100%;max-width:none;padding-left:42px;text-align:left}
  .node{left:15px}
  .st-num{font-size:82px;top:-38px;left:36px;right:auto;transform:none}
  .station.full .st-num{left:36px;transform:none}
  .st-h{font-size:29px}
  .station.full .duo,.station.full .triad,.station.full .synth{text-align:left}
  .station.full .st-p{margin-left:0}
  .station.right .st-card{margin-left:0}
}

/* ================= DESCENT V2 — interactive oracle · atmosphere · type tension ================= */
:root{--mono:"Space Mono",ui-monospace,"SFMono-Regular",monospace}
/* atmosphere — a vast faint character behind the descent, so the negative space breathes */
.atmos{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.atmos span{position:absolute;right:-6vw;top:48%;transform:translateY(-50%);font-family:var(--cjk);font-size:64vh;line-height:1;color:rgba(22,67,58,.05);font-weight:600}
.descent,.site-foot{position:relative;z-index:1}
/* type tension — the structural / label layer turns mono (homepage only) */
.threshold .tk,.st-kicker,.dotnav .lbl,.ha-cap,.branches a .bk,.oracle-lab{font-family:var(--mono);font-weight:400;text-transform:uppercase}
.threshold .tk{letter-spacing:.15em;font-size:11px}
.st-kicker{letter-spacing:.13em;font-size:10.5px}
.dsc-links a{font-family:var(--mono);text-transform:none;letter-spacing:0;font-size:12.5px}
.dsc-cue{font-family:var(--mono);font-weight:400}
.st-num{font-family:var(--mono);font-weight:700;font-size:74px;color:rgba(197,64,46,.14);top:-22px}
/* threshold tightens — the oracle is the hero now */
.threshold{min-height:auto;padding:118px 0 86px}
.dsc-seal{width:72px;height:72px;font-size:36px;margin-bottom:22px}
.threshold h1{font-size:60px;margin-bottom:14px}
.threshold .lede{font-size:18px;margin:0 auto 30px}
.dsc-cue{position:static;transform:none;margin:42px auto 0;font-size:10px}
/* the inline oracle — draw + cast, right on arrival */
.oracle{max-width:560px;margin:0 auto;text-align:left}
.oracle-lab{display:block;font-size:10px;letter-spacing:.16em;color:var(--soft);margin-bottom:9px}
.oracle input[type=text]{width:100%;font-family:var(--disp);font-size:21px;color:var(--ink);background:rgba(246,239,222,.72);border:1px solid var(--line);border-radius:8px;padding:14px 16px;margin-bottom:14px}
.oracle input[type=text]::placeholder{color:var(--faint)}
.oracle input[type=text]:focus{outline:none;border-color:var(--cin)}
.oracle .btn-fill{font-family:var(--mono);font-weight:700;letter-spacing:.04em;padding:15px 30px;width:100%}
.oracle .tool-out{margin-top:32px;width:min(900px,94vw);position:relative;left:50%;transform:translateX(-50%)}
/* west / east tradition tints — the two worlds, finally apart */
.station.west{background:radial-gradient(62% 80% at 24% 42%,rgba(168,132,58,.08),transparent 70%)}
.station.east{background:radial-gradient(62% 80% at 76% 42%,rgba(22,67,58,.08),transparent 70%)}
.station.west .st-kicker{color:var(--gold)}
.station.east .st-kicker{color:var(--jade)}
.station.west .node{border-color:var(--gold)}.station.west .node::after{background:var(--gold)}
.station.east .node{border-color:var(--jade)}.station.east .node::after{background:var(--jade)}
/* rhythm — less dead space, still room to breathe */
.station{min-height:auto;padding:13vh 0}
.journey{background:linear-gradient(180deg,transparent,rgba(22,67,58,.02) 50%,transparent)}
@media (max-width:760px){
  .threshold{min-height:auto;padding:88px 0 56px}
  .threshold h1{font-size:37px}
  .atmos span{font-size:42vh;right:-14vw}
  .oracle .tool-out{width:94vw}
  .st-num{font-size:60px}
}
