*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --purple: #7B4FA6; --purple-light: #A67DC8; --purple-pale: #F3EEF9; --purple-dark: #4A2870;
  --gold: #C9A84C; --gold-light: #F0D98A;
  --white: #FEFEFE; --off-white: #FAF8FC;
  --text: #1A1020; --text-mid: #4A3D5A; --text-light: #8A7A9A; --border: #E2D5F0;
}
body { font-family:'DM Sans',sans-serif; background:var(--white); color:var(--text); font-size:16px; line-height:1.7; overflow-x:hidden; padding-bottom:70px; }
h1,h2,h3,h4 { font-family:'Playfair Display',serif; line-height:1.2; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }

.ann-bar { background:var(--purple-dark); color:#fff; text-align:center; padding:10px 20px; font-size:14px; font-weight:500; }
.ann-bar span { color:var(--gold-light); font-weight:700; }

header { background:var(--white); border-bottom:1px solid var(--border); padding:14px 24px; display:flex; align-items:center; justify-content:space-between; position:sticky; top:0; z-index:100; box-shadow:0 2px 12px rgba(123,79,166,0.08); }
.logo { font-family:'Playfair Display',serif; font-size:26px; font-weight:700; color:var(--purple-dark); }
.logo span { color:var(--gold); }
nav { display:flex; gap:28px; }
nav a { font-size:14px; font-weight:500; color:var(--text-mid); transition:color 0.2s; }
nav a:hover { color:var(--purple); }
.header-cta { background:var(--purple); color:#fff; padding:10px 22px; border-radius:100px; font-size:14px; font-weight:600; border:none; cursor:pointer; display:inline-block; transition:background 0.2s; }
.header-cta:hover { background:var(--purple-dark); color:#fff; }

.urgency-bar { background:linear-gradient(135deg,#2D1246,#5A2A80); color:#fff; text-align:center; padding:14px 20px; font-size:15px; }
.t-wrap { display:inline-flex; gap:8px; margin-left:12px; vertical-align:middle; }
.t-box { background:rgba(255,255,255,0.15); border-radius:6px; padding:4px 10px; font-size:18px; font-weight:700; font-family:'Playfair Display',serif; min-width:44px; text-align:center; }
.t-lbl { font-size:10px; opacity:0.7; display:block; font-weight:400; letter-spacing:0.5px; }

.sec-label { font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--purple); margin-bottom:12px; display:block; text-align:center; }
.sec-title { font-size:clamp(26px,4vw,42px); color:var(--purple-dark); text-align:center; margin-bottom:16px; font-weight:700; }
.sec-sub { text-align:center; color:var(--text-mid); font-size:17px; max-width:580px; margin:0 auto 48px; }

.btn-primary { background:var(--purple); color:#fff; border:none; padding:18px 48px; border-radius:100px; font-family:'DM Sans',sans-serif; font-size:18px; font-weight:600; cursor:pointer; display:inline-block; box-shadow:0 6px 30px rgba(123,79,166,0.35); transition:all 0.2s; }
.btn-primary:hover { background:var(--purple-dark); transform:translateY(-2px); color:#fff; }
.btn-gold { background:var(--gold); color:#fff; border:none; padding:18px 52px; border-radius:100px; font-family:'DM Sans',sans-serif; font-size:18px; font-weight:700; cursor:pointer; box-shadow:0 6px 28px rgba(201,168,76,0.4); transition:all 0.2s; display:inline-block; }
.btn-gold:hover { background:#B8952C; transform:translateY(-2px); color:#fff; }

.trust-row { display:flex; justify-content:center; gap:28px; margin-top:16px; flex-wrap:wrap; }
.trust-item { display:flex; align-items:center; gap:6px; font-size:13px; color:var(--text-mid); }
.trust-item img { width:16px; height:16px; }

.cta-break { background:linear-gradient(135deg,#F3EEF9,#EAE0F5); padding:52px 24px; text-align:center; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.ship-label { font-size:13px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--purple); margin-bottom:14px; }

.sticky-cta { position:fixed; bottom:0; left:0; right:0; background:var(--purple-dark); color:#fff; padding:14px 24px; display:flex; align-items:center; justify-content:space-between; z-index:200; box-shadow:0 -4px 20px rgba(0,0,0,0.2); gap:16px; }
.sticky-cta p { font-size:14px; color:rgba(255,255,255,0.85); margin:0; }
.sticky-cta strong { color:var(--gold-light); }
.sticky-btn { background:var(--gold); color:#fff; border:none; padding:11px 28px; border-radius:100px; font-family:'DM Sans',sans-serif; font-size:14px; font-weight:700; cursor:pointer; white-space:nowrap; flex-shrink:0; }

footer { background:#0F0A18; padding:56px 24px 40px; }
.footer-inner { max-width:1000px; margin:0 auto; display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; margin-bottom:40px; }
.footer-logo { font-family:'Playfair Display',serif; font-size:22px; font-weight:700; color:rgba(255,255,255,0.5); margin-bottom:14px; }
.footer-logo span { color:var(--gold); }
.footer-desc { font-size:14px; color:rgba(255,255,255,0.3); line-height:1.7; max-width:240px; }
.footer-col h4 { font-family:'DM Sans',sans-serif; font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.35); margin-bottom:16px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul li a { font-size:14px; color:rgba(255,255,255,0.45); transition:color 0.2s; }
.footer-col ul li a:hover { color:rgba(255,255,255,0.8); }
.footer-bottom { max-width:1000px; margin:0 auto; border-top:1px solid rgba(255,255,255,0.07); padding-top:28px; }
.footer-disclaimer { font-size:12px; color:rgba(255,255,255,0.2); line-height:1.7; max-width:740px; margin-bottom:12px; }
.footer-copy { font-size:12px; color:rgba(255,255,255,0.15); }

.page-hero { background:linear-gradient(160deg,#F3EEF9,#EAE0F5); padding:60px 24px; text-align:center; border-bottom:1px solid var(--border); }
.page-hero h1 { font-size:clamp(28px,4vw,44px); color:var(--purple-dark); margin-bottom:12px; }
.page-hero p { font-size:17px; color:var(--text-mid); max-width:500px; margin:0 auto; }
.page-content { max-width:780px; margin:0 auto; padding:60px 24px; }
.page-content h2 { font-size:24px; color:var(--purple-dark); margin:36px 0 12px; }
.page-content p { font-size:16px; color:var(--text-mid); margin-bottom:16px; line-height:1.8; }
.page-content ul,.page-content ol { margin:0 0 20px 24px; color:var(--text-mid); font-size:16px; line-height:1.8; }
.page-content li { margin-bottom:8px; }

.ugc-ph { background:linear-gradient(135deg,#3D1A6E,#7B4FA6); border-radius:16px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; position:relative; overflow:hidden; cursor:pointer; }
.ugc-ph .play { width:52px; height:52px; background:rgba(255,255,255,0.2); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:20px; color:#fff; padding-left:4px; }
.ugc-ph .ph-note { font-size:11px; color:rgba(255,255,255,0.35); font-family:'DM Sans',sans-serif; position:absolute; bottom:10px; left:12px; }

.faq-item { border-bottom:1px solid var(--border); padding:22px 0; }
.faq-q { font-family:'DM Sans',sans-serif; font-size:17px; font-weight:600; color:var(--text); cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq-q::after { content:'+'; font-size:22px; color:var(--purple); flex-shrink:0; transition:transform 0.2s; }
.faq-item.open .faq-q::after { content:'−'; }
.faq-a { font-size:15px; color:var(--text-mid); line-height:1.7; max-height:0; overflow:hidden; transition:max-height 0.3s ease,padding 0.3s; }
.faq-item.open .faq-a { max-height:300px; padding-top:14px; }

@media(max-width:768px) { .footer-inner{grid-template-columns:1fr 1fr;gap:28px;} nav{display:none;} }
@media(max-width:480px) { .footer-inner{grid-template-columns:1fr;} }
