/* ============================================================
   THE CHURCH OF JJ — The Fondement
   Black · Gold · Violet · Blood-red · Sacred
   ============================================================ */

:root{
  --black:#07060a;
  --black-2:#0d0a12;
  --ink:#14101c;
  --gold:#c8a24a;
  --gold-bright:#eccf83;
  --gold-deep:#8a6a25;
  --silver:#cfd2da;
  --violet:#8b3fe0;
  --violet-bright:#b884ff;
  --violet-glow:#6a23c9;
  --blood:#8e1b2e;
  --blood-bright:#c23047;
  --paper:#e9e0cf;
  --muted:#9a8f7d;
  --maxw:1180px;
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --display:"Cinzel",Georgia,serif;
  --uncial:"Uncial Antiqua",var(--display);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}

body{
  margin:0;
  background:var(--black);
  color:var(--paper);
  font-family:var(--serif);
  font-size:clamp(18px,1.15vw + 14px,22px);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body.locked{overflow:hidden;height:100vh;}

img{max-width:100%;display:block;}
a{color:var(--gold-bright);text-decoration:none;}
em{color:var(--violet-bright);font-style:italic;}
strong{color:var(--gold-bright);font-weight:600;}
.goldword{color:var(--gold-bright);font-family:var(--display);letter-spacing:.04em;}

/* ---------- BACKGROUND LAYERS ---------- */
#cosmos{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.55;}
.beam{
  position:fixed;top:-20vh;left:50%;transform:translateX(-50%);
  width:38vw;height:150vh;z-index:0;pointer-events:none;mix-blend-mode:screen;
  background:linear-gradient(to bottom,
     rgba(184,132,255,.42),rgba(139,63,224,.22) 35%,rgba(106,35,201,.07) 70%,transparent);
  filter:blur(28px);
  -webkit-mask-image:linear-gradient(to bottom,black,transparent 85%);
  mask-image:linear-gradient(to bottom,black,transparent 85%);
  animation:beamPulse 5.5s ease-in-out infinite;opacity:.5;
}
@keyframes beamPulse{0%,100%{opacity:.32;width:34vw;}50%{opacity:.6;width:42vw;}}
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.cursor-glow{
  position:fixed;top:0;left:0;width:520px;height:520px;z-index:1;pointer-events:none;
  border-radius:50%;transform:translate(-50%,-50%);opacity:0;transition:opacity .4s;
  background:radial-gradient(circle,rgba(139,63,224,.16),transparent 62%);
  mix-blend-mode:screen;
}

/* ============== ENTER GATE ============== */
.gate{
  position:fixed;inset:0;z-index:80;display:grid;place-items:center;text-align:center;padding:6vw;
  background:radial-gradient(120% 120% at 50% 0%,#16101f 0%,#07060a 60%);
  transition:opacity 1.1s ease,visibility 1.1s;
}
.gate.gone{opacity:0;visibility:hidden;}
.gate-inner{max-width:680px;animation:floatUp 1.4s ease both;}
.gate-crest{width:148px;margin:0 auto 1.4rem;filter:drop-shadow(0 0 34px rgba(139,63,224,.5));animation:breathe 6s ease-in-out infinite;}
.gate-kicker{font-family:var(--display);letter-spacing:.35em;text-transform:uppercase;font-size:.74rem;color:var(--gold);margin:0 0 1rem;}
.gate-title{font-family:var(--display);font-weight:900;font-size:clamp(2.6rem,8vw,5rem);line-height:1.02;margin:0 0 1.2rem;color:var(--paper);text-shadow:0 0 40px rgba(139,63,224,.4);}
.gate-title em{color:var(--violet-bright);font-style:italic;}
.gate-sub{color:#cabfae;margin:0 auto 2.2rem;max-width:540px;}
.gate-warn{margin-top:1.6rem;color:var(--muted);font-size:.9rem;font-style:italic;}

.enter-btn{
  position:relative;display:inline-flex;flex-direction:column;align-items:center;gap:.25rem;
  font-family:var(--display);font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:#1a1206;background:linear-gradient(180deg,var(--gold-bright),var(--gold) 55%,var(--gold-deep));
  border:none;border-radius:6px;padding:1.05rem 2.4rem;cursor:pointer;font-size:1rem;
  box-shadow:0 0 0 1px rgba(236,207,131,.4),0 14px 40px rgba(139,63,224,.35),inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .25s,box-shadow .25s;
}
.enter-btn small{font-family:var(--serif);font-weight:500;letter-spacing:.02em;text-transform:none;font-size:.74rem;color:#3a2a08;opacity:.8;}
.enter-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 0 0 1px var(--gold-bright),0 22px 60px rgba(139,63,224,.55);}
.enter-btn--sm{padding:.85rem 2rem;}

/* ============== NAV ============== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;gap:1rem;
  padding:.6rem clamp(1rem,4vw,2.4rem);
  background:linear-gradient(180deg,rgba(7,6,10,.92),rgba(7,6,10,0));
  backdrop-filter:blur(6px);
  transform:translateY(-110%);transition:transform .5s ease;
}
.nav.show{transform:translateY(0);}
.nav-brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:700;letter-spacing:.06em;color:var(--paper);font-size:.95rem;}
.nav-brand img{width:34px;filter:drop-shadow(0 0 8px rgba(139,63,224,.6));}
.nav-links{display:flex;gap:.2rem;margin-left:auto;flex-wrap:wrap;}
.nav-links a{font-family:var(--display);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#b9ad97;padding:.4rem .55rem;border-radius:4px;transition:color .2s,background .2s;}
.nav-links a:hover{color:var(--gold-bright);background:rgba(139,63,224,.14);}
.nav-cta{color:#1a1206 !important;background:linear-gradient(180deg,var(--gold-bright),var(--gold));font-weight:700;}
.mute-btn{margin-left:.4rem;background:rgba(139,63,224,.12);border:1px solid rgba(200,162,74,.35);color:var(--gold-bright);width:42px;height:42px;border-radius:50%;cursor:pointer;font-size:1.1rem;flex:none;transition:background .2s,transform .2s;}
.mute-btn:hover{background:rgba(139,63,224,.28);transform:scale(1.07);}
.mute-btn .ico-off{display:none;}
.mute-btn.muted .ico-on{display:none;}
.mute-btn.muted .ico-off{display:inline;}

.progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:70;background:rgba(255,255,255,.04);}
#progressBar{height:100%;width:0;background:linear-gradient(90deg,var(--violet),var(--gold-bright));box-shadow:0 0 12px var(--violet-bright);}

/* ============== SHARED SECTION SCAFFOLD ============== */
.book,.hero{position:relative;z-index:2;}
.panel{min-height:100svh;}
.book{padding:clamp(4rem,11vh,9rem) clamp(1.2rem,5vw,3rem);overflow:hidden;}
.book-num{font-family:var(--display);letter-spacing:.4em;text-transform:uppercase;font-size:.8rem;color:var(--gold);margin-bottom:.8rem;}
.book-title{font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,4.6vw,3.4rem);line-height:1.08;margin:0 0 1.6rem;color:var(--paper);text-shadow:0 2px 30px rgba(0,0,0,.6);}
.section-lede{color:#c9bda9;max-width:60ch;margin:0 auto 3rem;text-align:center;}
.section-lede .hint{color:var(--muted);font-style:italic;font-size:.86em;}
.book--center{max-width:var(--maxw);margin:0 auto;text-align:center;}
.book--center .book-num{margin-bottom:.8rem;}

/* dropcap & pulls */
.dropcap{float:left;font-family:var(--uncial);font-size:4.6rem;line-height:.7;padding:.34rem .55rem .2rem 0;color:var(--gold-bright);text-shadow:0 0 26px rgba(200,162,74,.45);}
.pull{font-family:var(--display);font-size:1.3em;text-align:center;margin-top:2rem;color:var(--paper);}
.pull .goldword{font-size:1.3em;}

/* ============== HERO ============== */
.hero{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:2rem;padding:8rem clamp(1.4rem,5vw,4rem) 4rem;min-height:100svh;max-width:1320px;margin:0 auto;}
.hero-figure{position:relative;justify-self:center;max-width:560px;}
.hero-figure img{border-radius:50% 50% 12px 12px / 60% 60% 12px 12px;
  -webkit-mask-image:radial-gradient(120% 100% at 50% 38%,#000 55%,transparent 78%);
  mask-image:radial-gradient(120% 100% at 50% 38%,#000 55%,transparent 78%);
  filter:drop-shadow(0 0 60px rgba(139,63,224,.45));animation:breathe 8s ease-in-out infinite;}
.hero-copy{max-width:560px;}
.kicker{font-family:var(--display);letter-spacing:.2em;text-transform:uppercase;font-size:.72rem;color:var(--gold);}
.hero-title{font-family:var(--display);font-weight:900;font-size:clamp(2.4rem,6vw,4.6rem);line-height:.98;margin:.4rem 0 1rem;color:var(--paper);}
.hero-title .huge{display:block;font-family:var(--uncial);font-size:1.55em;color:var(--gold-bright);text-shadow:0 0 50px rgba(200,162,74,.5);}
.hero-tag{font-family:var(--display);font-size:1.1rem;color:var(--violet-bright);letter-spacing:.02em;margin:0 0 1.4rem;}
.hero-lede{color:#cabfae;margin:0 0 2rem;}
.scroll-cue{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--display);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--gold-bright);}
.scroll-cue .chev{display:inline-block;animation:bob 1.8s ease-in-out infinite;font-size:1.4rem;}

/* ============== BOOK WITH BG IMAGE ============== */
.book--img,.book--finale{display:grid;place-items:center;min-height:100svh;text-align:center;}
.book-bg{position:absolute;inset:-8% 0;background-size:cover;background-position:center;z-index:0;will-change:transform;}
.book-veil{position:absolute;inset:0;z-index:1;background:radial-gradient(120% 90% at 50% 40%,rgba(7,6,10,.42),rgba(7,6,10,.86) 75%);}
.book-veil--deep{background:radial-gradient(120% 90% at 50% 50%,rgba(13,6,24,.55),rgba(7,6,10,.92) 80%);}
.book--img .book-num,.book--img .book-body,.book--finale .book-body{position:relative;z-index:2;}
.book-body{max-width:760px;margin:0 auto;}
.book-body p{margin:0 0 1.3rem;}
.book-body--center{text-align:center;}

.omen-list{list-style:none;padding:0;margin:1.6rem auto;max-width:620px;text-align:left;display:grid;gap:.7rem;}
.omen-list li{padding:.7rem 1.1rem;border-left:2px solid var(--violet-glow);background:rgba(139,63,224,.07);border-radius:0 8px 8px 0;}

/* ============== BOOK II SPLIT ============== */
.book--split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,4rem);max-width:var(--maxw);margin:0 auto;align-items:center;}
.split-media{position:relative;}
.split-media img{border-radius:14px;border:1px solid rgba(200,162,74,.25);box-shadow:0 30px 70px rgba(0,0,0,.6),0 0 50px rgba(139,63,224,.25);}
.cows{position:absolute;bottom:-18px;left:50%;transform:translateX(-50%);font-size:2rem;display:flex;gap:1.5rem;filter:grayscale(.2) drop-shadow(0 4px 10px rgba(0,0,0,.6));}
.caption{font-style:italic;color:var(--muted);font-size:.92rem;text-align:center;margin-top:2rem;}
.prophecy{font-family:var(--display);font-style:normal;font-size:1.05rem;line-height:1.55;color:var(--gold-bright);border:none;margin:1.8rem 0;padding:1.4rem 1.6rem;background:linear-gradient(180deg,rgba(139,63,224,.1),rgba(0,0,0,0));border-top:1px solid rgba(200,162,74,.4);border-bottom:1px solid rgba(200,162,74,.4);}

/* ============== IMPLEMENTS ============== */
.implements{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.3rem;text-align:left;margin-bottom:3.5rem;}
.implement{position:relative;padding:2rem 1.6rem;border-radius:14px;background:linear-gradient(160deg,rgba(20,16,28,.92),rgba(10,8,14,.92));border:1px solid rgba(200,162,74,.22);overflow:hidden;cursor:pointer;transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,border-color .35s;outline:none;}
.implement::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 60% at 50% 0%,rgba(139,63,224,.22),transparent 70%);opacity:0;transition:opacity .35s;}
.implement:hover,.implement:focus-visible{transform:translateY(-8px) rotateX(4deg);box-shadow:0 26px 60px rgba(0,0,0,.6),0 0 40px rgba(139,63,224,.4);border-color:var(--gold);}
.implement:hover::before,.implement:focus-visible::before{opacity:1;}
.implement-glyph{font-size:2.6rem;color:var(--violet-bright);text-shadow:0 0 24px rgba(184,132,255,.6);margin-bottom:.6rem;line-height:1;}
.implement h3{font-family:var(--display);font-size:1.06rem;line-height:1.25;color:var(--gold-bright);margin:0 0 .2rem;}
.implement-roman{font-family:var(--uncial);color:var(--gold-deep);font-size:1.4rem;margin:0 0 .6rem;}
.implement p{font-size:.95rem;color:#bdb29e;margin:0;}
.implement--forbidden{border-color:rgba(194,48,71,.5);background:linear-gradient(160deg,rgba(40,12,20,.9),rgba(12,6,10,.95));}
.implement--forbidden .implement-glyph{color:var(--blood-bright);text-shadow:0 0 24px rgba(194,48,71,.7);}
.implement--forbidden:hover{box-shadow:0 26px 60px rgba(0,0,0,.6),0 0 46px rgba(194,48,71,.5);border-color:var(--blood-bright);}
.redact{color:var(--muted);font-style:italic;}

.dindong-meter{max-width:520px;margin:0 auto;padding:1.6rem;border:1px dashed rgba(200,162,74,.35);border-radius:14px;background:rgba(139,63,224,.05);}
.meter-label{font-family:var(--display);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin:0 0 1rem;}
input[type=range]{width:100%;appearance:none;-webkit-appearance:none;height:6px;border-radius:6px;background:linear-gradient(90deg,var(--violet),var(--blood-bright));outline:none;}
input[type=range]::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:26px;height:26px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--gold-bright),var(--gold-deep));border:2px solid #1a1206;cursor:grab;box-shadow:0 0 18px rgba(200,162,74,.7);}
input[type=range]::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:var(--gold-bright);border:2px solid #1a1206;cursor:grab;}
.meter-out{font-style:italic;color:var(--violet-bright);margin:1rem 0 0;min-height:1.5em;}

/* ============== SERMONS ============== */
.accordion{max-width:760px;margin:0 auto;text-align:left;display:grid;gap:.9rem;}
.serm{border:1px solid rgba(200,162,74,.2);border-radius:12px;background:linear-gradient(160deg,rgba(18,14,26,.9),rgba(9,7,13,.9));overflow:hidden;transition:border-color .3s;}
.serm[open]{border-color:var(--gold);}
.serm summary{cursor:pointer;list-style:none;padding:1.15rem 1.4rem;font-family:var(--display);font-size:1.02rem;color:var(--gold-bright);display:flex;align-items:center;gap:.6rem;transition:background .2s;}
.serm summary::-webkit-details-marker{display:none;}
.serm summary::before{content:"✦";color:var(--violet-bright);transition:transform .3s;}
.serm[open] summary::before{transform:rotate(180deg) scale(1.2);}
.serm summary em{color:#c9bda9;font-size:.92em;}
.serm summary:hover{background:rgba(139,63,224,.1);}
.serm > p{padding:0 1.5rem;margin:.4rem 0;color:#c4b9a5;}
.serm > p:last-child{padding-bottom:1.4rem;}
.serm--prayer[open]{border-color:var(--violet-bright);box-shadow:0 0 40px rgba(139,63,224,.25);}
.moan-console{padding:1.2rem 1.5rem 1.6rem;}
.moan-console > p{font-family:var(--display);color:var(--gold);font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;margin:0 0 .9rem;}
.moan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.6rem;}
.moan-key{font-family:var(--serif);font-size:.92rem;padding:.7rem .5rem;border-radius:10px;border:1px solid rgba(184,132,255,.3);background:rgba(139,63,224,.1);color:var(--paper);cursor:pointer;transition:transform .15s,background .2s,box-shadow .2s;}
.moan-key:hover{background:rgba(139,63,224,.28);transform:translateY(-3px);box-shadow:0 8px 22px rgba(139,63,224,.4);}
.moan-key:active{transform:scale(.94);}
.moan-key.playing{background:var(--violet);box-shadow:0 0 26px var(--violet-bright);}

/* ============== COMMANDMENTS ============== */
.cmd-list{list-style:none;counter-reset:cmd;padding:0;max-width:820px;margin:0 auto;text-align:left;display:grid;gap:.7rem;}
.cmd-list li{counter-increment:cmd;position:relative;padding:1.1rem 1.3rem 1.1rem 4.4rem;border-radius:12px;background:linear-gradient(100deg,rgba(20,16,28,.85),rgba(9,7,13,.6));border:1px solid rgba(200,162,74,.15);color:#c9bda9;transition:transform .3s,border-color .3s,background .3s;}
.cmd-list li::before{content:counter(cmd,upper-roman);position:absolute;left:0;top:0;bottom:0;width:3.4rem;display:grid;place-items:center;font-family:var(--uncial);font-size:1.25rem;color:var(--gold-bright);background:rgba(139,63,224,.12);border-radius:12px 0 0 12px;}
.cmd-list li:hover{transform:translateX(8px);border-color:var(--gold);background:linear-gradient(100deg,rgba(34,24,48,.9),rgba(12,9,16,.7));}
.cmd-list strong{color:var(--gold-bright);}

/* ============== TRAILER / VIDEO ============== */
.video-frame{max-width:960px;margin:0 auto;border-radius:16px;overflow:hidden;border:1px solid rgba(200,162,74,.3);box-shadow:0 30px 80px rgba(0,0,0,.7),0 0 60px rgba(139,63,224,.3);background:#000;}
.video-frame video{width:100%;display:block;aspect-ratio:16/9;}

/* ============== TESTIMONIES ============== */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.3rem;text-align:left;margin-bottom:2.5rem;}
.testi{margin:0;padding:1.8rem;border-radius:14px;background:linear-gradient(160deg,rgba(18,14,26,.9),rgba(9,7,13,.9));border:1px solid rgba(200,162,74,.2);position:relative;}
.testi::before{content:"“";position:absolute;top:-.2rem;left:1rem;font-family:var(--display);font-size:4rem;color:rgba(139,63,224,.35);}
.testi blockquote{margin:1.4rem 0 1rem;font-size:1.08rem;font-style:italic;color:var(--paper);line-height:1.5;}
.testi figcaption{font-family:var(--display);font-size:.78rem;letter-spacing:.04em;color:var(--gold);}
.testi-stat{max-width:720px;margin:0 auto;color:#c9bda9;}

/* ============== FINALE / ALTAR ============== */
.book--finale{padding:clamp(5rem,12vh,10rem) 1.4rem;}
.big-line{font-family:var(--display);font-size:clamp(1.3rem,3vw,1.9rem);color:var(--paper);margin:2rem 0;}
.moan-altar{margin:3rem auto;}
.altar-label{font-family:var(--display);letter-spacing:.16em;text-transform:uppercase;font-size:.82rem;color:var(--gold);margin-bottom:1.6rem;}
.big-moan{position:relative;width:190px;height:190px;border-radius:50%;border:none;cursor:pointer;background:radial-gradient(circle at 38% 32%,var(--violet-bright),var(--violet) 45%,var(--violet-glow) 100%);color:#fff;font-family:var(--display);font-weight:700;letter-spacing:.18em;font-size:1.5rem;box-shadow:0 0 60px rgba(139,63,224,.6),inset 0 2px 14px rgba(255,255,255,.35);transition:transform .15s;}
.big-moan:hover{transform:scale(1.05);}
.big-moan:active{transform:scale(.93);}
.big-moan .bm-ring{position:absolute;inset:-6px;border-radius:50%;border:2px solid var(--violet-bright);opacity:.6;animation:ringPulse 2.6s ease-out infinite;}
.big-moan .bm-text{position:relative;z-index:2;text-shadow:0 2px 10px rgba(0,0,0,.5);}
.altar-count{margin-top:1.6rem;color:#c9bda9;}
.altar-count strong{color:var(--gold-bright);font-size:1.3em;}

.doxology{font-family:var(--uncial);font-size:clamp(1.2rem,3vw,1.8rem);line-height:1.7;color:var(--gold-bright);margin-top:3rem;text-shadow:0 0 40px rgba(200,162,74,.4);}

/* ============== PLAYLIST ============== */
.spotify-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.2rem;max-width:820px;margin:0 auto;}

/* ============== JOIN ============== */
.join{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center;max-width:var(--maxw);margin:0 auto;text-align:left;}
.join-cover{border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.7),0 0 50px rgba(139,63,224,.3);border:1px solid rgba(200,162,74,.3);animation:breathe 9s ease-in-out infinite;}
.join .book-title,.join .section-lede{text-align:left;margin-left:0;}
.join .section-lede{margin-bottom:2rem;}
.join-form{display:grid;gap:1.1rem;}
.join-form label{display:grid;gap:.4rem;font-family:var(--display);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);}
.join-form .req{text-transform:none;letter-spacing:0;color:var(--muted);font-family:var(--serif);font-size:1.05em;font-style:italic;}
.join-form input[type=text],.join-form select{font-family:var(--serif);font-size:1rem;padding:.8rem 1rem;border-radius:10px;border:1px solid rgba(200,162,74,.3);background:rgba(12,9,18,.8);color:var(--paper);}
.join-form input[type=text]:focus,.join-form select:focus{outline:none;border-color:var(--violet-bright);box-shadow:0 0 0 3px rgba(139,63,224,.25);}
.join-form .check{flex-direction:row;display:flex;gap:.7rem;align-items:flex-start;text-transform:none;letter-spacing:0;font-family:var(--serif);font-size:.92rem;color:#c4b9a5;}
.join-form .check input{margin-top:.3rem;width:18px;height:18px;accent-color:var(--violet);flex:none;}
.join-msg{font-family:var(--display);color:var(--violet-bright);min-height:1.4em;margin:.4rem 0 0;}

/* ============== FOOTER ============== */
.footer{position:relative;z-index:2;text-align:center;padding:5rem 1.5rem 6rem;border-top:1px solid rgba(200,162,74,.18);background:linear-gradient(180deg,rgba(7,6,10,0),rgba(13,6,24,.6));}
.footer-crest{width:96px;margin:0 auto 1.5rem;opacity:.85;filter:drop-shadow(0 0 20px rgba(139,63,224,.4));}
.footer-dox{font-family:var(--display);letter-spacing:.1em;color:var(--gold);margin:0 0 1rem;}
.footer-fine{max-width:600px;margin:0 auto .6rem;font-size:.84rem;color:var(--muted);font-style:italic;}
.footer-cows{font-style:normal;letter-spacing:.1em;color:var(--gold-bright);font-family:var(--display);}

/* ============== FLOATING MOAN ============== */
.float-moan{position:fixed;right:18px;bottom:18px;z-index:55;font-family:var(--display);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:#1a1206;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border:none;border-radius:40px;padding:.7rem 1.2rem;cursor:pointer;box-shadow:0 8px 26px rgba(0,0,0,.5),0 0 24px rgba(139,63,224,.4);opacity:0;transform:translateY(20px);transition:opacity .4s,transform .4s,box-shadow .2s;}
.float-moan.show{opacity:1;transform:translateY(0);}
.float-moan:hover{box-shadow:0 8px 30px rgba(0,0,0,.6),0 0 40px var(--violet-bright);}
.float-moan:active{transform:scale(.92);}

/* ============== EASTER-EGG FLOATING FACE & COW RAIN ============== */
.jjface{position:fixed;z-index:54;width:110px;pointer-events:none;border-radius:50%;
  -webkit-mask-image:radial-gradient(circle at 50% 45%,#000 58%,transparent 70%);
  mask-image:radial-gradient(circle at 50% 45%,#000 58%,transparent 70%);
  filter:drop-shadow(0 0 20px rgba(139,63,224,.6));}
.cowdrop{position:fixed;top:-60px;z-index:53;font-size:2rem;pointer-events:none;}

/* ============== REVEAL ANIMATION ============== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.8,.2,1);}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  .beam,.gate-crest,.hero-figure img,.join-cover,.bm-ring,.scroll-cue .chev{animation:none !important;}
}

/* ============== KEYFRAMES ============== */
@keyframes floatUp{from{opacity:0;transform:translateY(40px);}to{opacity:1;transform:none;}}
@keyframes breathe{0%,100%{transform:scale(1);}50%{transform:scale(1.03);}}
@keyframes bob{0%,100%{transform:translateY(0);}50%{transform:translateY(6px);}}
@keyframes ringPulse{0%{transform:scale(1);opacity:.6;}100%{transform:scale(1.5);opacity:0;}}
@keyframes flash{0%{opacity:0;}10%{opacity:.9;}100%{opacity:0;}}
.skyflash{position:fixed;inset:0;z-index:75;pointer-events:none;background:radial-gradient(circle at 50% 30%,rgba(184,132,255,.9),rgba(139,63,224,.3) 40%,transparent 70%);animation:flash .7s ease-out forwards;}

/* ============== THE SACRED CHAMBER · THE RITE ============== */
.chamber{max-width:var(--maxw);margin:0 auto;}
.chamber-stage{position:relative;max-width:680px;margin:0 auto;min-height:430px;
  padding:clamp(1.6rem,4vw,2.8rem);border-radius:18px;
  border:1px solid rgba(200,162,74,.28);
  background:linear-gradient(160deg,rgba(22,14,32,.94),rgba(9,7,13,.96));
  box-shadow:0 30px 80px rgba(0,0,0,.55),inset 0 0 60px rgba(139,63,224,.08);
  overflow:hidden;display:grid;place-items:center;}
.chamber-stage::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(90% 60% at 50% 0%,rgba(139,63,224,.18),transparent 65%);}

.rite-screen{position:relative;z-index:2;width:100%;text-align:center;
  display:none;animation:riteIn .55s ease both;}
.rite-screen.is-active{display:block;}
@keyframes riteIn{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}
.rite-screen h3{font-family:var(--display);font-weight:700;color:var(--gold-bright);
  font-size:clamp(1.4rem,3.4vw,2rem);margin:0 0 1rem;}
.rite-screen p{color:#c4b9a5;max-width:48ch;margin:0 auto 1.4rem;}
.rite-glyph{font-size:3rem;color:var(--violet-bright);line-height:1;margin-bottom:.6rem;
  text-shadow:0 0 30px rgba(184,132,255,.6);}
.rite-fine{font-size:.86rem;color:var(--muted);font-style:italic;}
.rite-quote{font-style:italic;color:var(--violet-bright);}
.rite-quote span{display:block;color:var(--muted);font-style:normal;font-size:.78rem;
  font-family:var(--display);letter-spacing:.06em;text-transform:uppercase;margin-top:.4rem;}

.rite-field{display:block;max-width:340px;margin:0 auto 1rem;text-align:left;
  font-family:var(--display);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);}
.rite-field input{display:block;width:100%;margin-top:.45rem;padding:.75rem 1rem;
  font-family:var(--serif);font-size:1rem;color:var(--paper);
  background:rgba(7,6,10,.6);border:1px solid rgba(184,132,255,.35);border-radius:10px;
  text-transform:none;letter-spacing:normal;transition:border-color .2s,box-shadow .2s;}
.rite-field input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 22px rgba(139,63,224,.35);}

.nature-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;max-width:520px;margin:0 auto;}
.nature-card{display:flex;flex-direction:column;align-items:center;gap:.4rem;text-align:center;
  padding:1.6rem 1.2rem;border-radius:14px;cursor:pointer;color:var(--paper);
  background:linear-gradient(160deg,rgba(20,16,28,.92),rgba(10,8,14,.92));
  border:1px solid rgba(200,162,74,.25);
  transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s,border-color .3s;}
.nature-card:hover,.nature-card:focus-visible{transform:translateY(-6px);outline:none;
  border-color:var(--gold);box-shadow:0 22px 50px rgba(0,0,0,.55),0 0 36px rgba(139,63,224,.4);}
.nature-ico{font-size:2.4rem;line-height:1;text-shadow:0 0 22px rgba(184,132,255,.55);}
.nature-card strong{font-family:var(--display);color:var(--gold-bright);font-size:1.1rem;}
.nature-card span:last-child{font-size:.86rem;color:#bdb29e;font-weight:400;}

#intensity{width:min(380px,90%);margin:.4rem auto 0;}
.intensity-out{font-family:var(--display);letter-spacing:.04em;color:var(--violet-bright);
  font-size:1.05rem;min-height:1.4em;margin:.8rem auto 1.6rem;}

.tension{width:min(420px,92%);height:8px;margin:0 auto 1.8rem;border-radius:99px;
  background:rgba(7,6,10,.7);border:1px solid rgba(184,132,255,.25);overflow:hidden;}
.tension-bar{height:100%;width:0;border-radius:99px;
  background:linear-gradient(90deg,var(--violet),var(--violet-bright),var(--blood-bright));
  box-shadow:0 0 18px rgba(184,132,255,.6);transition:width .6s cubic-bezier(.4,0,.2,1);}
.rite-step-num{font-family:var(--uncial);color:var(--gold-deep);font-size:2rem;margin:0 0 .4rem;}
.rite-instruction{font-family:var(--serif);font-size:clamp(1.2rem,2.6vw,1.6rem);
  line-height:1.4;color:var(--paper);min-height:3.2em;max-width:42ch;
  display:flex;align-items:center;justify-content:center;margin:0 auto 1.6rem;}
.rite-instruction em{color:var(--violet-bright);}

.safeword-btn{position:absolute;bottom:14px;right:14px;z-index:5;
  font-family:var(--display);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:#fff;background:linear-gradient(180deg,var(--blood-bright),var(--blood));
  border:1px solid rgba(255,180,190,.4);border-radius:40px;padding:.55rem 1.05rem;cursor:pointer;
  box-shadow:0 6px 22px rgba(142,27,46,.5);transition:transform .15s,box-shadow .2s;}
.safeword-btn span{margin-left:.4rem;opacity:.85;font-style:italic;text-transform:none;letter-spacing:0;}
.safeword-btn:hover{transform:scale(1.05);box-shadow:0 8px 30px rgba(194,48,71,.7);}
.safeword-btn:active{transform:scale(.94);}

/* ============== RESPONSIVE ============== */
@media (max-width:900px){
  .hero{grid-template-columns:1fr;text-align:center;padding-top:7rem;}
  .hero-copy{margin:0 auto;}
  .hero-figure{max-width:340px;order:-1;}
  .scroll-cue{justify-content:center;}
  .book--split{grid-template-columns:1fr;}
  .split-media{max-width:460px;margin:0 auto;}
  .join{grid-template-columns:1fr;text-align:center;}
  .join-cover{max-width:300px;margin:0 auto;}
  .join .book-title,.join .section-lede{text-align:center;}
  .join-form{text-align:left;max-width:480px;margin:0 auto;width:100%;}
}
@media (max-width:680px){
  .nav-links a:not(.nav-cta){display:none;}
  .nav-links{margin-left:auto;}
  .big-moan{width:160px;height:160px;font-size:1.3rem;}
  .float-moan{right:12px;bottom:12px;}
  .nature-grid{grid-template-columns:1fr;}
  .chamber-stage{padding-bottom:4.4rem;}
  .safeword-btn{left:50%;right:auto;transform:translateX(-50%);}
  .safeword-btn:hover{transform:translateX(-50%) scale(1.05);}
}
