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

:root{
  --bg:#fff8f6;
  --cream:#fbeee9;
  --cream-2:#f6e2da;
  --surface:#ffffff;
  --ink:#2b1f29;
  --muted:#8a7682;
  --line:#f0dcd6;
  --line-soft:#f7e9e4;
  --accent:#d8638a;
  --accent-dark:#b9466e;
  --accent-soft:#fbe4ec;
  --plum:#5d3b58;
  --plum-soft:#efe2ee;
  --rose-gold:#c98a73;
  --blush:#f7d9e2;
  --blush-deep:#e29ab2;
  --gold:#e0a93b;
  --good:#3f9b7c;
  --bad:#d86a73;
  --radius:22px;
  --radius-sm:14px;
  --maxw:1200px;
  --shadow:0 22px 50px rgba(93,59,88,.12);
  --shadow-sm:0 10px 26px rgba(93,59,88,.08);
  --shadow-glow:0 14px 34px rgba(216,99,138,.30);
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

body{background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;line-height:1.65;font-size:16px;-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}

h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:600;letter-spacing:-.01em;line-height:1.13;color:var(--plum)}
img{display:block;max-width:100%;object-fit:cover}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit}

/* ===== Layout ===== */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.wrap-narrow{max-width:780px;margin:0 auto;padding:0 24px}
.section{padding:80px 0}
.section.tint{background:var(--cream)}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:44px;gap:24px;flex-wrap:wrap}
.section-head.center{flex-direction:column;align-items:center;text-align:center}
.section-head h2{font-size:clamp(1.9rem,3.4vw,2.7rem)}
.section-head p{color:var(--muted);margin-top:12px;max-width:58ch}
.eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:.18em;font-weight:700;font-size:.74rem;font-family:'Inter',sans-serif}
.center{text-align:center}

/* ===== Animations ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes slideInRight{from{transform:translateX(100%)}to{transform:translateX(0)}}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.is-visible{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none}
  .announce,.announce-track,.hero-text,.hero-media,.hero-float{animation:none!important}
}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;font-weight:600;padding:15px 28px;border:1px solid transparent;cursor:pointer;font-size:.96rem;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,border-color .2s ease,color .2s ease}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{box-shadow:var(--shadow-glow)}
.btn-plum{background:var(--plum);color:#fff}
.btn-plum:hover{background:#4a2e46}
.btn-blush{background:var(--blush);color:var(--accent-dark)}
.btn-blush:hover{background:var(--blush-deep);color:#fff}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-block{width:100%}
.btn-lg{padding:17px 34px;font-size:1.02rem}

.stars{color:var(--gold);letter-spacing:.06em}

/* ===== Announcement ===== */
.announce{background:linear-gradient(90deg,var(--accent),var(--plum),var(--accent));background-size:200% 100%;color:#fff;font-size:.84rem;font-weight:500;animation:shimmer 12s linear infinite;overflow:hidden}
.announce-track{display:flex;gap:48px;white-space:nowrap;padding:10px 0;width:max-content;animation:marquee 26s linear infinite}
.announce-track span{display:inline-flex;align-items:center;gap:10px}
.announce strong{font-weight:700}
@media(prefers-reduced-motion:reduce){.announce-track{width:auto;justify-content:center;flex-wrap:wrap}}

/* ===== Header ===== */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,248,246,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;height:74px;gap:24px}
.logo{display:inline-flex;align-items:center;gap:10px;font-family:'Playfair Display',serif;font-weight:600;font-size:1.4rem;letter-spacing:-.01em;color:var(--plum)}
.logo .mark{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--plum));color:#fff;display:grid;place-items:center;font-size:1.05rem}
.nav>ul{display:flex;align-items:center;gap:28px;margin-left:8px}
.nav ul a{color:var(--ink);font-weight:500;font-size:.95rem;transition:color .15s;position:relative}
.nav ul a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--accent);transition:width .25s ease}
.nav ul a:hover,.nav ul a.active{color:var(--accent)}
.nav ul a:hover::after,.nav ul a.active::after{width:100%}
.right{margin-left:auto;display:flex;align-items:center;gap:8px}
.icon-btn{width:42px;height:42px;border-radius:50%;background:transparent;border:1px solid transparent;display:grid;place-items:center;font-size:1.05rem;cursor:pointer;color:var(--ink);position:relative;transition:background .15s,color .15s}
.icon-btn:hover{background:var(--accent-soft);color:var(--accent)}
.region{border:1px solid var(--line);border-radius:999px;background:var(--surface);color:var(--ink);font-family:inherit;font-size:.82rem;font-weight:600;padding:8px 12px;cursor:pointer}
.region:focus{outline:none;border-color:var(--accent)}
.cart-count{position:absolute;top:-2px;right:-2px;background:var(--accent);color:#fff;font-size:.66rem;font-weight:700;min-width:18px;height:18px;border-radius:999px;display:grid;place-items:center;padding:0 4px}
.menu-toggle{display:none}
.mobile-menu{border-top:1px solid var(--line);background:var(--surface)}
.mobile-menu ul{display:grid;padding:8px 24px 18px}
.mobile-menu li{border-bottom:1px solid var(--line-soft)}
.mobile-menu a{display:block;padding:14px 0;color:var(--ink);font-weight:600}
.mobile-menu a:hover{color:var(--accent)}

/* ===== Cart drawer ===== */
.cart-drawer[hidden]{display:none}
.cart-drawer{position:fixed;inset:0;z-index:80}
.cart-drawer-overlay{position:absolute;inset:0;background:rgba(43,31,41,.42);animation:fadeIn .3s ease}
.cart-drawer-panel{position:absolute;top:0;right:0;height:100%;width:min(420px,92vw);background:var(--bg);display:flex;flex-direction:column;box-shadow:var(--shadow);animation:slideInRight .35s cubic-bezier(.16,1,.3,1)}
.cart-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--line)}
.cart-drawer-head h2{font-size:1.2rem}
.cart-drawer-body{flex:1;overflow:auto;padding:20px 22px;display:grid;gap:6px}
.cart-drawer-foot{padding:18px 22px;border-top:1px solid var(--line);display:grid;gap:10px}
.cd-item{display:grid;grid-template-columns:70px 1fr auto;gap:14px;align-items:center;padding:12px 0;border-bottom:1px solid var(--line-soft)}
.cd-item img{width:70px;height:70px;border-radius:12px;border:1px solid var(--line)}
.cd-item b{display:block;font-size:.92rem;color:var(--plum)}
.cd-item small{color:var(--muted);font-size:.82rem}
.cd-item .lt{font-weight:700;font-family:'Playfair Display',serif}

/* ===== Hero ===== */
.hero{padding:66px 0 78px;background:linear-gradient(165deg,#fff8f6 0%,#fbeee9 55%,#efe2ee 100%);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:56px;align-items:center}
.hero-text{animation:fadeUp .9s cubic-bezier(.16,1,.3,1) both}
.hero-rating{display:inline-flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:.84rem;font-weight:600;box-shadow:var(--shadow-sm)}
.hero-rating .stars{font-size:.95rem}
.hero h1{font-size:clamp(2.5rem,5vw,4rem);line-height:1.05;margin:18px 0 0}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero p{color:var(--muted);font-size:1.12rem;margin:18px 0 28px;max-width:48ch}
.hero-cta{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.hero-badge-mb{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:.86rem;font-weight:600}
.hero-badge-mb .ic{color:var(--accent)}
.hero-media{position:relative;animation:fadeUp 1s cubic-bezier(.16,1,.3,1) .15s both}
.hero-media>img{width:100%;height:540px;border-radius:30px;box-shadow:var(--shadow)}
.hero-float{position:absolute;bottom:24px;left:-18px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:14px 18px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;animation:floaty 5s ease-in-out infinite}
.hero-float .seal{width:40px;height:40px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-size:1.2rem;flex-shrink:0}
.hero-float b{display:block;font-size:.92rem;color:var(--plum)}
.hero-float small{color:var(--muted);font-size:.78rem}

/* ===== USP bar ===== */
.usp-bar{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.usp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:26px 0}
.usp{display:flex;align-items:center;gap:12px;justify-content:center}
.usp .ic{width:44px;height:44px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-size:1.3rem;flex-shrink:0}
.usp b{display:block;font-size:.92rem;color:var(--plum)}
.usp small{color:var(--muted);font-size:.8rem}

/* ===== Collection list ===== */
.coll-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:24px}
.coll{position:relative;border-radius:var(--radius);overflow:hidden;display:block;box-shadow:var(--shadow-sm)}
.coll img{width:100%;height:300px;transition:transform .5s ease}
.coll:hover img{transform:scale(1.06)}
.coll-ov{position:absolute;inset:auto 0 0 0;padding:22px;background:linear-gradient(0deg,rgba(43,31,41,.78),transparent);color:#fff}
.coll-ov h3{color:#fff}
.coll-ov span{font-size:.85rem;opacity:.92}

/* ===== Product grid / cards ===== */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:24px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s ease,box-shadow .25s ease;box-shadow:var(--shadow-sm)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .media{position:relative;aspect-ratio:1/1;background:var(--cream);overflow:hidden}
.card .media img{width:100%;height:100%;transition:transform .5s ease}
.card:hover .media img{transform:scale(1.05)}
.card .tag{position:absolute;top:12px;left:12px;background:var(--blush);color:var(--accent-dark);padding:4px 11px;border-radius:999px;font-weight:700;font-size:.66rem;text-transform:uppercase;letter-spacing:.05em;z-index:1}
.card .body{padding:18px;display:flex;flex-direction:column;gap:6px;flex:1}
.card .cat{color:var(--accent);font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;font-weight:700}
.card h3{font-size:1.08rem;font-weight:600}
.card h3 a{color:var(--plum)}
.card .stars{font-size:.85rem}
.card .price{margin-top:auto;display:flex;align-items:baseline;gap:8px;padding-top:6px}
.card .price b{font-family:'Playfair Display',serif;font-weight:600;font-size:1.2rem;color:var(--plum)}
.card .price s{color:var(--muted);text-decoration:line-through;font-size:.92rem}
.card .add{margin-top:12px;width:100%}

/* ===== Image with text ===== */
.iwt{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.iwt-media img{width:100%;height:460px;border-radius:24px;box-shadow:var(--shadow)}
.iwt h2{font-size:clamp(1.9rem,3.6vw,2.8rem);margin:14px 0 16px}
.iwt p{color:var(--muted);font-size:1.06rem;margin-bottom:16px}
.iwt .btn{margin-top:8px}

/* ===== Promo banner ===== */
.promo-box{position:relative;border-radius:26px;overflow:hidden;padding:64px 56px;color:#fff;background:linear-gradient(120deg,var(--plum),var(--accent))}
.promo-box::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(255,255,255,.18),transparent 55%)}
.promo-inner{position:relative;max-width:600px}
.promo-box .eyebrow{color:#fff;opacity:.9}
.promo-box h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.8rem);margin:8px 0 10px}
.promo-box p{opacity:.92;margin-bottom:24px;max-width:46ch}
.promo-btn{background:#fff;color:var(--accent-dark)}
.promo-btn:hover{background:var(--cream)}

/* ===== Featured product spotlight ===== */
.fp{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.fp-media{position:relative}
.fp-media img{width:100%;height:520px;border-radius:24px;box-shadow:var(--shadow)}
.fp-badge{position:absolute;top:18px;left:18px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-weight:700;font-size:.82rem;color:var(--accent);box-shadow:var(--shadow-sm)}
.fp h2{font-size:clamp(1.9rem,3.6vw,2.7rem)}
.fp .tagline{color:var(--muted);font-size:1.08rem;margin:10px 0 24px}
.fp-feats{display:grid;gap:16px;margin-bottom:24px}
.fp-feat{display:flex;gap:14px;align-items:flex-start}
.fp-feat .ic{width:44px;height:44px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-size:1.3rem;flex-shrink:0}
.fp-feat b{display:block;font-size:1rem;color:var(--plum)}
.fp-feat p{color:var(--muted);font-size:.92rem}
.fp-buy{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:10px}
.fp-price{font-family:'Playfair Display',serif;font-weight:600;font-size:2rem;color:var(--plum)}
.fp-price s{font-family:'Inter',sans-serif;font-size:1.1rem;color:var(--muted);font-weight:400;margin-left:8px}
.scarcity{color:var(--accent-dark);font-size:.86rem;font-weight:600;display:inline-flex;align-items:center;gap:6px}

/* ===== Testimonials ===== */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease}
.tcard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.tcard .stars{font-size:.95rem}
.tcard blockquote{font-size:.98rem;line-height:1.6;color:var(--ink);flex:1}
.tcard .who{display:flex;align-items:center;gap:12px}
.who img{width:46px;height:46px;border-radius:50%}
.who b{display:block;font-size:.92rem;color:var(--plum)}
.who small{color:var(--accent);font-size:.78rem;font-weight:600;display:inline-flex;align-items:center;gap:4px}

/* ===== Instagram ===== */
.ig-handle{display:block;text-align:center;color:var(--accent);font-weight:700;margin-top:6px}
.ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-top:24px}
.ig-item{position:relative;aspect-ratio:1/1;border-radius:16px;overflow:hidden;display:block}
.ig-item img{width:100%;height:100%;transition:transform .4s ease}
.ig-item::after{content:"♥";position:absolute;inset:0;background:rgba(216,99,138,.55);opacity:0;display:grid;place-items:center;transition:opacity .3s ease;color:#fff;font-size:1.6rem}
.ig-item:hover img{transform:scale(1.08)}
.ig-item:hover::after{opacity:1}

/* ===== FAQ ===== */
.faq-list{max-width:800px;margin:0 auto;display:grid;gap:12px}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 22px;cursor:pointer;font-weight:600;list-style:none;font-family:'Playfair Display',serif;color:var(--plum)}
.faq-q::-webkit-details-marker{display:none}
.faq-ic{width:28px;height:28px;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-size:1.2rem;display:grid;place-items:center;transition:transform .25s ease,background .25s ease,color .25s ease;flex-shrink:0}
.faq-item[open] .faq-ic{transform:rotate(45deg);background:var(--accent);color:#fff}
.faq-a{padding:0 22px 20px;color:var(--muted)}

/* ===== Newsletter ===== */
.news{position:relative;background:linear-gradient(135deg,var(--cream),var(--plum-soft));border:1px solid var(--line);border-radius:26px;padding:60px;text-align:center;overflow:hidden}
.news h2{font-size:clamp(1.8rem,3vw,2.4rem)}
.news p{color:var(--muted);margin:12px auto 24px;max-width:46ch}
.news form{display:flex;gap:12px;max-width:480px;margin:0 auto;flex-wrap:wrap}
.news input{flex:1;min-width:200px;padding:15px 18px;border-radius:999px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-family:inherit}
.news input:focus{outline:none;border-color:var(--accent)}

/* ===== CTA band ===== */
.cta-box{background:linear-gradient(135deg,var(--accent),var(--accent-dark));border-radius:26px;padding:48px 56px;display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;color:#fff}
.cta-box .eyebrow{color:#fff;opacity:.88}
.cta-box h2{color:#fff;font-size:clamp(1.6rem,3vw,2.4rem);margin:6px 0}
.cta-box p{opacity:.92;max-width:48ch}
.cta-btn{background:#fff;color:var(--accent-dark);flex-shrink:0}
.cta-btn:hover{background:var(--cream)}

/* ===== Breadcrumb ===== */
.breadcrumb{color:var(--muted);font-size:.85rem;margin-bottom:18px}
.breadcrumb a:hover{color:var(--accent)}

/* ===== PDP ===== */
.pdp{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:start}
.pdp-gallery .main-img{width:100%;aspect-ratio:1/1;border-radius:22px;box-shadow:var(--shadow-sm);background:var(--cream)}
.pdp-thumbs{display:flex;gap:10px;margin-top:14px}
.pdp-thumbs img{width:80px;height:80px;border-radius:12px;border:1px solid var(--line);cursor:pointer;transition:border-color .15s}
.pdp-thumbs img:hover,.pdp-thumbs img.sel{border-color:var(--accent)}
.pdp-info h1{font-size:clamp(1.9rem,3vw,2.6rem);margin:6px 0 8px}
.rating{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.rating span{color:var(--muted);font-size:.9rem}
.pdp-price{display:flex;align-items:center;gap:12px;margin:0 0 16px}
.pdp-price b{font-family:'Playfair Display',serif;font-weight:600;font-size:1.9rem;color:var(--plum)}
.pdp-price s{color:var(--muted);text-decoration:line-through}
.pdp-price .save{background:var(--blush);color:var(--accent-dark);font-weight:700;font-size:.72rem;padding:5px 12px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}
.desc{color:var(--muted)}
.pdp-opt{margin:18px 0}
.pdp-opt>label{display:block;font-weight:700;margin-bottom:10px;font-size:.9rem;color:var(--plum)}
.pills{display:flex;gap:10px;flex-wrap:wrap}
.pill{padding:10px 18px;border-radius:999px;background:var(--surface);border:1px solid var(--line);font-weight:600;font-size:.92rem;cursor:pointer;transition:border-color .15s,background .15s,color .15s}
.pill.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-dark)}
.pdp-buy{display:flex;gap:12px;margin:20px 0;flex-wrap:wrap}
.qty{display:inline-flex;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:999px;overflow:hidden}
.qty button{width:44px;height:50px;background:transparent;color:var(--ink);cursor:pointer;font-size:1.2rem;border:none}
.qty button:hover{background:var(--cream)}
.qty input{width:52px;height:50px;text-align:center;background:transparent;color:var(--ink);border:none;font-family:inherit}
.qty input:focus{outline:none}
.pdp-buy .btn{flex:1;min-width:200px}
.trust-row{display:flex;flex-wrap:wrap;gap:18px;padding:18px 0;border-top:1px solid var(--line);margin-top:8px;color:var(--muted);font-size:.85rem}
.trust-row span{display:inline-flex;align-items:center;gap:7px}
.facts{border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;margin:18px 0}
.facts h4{background:var(--cream);padding:12px 18px;font-family:'Playfair Display',serif;font-size:1.02rem;border-bottom:1px solid var(--line);color:var(--plum)}
.facts table{width:100%;border-collapse:collapse}
.facts td{padding:11px 18px;border-bottom:1px solid var(--line-soft);font-size:.9rem}
.facts td:last-child{text-align:right;color:var(--muted)}
.facts tr:last-child td{border-bottom:none}
.acc{margin-top:18px}

/* ===== Sticky ATC ===== */
.sticky-atc{position:fixed;bottom:0;left:0;right:0;z-index:60;background:rgba(255,248,246,.96);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:12px 0;box-shadow:0 -8px 24px rgba(93,59,88,.08)}
.sticky-atc[hidden]{display:none}
.sticky-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.s-info{display:flex;align-items:center;gap:12px}
.s-info img{width:48px;height:48px;border-radius:12px}
.s-info b{display:block;color:var(--plum)}
.s-info span{color:var(--muted);font-size:.9rem}

/* ===== Related ===== */
.related{margin-top:64px}

/* ===== Shop ===== */
.shop-layout{display:grid;grid-template-columns:250px 1fr;gap:32px;align-items:start}
.filters{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;position:sticky;top:90px;box-shadow:var(--shadow-sm)}
.filters h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin:0 0 12px;font-family:'Inter',sans-serif}
.filters h4:not(:first-child){margin-top:22px}
.filters label{display:flex;align-items:center;gap:9px;padding:6px 0;cursor:pointer;font-size:.92rem}
.filters input[type=checkbox],.filters input[type=radio]{accent-color:var(--accent);width:16px;height:16px}
.filters select{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-family:inherit;margin-top:6px}
.shop-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;flex-wrap:wrap;gap:12px}
.shop-bar .count{color:var(--muted);font-size:.9rem}
.shop-bar select{padding:10px 14px;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-family:inherit}
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:40px}
.pagination a,.pagination span{padding:9px 15px;border-radius:10px;border:1px solid var(--line);color:var(--ink);font-weight:600;font-size:.9rem}
.pagination .current{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ===== Cart ===== */
.cart-table{width:100%}
.cart-row{display:grid;grid-template-columns:90px 1fr auto auto auto;gap:18px;align-items:center;padding:18px 0;border-bottom:1px solid var(--line)}
.cart-row img{width:90px;height:90px;border-radius:14px;border:1px solid var(--line)}
.cart-row .nm{font-weight:600;color:var(--plum)}
.cart-row .vr{color:var(--muted);font-size:.85rem}
.cart-row .rm{color:var(--bad);font-size:.82rem;display:inline-block;margin-top:6px;cursor:pointer}
.cart-row .lt{font-weight:700;min-width:80px;text-align:right;font-family:'Playfair Display',serif}
.cart-upsell{display:flex;align-items:center;gap:16px;background:var(--accent-soft);border:1px solid var(--blush);border-radius:var(--radius-sm);padding:16px 20px;margin-top:24px;flex-wrap:wrap}
.cart-upsell .ic{font-size:1.4rem}
.cart-upsell p{flex:1;font-size:.92rem;min-width:200px}
.cart-summary{margin-top:28px;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.cart-summary .sub{display:flex;gap:18px;align-items:baseline;font-size:1.1rem}
.cart-summary .sub strong{font-size:1.7rem;font-family:'Playfair Display',serif;font-weight:600;color:var(--plum)}
.cart-summary .note{color:var(--muted);font-size:.85rem}
.cart-summary .acts{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap}
.cart-empty{text-align:center;padding:48px 0}
.cart-empty p{color:var(--muted);margin-bottom:18px}

/* ===== About ===== */
.about-hero img{width:100%;height:420px;border-radius:24px;box-shadow:var(--shadow);margin-top:24px}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:24px}
.value{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}
.value .ic{width:50px;height:50px;border-radius:14px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-size:1.5rem;margin-bottom:14px}
.value h3{font-size:1.2rem;margin-bottom:8px}
.value p{color:var(--muted);font-size:.94rem}
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:24px}
.team-card{text-align:center}
.team-card img{width:100%;height:260px;border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.team-card b{display:block;margin-top:12px;color:var(--plum);font-family:'Playfair Display',serif;font-size:1.1rem}
.team-card small{color:var(--accent);font-weight:600}
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:24px;text-align:center}
.stat .num{font-family:'Playfair Display',serif;font-size:2.6rem;color:var(--accent);font-weight:600}
.stat small{color:var(--muted)}

/* ===== Blog ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.article-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease}
.article-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.article-card .img{width:100%;height:210px;overflow:hidden}
.article-card .img img{width:100%;height:100%;transition:transform .5s ease}
.article-card:hover .img img{transform:scale(1.05)}
.article-card .body{padding:18px;display:flex;flex-direction:column;gap:8px;flex:1}
.article-card .date{color:var(--accent);font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;font-weight:700}
.article-card h3{font-size:1.15rem}
.article-card p{color:var(--muted);font-size:.9rem}
.article-card .more{color:var(--accent);font-weight:600;font-size:.9rem;margin-top:auto}
.feat-post{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:40px}
.feat-post img{width:100%;height:100%;min-height:340px}
.feat-post .body{padding:40px}
.feat-post h2{font-size:clamp(1.6rem,3vw,2.2rem);margin:8px 0 12px}
.feat-post p{color:var(--muted);margin-bottom:18px}

/* ===== Contact ===== */
.page-hero{padding:56px 0 36px;background:var(--cream);border-bottom:1px solid var(--line)}
.page-hero h1{font-size:clamp(2rem,4vw,3.2rem)}
.page-hero p{color:var(--muted);margin-top:10px;max-width:56ch}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.form-field{margin-bottom:18px}
.form-field label{display:block;font-weight:600;margin-bottom:6px;font-size:.9rem;color:var(--plum)}
.form-field input,.form-field textarea,.form-field select{width:100%;padding:13px 15px;border-radius:12px;background:var(--surface);border:1px solid var(--line);color:var(--ink);font-family:inherit}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-color:var(--accent)}
.form-field textarea{min-height:130px;resize:vertical}
.form-field .err{color:var(--bad);font-size:.82rem;display:none;margin-top:6px}
.form-field.invalid input,.form-field.invalid textarea{border-color:var(--bad)}
.form-field.invalid .err{display:block}
.form-success{display:none;background:var(--accent-soft);border:1px solid var(--blush);color:var(--accent-dark);padding:14px 16px;border-radius:12px;margin-bottom:18px;font-weight:600}
.contact-info{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;display:grid;gap:18px;box-shadow:var(--shadow-sm)}
.contact-info .row b{display:block;color:var(--plum)}
.contact-info .row span{color:var(--muted)}
.map{margin-top:18px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.map img{width:100%;height:220px}

/* ===== Footer ===== */
footer.site{border-top:1px solid var(--line);background:var(--cream);padding:60px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:36px}
footer .logo{margin-bottom:14px}
footer p{color:var(--muted);font-size:.92rem;max-width:34ch}
.foot-socials{display:flex;gap:10px;margin-top:16px}
.foot-socials a{width:38px;height:38px;border-radius:50%;background:var(--surface);border:1px solid var(--line);display:grid;place-items:center;color:var(--accent);transition:background .15s,color .15s}
.foot-socials a:hover{background:var(--accent);color:#fff}
footer h4{font-size:.72rem;text-transform:uppercase;color:var(--muted);letter-spacing:.16em;margin-bottom:16px;font-family:'Inter',sans-serif}
footer ul{display:grid;gap:10px}
footer ul a{color:var(--ink);opacity:.82;font-size:.92rem;transition:color .15s,opacity .15s}
footer ul a:hover{color:var(--accent);opacity:1}
.foot-news{margin-top:14px;display:flex;gap:8px;max-width:300px}
.foot-news input{flex:1;padding:11px 14px;border-radius:999px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-family:inherit;font-size:.86rem}
.foot-news input:focus{outline:none;border-color:var(--accent)}
.foot-pay{display:flex;gap:8px;flex-wrap:wrap;margin:24px 0}
.foot-pay span{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:5px 10px;font-size:.7rem;font-weight:700;color:var(--muted)}
.foot-disclaimer{color:var(--muted);font-size:.78rem;line-height:1.6;border-top:1px solid var(--line);padding-top:22px;margin-bottom:18px;max-width:none}
.foot-bottom{border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:center;color:var(--muted);font-size:.85rem}
.foot-bottom .region{font-size:.8rem}

/* ===== Responsive ===== */
@media(max-width:980px){
  .hero-grid,.pdp,.contact-grid,.iwt,.fp,.feat-post{grid-template-columns:1fr}
  .usp-grid{grid-template-columns:repeat(2,1fr)}
  .shop-grid,.tgrid,.blog-grid,.values,.team,.coll-grid,.prod-grid{grid-template-columns:repeat(2,1fr)}
  .ig-grid{grid-template-columns:repeat(3,1fr)}
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav>ul{display:none}
  .menu-toggle{display:grid}
  .region{display:none}
  .shop-layout{grid-template-columns:1fr}
  .filters{position:static}
  .hero-media>img{height:440px}
  .fp-media img{height:440px}
  .cta-box,.promo-box{text-align:center;justify-content:center}
  .feat-post img{min-height:240px}
}
@media(max-width:560px){
  .tgrid,.shop-grid,.blog-grid,.values,.team,.coll-grid,.prod-grid{grid-template-columns:1fr 1fr;gap:14px}
  .usp-grid{grid-template-columns:1fr 1fr}
  .ig-grid{grid-template-columns:repeat(3,1fr)}
  .foot-grid{grid-template-columns:1fr}
  .section{padding:56px 0}
  .cart-row{grid-template-columns:70px 1fr auto;row-gap:8px}
  .news,.cta-box,.promo-box{padding:32px 24px}
  .pdp-buy .btn{min-width:0}
  .team{grid-template-columns:1fr 1fr}
}
