@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;1,400&family=DM+Sans:wght@300;400;500&display=swap');

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--cream);color:var(--text);min-height:100vh;overflow-x:hidden}
img{max-width:100%;display:block}
button,input,textarea,select{font-family:inherit}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--cream)}
::-webkit-scrollbar-thumb{background:var(--red);border-radius:4px}
h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.2}
h1{font-size:clamp(2rem,7vw,3.2rem)}
h2{font-size:clamp(1.4rem,4vw,2rem)}

/* ── Layout ── */
.page{display:none}.page.active{display:block}
.mb-80{margin-bottom:80px}.text-center{text-align:center}
#snow-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;opacity:0.7}

/* ── Nav ── */
.nav{position:sticky;top:0;z-index:100;background:var(--nav-bg);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:12px 20px;display:flex;align-items:center;justify-content:space-between}
.nav-brand{font-family:var(--font-display);font-size:1.1rem;color:var(--red);cursor:pointer;display:flex;align-items:center;gap:6px}
.nav-brand .star{color:var(--gold);animation:twinkle 2.4s ease-in-out infinite}
@keyframes twinkle{0%,100%{opacity:1;transform:scale(1) rotate(0deg)}50%{opacity:.5;transform:scale(.8) rotate(20deg)}}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-btn{background:none;border:1px solid var(--border);border-radius:50px;padding:6px 12px;font-size:.75rem;cursor:pointer;color:var(--text);transition:.2s}
.nav-btn:hover{background:var(--red);color:#fff;border-color:var(--red)}
.cart-btn{position:relative;background:var(--red);color:#fff;border:none;border-radius:50%;width:38px;height:38px;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s}
.cart-btn:hover{background:var(--red-light);transform:scale(1.05)}
.cart-count{position:absolute;top:-5px;right:-5px;background:var(--gold);color:var(--dark);width:18px;height:18px;border-radius:50%;font-size:.6rem;font-weight:500;display:none;align-items:center;justify-content:center}
.cart-count.show{display:flex}

/* ── Bottom nav ── */
.bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;background:var(--bnav-bg);backdrop-filter:blur(12px);border-top:1px solid var(--border);display:flex;z-index:200}
.bnav-item{flex:1;padding:10px 4px 14px;text-align:center;cursor:pointer;transition:.15s;color:var(--muted);font-size:.6rem;border:none;background:none;display:flex;flex-direction:column;align-items:center;gap:3px}
.bnav-item.active{color:var(--red)}
.bnav-icon{font-size:1.3rem}

/* ── Toast ── */
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--dark);color:#fff;padding:10px 20px;border-radius:50px;font-size:.78rem;opacity:0;transition:.3s;z-index:500;pointer-events:none;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── Footer ── */
.footer{background:var(--dark);color:rgba(255,255,255,.6);padding:28px 20px;font-size:.75rem;text-align:center;line-height:1.8;position:relative;z-index:1}
.footer-brand{font-family:var(--font-display);font-size:1.1rem;color:#fff;margin-bottom:8px}
.footer-links{display:flex;justify-content:center;gap:20px;margin-bottom:12px}
.footer-link{color:rgba(255,255,255,.6);text-decoration:none;cursor:pointer}
.footer-link:hover{color:#fff}

/* ── Hero ── */
.hero{position:relative;color:#fff;overflow:hidden;text-align:center;z-index:1}
.hero-img-wrap{position:relative;width:100%;overflow:hidden}
.hero-img-wrap svg{display:block;width:100%;max-height:260px}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,0.25) 0%,rgba(0,0,0,0.55) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px 20px}
.hero-eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.15em;opacity:.85;margin-bottom:10px;background:rgba(0,0,0,.2);padding:4px 12px;border-radius:20px}
.hero h1{font-style:italic;margin-bottom:10px;text-shadow:0 2px 20px rgba(0,0,0,.5)}
.hero-sub{font-size:.9rem;opacity:.9;max-width:300px;margin:0 auto 24px;line-height:1.6;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.hero-cta{display:inline-block;background:var(--gold-light);color:var(--dark);padding:12px 32px;border-radius:50px;font-weight:500;font-size:.88rem;cursor:pointer;border:none;text-decoration:none;transition:.25s;animation:pulse-gold 3s ease-in-out infinite}
.hero-cta:hover{background:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
@keyframes pulse-gold{0%,100%{box-shadow:0 0 0 0 rgba(212,160,23,.5)}50%{box-shadow:0 0 0 12px rgba(212,160,23,0)}}
.hero-sound{position:absolute;top:12px;right:12px;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);color:#fff;padding:5px 12px;border-radius:20px;font-size:.68rem;cursor:pointer;z-index:2}

/* ── Section header ── */
.section-wrap{padding:24px 20px;position:relative;z-index:1}
.section-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:6px}
.section-title-text{font-family:var(--font-display);font-size:1.25rem;color:var(--text);margin-bottom:14px}

/* ── Size picker ── */
.size-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.size-card{border:1.5px solid var(--border);border-radius:var(--r);padding:14px 8px;text-align:center;cursor:pointer;transition:.2s;background:var(--card-bg);position:relative}
.size-card:hover{border-color:var(--red);transform:translateY(-2px)}
.size-card.active{border-color:var(--red);background:rgba(155,28,28,.05);box-shadow:0 0 0 3px rgba(155,28,28,.1)}
.size-card.active::after{content:'✓';position:absolute;top:-8px;right:-8px;background:var(--red);color:#fff;width:20px;height:20px;border-radius:50%;font-size:.65rem;display:flex;align-items:center;justify-content:center}
.size-emoji{font-size:2rem;margin-bottom:6px}
.size-name{font-weight:500;font-size:.85rem;margin-bottom:2px}
.size-desc{font-size:.7rem;color:var(--muted);margin-bottom:6px}
.size-price{font-size:.9rem;font-weight:500;color:var(--red)}

/* ── Trust bar ── */
.trust-bar{display:flex;overflow-x:auto;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--card-bg);padding:12px 0;scrollbar-width:none}
.trust-bar::-webkit-scrollbar{display:none}
.trust-item{flex:1;min-width:70px;text-align:center;padding:0 10px;border-right:1px solid var(--border)}
.trust-item:last-child{border-right:none}
.trust-icon{font-size:1.3rem;margin-bottom:4px}
.trust-label{font-size:.65rem;color:var(--muted);line-height:1.3}

/* ── Products ── */
.product-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.product-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:.2s;position:relative}
.product-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.product-img{aspect-ratio:1;background:var(--cream-dark);display:flex;align-items:center;justify-content:center;font-size:3.5rem;position:relative;overflow:hidden}
.product-badge{position:absolute;top:8px;left:8px;background:var(--red);color:#fff;font-size:.6rem;font-weight:500;padding:3px 8px;border-radius:20px;z-index:1;text-transform:uppercase}
.product-body{padding:10px 12px 0}
.product-name{font-size:.85rem;font-weight:500;margin-bottom:2px}
.product-tagline{font-size:.7rem;color:var(--muted);margin-bottom:8px;line-height:1.4}
.product-price{font-size:.8rem;color:var(--red);font-weight:500;margin-bottom:10px}
.product-add{width:100%;padding:9px;background:var(--green);color:#fff;border:none;font-size:.75rem;font-weight:500;cursor:pointer;transition:.2s}
.product-add:hover{background:var(--green-light)}

/* ── Featured banner ── */
.featured-banner{margin:0 20px 24px;background:linear-gradient(135deg,var(--green),var(--green-light));border-radius:var(--r);padding:20px;color:#fff;position:relative;overflow:hidden;z-index:1}
.featured-banner::before{content:'🎄';position:absolute;right:-10px;bottom:-10px;font-size:5rem;opacity:.15}
.featured-tag{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;opacity:.75;margin-bottom:6px}
.featured-title{font-family:var(--font-display);font-size:1.2rem;margin-bottom:6px}
.featured-sub{font-size:.78rem;opacity:.85;margin-bottom:14px;line-height:1.5}
.featured-btn{display:inline-block;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.4);color:#fff;padding:8px 20px;border-radius:50px;font-size:.75rem;cursor:pointer;transition:.2s}
.featured-btn:hover{background:rgba(255,255,255,.35)}

/* ── PDP ── */
.pdp-back{padding:14px 20px 0;position:relative;z-index:1}
.back-link{background:none;border:1px solid var(--border);border-radius:50px;padding:6px 14px;font-size:.75rem;cursor:pointer;color:var(--text);transition:.2s;display:inline-flex;align-items:center;gap:6px}
.back-link:hover{background:var(--red);color:#fff;border-color:var(--red)}
.pdp-hero{aspect-ratio:4/3;background:var(--cream-dark);display:flex;align-items:center;justify-content:center;font-size:6rem;margin:14px 0 0;position:relative;overflow:hidden}
/* Analytics — ADMIN ONLY, never shown to public */
.pdp-analytics{display:none}
.admin-mode .pdp-analytics{display:grid;grid-template-columns:repeat(3,1fr);background:var(--dark);color:#fff}
.pdp-stat{text-align:center;padding:10px 4px;border-right:1px solid rgba(255,255,255,.1)}
.pdp-stat:last-child{border-right:none}
.pdp-stat-val{font-size:1.1rem;font-weight:500;display:block}
.pdp-stat-lbl{font-size:.6rem;opacity:.6;text-transform:uppercase;letter-spacing:.05em}
.pdp-stat-val.views{color:#60A5FA}.pdp-stat-val.clicks{color:#4ADE80}.pdp-stat-val.lost{color:#F87171}
.pdp-body{padding:20px;position:relative;z-index:1}
.pdp-title{font-size:1.5rem;margin-bottom:4px}
.pdp-sub{font-size:.8rem;color:var(--muted);margin-bottom:20px;line-height:1.5}
.pdp-size-label{font-size:.75rem;font-weight:500;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}
.pdp-sizes{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px}
.pdp-size{border:1.5px solid var(--border);border-radius:var(--r-sm);padding:12px 6px;text-align:center;cursor:pointer;transition:.2s;background:var(--card-bg)}
.pdp-size:hover{border-color:var(--red)}
.pdp-size.selected{border-color:var(--red);background:rgba(155,28,28,.05)}
.pdp-size-name{font-size:.8rem;font-weight:500;margin-bottom:2px}
.pdp-size-qty{font-size:.65rem;color:var(--muted);margin-bottom:4px}
.pdp-size-price{font-size:.9rem;color:var(--red);font-weight:500}
.pdp-desc{font-size:.85rem;color:var(--muted);line-height:1.7;margin-bottom:20px;padding:14px;background:var(--cream-dark);border-radius:var(--r-sm)}
.btn-paypal{width:100%;padding:15px;border-radius:50px;background:#0070BA;color:#fff;border:none;font-size:.95rem;font-weight:500;cursor:pointer;margin-bottom:10px;transition:.2s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-paypal:hover{background:#005EA6;transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,112,186,.3)}
.btn-cart{width:100%;padding:14px;border-radius:50px;background:var(--green);color:#fff;border:none;font-size:.95rem;font-weight:500;cursor:pointer;transition:.2s;margin-bottom:24px}
.btn-cart:hover{background:var(--green-light);transform:translateY(-1px)}

/* ── Cart ── */
.cart-page{padding:20px;position:relative;z-index:1;min-height:60vh}
.cart-title{font-size:1.4rem;margin-bottom:20px}
.cart-empty{text-align:center;padding:60px 20px;color:var(--muted)}
.cart-empty-icon{font-size:4rem;margin-bottom:16px}
.cart-item{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border);align-items:center}
.cart-item-img{width:56px;height:56px;background:var(--cream-dark);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:1.8rem;flex-shrink:0;overflow:hidden}
.cart-item-info{flex:1}
.cart-item-name{font-size:.85rem;font-weight:500;margin-bottom:2px}
.cart-item-size{font-size:.7rem;color:var(--muted)}
.cart-item-price{font-size:.9rem;color:var(--red);font-weight:500}
.cart-item-remove{background:none;border:none;cursor:pointer;color:var(--muted);font-size:1.1rem;padding:4px;transition:.2s}
.cart-item-remove:hover{color:var(--red)}
.cart-summary{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:16px}
.cart-row{display:flex;justify-content:space-between;font-size:.85rem;padding:5px 0}
.cart-row.total{font-weight:500;font-size:1rem;border-top:1px solid var(--border);padding-top:10px;margin-top:6px}
.paypal-hosted{background:var(--cream-dark);border-radius:var(--r);padding:16px;text-align:center;margin-bottom:12px}
.paypal-hosted-label{font-size:.72rem;color:var(--muted);margin-bottom:10px}
.paypal-button-wrap{display:flex;justify-content:center}
.pp-btn-demo{display:inline-flex;align-items:center;gap:8px;background:#0070BA;color:#fff;padding:12px 32px;border-radius:4px;font-size:.9rem;font-weight:700;cursor:pointer;border:none}

/* ── Confirm ── */
.confirm-hero{background:linear-gradient(135deg,var(--green),var(--green-light));padding:40px 20px;text-align:center;color:#fff}
.confirm-check{width:64px;height:64px;background:rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 16px;animation:pop .4s ease}
@keyframes pop{0%{transform:scale(0)}60%{transform:scale(1.1)}100%{transform:scale(1)}}
.confirm-title{font-size:1.6rem;margin-bottom:6px}
.confirm-order-num{font-size:.8rem;opacity:.75}
.confirm-body{padding:20px;position:relative;z-index:1}
.confirm-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:16px}
.confirm-row{display:flex;justify-content:space-between;padding:11px 16px;border-bottom:1px solid var(--border);font-size:.83rem}
.confirm-row:last-child{border-bottom:none}
.confirm-row .lbl{color:var(--muted)}
.confirm-row.total-row{font-weight:500;font-size:.95rem}
.confirm-email-note{background:rgba(27,94,32,.08);border:1px solid rgba(27,94,32,.2);border-radius:var(--r-sm);padding:12px 14px;font-size:.78rem;color:var(--green);line-height:1.6;margin-bottom:16px;display:flex;gap:10px}
.btn-continue{width:100%;padding:14px;border-radius:50px;background:var(--red);color:#fff;border:none;font-size:.9rem;font-weight:500;cursor:pointer;transition:.2s}
.btn-continue:hover{background:var(--red-light)}
