:root{
  --ink:#0d0406; --bg:#140609; --oxblood:#2a0a10; --crimson:#6e1320; --crimson-lit:#9a1626;
  --gold:#e7c46a; --gold-bright:#f7e6ad; --gold-deep:#a9852f;
  --cream:#f1e7da; --muted:#b39790; --line:rgba(231,196,106,.16);
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Jost',-apple-system,BlinkMacSystemFont,sans-serif;
  --maxw:1120px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);font-weight:400;color:var(--cream);background:var(--ink);
  line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative;
  background-image:
    radial-gradient(120% 80% at 50% -10%, rgba(120,16,30,.55), rgba(13,4,6,0) 55%),
    radial-gradient(80% 50% at 80% 110%, rgba(110,19,32,.28), rgba(13,4,6,0) 60%);
  background-attachment:fixed;
}
img{display:block;max-width:100%}
a{color:var(--gold);text-decoration:none}
em{font-style:italic;color:var(--gold);font-family:var(--serif)}

/* texture + dust */
.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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
#dust{position:fixed;inset:0;z-index:0;pointer-events:none}
main,.nav{position:relative;z-index:2}

/* entrances — hero rises on load via pure CSS (no JS needed) */
.rise{animation:rise .9s both cubic-bezier(.2,.7,.2,1);animation-delay:var(--d,0s)}
@keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
/* below-fold scroll reveals — only hidden when JS is active, so content shows if JS fails */
.js .reveal{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1);transition-delay:var(--d,0s)}
.js .reveal.in{opacity:1;transform:none}

/* buttons */
.btn{position:relative;display:inline-block;overflow:hidden;border:0;cursor:pointer;
  background:linear-gradient(165deg,var(--gold-bright),var(--gold) 45%,var(--gold-deep));
  color:#2a1700;font-family:var(--sans);font-weight:600;font-size:1rem;letter-spacing:.3px;
  padding:16px 30px;border-radius:999px;box-shadow:0 10px 30px rgba(231,196,106,.22),inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .2s,box-shadow .2s}
.btn span{position:relative;z-index:1}
.btn::after{content:"";position:absolute;top:0;left:-60%;width:50%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.65),transparent);transform:skewX(-18deg);transition:left .6s}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(231,196,106,.34)}
.btn:hover::after{left:120%}
.btn-sm{padding:9px 18px;font-size:.84rem;box-shadow:0 4px 14px rgba(231,196,106,.18)}

/* nav */
.nav{position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;background:rgba(13,4,6,.55);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:11px;color:var(--cream);font-family:var(--serif);font-weight:700;font-size:1.45rem;letter-spacing:.5px}
.brand img{border-radius:8px}

/* hero */
.hero{position:relative;min-height:100svh;display:grid;place-items:center;text-align:center;padding:90px 22px 70px;overflow:hidden}
.spotlight{position:absolute;left:50%;top:18%;width:min(900px,120vw);height:min(900px,120vw);transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(154,22,38,.55),rgba(120,16,30,.18) 40%,transparent 66%);
  filter:blur(8px);animation:breathe 8s ease-in-out infinite;pointer-events:none;z-index:0}
.spotlight.soft{opacity:.7;top:30%}
@keyframes breathe{50%{transform:translate(-50%,-50%) scale(1.08);opacity:.85}}

.hero-inner{position:relative;z-index:3;max-width:760px}
.hero-icon{width:96px;height:96px;border-radius:23px;margin:0 auto 22px;
  box-shadow:0 18px 50px rgba(0,0,0,.6),0 0 0 1px rgba(231,196,106,.25),0 0 60px rgba(154,22,38,.4)}
.eyebrow{font-size:.78rem;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:14px}
h1{font-family:var(--serif);font-weight:600;font-size:clamp(4rem,15vw,8.5rem);line-height:.92;letter-spacing:-.5px;
  background:linear-gradient(180deg,#fff7ea,#e7c46a 60%,#a9852f);-webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 2px 40px rgba(231,196,106,.18)}
.tagline{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,5vw,2.4rem);font-weight:500;margin-top:8px;color:var(--cream)}
.shimmer{font-style:italic;background:linear-gradient(100deg,#9a6b1e 18%,#f7e6ad 42%,#fffaf0 50%,#f7e6ad 58%,#9a6b1e 82%);
  -webkit-background-clip:text;background-clip:text;color:transparent;background-size:220% auto;animation:shine 5s linear infinite}
@keyframes shine{to{background-position:-220% center}}
.sub{color:var(--muted);font-size:1.1rem;max-width:540px;margin:20px auto 0;line-height:1.7}

/* signup */
.signup{margin:32px auto 0;max-width:540px}
.join-label{font-size:.86rem;color:var(--gold);letter-spacing:.04em;margin-bottom:12px}
.signup .row{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.signup input[type=email]{flex:1 1 230px;min-width:0;padding:16px 20px;border-radius:999px;font-family:var(--sans);
  border:1px solid var(--line);background:rgba(42,10,16,.6);color:var(--cream);font-size:1rem}
.signup input[type=email]::placeholder{color:#8a6f6b}
.signup input[type=email]:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(231,196,106,.18)}
.signup .hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.msg{min-height:1.2em;margin-top:13px;font-size:.95rem;font-weight:500}
.msg.ok{color:var(--gold-bright)} .msg.err{color:#ff9b8a}
.coming{margin-top:20px;color:var(--muted);font-size:.9rem;letter-spacing:.16em;text-transform:uppercase}

.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);width:24px;height:38px;border:1.5px solid rgba(231,196,106,.4);border-radius:14px;z-index:3}
.scroll-cue span{position:absolute;top:8px;left:50%;width:4px;height:7px;margin-left:-2px;border-radius:2px;background:var(--gold);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:0;transform:translateY(0)}40%{opacity:1}80%{opacity:0;transform:translateY(12px)}}

/* floating cards */
.deck{position:absolute;inset:0;z-index:1;perspective:1300px;pointer-events:none}
.pcard{position:absolute;left:50%;top:44%;width:clamp(96px,13vw,164px);aspect-ratio:5/7;border-radius:13px;
  background:linear-gradient(155deg,#fbf7ee,#efe6d6);color:#181818;
  box-shadow:0 30px 55px rgba(0,0,0,.55),inset 0 0 0 1px rgba(0,0,0,.05),inset 0 0 0 5px #fff,inset 0 0 0 6px rgba(231,196,106,.35);
  animation:float 10s ease-in-out infinite;will-change:transform;backface-visibility:hidden}
.pcard::before{content:attr(data-r) "\A" attr(data-s);white-space:pre;position:absolute;top:8px;left:11px;
  font-family:var(--serif);font-weight:600;font-size:clamp(13px,1.6vw,19px);line-height:.9;text-align:center}
.pcard::after{content:attr(data-s);position:absolute;inset:0;display:grid;place-items:center;
  font-size:clamp(34px,5vw,56px);opacity:.92}
.pcard.red{color:#b3122a}
.pcard.back{background:
  radial-gradient(circle at 50% 50%, rgba(231,196,106,.22), transparent 60%),
  repeating-linear-gradient(45deg,#5e0f1a,#5e0f1a 7px,#6e1320 7px,#6e1320 14px);
  box-shadow:0 30px 55px rgba(0,0,0,.55),inset 0 0 0 5px rgba(231,196,106,.5),inset 0 0 0 6px #3a0a12}
.pcard.back::before,.pcard.back::after{content:""}
.pcard.back::after{content:"✦";color:var(--gold);font-size:clamp(30px,4vw,48px);text-shadow:0 0 14px rgba(231,196,106,.6)}
@keyframes float{
  0%,100%{transform:translate(-50%,-50%) translate(var(--px,0px),var(--py,0px)) translate(var(--x),var(--y)) rotate(var(--r)) translateY(0px) scale(var(--s))}
  50%{transform:translate(-50%,-50%) translate(var(--px,0px),var(--py,0px)) translate(var(--x),var(--y)) rotate(calc(var(--r) + 2.4deg)) translateY(-16px) scale(calc(var(--s) * 1.02))}
}

/* section title */
.section-title{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,6vw,3.4rem);text-align:center;letter-spacing:-.5px;line-height:1.05;margin-bottom:14px}

/* showcase */
.showcase{padding:90px 0 70px;overflow:hidden}
.stage{margin-top:42px;perspective:1500px}
.track{display:flex;gap:26px;width:max-content;padding:30px 26px;transform-style:preserve-3d;animation:marquee 46s linear infinite}
.stage:hover .track{animation-play-state:paused}
.track figure{flex:0 0 auto;width:236px;border-radius:26px;overflow:hidden;
  transform:rotateY(14deg) rotateZ(-1.5deg);transition:transform .4s;
  box-shadow:0 26px 60px rgba(0,0,0,.55),0 0 0 1px rgba(231,196,106,.1),0 0 50px rgba(110,19,32,.35)}
.track figure:nth-child(even){transform:rotateY(-12deg) rotateZ(1.5deg)}
.track figure:hover{transform:rotateY(0) rotateZ(0) translateY(-10px) scale(1.03)}
.track img{width:100%;height:auto}
@keyframes marquee{to{transform:translateX(-50%)}}

/* features */
.features{max-width:var(--maxw);margin:0 auto;padding:80px 22px}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:18px;margin-top:46px}
.fcard{position:relative;background:linear-gradient(168deg,rgba(42,10,16,.9),rgba(20,6,9,.85));
  border:1px solid var(--line);border-radius:18px;padding:30px 26px 30px;overflow:hidden;
  transition:transform .25s cubic-bezier(.2,.7,.2,1),border-color .25s,box-shadow .25s;transform-style:preserve-3d}
.fcard::before{content:attr(data-s);position:absolute;top:14px;right:18px;font-family:var(--serif);font-size:1.7rem;color:rgba(231,196,106,.32)}
.fcard::after{content:attr(data-s);position:absolute;bottom:14px;left:18px;font-family:var(--serif);font-size:1.7rem;color:rgba(231,196,106,.14);transform:rotate(180deg)}
.fcard:hover{border-color:rgba(231,196,106,.5);box-shadow:0 24px 50px rgba(0,0,0,.5),0 0 40px rgba(110,19,32,.3)}
.fcard h3{font-family:var(--serif);font-weight:600;font-size:1.5rem;margin-bottom:9px;color:var(--cream)}
.fcard p{color:var(--muted);font-size:.99rem;line-height:1.65}

/* final cta */
.cta{position:relative;max-width:var(--maxw);margin:30px auto 0;padding:96px 22px;text-align:center;overflow:hidden}
.cta p{color:var(--muted);font-size:1.1rem;margin:14px auto 30px;max-width:480px}

/* footer */
footer{position:relative;z-index:2;border-top:1px solid var(--line);margin:60px auto 0;padding:32px 24px;max-width:var(--maxw);
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
footer p{color:var(--muted);font-size:.9rem}
footer nav{display:flex;gap:24px}
footer nav a{color:var(--muted);font-size:.9rem;transition:color .2s}
footer nav a:hover{color:var(--gold)}

@media(max-width:600px){
  .hero{padding:80px 20px 60px}
  .signup .row{flex-direction:column}.signup button{width:100%}
  .pcard{display:none}.pcard.back,.pcard.red:first-of-type{display:block;opacity:.5}
  .track figure{width:188px}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal,.rise{opacity:1!important;transform:none!important}
  .track{transform:none;flex-wrap:wrap;justify-content:center;width:auto}
  .track figure{transform:none}
}

/* ---- privacy page ---- */
.legal{max-width:740px;margin:0 auto;padding:54px 22px 70px;position:relative;z-index:2}
.legal h1{font-family:var(--serif);font-weight:600;font-size:2.6rem;background:none;color:var(--cream);text-shadow:none;letter-spacing:0;line-height:1.1}
.legal h2{font-family:var(--serif);font-size:1.5rem;font-weight:600;margin-top:1.9em;color:var(--gold)}
.legal p,.legal li{color:#e6dccf;font-size:1rem}
.legal .muted{color:var(--muted);font-size:.9rem}
.legal ul{padding-left:1.2em;margin:.4em 0}
.legal a{text-decoration:underline}
.legal code{background:var(--oxblood);padding:1px 6px;border-radius:5px;font-size:.9em}
.backlink{display:inline-block;margin-bottom:26px;color:var(--muted)}
.backlink:hover{color:var(--gold)}
