/* ============================================================
   EatMeOut — noir brand system
   Near-black base, glossy cherry red, soft blush, champagne.
   Bodoni Moda for the sultry serif, Jost for clean body text.
   Sexy, not seedy: candlelight, not strip-light.
   ============================================================ */

:root{
  --noir:#0b0709;
  --noir-soft:#150d11;
  --wine:#1d0d14;
  --cherry:#d4244e;
  --cherry-deep:#8e1535;
  --blush:#f07a96;
  --champagne:#d9b98a;
  --cream:#f7eef0;
  --muted:rgba(247,238,240,.66);
  --line:rgba(247,238,240,.12);
  --grad:linear-gradient(120deg,var(--cherry),var(--cherry-deep));
  --display:'Bodoni Moda',serif;
  --body:'Jost',sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  font-weight:300;
  color:var(--cream);
  background:var(--noir);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img,svg{max-width:100%;display:block}
a{color:inherit}
strong{font-weight:500}

h1,h2,h3{font-family:var(--display);font-weight:500;line-height:1.1;letter-spacing:.01em}
h2{font-size:clamp(2rem,4.5vw,3.4rem)}
h3{font-size:1.3rem}
.ital{font-style:italic;color:var(--cherry)}
.center{text-align:center}
.lede{max-width:42rem;margin:1.2rem auto 0;font-size:1.05rem;color:var(--muted)}

.kicker{
  font-family:var(--body);font-size:.74rem;font-weight:500;
  letter-spacing:.42em;text-transform:uppercase;text-align:center;
  color:var(--champagne);margin-bottom:1rem;
}
.kicker-left{text-align:left}

/* ---------- 18+ gate ---------- */
.gate[hidden]{display:none}
.gate{
  position:fixed;inset:0;z-index:100;
  background:rgba(11,7,9,.92);backdrop-filter:blur(18px);
  display:flex;align-items:center;justify-content:center;padding:1.5rem;
}
.gate-card{
  max-width:26rem;text-align:center;
  background:var(--noir-soft);border:1px solid var(--line);
  border-radius:22px;padding:2.8rem 2.2rem;
  box-shadow:0 40px 120px rgba(212,36,78,.18);
}
.gate-lips{width:84px;margin:0 auto 1.4rem}
.gate-card h2{margin-bottom:.7rem}
.gate-card p{color:var(--muted);font-size:.95rem;margin-bottom:1.8rem}
.gate-actions{display:flex;flex-direction:column;gap:.7rem}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:60;
  display:flex;align-items:center;gap:2rem;
  padding:.8rem clamp(1rem,4vw,3.5rem);
  background:rgba(11,7,9,.85);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-brand{display:flex;align-items:center;gap:.6rem;text-decoration:none}
.brand-mark{width:42px;height:26px}
.brand-word{
  font-family:var(--display);font-weight:500;font-size:1.25rem;
  color:var(--cream);letter-spacing:.02em;white-space:nowrap;
}
.brand-word em{font-style:italic;color:var(--cherry)}
.nav nav{display:flex;gap:1.8rem;margin-left:auto}
.nav nav a{
  text-decoration:none;font-size:.84rem;font-weight:400;
  letter-spacing:.12em;text-transform:uppercase;color:var(--muted);
  transition:color .2s;
}
.nav nav a:hover{color:var(--cream)}
.nav-cta{margin-left:.25rem}
.nav-toggle{display:none}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  font-family:var(--body);font-weight:500;font-size:.84rem;
  letter-spacing:.14em;text-transform:uppercase;text-decoration:none;
  padding:.85rem 1.8rem;border-radius:999px;border:1px solid transparent;
  cursor:pointer;
  transition:transform .2s,box-shadow .2s,background .2s,color .2s,border-color .2s;
}
.btn:hover{transform:translateY(-2px)}
.btn-lg{padding:1.05rem 2.3rem;font-size:.9rem}
.btn-cherry{
  background:var(--grad);color:var(--cream);
  box-shadow:0 12px 34px rgba(212,36,78,.4);
}
.btn-cherry:hover{box-shadow:0 16px 44px rgba(212,36,78,.55)}
.btn-ghost{
  border-color:rgba(247,238,240,.3);color:var(--cream);
  background:rgba(247,238,240,.04);
}
.btn-ghost:hover{border-color:var(--cream);background:rgba(247,238,240,.08)}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;text-align:center;
  padding:clamp(4.5rem,9vw,7.5rem) clamp(1.25rem,5vw,4rem) clamp(5rem,10vw,8rem);
}
.hero-glow{
  position:absolute;width:900px;height:900px;border-radius:50%;
  left:50%;top:-420px;transform:translateX(-50%);
  background:radial-gradient(circle,rgba(212,36,78,.32),rgba(142,21,53,.12) 45%,transparent 70%);
  filter:blur(12px);
  animation:breathe 9s ease-in-out infinite alternate;
}
@keyframes breathe{from{opacity:.75;transform:translateX(-50%) scale(1)}to{opacity:1;transform:translateX(-50%) scale(1.07)}}
.hero-inner{position:relative;max-width:52rem;margin:0 auto}
.hero-lips{
  width:clamp(150px,20vw,220px);margin:0 auto 2rem;
  filter:drop-shadow(0 18px 50px rgba(212,36,78,.45));
  animation:fadeUp 1s ease both;
}
.eyebrow{
  font-size:.76rem;font-weight:500;letter-spacing:.42em;text-transform:uppercase;
  color:var(--champagne);margin-bottom:1.4rem;
  animation:fadeUp 1s .12s ease both;
}
.hero h1{
  font-size:clamp(2.8rem,7vw,5.2rem);font-weight:500;
  animation:fadeUp 1s .24s ease both;
}
.hero h1 .ital{font-weight:400}
.hero-sub{
  max-width:36rem;margin:1.6rem auto 2.4rem;font-size:1.1rem;color:var(--muted);
  animation:fadeUp 1s .36s ease both;
}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;animation:fadeUp 1s .48s ease both}
.hero-note{
  margin-top:2.2rem;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(247,238,240,.45);
  animation:fadeUp 1s .6s ease both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* ---------- Ticker ---------- */
.ticker{
  background:var(--cherry-deep);color:var(--cream);
  overflow:hidden;white-space:nowrap;
}
.ticker-track{
  display:inline-flex;gap:2.4rem;padding:.8rem 0;
  font-family:var(--display);font-style:italic;font-size:.92rem;letter-spacing:.12em;
  animation:ticker 34s linear infinite;
}
.ticker-track span{flex:none}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Sections ---------- */
.section{padding:clamp(4.5rem,9vw,8rem) clamp(1.25rem,5vw,4rem);position:relative}
.section-wine{background:linear-gradient(180deg,var(--wine),var(--noir-soft))}
.container{max-width:72rem;margin:0 auto}
.container-narrow{max-width:46rem}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-top:3.5rem}
.step{
  border:1px solid var(--line);border-radius:18px;
  padding:2.2rem 1.6rem;background:rgba(247,238,240,.025);
  transition:transform .3s,border-color .3s,background .3s;
}
.step:hover{transform:translateY(-6px);border-color:rgba(212,36,78,.5);background:rgba(212,36,78,.06)}
.step-num{
  font-family:var(--display);font-style:italic;font-size:1.7rem;color:var(--champagne);
  display:block;margin-bottom:1rem;
}
.step h3{margin-bottom:.6rem}
.step p{font-size:.92rem;color:var(--muted)}

/* ---------- Rules ---------- */
.rules{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-top:3.5rem}
.rule{
  border-left:2px solid var(--cherry);
  padding:1.6rem 1.8rem;background:rgba(247,238,240,.025);border-radius:0 16px 16px 0;
  transition:background .3s,transform .3s;
}
.rule:hover{background:rgba(212,36,78,.07);transform:translateX(4px)}
.rule h3{margin-bottom:.5rem}
.rule p{font-size:.94rem;color:var(--muted)}

/* ---------- Safety ---------- */
.split{
  max-width:74rem;margin:0 auto;
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.5rem,6vw,5rem);
  align-items:center;
}
.split-copy h2{margin-bottom:1.2rem}
.split-copy>p{color:var(--muted);margin-bottom:1.8rem;max-width:32rem}
.checks{list-style:none;display:flex;flex-direction:column;gap:1.1rem}
.checks li{padding-left:1.9rem;position:relative;font-size:.95rem;color:var(--muted)}
.checks li strong{color:var(--cream);display:block;font-weight:500}
.checks li::before{
  content:"✦";position:absolute;left:0;top:.1rem;color:var(--cherry);
}
.safe-card{
  background:rgba(247,238,240,.035);border:1px solid var(--line);
  border-radius:20px;padding:1.8rem;max-width:400px;margin:0 auto;
  box-shadow:0 30px 80px rgba(212,36,78,.15);
}
.safe-title{
  font-family:var(--display);font-style:italic;font-size:1.05rem;
  color:var(--champagne);margin-bottom:1.2rem;
}
.safe-row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.88rem;padding:.85rem 1rem;border-radius:12px;
  background:rgba(247,238,240,.04);margin-bottom:.6rem;
}
.safe-row span{color:var(--muted)}
.safe-row strong{font-weight:500;font-size:.82rem;letter-spacing:.04em}
.safe-ok{border:1px solid rgba(212,36,78,.45)}
.safe-ok strong{color:var(--blush)}
.safe-cancel strong{color:var(--champagne)}

/* ---------- Register ---------- */
.form-shell{
  margin-top:3rem;border-radius:24px;padding:2px;
  background:linear-gradient(140deg,rgba(212,36,78,.7),rgba(217,185,138,.35),rgba(212,36,78,.25));
  box-shadow:0 30px 90px rgba(212,36,78,.18);
}
.form-embed{
  background:#fff;border-radius:22px;overflow:hidden;
  padding:clamp(.8rem,2vw,1.6rem);
}
.form-foot{
  margin-top:1.8rem;text-align:center;
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(247,238,240,.45);
}

/* ---------- Register page ---------- */
.page-hero{position:relative;overflow:hidden}
.page-hero .hero-glow{top:-560px}
.page-hero .container{position:relative}
.page-lips{
  width:110px;margin:0 auto 1.6rem;
  filter:drop-shadow(0 14px 40px rgba(212,36,78,.45));
}

/* ---------- FAQ ---------- */
.faq-list{margin-top:3rem;display:flex;flex-direction:column;gap:.8rem}
details{
  border:1px solid var(--line);border-radius:14px;
  background:rgba(247,238,240,.025);overflow:hidden;
}
summary{
  cursor:pointer;list-style:none;
  font-family:var(--display);font-size:1.05rem;font-weight:500;
  padding:1.2rem 3.2rem 1.2rem 1.5rem;position:relative;
}
summary::-webkit-details-marker{display:none}
summary::after{
  content:"+";position:absolute;right:1.4rem;top:50%;transform:translateY(-50%);
  font-family:var(--body);font-size:1.3rem;color:var(--cherry);transition:transform .25s;
}
details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
details p{padding:0 1.5rem 1.4rem;font-size:.93rem;color:var(--muted)}
details[open]{border-color:rgba(212,36,78,.5)}

/* ---------- CTA band ---------- */
.cta-band{
  text-align:center;position:relative;overflow:hidden;
  padding:clamp(4.5rem,9vw,7.5rem) 1.5rem;
  background:radial-gradient(110% 160% at 50% 110%,rgba(212,36,78,.28),transparent 55%),var(--wine);
}
.cta-lips{width:110px;margin:0 auto 1.6rem;filter:drop-shadow(0 14px 40px rgba(212,36,78,.5))}
.cta-band h2{font-size:clamp(2.2rem,5vw,3.6rem)}
.cta-band p{margin:1rem auto 2.2rem;color:var(--muted)}

/* ---------- Footer ---------- */
.footer{
  text-align:center;padding:3.5rem 1.5rem 2.5rem;
  border-top:1px solid var(--line);background:var(--noir);
}
.footer-brand{font-family:var(--display);font-size:1.5rem;color:var(--cream)}
.footer-brand em{font-style:italic;color:var(--cherry)}
.footer-tag{font-family:var(--display);font-style:italic;color:var(--champagne);margin:.4rem 0 1.6rem}
.footer nav{display:flex;gap:1.8rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.8rem}
.footer nav a{
  font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;
  text-decoration:none;color:var(--muted);transition:color .2s;
}
.footer nav a:hover{color:var(--cream)}
.footer-small{font-size:.76rem;letter-spacing:.08em;color:rgba(247,238,240,.4)}

/* ---------- Reveal ---------- */
html.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
html.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  html.js .reveal{opacity:1;transform:none;transition:none}
  .hero-lips,.eyebrow,.hero h1,.hero-sub,.hero-cta,.hero-note{animation:none}
  .ticker-track,.hero-glow{animation:none}
  html{scroll-behavior:auto}
}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .steps{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:980px){
  .nav nav{display:none}
  .nav-cta{margin-left:auto}
  .nav-toggle{
    display:flex;flex-direction:column;gap:5px;
    background:none;border:0;cursor:pointer;padding:.4rem;
  }
  .nav-toggle span{width:24px;height:2px;background:var(--cream)}
  .nav.open nav{
    display:flex;flex-direction:column;gap:1.1rem;
    position:absolute;top:100%;left:0;right:0;
    background:var(--noir);border-bottom:1px solid var(--line);
    padding:1.5rem clamp(1rem,4vw,3rem);
  }
  .split{grid-template-columns:1fr}
  .rules{grid-template-columns:1fr}
}
@media (max-width:600px){
  .steps{grid-template-columns:1fr}
  .brand-word{font-size:1.05rem}
  .nav-cta{display:none}
  .gate-card{padding:2.2rem 1.6rem}
}
