/* ============================================================
   THE LITERATI — Ever After Books
   A candlelit secret-society landing page
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=EB+Garamond:ital,wght@0,400;0,500;1,400&display=swap');

:root{
  /* gold hue is tweakable via --gold-h */
  --gold-h: 41;
  --leather-0:#0a0805;
  --leather-1:#100d08;
  --leather-2:#16120b;
  --frame:#4a3c28;
  --gold-deep:  oklch(0.62 0.10 var(--gold-h));
  --gold:       oklch(0.74 0.12 var(--gold-h));
  --gold-bright:oklch(0.84 0.11 var(--gold-h));
  --amber:      oklch(0.88 0.13 calc(var(--gold-h) + 6));
  --parchment:#ddd0b4;
  --parch-dim:#9d8f72;
  --parch-faint:#6e6149;
  --glow: 1;          /* glow intensity multiplier */
  --motion: 1;        /* 1 = animations on, 0 = reduced */
  --maxw: 1180px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --serif:'EB Garamond', Georgia, serif;
  --display:'Cormorant Garamond', Georgia, serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--leather-1);
  color:var(--parchment);
  font-family:var(--serif);
  font-size:19px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ---- textured backdrop: leather grain + candle vignette + faint stars ---- */
.backdrop{position:fixed;inset:0;z-index:0;pointer-events:none;}
.backdrop .grain{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 50% -10%, oklch(0.28 0.05 var(--gold-h) / .18), transparent 55%),
    radial-gradient(80% 60% at 50% 8%, oklch(0.5 0.09 var(--gold-h) / calc(.10 * var(--glow))), transparent 60%),
    var(--leather-1);
}
.backdrop .vignette{
  position:absolute;inset:0;
  background:radial-gradient(130% 120% at 50% 38%, transparent 40%, var(--leather-0) 100%);
}
.backdrop .noise{
  position:absolute;inset:0;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
#stars{position:absolute;inset:0;}
.star{position:absolute;width:2px;height:2px;border-radius:50%;background:var(--gold-bright);
  box-shadow:0 0 4px var(--amber);opacity:.0;
  animation:twinkle calc(var(--motion) * var(--dur,6s)) var(--ease) infinite;}
@keyframes twinkle{0%,100%{opacity:.08;transform:scale(.7);}50%{opacity:.7;transform:scale(1);}}

main{position:relative;z-index:1;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* ---- shared type ---- */
.eyebrow{
  font-family:var(--display);
  text-transform:uppercase;letter-spacing:.42em;
  font-size:.82rem;font-weight:600;
  color:var(--gold);
  display:inline-block;
}
.eyebrow.line{position:relative;padding:0 1.6em;}
.eyebrow.line::before,.eyebrow.line::after{
  content:"";position:absolute;top:50%;width:1.1em;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-deep));
}
.eyebrow.line::before{left:-0.2em;transform:scaleX(-1);}
.eyebrow.line::after{right:-0.2em;}

h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.04;margin:0;
  color:var(--parchment);letter-spacing:.005em;}
h1{font-size:clamp(2.6rem,5.6vw,4.8rem);font-weight:700;}
h2{font-size:clamp(2rem,4.4vw,3.6rem);}
h3{font-size:1.6rem;}
.gild{
  background:linear-gradient(176deg,var(--gold-bright),var(--gold) 42%,var(--gold-deep));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
p{margin:0 0 1em;color:var(--parch-dim);max-width:62ch;text-wrap:pretty;}
.lede{font-size:1.18rem;color:var(--parchment);}
/* brand link to Ever After Books: subtle, no underline */
.eab-link,.eab-link:link,.eab-link:visited,.eab-link:active{color:var(--gold);text-decoration:none;border-bottom:0;
  transition:color .3s var(--ease);}
.eab-link:hover,.eab-link:focus{color:var(--gold-bright);}

/* ---- buttons ---- */
.btn{
  --bh:var(--gold-h);
  font-family:var(--display);font-weight:600;
  text-transform:uppercase;letter-spacing:.18em;font-size:.92rem;
  display:inline-flex;align-items:center;gap:.7em;
  padding:1.05em 2.1em;border-radius:2px;cursor:pointer;border:none;
  color:var(--leather-0);
  background:linear-gradient(178deg,var(--gold-bright),var(--gold) 55%,var(--gold-deep));
  box-shadow:0 1px 0 oklch(0.95 0.06 var(--bh) / .6) inset, 0 14px 34px -14px oklch(0.7 0.12 var(--bh) / .8);
  position:relative;overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease);
  text-decoration:none;
}
.btn::after{content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 30%,oklch(0.99 0.04 var(--bh) / .8) 48%,transparent 62%);
  transform:translateX(-120%);transition:transform .9s var(--ease);}
.btn:hover{transform:translateY(-2px);box-shadow:0 1px 0 oklch(0.95 0.06 var(--bh) / .6) inset,0 22px 46px -16px oklch(0.7 0.13 var(--bh) / .95);}
.btn:hover::after{transform:translateX(120%);}
.btn.ghost{
  background:transparent;color:var(--gold);
  border:1px solid var(--gold-deep);box-shadow:none;
}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold-bright);box-shadow:0 0 30px -10px oklch(0.7 0.12 var(--gold-h)/.6);}

/* ---- reveal on scroll ---- */
.reveal{opacity:0;transform:translateY(26px);
  transition:opacity 1s var(--ease),transform 1s var(--ease);}
.reveal.in{opacity:1;transform:none;}
/* failsafe: guarantee visibility without depending on a transition advancing */
.reveal.seen{opacity:1 !important;transform:none !important;transition:none !important;}
.reveal.d1{transition-delay:.08s;}.reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;}.reveal.d4{transition-delay:.32s;}

/* ============================== HERO ============================== */
.hero{min-height:100svh;display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;padding:84px 28px 64px;position:relative;}
.topbar{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;
  align-items:center;padding:26px 36px;font-size:.82rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--parch-faint);font-family:var(--display);font-weight:500;}
.topbar .dot{display:inline-flex;align-items:center;gap:.6em;}
.topbar .dot::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold);
  box-shadow:0 0 10px var(--amber);animation:breathe calc(var(--motion)*3.4s) ease-in-out infinite;}
@keyframes breathe{0%,100%{opacity:.4;}50%{opacity:1;}}

.seal-stage{position:relative;width:min(272px,52vw);aspect-ratio:1;margin:0 auto 6px;
  display:grid;place-items:center;}
.seal-glow{position:absolute;inset:-30%;border-radius:50%;
  background:radial-gradient(circle at 50% 50%,
    oklch(0.9 0.14 var(--gold-h) / calc(.55*var(--glow))) 0%,
    oklch(0.78 0.13 var(--gold-h) / calc(.22*var(--glow))) 22%,
    transparent 56%);
  filter:blur(8px);
  animation:halo calc(var(--motion)*6s) ease-in-out infinite;
  will-change:transform,opacity;}
@keyframes halo{0%,100%{transform:scale(.96);opacity:.85;}50%{transform:scale(1.06);opacity:1;}}
.seal{width:100%;height:100%;object-fit:contain;position:relative;z-index:2;
  filter:drop-shadow(0 18px 40px oklch(0 0 0 / .7));}
/* the living eye: a hotspot positioned over the seal's eye */
.eye-spark{position:absolute;left:50%;top:50.5%;width:34%;height:34%;
  transform:translate(-50%,-50%);z-index:3;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,
    oklch(0.97 0.12 calc(var(--gold-h)+8) / calc(.9*var(--glow))) 0%,
    oklch(0.9 0.14 var(--gold-h) / calc(.3*var(--glow))) 30%,transparent 60%);
  mix-blend-mode:screen;opacity:.55;
  animation:pulse calc(var(--motion)*4.2s) ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:.4;transform:translate(-50%,-50%) scale(.92);}
  50%{opacity:.85;transform:translate(-50%,-50%) scale(1.05);}}
/* blink: a quick dimming sweep */
.eye-spark.blink{animation:none;opacity:.05;transition:opacity .12s;}

.hero h1{margin-top:.1em;max-width:16ch;}
.hero .lede{max-width:54ch;margin:1.05em auto 0;font-size:clamp(1.05rem,1.7vw,1.32rem);}
.hero-cta{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;margin-top:1.9em;}
.scroll-cue{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);
  font-family:var(--display);text-transform:uppercase;letter-spacing:.3em;font-size:.72rem;
  color:var(--parch-faint);display:flex;flex-direction:column;align-items:center;gap:10px;}
.scroll-cue .ln{width:1px;height:42px;background:linear-gradient(var(--gold-deep),transparent);
  animation:drip calc(var(--motion)*2.6s) ease-in-out infinite;transform-origin:top;}
@keyframes drip{0%,100%{transform:scaleY(.5);opacity:.4;}50%{transform:scaleY(1);opacity:1;}}
/* on short viewports the hero content fills the screen; hide the cue so it never collides */
@media (max-height:760px){.scroll-cue{display:none;}}

/* ---- divider rule with eye glyph ---- */
.rule{display:flex;align-items:center;gap:22px;justify-content:center;margin:0 auto;
  color:var(--gold-deep);max-width:520px;}
.rule .ln{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gold-deep));}
.rule .ln.r{background:linear-gradient(90deg,var(--gold-deep),transparent);}
.rule svg{width:34px;height:34px;flex:none;}

/* ============================== SECTIONS ============================== */
section{position:relative;padding:clamp(80px,11vw,150px) 0;}
.section-head{text-align:center;max-width:42ch;margin:0 auto clamp(48px,6vw,76px);}
.section-head h2{margin:.5em 0 .35em;}
.section-head p{margin-inline:auto;}

/* ---- LitCoin block ---- */
.coin-block{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,6vw,90px);
  align-items:center;}
.coin-copy h2{margin:.4em 0 .5em;}
.coin-note{font-size:.92rem;color:var(--parch-faint);margin-top:1.4em;
  display:flex;align-items:center;gap:.7em;}
.coin-note::before{content:"✦";color:var(--gold-deep);}

/* signup */
.signup{display:flex;gap:12px;flex-wrap:wrap;margin-top:1.8em;max-width:480px;}
.signup input{flex:1;min-width:220px;background:oklch(0.18 0.02 var(--gold-h) / .5);
  border:1px solid var(--frame);color:var(--parchment);padding:1.05em 1.3em;border-radius:2px;
  font-family:var(--serif);font-size:1rem;outline:none;transition:border-color .3s,box-shadow .3s;}
.signup input::placeholder{color:var(--parch-faint);}
.signup input:focus{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold-deep),0 0 28px -8px oklch(0.7 0.12 var(--gold-h)/.6);}
.signup .ok{color:var(--gold-bright);font-size:.95rem;margin-top:1em;display:none;}
.signup.done .ok{display:block;}

/* the coin */
.coin-stage{display:grid;place-items:center;perspective:1100px;min-height:340px;}
.coin{width:min(280px,70%);aspect-ratio:1;position:relative;transform-style:preserve-3d;
  animation:spin calc(var(--motion)*9s) linear infinite;cursor:pointer;}
.coin:hover{animation-duration:calc(var(--motion)*2.4s);}
@keyframes spin{from{transform:rotateY(0);}to{transform:rotateY(360deg);}}
.coin .face{position:absolute;inset:0;border-radius:50%;backface-visibility:hidden;
  display:grid;place-items:center;overflow:hidden;
  background:
    radial-gradient(circle at 38% 32%, var(--gold-bright), var(--gold) 42%, var(--gold-deep) 78%, oklch(0.5 0.09 var(--gold-h)) 100%);
  box-shadow:0 0 0 8px oklch(0.55 0.09 var(--gold-h)) inset,
             0 0 0 11px oklch(0.72 0.11 var(--gold-h)) inset,
             0 30px 60px -22px oklch(0 0 0 / .9);}
.coin .face.back{transform:rotateY(180deg);}
.coin .shine{position:absolute;inset:0;border-radius:50%;
  background:linear-gradient(115deg,transparent 36%,oklch(1 0 0 / .55) 48%,transparent 60%);
  transform:translateX(-30%);animation:coinshine calc(var(--motion)*9s) linear infinite;}
@keyframes coinshine{0%,100%{transform:translateX(-60%);}50%{transform:translateX(60%);}}
.coin .emblem{position:relative;z-index:2;width:62%;height:62%;color:oklch(0.34 0.06 var(--gold-h));}
.coin .ctext{position:absolute;z-index:2;font-family:var(--display);font-weight:700;
  text-transform:uppercase;color:oklch(0.34 0.06 var(--gold-h));letter-spacing:.2em;}
.coin .ctext.top{top:13%;font-size:.8rem;}
.coin .ctext.bot{bottom:12%;font-size:1.1rem;letter-spacing:.06em;}
.coin .one{font-family:var(--display);font-weight:700;font-size:3.4rem;
  color:oklch(0.34 0.06 var(--gold-h));position:relative;z-index:2;}

/* ============================== GUILD / RANKS ============================== */
.guild{background:
  linear-gradient(var(--leather-0),var(--leather-1) 18% 82%,var(--leather-0));}
.ladder{display:flex;align-items:flex-end;justify-content:center;gap:clamp(8px,1.6vw,22px);
  max-width:760px;margin:0 auto clamp(60px,7vw,90px);position:relative;}
.rung{flex:1;text-align:center;position:relative;}
.rung .bar{height:var(--h);border-radius:3px 3px 0 0;position:relative;
  background:linear-gradient(var(--leather-2),oklch(0.22 0.03 var(--gold-h)));
  border:1px solid var(--frame);border-bottom:none;overflow:hidden;
  transition:box-shadow .6s var(--ease);}
.rung .bar::before{content:"";position:absolute;inset:0;
  background:linear-gradient(var(--gold),var(--gold-deep));
  transform:scaleY(0);transform-origin:bottom;transition:transform .9s var(--ease);}
.rung.lit .bar::before{transform:scaleY(1);}
.rung.lit .bar{box-shadow:0 0 28px -6px oklch(0.7 0.12 var(--gold-h) / .7);}
.rung .lbl{font-family:var(--display);font-weight:700;font-size:1.5rem;margin-top:.5em;
  color:var(--parch-faint);transition:color .5s;}
.rung.lit .lbl{color:var(--gold-bright);}
.rung .lbl small{display:block;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--parch-faint);font-weight:500;margin-top:.2em;}
.climber{position:absolute;top:-34px;left:0;width:46px;height:46px;margin-left:-23px;
  transition:left 1.1s var(--ease);color:var(--gold-bright);
  filter:drop-shadow(0 0 12px var(--amber));opacity:0;}
.climber.show{opacity:1;}

.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,34px);}
.card{background:linear-gradient(165deg,oklch(0.17 0.02 var(--gold-h) / .75),oklch(0.12 0.015 var(--gold-h) / .6));
  border:1px solid var(--frame);border-radius:4px;padding:clamp(28px,3vw,42px);
  position:relative;overflow:hidden;transition:transform .5s var(--ease),border-color .5s,box-shadow .5s;}
.card::before{content:"";position:absolute;inset:0;border-radius:4px;padding:1px;
  background:linear-gradient(160deg,oklch(0.7 0.1 var(--gold-h)/.5),transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .5s;}
.card:hover{transform:translateY(-5px);border-color:var(--gold-deep);
  box-shadow:0 30px 60px -30px oklch(0 0 0 / .8);}
.card:hover::before{opacity:1;}
.card .ic{width:46px;height:46px;color:var(--gold);margin-bottom:1.1em;}
.card h3{margin-bottom:.4em;}
.card p{margin:0;font-size:.98rem;}
.card .tag{position:absolute;top:22px;right:22px;font-family:var(--display);font-weight:700;
  font-size:1.1rem;color:var(--gold-deep);letter-spacing:.1em;}

/* ============================== CLOSER ============================== */
.closer{text-align:center;}
.closer .panel{max-width:780px;margin:0 auto;position:relative;
  padding:clamp(50px,7vw,90px) clamp(28px,5vw,70px);
  border:1px solid var(--frame);border-radius:6px;
  background:radial-gradient(120% 140% at 50% 0%,oklch(0.2 0.03 var(--gold-h)/.6),transparent 60%);}
.closer .panel::after{content:"";position:absolute;inset:8px;border:1px solid oklch(0.5 0.08 var(--gold-h)/.25);border-radius:4px;pointer-events:none;}
.closer h2{margin:.5em 0 .6em;}
.closer .signup{margin-inline:auto;justify-content:center;}

/* ============================== FOOTER ============================== */
footer{border-top:1px solid var(--frame);padding:30px 44px;position:relative;z-index:1;
  display:flex;align-items:center;justify-content:space-between;gap:24px 40px;flex-wrap:wrap;}
footer .foot-left{display:flex;align-items:center;gap:14px;text-align:left;}
footer .mark{font-family:var(--display);font-weight:700;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);font-size:.9rem;}
footer .addr{color:var(--parch-faint);font-size:.84rem;margin:0;max-width:none;}
footer .credit{color:var(--parch-faint);font-size:.78rem;margin:0;
  font-family:var(--display);text-transform:uppercase;letter-spacing:.18em;opacity:.78;white-space:nowrap;}
footer .credit .heart{color:var(--gold);font-size:.9em;}
footer a,footer a:link,footer a:visited,footer a:active{color:var(--gold);text-decoration:none;border-bottom:0;}
footer a:hover,footer a:focus{color:var(--gold-bright);}
footer .seal-mini{width:40px;height:40px;opacity:.7;flex:none;
  filter:drop-shadow(0 0 14px oklch(0.7 0.12 var(--gold-h)/.5));}
/* if the row can't fit on narrow screens, stack and centre everything */
@media (max-width:780px){
  footer{flex-direction:column;align-items:center;text-align:center;gap:18px;}
  footer .foot-left{flex-direction:column;text-align:center;gap:12px;}
  footer .credit{white-space:normal;}
}

/* ============================== RESPONSIVE ============================== */
@media(max-width:880px){
  .coin-block{grid-template-columns:1fr;text-align:center;}
  .coin-copy p,.coin-copy .lede{margin-inline:auto;}
  .signup{margin-inline:auto;justify-content:center;}
  .coin-note{justify-content:center;}
  .pillars{grid-template-columns:1fr;max-width:440px;margin-inline:auto;}
  .coin-stage{order:-1;}
}
@media(max-width:560px){
  .topbar{padding:18px 20px;font-size:.7rem;}
  .topbar .where{display:none;}
  .ladder{gap:5px;}
  .rung .lbl{font-size:1.1rem;}
  .rung .lbl small{display:none;}
}
@media(prefers-reduced-motion:reduce){
  :root{--motion:0.0001;}
  *{animation:none !important;}
  html{scroll-behavior:auto;}
}
