:root {
  --red: #a31f23;
  --red-dark: #8a1a1d;
  --cream: #f4ecdd;
  --cream-2: #faf5ea;
  --ink: #2a1713;
  --ink-soft: #6b574f;
  --gold: #c9a24b;
  --serif: 'Playfair Display', Georgia, serif;
  --body: 'Inter', system-ui, sans-serif;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 90px; }
body { font-family: var(--body); background: var(--cream); color: var(--ink); line-height: 1.65; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
img { display: block; max-width: 100%; }
.serif { font-family: var(--serif); font-weight: 800; line-height: 1.05; }
.serif em { font-style: italic; font-weight: 400; }

.skip-link { position:absolute; left:-999px; }
.skip-link:focus { left:8px; top:8px; background:var(--red); color:#fff; padding:8px 14px; z-index:999; }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }
.js .reveal { opacity:0; transform: translateY(26px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.js .reveal.is-visible { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} .js .reveal{opacity:1!important;transform:none!important} }

.btn { display:inline-flex; align-items:center; justify-content:center; padding:.9rem 2rem; border-radius:2rem; background:var(--red); color:var(--cream); font-weight:600; font-size:.92rem; letter-spacing:.02em; border:1px solid var(--red); cursor:pointer; transition:all .25s var(--ease); }
@media (hover: hover) { .btn:hover { background:var(--red-dark); border-color:var(--red-dark); transform:translateY(-2px); } }
.btn-light { background:var(--cream); color:var(--red); border-color:var(--cream); }
@media (hover: hover) { .btn-light:hover { background:#fff; } }

/* Header */
#siteHeader { position:sticky; top:0; z-index:100; background:var(--red); color:var(--cream); transition: box-shadow .3s; }
#siteHeader.scrolled { box-shadow: 0 6px 24px rgba(0,0,0,.25); }
.head-inner { max-width:1280px; margin:0 auto; padding:1rem 2rem; display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:1rem; }
.brand { font-family:var(--serif); font-weight:800; font-size:1.5rem; letter-spacing:.02em; }
.nav-links { display:flex; gap:.6rem; justify-content:center; }
.nav-links a { font-size:.85rem; font-weight:500; padding:.45rem 1.1rem; border:1px solid rgba(244,236,221,.4); border-radius:2rem; transition:all .2s; }
@media (hover: hover) { .nav-links a:hover { background:var(--cream); color:var(--red); } }
.nav-links a.pill-new { background:var(--cream); color:var(--red); border-color:var(--cream); font-weight:600; }
.head-actions { display:flex; gap:.5rem; align-items:center; justify-content:flex-end; }
.head-icon { width:38px; height:38px; display:inline-flex; align-items:center; justify-content:center; border:1px solid rgba(244,236,221,.4); border-radius:50%; font-size:1rem; transition:all .2s; }
@media (hover: hover) { .head-icon:hover { background:var(--cream); color:var(--red); } }
.mobile-menu-btn { display:none; background:none; border:none; cursor:pointer; width:40px; height:40px; align-items:center; justify-content:center; }
.burger, .burger::before, .burger::after { content:""; display:block; width:24px; height:2px; background:var(--cream); transition:transform .3s var(--ease), opacity .2s; }
.burger { position:relative; }
.burger::before { position:absolute; top:-7px; } .burger::after { position:absolute; top:7px; }
#siteHeader.nav-open .burger { background:transparent; }
#siteHeader.nav-open .burger::before { transform:translateY(7px) rotate(45deg); }
#siteHeader.nav-open .burger::after { transform:translateY(-7px) rotate(-45deg); }

/* Hero */
.hero { background:var(--red); color:var(--cream); text-align:center; padding:4rem 2rem 0; overflow:hidden; }
.hero-title { font-family:var(--serif); font-size:clamp(3rem,10vw,8rem); line-height:.95; letter-spacing:.04em; margin-bottom:1.5rem; }
.hero-title .bold { font-weight:800; } .hero-title .thin { font-weight:400; letter-spacing:.18em; }
.hero-sub { max-width:620px; margin:0 auto 3rem; color:rgba(244,236,221,.85); font-size:1.05rem; }
.hero-row { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; max-width:1100px; margin:0 auto; transform:translateY(1px); }
.hero-row img { width:100%; height:320px; object-fit:cover; border-radius:1rem 1rem 0 0; }

/* Proof */
.proof { max-width:1180px; margin:0 auto; padding:6rem 2rem; display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.proof-img { position:relative; }
.proof-img img { width:100%; height:480px; object-fit:cover; border-radius:1.2rem; }
.proof-img::after { content:""; position:absolute; inset:-12px; border:2px solid var(--gold); border-radius:1.4rem; z-index:-1; }
.proof-text h2 { font-size:clamp(2.2rem,4.5vw,3.4rem); color:var(--red); margin-bottom:1.5rem; }
.proof-text p { color:var(--ink-soft); margin-bottom:1.2rem; font-size:1.05rem; }
.proof-text .btn { margin-top:1rem; }

/* Sellers */
.sellers { background:var(--cream-2); padding:6rem 2rem; }
.sellers-head { display:flex; align-items:center; gap:2rem; justify-content:center; max-width:1100px; margin:0 auto 3.5rem; }
.sellers-head h2 { font-size:clamp(2rem,4vw,3rem); color:var(--red); white-space:nowrap; }
.sellers-head .rule { flex:1; height:1px; background:var(--red); opacity:.35; }
.seller-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; max-width:1180px; margin:0 auto; }
.seller { background:var(--cream); border-radius:1.2rem; padding:1.5rem; text-align:center; transition:transform .3s var(--ease), box-shadow .3s; }
@media (hover: hover) { .seller:hover { transform:translateY(-6px); box-shadow:0 20px 40px rgba(163,31,35,.14); } }
.seller-img { aspect-ratio:1; border-radius:1rem; overflow:hidden; margin-bottom:1.3rem; background:#e7ddca; }
.seller-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
@media (hover: hover) { .seller:hover .seller-img img { transform:scale(1.06); } }
.tag { display:inline-block; font-family:var(--serif); font-size:1.15rem; font-weight:600; color:var(--red); border:1px solid var(--red); border-radius:2rem; padding:.3rem 1.2rem; margin-bottom:.9rem; }
.seller p { font-size:.9rem; color:var(--ink-soft); margin-bottom:1rem; min-height:2.6em; }
.price { font-family:var(--serif); font-weight:800; font-size:1.3rem; color:var(--ink); }

/* Magic */
.magic { background:var(--red); color:var(--cream); padding:6rem 2rem; text-align:center; }
.magic h2 { font-size:clamp(2.2rem,5vw,3.6rem); margin-bottom:1rem; }
.magic-sub { max-width:560px; margin:0 auto 3rem; color:rgba(244,236,221,.8); }
.magic-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; max-width:1100px; margin:0 auto; }
.magic-grid img { width:100%; height:420px; object-fit:cover; border-radius:1.2rem; }

/* Steps */
.steps { max-width:1100px; margin:0 auto; padding:6rem 2rem; display:grid; grid-template-columns:repeat(3,1fr); gap:2.5rem; }
.step { text-align:center; padding:0 1rem; }
.step-n { font-family:var(--serif); font-size:2.4rem; font-weight:800; color:var(--gold); display:block; margin-bottom:.6rem; }
.step h3 { font-family:var(--serif); font-size:1.5rem; color:var(--red); margin-bottom:.6rem; }
.step p { color:var(--ink-soft); font-size:.98rem; }

/* Collect */
.collect { background:var(--cream-2); padding:6rem 2rem; display:grid; grid-template-columns:1.3fr 1fr; gap:4rem; align-items:center; max-width:1180px; margin:0 auto; }
.collect-text h2 { font-size:clamp(2.2rem,4.5vw,3.4rem); color:var(--red); margin-bottom:1.3rem; }
.collect-text p { color:var(--ink-soft); margin-bottom:1.8rem; max-width:460px; }
.collect-form { display:flex; gap:.8rem; max-width:440px; flex-wrap:wrap; }
.collect-form input { flex:1; min-width:200px; padding:.9rem 1.2rem; border:1px solid #d8cdb8; border-radius:2rem; background:var(--cream); font-family:var(--body); font-size:.95rem; }
.collect-form input:focus { outline:none; border-color:var(--red); }
.form-note { margin-top:1rem; color:var(--red); font-weight:500; }
.collect-badge { position:relative; display:flex; justify-content:center; }
.collect-badge img { width:78%; aspect-ratio:1; object-fit:cover; border-radius:50%; }
.badge-ring { position:absolute; top:-12px; right:0; width:120px; height:120px; border-radius:50%; background:var(--red); color:var(--cream); display:flex; align-items:center; justify-content:center; z-index:2; animation:spin 14s linear infinite; }
.badge-svg { position:absolute; inset:0; width:100%; height:100%; }
.badge-svg text { text-transform:uppercase; }
.badge-star { width:20px; height:20px; }
@keyframes spin { to { transform:rotate(360deg); } }
@media (prefers-reduced-motion: reduce){ .badge-ring{ animation:none; } }

/* Footer */
.site-footer { background:var(--ink); color:rgba(244,236,221,.85); padding:4.5rem 2rem 2rem; }
.foot-grid { max-width:1180px; margin:0 auto; display:grid; grid-template-columns:1.8fr 1fr 1fr 1fr; gap:2.5rem; padding-bottom:3rem; border-bottom:1px solid rgba(244,236,221,.15); }
.foot-brand .brand { color:var(--cream); font-size:1.7rem; }
.foot-brand p { margin-top:1rem; font-size:.92rem; max-width:280px; opacity:.8; }
.foot-col h4 { font-family:var(--serif); color:var(--cream); font-size:1.1rem; margin-bottom:1rem; }
.foot-col li { font-size:.92rem; margin-bottom:.55rem; opacity:.85; }
@media (hover: hover) { .foot-col a:hover { color:var(--gold); } }
.foot-bottom { max-width:1180px; margin:0 auto; display:flex; justify-content:space-between; padding-top:1.6rem; font-size:.82rem; opacity:.7; gap:1rem; flex-wrap:wrap; }
.legal { display:flex; gap:1.2rem; }
@media (hover: hover) { .legal a:hover { color:var(--gold); } }

@media (max-width:980px){
  .proof, .collect { grid-template-columns:1fr; gap:2.5rem; }
  .magic-grid { grid-template-columns:1fr; }
  .seller-grid { grid-template-columns:1fr 1fr; }
  .foot-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:600px){
  .head-inner { grid-template-columns:auto 1fr auto; }
  .nav-links { display:none; position:absolute; top:100%; left:0; width:100%; flex-direction:column; gap:0; background:var(--red-dark); padding:.5rem 2rem 1rem; }
  #siteHeader.nav-open .nav-links { display:flex; }
  .nav-links a { border:none; border-bottom:1px solid rgba(244,236,221,.2); border-radius:0; padding:.85rem 0; text-align:center; }
  .mobile-menu-btn { display:flex; }
  .hero-row { grid-template-columns:1fr 1fr; }
  .hero-row img:nth-child(3) { display:none; }
  .hero-row img { height:200px; }
  .proof, .sellers, .magic, .steps, .collect { padding: 2.5rem 1.5rem; }
  .steps { grid-template-columns:1fr; gap:2rem; }
  .seller-grid { grid-template-columns:1fr 1fr; gap:1.2rem; }
  .collect-form { flex-direction: column; }
  .collect-form input { min-width: 0; flex: 1 1 auto; }
  .collect-form .btn-light { width: 100%; }
  .foot-grid { grid-template-columns:1fr 1fr; }
  .foot-brand { grid-column:1 / -1; }
  .badge-ring { width:90px; height:90px; }
}
@media (max-width:480px){ .seller-grid { grid-template-columns:1fr; } .foot-grid { grid-template-columns:1fr; } }
