/* MeinHochzeitsmix - 2026 redesign. Warm premium editorial wedding-music studio. */

/* ---------- Fonts (self-hosted, no Google hotlink) ---------- */
@font-face { font-family:'Fraunces'; font-style:normal; font-weight:400; font-display:swap; src:url('../fonts/fraunces-400.woff2') format('woff2'); }
@font-face { font-family:'Fraunces'; font-style:normal; font-weight:500; font-display:swap; src:url('../fonts/fraunces-500.woff2') format('woff2'); }
@font-face { font-family:'Fraunces'; font-style:normal; font-weight:600; font-display:swap; src:url('../fonts/fraunces-600.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-style:normal; font-weight:400; font-display:swap; src:url('../fonts/inter-400.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-style:normal; font-weight:500; font-display:swap; src:url('../fonts/inter-500.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-style:normal; font-weight:600; font-display:swap; src:url('../fonts/inter-600.woff2') format('woff2'); }

/* ---------- Tokens ---------- */
:root {
  --ivory:#fbf7f2; --paper:#ffffff; --ink:#1e1a17; --muted:#6e645b; --line:#eae0d5;
  --garnet:#a2425a; --garnet-dark:#832f45; --champagne:#c8a96a; --champagne-soft:#f4ecdb;
  --maxw:1140px; --radius:16px; --shadow:0 18px 50px rgba(60,38,30,.10);
  --display:'Fraunces', Georgia, serif;
  --body:'Inter', system-ui, -apple-system, sans-serif;
}

/* ---------- Base ---------- */
*,*::before,*::after { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body { margin:0; font-family:var(--body); color:var(--ink); background:var(--ivory); line-height:1.65; font-size:17px; -webkit-font-smoothing:antialiased; }
img { max-width:100%; height:auto; display:block; }
a { color:var(--garnet-dark); text-underline-offset:2px; }
a:hover { color:var(--ink); }
h1,h2,h3 { font-family:var(--display); font-weight:600; line-height:1.08; color:var(--ink); margin:0 0 .4em; letter-spacing:-.01em; }
h1 { font-size:clamp(2.3rem,6vw,4.2rem); font-weight:500; }
h2 { font-size:clamp(1.7rem,4vw,2.7rem); }
h3 { font-size:1.2rem; }
p { margin:0 0 1rem; }
:focus-visible { outline:3px solid var(--garnet); outline-offset:3px; border-radius:4px; }

.wrap { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 22px; }
.narrow { max-width:760px; }
.section { padding:72px 0; }
.center { text-align:center; }
.eyebrow { font-family:var(--body); font-weight:600; letter-spacing:.2em; text-transform:uppercase; font-size:.74rem; color:var(--garnet-dark); }
.lead { font-size:1.2rem; color:var(--muted); max-width:62ch; }
.center .lead { margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn { display:inline-block; font-family:var(--body); font-weight:600; font-size:1rem; text-decoration:none; padding:14px 26px; border-radius:999px; background:var(--garnet); color:#fff; transition:background .2s, transform .2s; }
.btn:hover { background:var(--garnet-dark); color:#fff; transform:translateY(-1px); }
.btn--ghost { background:transparent; color:var(--ink); border:1.5px solid var(--ink); }
.btn--ghost:hover { background:var(--ink); color:#fff; }

/* ---------- Header ---------- */
.site-header { position:sticky; top:0; z-index:30; background:rgba(251,247,242,.86); backdrop-filter:saturate(150%) blur(10px); border-bottom:1px solid var(--line); }
.site-header .wrap { display:flex; align-items:center; justify-content:space-between; min-height:68px; gap:16px; }
.brand { font-family:var(--display); font-weight:600; font-size:1.3rem; color:var(--ink); text-decoration:none; letter-spacing:-.01em; }
.brand b { color:var(--garnet-dark); font-weight:600; }
.nav { display:flex; gap:22px; }
.nav a { font-family:var(--body); font-weight:500; font-size:.92rem; text-decoration:none; color:var(--muted); }
.nav a:hover,.nav a[aria-current="page"] { color:var(--ink); }

/* ---------- Hero ---------- */
.hero { position:relative; color:#fff; isolation:isolate; }
.hero::before { content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(100deg, rgba(26,18,16,.74) 0%, rgba(26,18,16,.42) 46%, rgba(26,18,16,.12) 100%), url('../img/hero.jpg') center/cover no-repeat; }
.hero .wrap { padding-top:104px; padding-bottom:104px; max-width:var(--maxw); }
.hero .inner { max-width:34ch; }
.hero h1 { color:#fff; text-shadow:0 2px 28px rgba(0,0,0,.32); margin-bottom:.3em; }
.hero p.sub { color:#f6ebe6; font-size:1.22rem; max-width:38ch; }
.hero .eyebrow { color:#f0c9b8; }
.hero .hero-tag { margin-top:26px; display:inline-flex; align-items:center; gap:9px; font-family:var(--body); font-weight:500; font-size:.82rem; letter-spacing:.04em; color:#f6ebe6; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.34); border-radius:999px; padding:8px 16px; backdrop-filter:blur(4px); }
.hero .hero-tag .dot { width:7px; height:7px; border-radius:50%; background:var(--champagne); box-shadow:0 0 0 3px rgba(200,169,106,.3); flex:none; }

/* ---------- Scarcity / velvet rope ---------- */
.scarcity { background:var(--ink); color:#fff; }
.scarcity .wrap { max-width:780px; text-align:center; }
.scarcity .eyebrow { color:var(--champagne); }
.scarcity h2 { color:#fff; }
.scarcity p.big { font-size:1.22rem; color:#efe7df; max-width:58ch; margin:0 auto 1rem; }
.scarcity p.sub { color:#b8ada3; max-width:54ch; margin-inline:auto; }
.scarcity .hint { margin-top:20px; font-family:var(--body); font-size:.95rem; color:#cfc4ba; }
.scarcity .hint a { color:var(--champagne); font-weight:600; }

/* ---------- Intro ---------- */
.intro h2 { max-width:18ch; }
.intro .lead { font-size:1.28rem; color:var(--ink); }

/* ---------- USP editorial row ---------- */
.usp { display:grid; gap:30px; grid-template-columns:1fr; counter-reset:usp; }
@media (min-width:760px){ .usp { grid-template-columns:repeat(3,1fr); gap:36px; } }
.usp .item { border-top:2px solid var(--garnet); padding-top:18px; }
.usp .item .n { font-family:var(--display); font-weight:500; font-size:1rem; color:var(--garnet-dark); display:block; margin-bottom:10px; }
.usp .item h3 { margin-bottom:.35em; }
.usp .item p { color:var(--muted); margin:0; }

/* ---------- Process steps ---------- */
.process { background:var(--paper); border-block:1px solid var(--line); }
.steps { display:grid; gap:26px; grid-template-columns:1fr; margin-top:30px; }
@media (min-width:760px){ .steps { grid-template-columns:repeat(3,1fr); } }
.step { position:relative; padding:26px 24px; background:var(--ivory); border:1px solid var(--line); border-radius:var(--radius); }
.step .num { font-family:var(--display); font-weight:600; font-size:2.4rem; color:var(--champagne); line-height:1; }
.step h3 { margin:.3em 0 .25em; }
.step p { color:var(--muted); margin:0; }

/* ---------- Split (image + text) ---------- */
.split { display:grid; gap:34px; align-items:center; grid-template-columns:1fr; }
@media (min-width:860px){ .split { grid-template-columns:1.05fr .95fr; } .split--rev .media { order:2; } }
.split .media img { border-radius:var(--radius); box-shadow:var(--shadow); }

/* ---------- Trust band ---------- */
.trust { background:var(--champagne-soft); border-block:1px solid #e8d6b3; text-align:center; }
.trust .stars { color:#c79a3f; font-size:1.3rem; letter-spacing:.22em; margin:0 0 6px; }
.trust h2 { max-width:24ch; margin-inline:auto; }
.trust .quotes { display:grid; grid-template-columns:1fr; gap:22px; margin:34px 0 8px; text-align:left; }
@media (min-width:760px){ .trust .quotes { grid-template-columns:1fr 1fr; } }
.trust .quote { background:var(--paper); border:1px solid #e8d6b3; border-radius:var(--radius); padding:26px 26px 22px; box-shadow:var(--shadow); margin:0; display:flex; flex-direction:column; }
.trust .quote .stars { font-size:1rem; letter-spacing:.18em; margin:0 0 12px; }
.trust .quote blockquote { margin:0 0 16px; font-family:var(--display); font-weight:400; font-size:1.12rem; line-height:1.5; color:var(--ink); }
.trust .quote figcaption { margin-top:auto; font-family:var(--body); font-weight:600; font-size:.9rem; color:var(--garnet-dark); letter-spacing:.02em; }
.trust .stats { display:grid; grid-template-columns:1fr; gap:30px; margin-top:44px; }
@media (min-width:680px){ .trust .stats { grid-template-columns:repeat(3,1fr); gap:24px; } }
.trust .stat { padding:0 8px; }
.trust .stat .num { display:block; font-family:var(--display); font-weight:600; font-size:clamp(2.2rem,5vw,3rem); color:var(--garnet-dark); line-height:1; }
.trust .stat .lbl { display:block; margin-top:10px; font-size:.95rem; color:var(--muted); }
.trust .stat + .stat { border-top:1px solid #e8d6b3; padding-top:24px; }
@media (min-width:680px){ .trust .stat + .stat { border-top:0; border-left:1px solid #e8d6b3; padding-top:0; } }

/* ---------- Celebration band ---------- */
.band { position:relative; color:#fff; isolation:isolate; text-align:center; }
.band::before { content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg, rgba(26,18,16,.5), rgba(26,18,16,.62)), url('../img/celebration.jpg') center/cover no-repeat; }
.band .wrap { padding:96px 22px; }
.band h2 { color:#fff; max-width:20ch; margin-inline:auto; text-shadow:0 2px 24px rgba(0,0,0,.3); }
.band p { color:#f4ebe6; max-width:54ch; margin-inline:auto; }

/* ---------- Video embeds (click to load) ---------- */
.videos { display:grid; gap:22px; grid-template-columns:1fr; margin-top:30px; }
@media (min-width:760px){ .videos { grid-template-columns:1fr 1fr; } }
.embed { position:relative; aspect-ratio:16/9; border-radius:var(--radius); overflow:hidden; background:#241a17; border:1px solid var(--line); }
.embed button.embed__btn { position:absolute; inset:0; width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; background:linear-gradient(160deg,#2e2522,#1e1a17); color:#fff; border:0; cursor:pointer; font-family:var(--display); font-weight:500; font-size:1rem; }
.embed button.embed__btn:hover { background:linear-gradient(160deg,#3c302c,#241a17); }
.embed .play { width:62px; height:62px; border-radius:50%; background:var(--garnet); display:grid; place-items:center; box-shadow:0 6px 20px rgba(0,0,0,.4); }
.embed .play svg { width:24px; height:24px; fill:#fff; margin-left:4px; }
.embed small { color:#d9cfcf; font-family:var(--body); font-weight:400; }
.embed iframe { position:absolute; inset:0; width:100%; height:100%; border:0; }

/* ---------- FAQ ---------- */
.faq { max-width:780px; margin-inline:auto; }
.faq details { border-bottom:1px solid var(--line); }
.faq summary { cursor:pointer; padding:20px 4px; font-family:var(--display); font-weight:500; font-size:1.18rem; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:14px; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:"+"; color:var(--garnet-dark); font-size:1.5rem; line-height:1; flex:none; }
.faq details[open] summary::after { content:"\2013"; }
.faq .a { padding:0 4px 20px; color:var(--muted); max-width:64ch; }

/* ---------- Waitlist (hidden until activated) ---------- */
.waitlist { background:var(--ink); color:#fff; }
.waitlist .wrap { text-align:center; }
.waitlist h2 { color:#fff; }
.waitlist p { color:#d9cdc4; max-width:52ch; margin-inline:auto; }
.waitlist .btn { margin-top:18px; background:var(--champagne); color:var(--ink); }
.waitlist .btn:hover { background:#d8bd86; }

/* ---------- Status (visible now) ---------- */
.status-box { background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:34px 28px; text-align:center; box-shadow:var(--shadow); max-width:680px; margin:0 auto; }
.status-box h2 { font-size:clamp(1.5rem,3vw,2rem); }
.status-box p { color:var(--muted); max-width:50ch; margin:0 auto 6px; }

/* ---------- Legal ---------- */
.legal { max-width:760px; margin-inline:auto; }
.legal h1 { font-size:clamp(2rem,5vw,2.8rem); }
.legal h2 { font-size:1.25rem; margin-top:1.7em; }
.legal address { font-style:normal; line-height:1.85; }
.legal .draft { background:#fff7e6; border:1px solid #f0d488; border-radius:10px; padding:14px 18px; color:#7a5a14; font-size:.95rem; margin-bottom:24px; }
.back { display:inline-block; margin-top:26px; font-family:var(--body); font-weight:600; }

/* ---------- Footer ---------- */
.site-footer { border-top:1px solid var(--line); background:var(--paper); padding:36px 0; }
.site-footer .wrap { display:flex; flex-wrap:wrap; gap:12px 24px; align-items:center; justify-content:space-between; }
.site-footer nav { display:flex; gap:20px; flex-wrap:wrap; }
.site-footer a { font-family:var(--body); font-weight:500; font-size:.9rem; text-decoration:none; color:var(--muted); }
.site-footer a:hover { color:var(--ink); }
.site-footer .copy { color:var(--muted); font-size:.85rem; }

@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } .btn:hover{ transform:none; } }
