@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --bg:#fffdf9;
  --cream:#f6f1e7;
  --cream-2:#efe7d7;
  --surface:#ffffff;
  --ink:#23302c;
  --muted:#6f7b74;
  --line:#e8e1d4;
  --line-soft:#f0eadd;
  --accent:#2f8f7a;
  --accent-dark:#236b5c;
  --accent-soft:#e3f1ec;
  --blush:#f4dcd6;
  --blush-deep:#e9a9a0;
  --gold:#e0a93b;
  --good:#2f8f7a;
  --bad:#d98a82;
  --radius:20px;
  --radius-sm:14px;
  --maxw:1180px;
  --shadow:0 18px 40px rgba(45,60,54,.10);
  --shadow-sm:0 8px 22px rgba(45,60,54,.07);
  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:'Fraunces',Georgia,serif;font-weight:600;letter-spacing:-.01em;line-height:1.14;color:var(--ink)}
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:42px;gap:24px;flex-wrap:wrap}
.section-head.center{flex-direction:column;align-items:center;text-align:center}
.section-head h2{font-size:clamp(1.8rem,3.4vw,2.6rem)}
.section-head p{color:var(--muted);margin-top:10px;max-width:56ch}
.eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:.16em;font-weight:700;font-size:.74rem;font-family:'Inter',sans-serif}
.center{text-align:center}

/* ===== 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 .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease,color .18s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--accent-dark);box-shadow:0 14px 30px rgba(47,143,122,.28)}
.btn-blush{background:var(--blush);color:#7c4a43}
.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:var(--accent);
  color:#fff;
  text-align:center;
  font-size:.84rem;
  font-weight:500;
  padding:10px 16px;
}
.announce span{margin:0 14px;display:inline-block}
.announce strong{font-weight:700}

/* ===== Header ===== */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(255,253,249,.88);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;height:72px;gap:24px}
.logo{display:inline-flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:600;font-size:1.34rem;letter-spacing:-.01em}
.logo .mark{
  width:34px;height:34px;border-radius:50%;
  background:var(--accent);color:#fff;
  display:grid;place-items:center;font-size:1.1rem;
}
.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}
.nav ul a:hover,.nav ul a.active{color:var(--accent)}
.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(--blush-deep);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)}

/* ===== Hero ===== */
.hero{padding:64px 0 72px;background:linear-gradient(180deg,#fffdf9 0%,#f6f1e7 100%)}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:56px;align-items:center}
.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.4rem,5vw,3.9rem);line-height:1.06;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}
.hero-media>img{width:100%;height:520px;border-radius:28px;box-shadow:var(--shadow)}
.hero-float{
  position:absolute;bottom:22px;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;
}
.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}
.hero-float small{color:var(--muted);font-size:.78rem}

/* ===== Social proof bar ===== */
.proof{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.proof-inner{display:flex;align-items:center;justify-content:center;gap:20px;padding:20px 0;flex-wrap:wrap}
.proof-rating{display:flex;align-items:center;gap:10px;font-weight:600}
.proof-rating .stars{font-size:1.1rem}
.proof-avatars{display:flex}
.proof-avatars img{width:40px;height:40px;border-radius:50%;border:2px solid var(--surface);margin-left:-10px}
.proof-avatars img:first-child{margin-left:0}
.proof-text{color:var(--muted);font-size:.92rem}

/* ===== Logos / featured in ===== */
.logos{padding:34px 0;background:var(--cream)}
.logos-label{text-align:center;color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;margin-bottom:18px;font-weight:600}
.logos-row{display:flex;justify-content:center;align-items:center;gap:46px;flex-wrap:wrap;opacity:.6}
.logos-row span{font-family:'Fraunces',serif;font-weight:600;font-size:1.25rem;color:var(--ink)}

/* ===== Cost comparison ===== */
.cost-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:28px;align-items:center}
.cost-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}
.cost-card.them{background:var(--cream)}
.cost-card.us{border:2px solid var(--accent);box-shadow:var(--shadow)}
.cost-card h3{font-size:1.2rem;margin-bottom:18px;display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.cost-card h3 .tot{font-family:'Inter',sans-serif;font-weight:700;color:var(--ink)}
.cost-card.us h3 .tot{color:var(--accent)}
.cost-list{display:grid;gap:12px}
.cost-list li{display:flex;justify-content:space-between;gap:12px;color:var(--muted);font-size:.94rem;padding-bottom:12px;border-bottom:1px solid var(--line-soft)}
.cost-list li:last-child{border-bottom:none;padding-bottom:0}
.cost-list li b{color:var(--ink);font-weight:600}
.cost-card.us .cost-line{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.cost-card.us .cost-line .ic{width:46px;height:46px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-size:1.3rem;flex-shrink:0}
.cost-card.us p{color:var(--muted);font-size:.94rem;margin:14px 0 0}
.cost-vs{font-family:'Fraunces',serif;font-style:italic;color:var(--muted);font-size:1.3rem}
.cost-save{margin-top:24px;text-align:center}
.cost-save .pill{display:inline-block;background:var(--blush);color:#7c4a43;font-weight:700;padding:10px 22px;border-radius:999px;font-size:1rem}

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

/* ===== Testimonials ===== */
.tgrid{display:grid;grid-template-columns:repeat(4,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)}
.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}
.who small{color:var(--accent);font-size:.78rem;font-weight:600;display:inline-flex;align-items:center;gap:4px}

/* ===== UGC gallery ===== */
.ugc-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.ugc-item{position:relative;aspect-ratio:1/1;border-radius:16px;overflow:hidden;display:block}
.ugc-item img{width:100%;height:100%;transition:transform .3s ease}
.ugc-item:hover img{transform:scale(1.06)}

/* ===== Product showcase ===== */
.showcase-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.showcase-item{aspect-ratio:1/1;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:var(--cream)}
.showcase-item img{width:100%;height:100%}

/* ===== Product highlights ===== */
.highlight{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.highlight-media{position:relative}
.highlight-media img{width:100%;height:500px;border-radius:24px;box-shadow:var(--shadow)}
.hl-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)}
.highlight h2{font-size:clamp(1.9rem,3.6vw,2.7rem)}
.highlight .tagline{color:var(--muted);font-size:1.08rem;margin:10px 0 24px}
.hl-feats{display:grid;gap:16px;margin-bottom:24px}
.hl-feat{display:flex;gap:14px;align-items:flex-start}
.hl-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}
.hl-feat b{display:block;font-size:1rem}
.hl-feat p{color:var(--muted);font-size:.92rem}
.hl-buy{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:10px}
.hl-price{font-family:'Fraunces',serif;font-weight:600;font-size:2rem}
.hl-price s{font-family:'Inter',sans-serif;font-size:1.1rem;color:var(--muted);font-weight:400;margin-left:8px}
.scarcity{color:var(--blush-deep);font-size:.86rem;font-weight:600;display:inline-flex;align-items:center;gap:6px}

/* ===== Guarantee band ===== */
.guarantee{padding:72px 0}
.guarantee-box{
  background:var(--accent-soft);border:1px solid #cfe6de;border-radius:var(--radius);
  display:flex;align-items:center;gap:28px;padding:40px;flex-wrap:wrap;
}
.seal{width:90px;height:90px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:2.2rem;flex-shrink:0}
.guarantee-box h2{font-size:1.6rem;margin-bottom:6px}
.guarantee-box p{color:var(--muted);max-width:60ch}

/* ===== Newsletter ===== */
.news{
  background:var(--cream);border:1px solid var(--line);border-radius:24px;padding:56px;text-align:center;
}
.news h2{font-size:clamp(1.7rem,3vw,2.3rem)}
.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)}

/* ===== FAQ ===== */
.faq-list{max-width:780px;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:'Fraunces',serif}
.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 .2s ease,background .2s ease,color .2s 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)}

/* ===== 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:'Fraunces',serif;font-weight:600;font-size:1.9rem}
.pdp-price s{color:var(--muted);text-decoration:line-through}
.pdp-price .save{background:var(--blush);color:#7c4a43;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}
.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)}

/* purchase options */
.purchase{display:grid;gap:12px;margin:18px 0}
.purchase-opt{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;position:relative;transition:border-color .15s,background .15s}
.purchase-opt.active{border-color:var(--accent);background:var(--accent-soft)}
.purchase-opt input{accent-color:var(--accent);width:18px;height:18px;flex-shrink:0}
.purchase-opt .p-copy{flex:1}
.purchase-opt .p-copy b{display:block}
.purchase-opt .p-copy small{color:var(--muted)}
.purchase-opt .p-price{font-family:'Fraunces',serif;font-weight:600;font-size:1.1rem;text-align:right}
.purchase-opt .p-tag{position:absolute;top:-9px;right:16px;background:var(--accent);color:#fff;font-size:.66rem;font-weight:700;padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}

.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:'Fraunces',serif;font-size:1.02rem;border-bottom:1px solid var(--line)}
.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}

/* ===== Sticky ATC ===== */
.sticky-atc{
  position:fixed;bottom:0;left:0;right:0;z-index:60;
  background:rgba(255,253,249,.95);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);padding:12px 0;box-shadow:0 -8px 24px rgba(45,60,54,.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}
.s-info span{color:var(--muted);font-size:.9rem}

/* ===== Shop ===== */
.shop-layout{display:grid;grid-template-columns:240px 1fr;gap:32px;align-items:start}
.filters{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;position:sticky;top:88px;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}

/* product cards (shop) */
.card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;
  transition:transform .2s ease,box-shadow .2s ease;box-shadow:var(--shadow-sm);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .media{position:relative;aspect-ratio:1/1;background:var(--cream)}
.card .media img{width:100%;height:100%}
.card .tag{position:absolute;top:12px;left:12px;background:var(--blush);color:#7c4a43;padding:4px 11px;border-radius:999px;font-weight:700;font-size:.66rem;text-transform:uppercase;letter-spacing:.05em}
.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 .stars{font-size:.85rem}
.card .price{margin-top:auto;display:flex;align-items:baseline;gap:8px;padding-top:6px}
.card .price b{font-family:'Fraunces',serif;font-weight:600;font-size:1.2rem}
.card .price s{color:var(--muted);text-decoration:line-through;font-size:.92rem}
.card .add{margin-top:12px;width:100%}

/* ===== Reviews wall ===== */
.rev-summary{display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:36px;box-shadow:var(--shadow-sm);margin-bottom:36px}
.rev-score{text-align:center}
.rev-score .num{font-family:'Fraunces',serif;font-size:3.6rem;font-weight:600;line-height:1}
.rev-score .stars{font-size:1.2rem;display:block;margin:6px 0}
.rev-score small{color:var(--muted)}
.rev-bars{display:grid;gap:8px}
.rev-bar{display:flex;align-items:center;gap:12px;font-size:.86rem;color:var(--muted)}
.rev-bar .lbl{width:42px}
.rev-bar .track{flex:1;height:9px;border-radius:999px;background:var(--cream-2);overflow:hidden}
.rev-bar .fill{height:100%;background:var(--gold);border-radius:999px}
.rev-bar .pct{width:42px;text-align:right}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rev-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.rev-card .top{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.rev-card .top img{width:44px;height:44px;border-radius:50%}
.rev-card .top b{display:block;font-size:.92rem}
.rev-card .top small{color:var(--accent);font-weight:600;font-size:.76rem}
.rev-card .stars{font-size:.9rem}
.rev-card p{color:var(--ink);font-size:.94rem;margin:8px 0}
.rev-card .date{color:var(--muted);font-size:.8rem}

/* ===== 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}
.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:'Fraunces',serif}
.cart-upsell{display:flex;align-items:center;gap:16px;background:var(--accent-soft);border:1px solid #cfe6de;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:'Fraunces',serif;font-weight:600}
.cart-summary .note{color:var(--muted);font-size:.85rem}
.cart-summary .acts{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap}

/* ===== 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}
.form-field input,.form-field textarea{
  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{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 #cfe6de;
  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}
.contact-info .row span{color:var(--muted)}

/* ===== 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}
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,.bigben,.highlight,.cost-grid{grid-template-columns:1fr}
  .cost-vs{display:none}
  .shop-grid,.tgrid,.rev-grid{grid-template-columns:repeat(2,1fr)}
  .showcase-grid{grid-template-columns:repeat(3,1fr)}
  .ugc-grid{grid-template-columns:repeat(4,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .rev-summary{grid-template-columns:1fr;text-align:center}
  .nav>ul{display:none}
  .menu-toggle{display:grid}
  .region{display:none}
  .shop-layout{grid-template-columns:1fr}
  .filters{position:static}
  .hero-media>img{height:420px}
  .highlight-media img{height:420px}
}
@media(max-width:560px){
  .tgrid,.shop-grid,.rev-grid{grid-template-columns:1fr 1fr;gap:14px}
  .showcase-grid{grid-template-columns:repeat(2,1fr)}
  .ugc-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,.guarantee-box,.cost-card,.rev-summary{padding:28px 22px}
  .pdp-buy .btn{min-width:0}
}
