/* ============ Couple of Drinks — design tokens + components ============ */
:root{
  /* palette */
  --black:#0a0908;
  --black-2:#111010;
  --black-3:#181513;
  --gold:#e7c074;          /* bright luminous champagne */
  --gold-deep:#c9a24f;
  --gold-soft:#f3dca4;
  --white:#f6f1e9;
  --muted:#b6ada1;
  --muted-2:#7d756b;
  --line:rgba(231,192,116,.18);
  --line-soft:rgba(246,241,233,.10);

  /* type */
  --font-display:"Cormorant Garamond","Cormorant",Georgia,serif;
  --font-body:"Switzer","Inter",system-ui,sans-serif;
  --text-hero:clamp(3.4rem,11vw,9.5rem);
  --text-3xl:clamp(2.6rem,6vw,5rem);
  --text-2xl:clamp(2rem,4.4vw,3.4rem);
  --text-xl:clamp(1.5rem,2.6vw,2.1rem);
  --text-lg:clamp(1.12rem,1.6vw,1.32rem);
  --text-base:clamp(1rem,1.1vw,1.08rem);
  --text-sm:.92rem;
  --text-xs:.78rem;

  /* spacing */
  --pad:clamp(1.25rem,5vw,7rem);
  --section:clamp(5rem,11vw,10rem);
  --maxw:1200px;
}

/* ============ light theme ============ */
html[data-theme="light"]{
  --black:#f7f2ea;
  --black-2:#fffdf8;
  --black-3:#efe7d8;
  --gold:#a9822e;
  --gold-deep:#8a6a23;
  --gold-soft:#7a5d1e;
  --white:#23201b;
  --muted:#5e564b;
  --muted-2:#8a8073;
  --line:rgba(169,130,46,.28);
  --line-soft:rgba(35,32,27,.12);
}

html{scroll-behavior:smooth}
body{
  background:var(--black);
  color:var(--white);
  font-family:var(--font-body);
  font-size:var(--text-base);
  overflow-x:hidden;
  transition:background .5s ease,color .5s ease;
}

/* ============ utilities ============ */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.eyebrow{
  font-family:var(--font-body);
  font-size:var(--text-xs);
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  display:inline-flex;align-items:center;gap:.7rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);opacity:.7}
.serif{font-family:var(--font-display);font-weight:500;line-height:1.04;letter-spacing:.005em}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ============ nav ============ */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.05rem var(--pad);
  transition:background .4s ease,backdrop-filter .4s ease,padding .4s ease,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:color-mix(in srgb,var(--black) 82%,transparent);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--line-soft);
  padding-block:.7rem;
}
.brand{display:flex;align-items:center;gap:.7rem;color:var(--gold)}
.brand svg{width:34px;height:34px}
.brand span{font-family:var(--font-display);font-size:1.22rem;letter-spacing:.06em;font-weight:600;color:var(--white)}
.nav-links{display:flex;align-items:center;gap:2.2rem}
.nav-links a{font-size:var(--text-sm);letter-spacing:.04em;color:var(--muted);transition:color .25s}
.nav-links a:hover{color:var(--gold)}
.nav-actions{display:flex;align-items:center;gap:1.1rem}
.theme-toggle{
  width:38px;height:38px;border-radius:50%;border:1px solid var(--line);
  background:transparent;display:grid;place-items:center;cursor:pointer;color:var(--gold);
  transition:background .25s,transform .25s
}
.theme-toggle:hover{background:color-mix(in srgb,var(--gold) 12%,transparent);transform:rotate(15deg)}
.theme-toggle svg{width:18px;height:18px}
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:var(--text-sm);font-weight:500;letter-spacing:.04em;
  padding:.72rem 1.4rem;border-radius:999px;cursor:pointer;
  transition:transform .25s,box-shadow .3s,background .3s,color .3s;
}
.btn-gold{background:linear-gradient(135deg,var(--gold-soft),var(--gold) 55%,var(--gold-deep));color:#1a1407;border:none;box-shadow:0 6px 26px rgba(231,192,116,.22)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 10px 34px rgba(231,192,116,.34)}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--white)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.nav-cta{display:inline-flex}
.menu-btn{display:none;background:none;border:none;color:var(--white);cursor:pointer}
.mobile-menu{display:none}

/* ============ hero ============ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:30% center}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg,var(--black) 4%,rgba(10,9,8,.55) 38%,rgba(10,9,8,.15) 60%,rgba(10,9,8,.78) 100%),
    linear-gradient(0deg,var(--black) 2%,transparent 32%);
}
html[data-theme="light"] .hero-bg::after{
  background:
    linear-gradient(90deg,var(--black) 6%,rgba(247,242,234,.5) 42%,rgba(247,242,234,.12) 62%,rgba(247,242,234,.72) 100%),
    linear-gradient(0deg,var(--black) 2%,transparent 34%);
}
.hero-inner{position:relative;z-index:2;width:100%}
.hero-eyebrow{margin-bottom:1.6rem}
.hero h1{font-family:var(--font-display);font-weight:500;font-size:var(--text-hero);line-height:.92;letter-spacing:.01em;text-transform:uppercase}
.hero h1 .of{display:block;font-style:italic;font-size:.52em;letter-spacing:.04em;color:var(--gold);margin:.05em 0 .02em;text-transform:lowercase;font-weight:500}
.hero .hairline{width:min(420px,70%);height:1px;background:linear-gradient(90deg,var(--gold),transparent);margin:1.6rem 0}
.hero .tagline{font-size:var(--text-lg);color:var(--muted);max-width:42ch;line-height:1.55}
.hero .with{display:block;font-family:var(--font-body);letter-spacing:.3em;text-transform:uppercase;font-size:var(--text-xs);color:var(--white);margin-top:1.1rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem}
.scroll-cue{position:absolute;bottom:1.7rem;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--muted-2);font-size:var(--text-xs);letter-spacing:.25em;text-transform:uppercase}
.scroll-cue .line{width:1px;height:42px;background:linear-gradient(var(--gold),transparent);animation:cue 2.4s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.5}50%{transform:scaleY(1);opacity:1}}

/* ============ section heads ============ */
.section{padding-block:var(--section);position:relative}
.sec-head{max-width:62ch;margin-bottom:clamp(2.4rem,5vw,4rem)}
.sec-head h2{font-size:var(--text-3xl);margin-top:1rem}
.sec-head p{color:var(--muted);font-size:var(--text-lg);margin-top:1.1rem;line-height:1.6}
.gold{color:var(--gold)}

/* ============ about ============ */
.about{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.about-media{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:0 30px 70px rgba(0,0,0,.5)}
.about-media img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.about-media:hover img{transform:scale(1.04)}
.about-body h2{font-size:var(--text-2xl);margin:1rem 0 1.3rem}
.about-body p{color:var(--muted);margin-bottom:1.1rem;max-width:54ch}
.about-body strong{color:var(--white);font-weight:600}
.stats{display:flex;gap:2.4rem;margin-top:2rem;flex-wrap:wrap}
.stat .n{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--gold);line-height:1}
.stat .l{font-size:var(--text-xs);letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2);margin-top:.4rem}

/* ============ pillars ============ */
.pillars-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.pillar{
  position:relative;border:1px solid var(--line-soft);border-radius:14px;
  padding:2rem 1.6rem 2.2rem;background:linear-gradient(160deg,var(--black-2),var(--black));
  overflow:hidden;transition:transform .4s cubic-bezier(.2,.7,.2,1),border-color .4s,box-shadow .4s;
}
.pillar::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% -10%,rgba(231,192,116,.12),transparent 60%);opacity:0;transition:opacity .4s}
.pillar:hover{transform:translateY(-6px);border-color:var(--line);box-shadow:0 22px 50px rgba(0,0,0,.45)}
.pillar:hover::before{opacity:1}
.pillar .icn{width:46px;height:46px;color:var(--gold);margin-bottom:1.3rem}
.pillar .idx{position:absolute;top:1.2rem;right:1.4rem;font-family:var(--font-display);font-size:1.4rem;color:var(--muted-2)}
.pillar h3{font-family:var(--font-display);font-size:clamp(1.45rem,1.7vw,1.85rem);font-weight:600;margin-bottom:.6rem;line-height:1.05;hyphens:auto;word-break:break-word}
.pillar p{color:var(--muted);font-size:var(--text-sm);line-height:1.55}
.pillar .tag{display:inline-block;margin-top:1rem;font-size:var(--text-xs);letter-spacing:.14em;text-transform:uppercase;padding:.3rem .7rem;border-radius:999px;font-weight:600}
.tag-red{background:rgba(214,69,69,.16);color:#f08a8a;border:1px solid rgba(214,69,69,.4)}
.tag-amber{background:rgba(231,170,72,.16);color:var(--gold-soft);border:1px solid rgba(231,170,72,.4)}

/* ============ shows ============ */
.shows{display:grid;gap:1.4rem}
.show{
  display:grid;grid-template-columns:auto 1fr auto;gap:1.6rem;align-items:center;
  padding:1.7rem clamp(1.3rem,3vw,2.3rem);border:1px solid var(--line-soft);border-radius:14px;
  background:linear-gradient(120deg,var(--black-2),var(--black));transition:border-color .35s,transform .35s,background .35s;
}
.show:hover{border-color:var(--line);transform:translateX(6px)}
.show-icn{width:54px;height:54px;border-radius:12px;display:grid;place-items:center;background:rgba(231,192,116,.1);border:1px solid var(--line);color:var(--gold)}
.show-icn svg{width:26px;height:26px}
.show h3{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600}
.show .meta{font-size:var(--text-xs);letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:.3rem}
.show p{color:var(--muted);font-size:var(--text-sm);margin-top:.25rem;max-width:60ch}
.show .when{font-size:var(--text-xs);color:var(--muted-2);text-align:right;white-space:nowrap;letter-spacing:.05em}
@media (max-width:640px){.show{grid-template-columns:auto 1fr}.show .when{display:none}}

/* ============ listen ============ */
.listen{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);padding:clamp(2.4rem,5vw,4rem)}
.listen-bg{position:absolute;inset:0;z-index:0}
.listen-bg img{width:100%;height:100%;object-fit:cover;opacity:.5}
.listen-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,var(--black) 30%,rgba(10,9,8,.6))}
.listen-inner{position:relative;z-index:1;display:grid;grid-template-columns:auto 1fr;gap:clamp(1.6rem,4vw,3rem);align-items:center}
.listen-cover{width:clamp(150px,22vw,230px);border-radius:12px;border:1px solid var(--line);box-shadow:0 24px 60px rgba(0,0,0,.6)}
.listen h2{font-size:var(--text-2xl);margin:.6rem 0 1rem}
.listen p{color:var(--muted);max-width:48ch;margin-bottom:1.8rem}
.platforms{display:flex;flex-wrap:wrap;gap:.8rem}
.platform{
  display:inline-flex;align-items:center;gap:.6rem;padding:.7rem 1.15rem;border-radius:999px;
  border:1px solid var(--line);background:color-mix(in srgb,var(--black) 55%,transparent);
  font-size:var(--text-sm);color:var(--white);transition:border-color .3s,transform .3s,background .3s,color .3s
}
.platform svg{width:18px;height:18px}
.platform:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-3px)}

/* ============ press / cta ============ */
.press{text-align:center;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.press .mono{width:62px;height:62px;margin:0 auto 1.6rem;opacity:.95}
.press h2{font-size:var(--text-3xl);margin-bottom:1rem}
.press p{color:var(--muted);max-width:52ch;margin:0 auto 2.2rem;font-size:var(--text-lg)}
.press-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ============ newsletter / footer ============ */
.footer{padding-top:var(--section);background:linear-gradient(180deg,var(--black),var(--black-2))}
.news{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;
  padding:clamp(2rem,4vw,3.4rem);border:1px solid var(--line);border-radius:16px;
  background:linear-gradient(135deg,var(--black-2),var(--black-3))
}
.news h2{font-size:var(--text-2xl);margin-bottom:.8rem}
.news p{color:var(--muted);max-width:42ch}
.news form{display:flex;gap:.7rem;flex-wrap:wrap}
.news input{
  flex:1;min-width:200px;padding:.95rem 1.2rem;border-radius:999px;
  border:1px solid var(--line);background:color-mix(in srgb,var(--black) 60%,transparent);
  color:var(--white);font-size:var(--text-base)
}
.news input::placeholder{color:var(--muted-2)}
.news input:focus{outline:none;border-color:var(--gold)}
.news .note{font-size:var(--text-xs);color:var(--muted-2);margin-top:.9rem}
.news .msg{font-size:var(--text-sm);color:var(--gold);margin-top:.8rem;min-height:1.2em}

.foot-grid{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;padding-block:clamp(2.6rem,5vw,3.6rem)}
.foot-brand{display:flex;flex-direction:column;gap:1rem;max-width:34ch}
.foot-brand .lk{display:flex;align-items:center;gap:.7rem;color:var(--gold)}
.foot-brand .lk svg{width:30px;height:30px}
.foot-brand .lk span{font-family:var(--font-display);font-size:1.15rem;letter-spacing:.06em;color:var(--white)}
.foot-brand p{color:var(--muted-2);font-size:var(--text-sm)}
.socials{display:flex;gap:.8rem}
.socials a{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);transition:color .3s,border-color .3s,transform .3s}
.socials a:hover{color:var(--gold);border-color:var(--gold);transform:translateY(-3px)}
.socials svg{width:18px;height:18px}
.foot-bottom{border-top:1px solid var(--line-soft);padding-block:1.6rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;color:var(--muted-2);font-size:var(--text-xs);letter-spacing:.05em}
.foot-bottom a:hover{color:var(--gold)}

/* ============ responsive ============ */
@media (max-width:980px){
  .pillars-grid{grid-template-columns:repeat(2,1fr)}
  .about{grid-template-columns:1fr}
  .about-media{order:-1}
  .listen-inner{grid-template-columns:1fr;text-align:center}
  .listen-cover{margin:0 auto}
  .platforms{justify-content:center}
  .news{grid-template-columns:1fr}
}
@media (max-width:720px){
  .nav-links{display:none}
  .nav-cta{display:none}
  .menu-btn{display:grid;place-items:center}
  .mobile-menu{
    display:flex;position:fixed;inset:0;z-index:60;background:color-mix(in srgb,var(--black) 96%,transparent);
    backdrop-filter:blur(10px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;
    opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s,visibility .35s
  }
  .mobile-menu.open{opacity:1;visibility:visible;pointer-events:auto}
  .mobile-menu a{font-family:var(--font-display);font-size:2rem;color:var(--white)}
  .mobile-menu .close{position:absolute;top:1.4rem;right:1.6rem;background:none;border:none;color:var(--gold);cursor:pointer}

  /* mobile hero: full couple photo on top, text below (no face cropping) */
  .hero{min-height:auto;display:block;padding-top:4.8rem}
  .hero-bg{position:relative;inset:auto;width:100%;height:auto}
  .hero-bg img{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover;object-position:center 22%}
  .hero-bg::after{background:linear-gradient(0deg,var(--black) 1%,transparent 22%)}
  html[data-theme="light"] .hero-bg::after{background:linear-gradient(0deg,var(--black) 1%,transparent 22%)}
  .hero-inner{padding-top:2rem;padding-bottom:3rem}
  .hero h1{font-size:clamp(3rem,17vw,5rem)}
  .hero .tagline{color:var(--muted)}
  .hero-actions{margin-top:2rem}
  .hero-actions .btn{justify-content:center;white-space:nowrap}
  .scroll-cue{display:none}
}
@media (max-width:520px){
  .pillars-grid{grid-template-columns:1fr}
  .foot-grid{flex-direction:column;align-items:flex-start}
}
