:root{
  --bg:#0f0c0b; --bg2:#181210; --card:#1d1611; --line:#312820;
  --txt:#efe9e2; --muted:#a59685; --accent:#d99a48; --accent2:#d4708a;
  --rad:18px; --max:1120px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--txt);font-family:Poppins,system-ui,sans-serif;line-height:1.6;
  background-image:radial-gradient(1200px 600px at 75% -10%,rgba(217,154,72,.13),transparent 60%),radial-gradient(900px 500px at 10% 10%,rgba(212,112,138,.07),transparent 55%);
  background-attachment:fixed}
.g{font-family:"Playfair Display",serif;font-weight:800;letter-spacing:-.01em;line-height:1.05}
.wrap{max-width:var(--max);margin:0 auto;padding:0 22px}
.narrow{max-width:760px}
a{color:inherit;text-decoration:none}
.accent{color:var(--accent)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;font-weight:600;font-size:15px;
  padding:13px 24px;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:.18s;white-space:nowrap}
.btn-red{background:linear-gradient(135deg,#e0a64e,#c2812f);color:#1a1208;box-shadow:0 8px 24px rgba(217,154,72,.30)}
.btn-red:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(217,154,72,.45)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--txt)}
.btn-ghost:hover{border-color:var(--accent);color:#fff}
.btn.sm{padding:10px 18px;font-size:14px}
.btn.big{padding:17px 40px;font-size:17px}

/* 18+ gate */
#gate{position:fixed;inset:0;z-index:99;background:rgba(8,6,10,.97);display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(6px)}
#gate .box{max-width:480px;text-align:center;background:var(--card);border:1px solid var(--line);border-radius:var(--rad);padding:42px 32px}
#gate h1{font-size:64px;margin:6px 0 14px}
#gate p{color:var(--muted);margin-bottom:24px}
#gate .row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* logo / header */
.logo{font-family:"Playfair Display",serif;font-weight:900;font-size:24px;letter-spacing:-.02em}
.logo .accent{font-style:italic}
.top{position:sticky;top:0;z-index:40;background:rgba(14,12,16,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.top .wrap{display:flex;align-items:center;justify-content:space-between;height:68px}

.eyebrow{text-transform:uppercase;letter-spacing:.22em;font-size:12px;font-weight:600;color:var(--accent2);margin-bottom:14px}

/* hero */
.hero{padding:86px 0 64px;text-align:center}
.hero h1{font-size:clamp(48px,9vw,104px)}
.hero .lead{max-width:680px;margin:22px auto 30px;color:#d6cede;font-size:19px}

/* grid */
.grid-sec{padding:42px 0 60px}
.grid-sec h2{font-size:clamp(30px,5vw,46px)}
.grid-sec .sub{color:var(--muted);margin:8px 0 36px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:860px){.cards{grid-template-columns:1fr;max-width:420px;margin:0 auto}}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--rad);overflow:hidden;transition:.22s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);border-color:rgba(217,154,72,.5);box-shadow:0 18px 44px rgba(0,0,0,.5)}
.card .ph{position:relative;aspect-ratio:3/4;overflow:hidden}
.card .ph img{width:100%;height:100%;object-fit:cover;display:block;transition:.4s}
.card:hover .ph img{transform:scale(1.05)}
.card .tag{position:absolute;left:12px;bottom:12px;background:rgba(14,12,16,.8);border:1px solid var(--line);color:var(--txt);font-size:12px;font-weight:600;padding:6px 12px;border-radius:999px;backdrop-filter:blur(4px)}
.card .bd{padding:22px 22px 24px;display:flex;flex-direction:column;gap:12px;flex:1}
.card .bd h3{font-family:"Playfair Display",serif;font-size:25px;font-weight:700}
.card .bd p{color:var(--muted);font-size:15px;flex:1}
.card .cta{display:flex;gap:10px;flex-wrap:wrap}
.card .cta .btn{flex:1;padding:12px 14px;font-size:14px}

/* guide + faq */
.guide,.faq{padding:56px 0;border-top:1px solid var(--line)}
.guide h2,.faq h2{font-size:clamp(28px,4.5vw,40px);margin-bottom:18px}
.guide p{color:#cfc6d6;margin-bottom:16px;font-size:16.5px}
.guide b{color:#fff}
.faq details{border:1px solid var(--line);border-radius:14px;padding:4px 20px;margin-bottom:12px;background:var(--bg2)}
.faq summary{cursor:pointer;font-weight:600;padding:16px 0;list-style:none;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:0;color:var(--accent);font-size:22px;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--muted);padding:0 0 18px;font-size:15px}

/* band + footer */
.band{padding:72px 0;text-align:center;border-top:1px solid var(--line);
  background:radial-gradient(700px 300px at 50% 0,rgba(217,154,72,.15),transparent 65%)}
.band h2{font-size:clamp(30px,5vw,48px)}
.band p{color:#d6cede;margin:14px 0 28px;font-size:18px}
footer{border-top:1px solid var(--line);padding:46px 0;text-align:center}
footer .logo{display:inline-block;margin-bottom:18px}
.fnav{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;margin-bottom:18px}
.fnav a{color:var(--muted);font-size:14px;transition:.15s}
.fnav a:hover{color:var(--accent)}
footer p{color:var(--muted);font-size:13px;letter-spacing:.02em}
footer .muted a{color:var(--accent2)}
