/* ============================================================
   THE PRIMAL ORACLE — visual system
   Dark celestial, editorial serif, brass + ivory + moon.
   ============================================================ */

:root{
  --ink:#0a0b14;
  --ink2:#10121f;
  --panel:#151728;
  --panel2:#1b1e33;
  --line:rgba(214,193,140,.18);
  --brass:#d6c18c;
  --brass-bright:#efe2b4;
  --moon:#f5ecd2;
  --ivory:#ece7d8;
  --muted:#adaec2;
  --body:#cfcfe0;
  --field-bg:#0c0e1a;
  --bg-glow:#1a1c33;
  --nav-bg:rgba(10,11,20,.92);
  --dd-bg1:#161832; --dd-bg2:#0d0f1d;
  --chip-bg:rgba(21,23,40,.6);
  --violet:#6b5cc4;
  --rose:#c98aa6;
  --twin:#7fe0c8;
  --btn-1:#efe2b4; --btn-2:#d6c18c; --btn-text:#1a160a;
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --maxw:1080px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:
    radial-gradient(1200px 700px at 50% -10%, var(--bg-glow) 0%, var(--ink) 60%) no-repeat,
    var(--ink);
  color:var(--ivory); font-family:var(--sans); line-height:1.65;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
  transition:background-color .3s ease, color .3s ease;
}
#sky{position:fixed; inset:0; z-index:0; pointer-events:none}
.wrap{position:relative; z-index:1; max-width:var(--maxw); margin:0 auto; padding:0 22px}

h1,h2,h3,h4{font-family:var(--serif); font-weight:600; letter-spacing:.3px; line-height:1.12; margin:0}
h1{font-size:clamp(2.2rem,5.2vw,3.9rem)}
h2{font-size:clamp(1.7rem,3.6vw,2.5rem)}
.eyebrow{font-family:var(--sans); text-transform:uppercase; letter-spacing:.34em; font-size:.72rem; color:var(--brass); font-weight:600}
p{color:var(--body)}
.dim{color:var(--muted)}
a{color:var(--brass-bright); text-decoration:none}

/* ---- top bar ---- */
.top{display:flex; align-items:center; justify-content:space-between; padding:22px 0}
.brand{font-family:var(--serif); font-size:1.35rem; letter-spacing:.5px; color:var(--moon)}
.brand b{color:var(--brass)}
.top nav a{font-size:.84rem; color:var(--muted); margin-left:22px; letter-spacing:.04em}
.top nav a:hover{color:var(--moon)}

/* ---- hero ---- */
.hero{padding:34px 0 26px; text-align:center}
.hero h1{color:var(--moon); margin:12px auto 10px; max-width:16ch}
.hero h1 em{font-style:italic; color:var(--brass)}
.lede{max-width:58ch; margin:0 auto 28px; font-size:1.08rem; color:var(--body)}

.wheel{width:min(360px,72vw); aspect-ratio:1; margin:6px auto 26px; position:relative; opacity:.9}
.wheel .ring{position:absolute; inset:0; border:1px solid var(--line); border-radius:50%}
.wheel .ring.r2{inset:34px; border-style:dashed; animation:spin 90s linear infinite}
.wheel .ring.r3{inset:78px; animation:spin 60s linear infinite reverse}
.wheel .core{position:absolute; inset:0; display:grid; place-items:center}
.wheel .glyphs span{position:absolute; left:50%; top:50%; font-family:var(--serif); color:var(--brass); font-size:1rem; transform-origin:0 0}
.moonball{width:96px; height:96px; border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #fffaf0, #d9cfa6 55%, #b6ac82 100%);
  box-shadow:0 0 60px rgba(245,236,210,.35), inset -14px -10px 30px rgba(0,0,0,.35)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---- form ---- */
.reader{background:linear-gradient(180deg,var(--panel),var(--ink2)); border:1px solid var(--line);
  border-radius:18px; padding:30px; max-width:540px; margin:0 auto; box-shadow:0 30px 80px rgba(0,0,0,.45)}
.reader h3{font-size:1.5rem; color:var(--moon); margin-bottom:4px}
.field{display:flex; gap:10px; margin-top:16px; flex-wrap:wrap}
input[type=date],input[type=email]{flex:1 1 200px; background:var(--field-bg); border:1px solid var(--line);
  color:var(--ivory); padding:14px 16px; border-radius:11px; font-size:1rem; font-family:var(--sans)}
input:focus{outline:none; border-color:var(--brass)}
.btn{appearance:none; cursor:pointer; border:none; border-radius:11px; padding:14px 22px; font-size:.98rem;
  font-weight:600; font-family:var(--sans); letter-spacing:.02em;
  background:linear-gradient(180deg,var(--btn-1),var(--btn-2)); color:var(--btn-text);
  transition:transform .15s ease, box-shadow .2s ease}
.btn:hover{transform:translateY(-1px); box-shadow:0 10px 28px rgba(214,193,140,.3)}
.btn.ghost{background:transparent; color:var(--brass-bright); border:1px solid var(--line)}
.btn.ghost:hover{border-color:var(--brass)}
.msg{min-height:1.2em; color:var(--rose); font-size:.86rem; margin-top:10px}
.hint{color:var(--muted); font-size:.82rem; margin-top:10px}

/* ---- result ---- */
#resultWrap{opacity:0; max-height:0; overflow:hidden; transition:opacity .6s ease}
#resultWrap.show{opacity:1; max-height:none; overflow:visible; margin-top:54px}
.reveal{text-align:center; padding:30px 0 6px}
.cross{display:inline-flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:center;
  color:var(--muted); font-size:.84rem; letter-spacing:.12em; text-transform:uppercase; margin-bottom:8px}
.cross span{color:var(--ivory)} .cross i{font-style:normal; color:var(--brass); font-size:.7rem} .cross b{color:var(--brass)}
.reveal h2.big{font-size:clamp(2.6rem,8vw,5.2rem); color:var(--moon); margin:6px 0 6px;
  text-shadow:0 0 50px rgba(245,236,210,.25); animation:rise .9s ease both}
.reveal .essence{font-family:var(--serif); font-style:italic; font-size:1.5rem; color:var(--brass-bright); max-width:30ch; margin:0 auto}
@keyframes rise{from{opacity:0; transform:translateY(20px) scale(.96)} to{opacity:1; transform:none}}

.gates{display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:16px; margin:34px 0}
.gate{background:var(--panel); border:1px solid var(--line); border-radius:14px; padding:22px 22px 24px;
  animation:rise .7s ease both}
.gate h4{font-size:1.32rem; color:var(--brass-bright); margin-bottom:8px}
.gate p{margin:0; font-size:1rem}

/* ---- stones + moon ---- */
.duo{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin:10px 0 30px}
@media(max-width:640px){.duo{grid-template-columns:1fr}}
.card{background:var(--panel2); border:1px solid var(--line); border-radius:14px; padding:24px}
.card h3{font-size:1.4rem; color:var(--moon); margin-bottom:12px}
.stoneList{list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:10px}
.stoneList li{background:var(--field-bg); border:1px solid var(--line); color:var(--brass-bright);
  padding:8px 14px; border-radius:999px; font-size:.9rem}
#moonNow{color:var(--body); margin:0}

/* ---- third eye HUD ---- */
.eyeHud{position:fixed; right:18px; bottom:18px; z-index:30; width:230px;
  background:linear-gradient(180deg,rgba(27,30,51,.96),rgba(16,18,31,.96)); backdrop-filter:blur(8px);
  border:1px solid var(--line); border-radius:16px; padding:16px; box-shadow:0 20px 50px rgba(0,0,0,.5)}
.eyeHud .eye{width:62px; height:38px; margin:2px auto 8px; position:relative; overflow:hidden;
  border-radius:50% / 60%; background:radial-gradient(circle at 50% 50%, #1b1e33, #0a0b14)}
.eyeHud .iris{position:absolute; inset:0; margin:auto; width:26px; height:26px; border-radius:50%;
  background:radial-gradient(circle at 40% 35%, #b9a6ff, var(--violet) 60%, #2a2350);
  box-shadow:0 0 16px rgba(124,108,196,.7)}
.eyeHud .iris::after{content:""; position:absolute; inset:8px; border-radius:50%; background:#0a0b14}
.eyeHud .lid{position:absolute; left:-2px; right:-2px; top:-2px; height:120%; transform-origin:top;
  background:linear-gradient(180deg,#0a0b14,#10121f); transition:transform .6s ease}
.eyeHud .meta{text-align:center}
.eyeHud .lab{font-family:var(--serif); color:var(--moon); font-size:1.05rem}
.eyeHud .desc{color:var(--muted); font-size:.72rem; margin:4px 0 8px; min-height:2.4em}
.track{height:6px; background:#0c0e1a; border-radius:99px; overflow:hidden}
.track i{display:block; height:100%; width:0; background:linear-gradient(90deg,var(--violet),var(--brass)); transition:width .6s ease}
.rites{list-style:none; margin:12px 0 0; padding:0; display:grid; gap:6px}
.rite{display:flex; align-items:center; gap:8px; font-size:.76rem; color:var(--muted); cursor:pointer}
.rite::before{content:""; width:13px; height:13px; border-radius:50%; border:1px solid var(--brass); flex:0 0 auto}
.rite.done{color:var(--ivory)} .rite.done::before{background:var(--brass); box-shadow:0 0 10px var(--brass)}
.streakRow{display:flex; align-items:center; justify-content:center; gap:6px; margin-top:10px;
  font-size:.74rem; color:var(--brass-bright); border-top:1px solid var(--line); padding-top:10px}
@media(max-width:720px){.eyeHud{display:none}}

/* ---- sections ---- */
section.band{padding:64px 0; border-top:1px solid var(--line); margin-top:60px}
.band h2{color:var(--moon); margin-bottom:8px}
.band .lede{margin:0 0 26px; text-align:left}

/* match */
.matchGrid{display:grid; grid-template-columns:1fr 1fr auto; gap:12px; align-items:end}
@media(max-width:640px){.matchGrid{grid-template-columns:1fr}}
.matchGrid label{display:block; font-size:.78rem; color:var(--muted); margin-bottom:6px; letter-spacing:.06em; text-transform:uppercase}
#matchResult{opacity:0; transition:opacity .5s ease; margin-top:24px}
#matchResult.show{opacity:1}
.matchHead{display:flex; align-items:center; justify-content:center; gap:18px; flex-wrap:wrap; margin-bottom:14px}
.matchHead .pair{font-family:var(--serif); font-size:1.7rem; color:var(--moon); text-align:center}
.matchHead .pair small{display:block; font-family:var(--sans); font-size:.72rem; color:var(--muted); letter-spacing:.08em; text-transform:uppercase}
.matchHead .amp{color:var(--brass); font-family:var(--serif); font-size:1.4rem}
.tierBadge{display:inline-block; padding:8px 18px; border-radius:999px; font-weight:600; letter-spacing:.04em;
  border:1px solid var(--line); margin:0 auto 16px; text-align:center; width:fit-content; display:block}
.tier-DeepRecognition{color:var(--twin); border-color:rgba(127,224,200,.5)}
.tier-Strong{color:var(--brass-bright)}
.tier-Workable{color:var(--ivory)}
.tier-Friction{color:var(--rose)}
.tier-HardTeacher{color:#c97f7f}
.matchNotes{list-style:none; padding:0; margin:0 auto; max-width:60ch; display:grid; gap:8px}
.matchNotes li{background:var(--panel); border:1px solid var(--line); border-radius:10px; padding:11px 15px; font-size:.92rem}

/* share + mail */
.shareBox{display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-top:16px}
#shareLine{flex:1 1 320px; background:#0c0e1a; border:1px solid var(--line); color:var(--ivory); border-radius:11px; padding:13px 15px; font-size:.92rem}

/* SEO content */
.prose{max-width:70ch}
.prose h3{font-family:var(--serif); color:var(--brass-bright); font-size:1.5rem; margin:26px 0 8px}
.prose p{margin:0 0 14px}
.faq dt{font-family:var(--serif); color:var(--moon); font-size:1.2rem; margin-top:18px}
.faq dd{margin:6px 0 0; color:var(--body)}

footer{padding:50px 0 90px; border-top:1px solid var(--line); margin-top:60px; color:var(--muted); font-size:.86rem}
footer .brand{font-size:1.1rem}
.disclaimer{font-size:.78rem; color:#9092a6; max-width:70ch; margin-top:14px}

/* toast */
#toast{position:fixed; left:50%; bottom:28px; transform:translateX(-50%) translateY(30px); z-index:50;
  background:linear-gradient(180deg,#1b1e33,#10121f); border:1px solid var(--brass); border-radius:12px;
  padding:12px 20px; display:flex; gap:12px; align-items:center; opacity:0; pointer-events:none; transition:all .35s ease}
#toast.show{opacity:1; transform:translateX(-50%) translateY(0)}
#toast strong{font-family:var(--serif); color:var(--moon); font-size:1.05rem}
#toast span{color:var(--brass-bright); font-size:.84rem}

.center{text-align:center}
.mt{margin-top:22px}

/* ---- crawlable sitemap footer (static, in initial HTML) ---- */
.sitemap-footer{border-top:1px solid var(--line); margin-top:40px; padding:40px 22px 70px; background:linear-gradient(180deg,transparent,rgba(0,0,0,.2))}
.sf-inner{max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:26px}
.sf-col h3{font-family:var(--sans); font-size:.68rem; letter-spacing:.24em; text-transform:uppercase; color:var(--brass); margin:0 0 12px}
.sf-col ul{list-style:none; margin:0; padding:0; display:grid; gap:8px}
.sf-col a{color:var(--muted); font-size:.9rem; text-decoration:none}
.sf-col a:hover{color:var(--moon)}
.sf-note{max-width:var(--maxw); margin:30px auto 0; color:var(--faint); font-size:.78rem}

/* ---- accessibility baseline (doc 19) ---- */
:focus-visible{outline:2px solid var(--brass-bright); outline-offset:2px; border-radius:4px}
.skip-link{position:absolute; left:-9999px; top:0; z-index:300; background:var(--panel); color:var(--moon); padding:10px 16px; border:1px solid var(--brass); border-radius:0 0 10px 0}
.skip-link:focus{left:0}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; scroll-behavior:auto!important}
}

/* screen-reader-only utility */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
