:root{
  --bg:#fcfdfc;
  --cream:#eef4f0;
  --surface:#ffffff;
  --ink:#1f2d28;
  --muted:#6b7d75;
  --line:#e3ebe6;
  --accent:#5b9c84;
  --accent-dark:#47806b;
  --accent-soft:#e4f0eb;
  --aqua:#7ec8c0;
  --aqua-soft:#e0f3f1;
  --gold:#e0b15a;
  --bad:#d98a82;
  --radius:18px;
  --radius-sm:13px;
  --maxw:1200px;
  --shadow:0 18px 44px rgba(31,45,40,.10);
  --shadow-sm:0 8px 22px rgba(31,45,40,.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:500;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:820px;margin:0 auto;padding:0 24px}
.section{padding:80px 0}
.section.tint{background:var(--cream)}
.section.aqua{background:var(--aqua-soft)}
.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.9rem,3.4vw,2.7rem)}
.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 .2s ease,box-shadow .2s ease,background .2s ease,border-color .2s ease,color .2s 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(91,156,132,.30)}
.btn-aqua{background:var(--aqua-soft);color:var(--accent-dark)}
.btn-aqua:hover{background:var(--aqua);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 (animated marquee) ===== */
.announce{
  background:var(--accent);
  color:#fff;
  overflow:hidden;
  white-space:nowrap;
  padding:10px 0;
  font-size:.84rem;
  font-weight:500;
}
.announce-track{
  display:inline-block;
  white-space:nowrap;
  will-change:transform;
  animation:marquee 26s linear infinite;
}
.announce-track span{margin:0 28px;display:inline-block}
.announce-track strong{font-weight:700}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ===== Header ===== */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(252,253,252,.86);
  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:500;font-size:1.36rem;letter-spacing:-.01em}
.logo .mark{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(140deg,var(--accent),var(--aqua));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}
.nav ul a:hover,.nav ul a.active{color:var(--accent)}
.right{margin-left:auto;display:flex;align-items:center;gap:6px}
.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)}
.cart-count{
  position:absolute;top:-2px;right:-2px;
  background:var(--aqua);color:#0f2b27;
  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)}
.mobile-menu a{display:block;padding:14px 0;color:var(--ink);font-weight:600}
.mobile-menu a:hover{color:var(--accent)}

/* ===== Hero ===== */
.hero{padding:66px 0 76px;background:linear-gradient(180deg,#fcfdfc 0%,var(--accent-soft) 100%)}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:56px;align-items:center}
.hero-text{animation:fadeUp .8s ease 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.4rem,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:50ch}
.hero-cta{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.hero-media{position:relative;animation:fadeIn 1s ease both}
.hero-media>img{width:100%;height:540px;border-radius:28px;box-shadow:var(--shadow)}
.hero-float{
  position:absolute;bottom:22px;left:-18px;
  background:rgba(255,255,255,.86);backdrop-filter:blur(8px);border:1px solid var(--line);
  border-radius:16px;padding:14px 18px;box-shadow:var(--shadow);
  display:flex;align-items:center;gap:12px;
  animation:floaty 4.5s ease-in-out infinite;
}
.hero-float .seal{width:42px;height:42px;border-radius:50%;background:var(--aqua-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}

@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:none}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ===== USP / benefits bar ===== */
.usp{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.usp-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:30px 0}
.usp-item{display:flex;align-items:center;gap:13px;justify-content:center}
.usp-item .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-item b{display:block;font-size:.94rem}
.usp-item small{color:var(--muted);font-size:.8rem}

/* ===== Collection list ===== */
.collist{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.col-card{position:relative;border-radius:var(--radius);overflow:hidden;display:block;aspect-ratio:3/4;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}
.col-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.col-card img{width:100%;height:100%}
.col-card .cap{position:absolute;left:0;right:0;bottom:0;padding:18px;background:linear-gradient(180deg,rgba(31,45,40,0),rgba(31,45,40,.72));color:#fff}
.col-card .cap b{font-family:'Fraunces',serif;font-weight:500;font-size:1.2rem;display:block}
.col-card .cap small{font-size:.8rem;opacity:.9}

/* ===== Product cards ===== */
.shop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.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(--aqua-soft);color:var(--accent-dark);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:500}
.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:500;font-size:1.2rem}
.card .price s{color:var(--muted);text-decoration:line-through;font-size:.92rem}
.card .add{margin-top:12px;width:100%}

/* ===== Image-with-text (science story) ===== */
.bigben{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.bigben-media img{width:100%;height:480px;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.04rem;margin-bottom:16px}
.ingredient-list{display:grid;gap:14px;margin:20px 0 26px}
.ingredient-list li{display:flex;gap:13px;align-items:flex-start}
.ingredient-list .ic{width:40px;height:40px;border-radius:11px;background:var(--aqua-soft);color:var(--accent-dark);display:grid;place-items:center;font-size:1.1rem;flex-shrink:0}
.ingredient-list b{display:block;font-size:.98rem}
.ingredient-list span{color:var(--muted);font-size:.9rem}

/* ===== Routine steps ===== */
.routine-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.routine-step{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}
.routine-step:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.routine-step .media{aspect-ratio:4/3;background:var(--cream);position:relative}
.routine-step .media img{width:100%;height:100%}
.routine-step .num{position:absolute;top:12px;left:12px;width:30px;height:30px;border-radius:50%;background:var(--surface);color:var(--accent);font-weight:700;display:grid;place-items:center;font-size:.86rem;box-shadow:var(--shadow-sm)}
.routine-step .body{padding:18px}
.routine-step h3{font-size:1.12rem;margin-bottom:6px}
.routine-step p{color:var(--muted);font-size:.9rem}

/* ===== Featured product spotlight ===== */
.highlight{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.highlight-media{position:relative}
.highlight-media img{width:100%;height:520px;border-radius:24px;box-shadow:var(--shadow)}
.hl-badge{position:absolute;top:18px;left:18px;background:rgba(255,255,255,.9);backdrop-filter:blur(6px);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.06rem;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(--aqua-soft);color:var(--accent-dark);display:grid;place-items:center;font-size:1.25rem;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}
.hl-price{font-family:'Fraunces',serif;font-weight:500;font-size:2rem}
.hl-price s{font-family:'Inter',sans-serif;font-size:1.1rem;color:var(--muted);font-weight:400;margin-left: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);transition:transform .2s ease,box-shadow .2s 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}
.who small{color:var(--accent);font-size:.78rem;font-weight:600;display:inline-flex;align-items:center;gap:4px}

/* ===== Instagram grid ===== */
.ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.ig-item{position:relative;aspect-ratio:1/1;border-radius:16px;overflow:hidden;display:block}
.ig-item img{width:100%;height:100%;transition:transform .3s ease}
.ig-item:hover img{transform:scale(1.06)}
.ig-handle{text-align:center;margin-top:22px;font-weight:600;color:var(--accent)}

/* ===== Guarantee / CTA 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:linear-gradient(140deg,var(--accent),var(--aqua));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}
.cta-band{background:linear-gradient(140deg,var(--accent),var(--aqua));border-radius:var(--radius);padding:54px;text-align:center;color:#fff}
.cta-band h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.6rem)}
.cta-band p{margin:12px auto 26px;max-width:50ch;opacity:.94}
.cta-band .btn-primary{background:#fff;color:var(--accent-dark)}
.cta-band .btn-primary:hover{background:#fff;color:var(--accent)}

/* ===== 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:820px;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:500;list-style:none;font-family:'Fraunces',serif;font-size:1.04rem}
.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)}

/* ===== Page hero ===== */
.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}

/* ===== 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:500;font-size:1.9rem}
.pdp-price s{color:var(--muted);text-decoration:line-through}
.pdp-price .save{background:var(--aqua-soft);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}
.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{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:500;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);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(252,253,252,.95);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);padding:12px 0;box-shadow:0 -8px 24px rgba(31,45,40,.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}
.filter-pills{display:flex;flex-wrap:wrap;gap:8px}
.filter-pills a{padding:8px 14px;border-radius:999px;border:1px solid var(--line);background:var(--surface);font-size:.86rem;font-weight:600;transition:border-color .15s,background .15s,color .15s}
.filter-pills a:hover,.filter-pills a.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-dark)}
.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.three{grid-template-columns:repeat(3,1fr)}

/* ===== Pagination ===== */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:42px}
.pagination a{min-width:42px;height:42px;padding:0 14px;border-radius:999px;border:1px solid var(--line);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:.92rem;transition:border-color .15s,background .15s,color .15s}
.pagination a:hover,.pagination a.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-dark)}

/* ===== About ===== */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.value-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}
.value-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.value-card .ic{width:50px;height:50px;border-radius:14px;background:var(--aqua-soft);color:var(--accent-dark);display:grid;place-items:center;font-size:1.4rem;margin-bottom:16px}
.value-card h3{font-size:1.2rem;margin-bottom:8px}
.value-card p{color:var(--muted);font-size:.94rem}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat .num{font-family:'Fraunces',serif;font-size:2.6rem;font-weight:500;color:var(--accent);line-height:1}
.stat .lbl{color:var(--muted);font-size:.9rem;margin-top:6px}
.team-note{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.team-note img{width:100%;height:440px;border-radius:24px;box-shadow:var(--shadow)}
.team-note h2{font-size:clamp(1.8rem,3.4vw,2.6rem);margin-bottom:14px}
.team-note p{color:var(--muted);margin-bottom:14px}
.team-note .sign{font-family:'Fraunces',serif;font-style:italic;font-size:1.2rem;color:var(--accent)}

/* ===== Blog ===== */
.blog-feat{display:grid;grid-template-columns:1.2fr 1fr;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:44px}
.blog-feat .media{aspect-ratio:16/11;background:var(--cream)}
.blog-feat .media img{width:100%;height:100%}
.blog-feat .body{padding:14px 40px 14px 0}
.blog-feat .body h2{font-size:clamp(1.6rem,3vw,2.3rem);margin:10px 0 12px}
.blog-feat .body p{color:var(--muted);margin-bottom:18px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-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 .2s ease,box-shadow .2s ease}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.post-card .media{aspect-ratio:16/10;background:var(--cream)}
.post-card .media img{width:100%;height:100%}
.post-card .body{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.post-card .meta{display:flex;gap:10px;align-items:center;font-size:.78rem;color:var(--muted)}
.post-card .meta .ptag{background:var(--accent-soft);color:var(--accent-dark);padding:3px 10px;border-radius:999px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:.66rem}
.post-card h3{font-size:1.18rem}
.post-card p{color:var(--muted);font-size:.92rem;flex:1}
.post-card .more{color:var(--accent);font-weight:600;font-size:.9rem;margin-top:4px}

/* ===== 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(--aqua-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:500}
.cart-summary .note{color:var(--muted);font-size:.85rem}
.cart-summary .acts{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap}

/* ===== Contact ===== */
.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)}
.contact-info img{width:100%;height:200px;border-radius:14px;margin-top:6px}

/* ===== 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-social{display:flex;gap:10px;margin-top:16px}
.foot-social a{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:var(--surface);display:grid;place-items:center;font-size:1rem;transition:border-color .15s,color .15s}
.foot-social a:hover{border-color:var(--accent);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}

/* ===== Scroll reveal ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.is-visible{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:980px){
  .hero-grid,.pdp,.contact-grid,.bigben,.highlight,.team-note,.blog-feat{grid-template-columns:1fr}
  .shop-grid,.shop-grid.three,.tgrid,.collist,.routine-grid,.blog-grid,.values-grid{grid-template-columns:repeat(2,1fr)}
  .ig-grid{grid-template-columns:repeat(4,1fr)}
  .usp-inner{grid-template-columns:repeat(2,1fr);gap:24px}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:28px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav>ul{display:none}
  .menu-toggle{display:grid}
  .shop-layout{grid-template-columns:1fr}
  .filters{position:static}
  .hero-media>img{height:430px}
  .highlight-media img,.team-note img{height:420px}
  .blog-feat .body{padding:0 28px 28px}
}
@media(max-width:560px){
  .tgrid,.shop-grid,.shop-grid.three,.collist,.routine-grid,.blog-grid,.values-grid{grid-template-columns:1fr 1fr;gap:14px}
  .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,.guarantee-box,.cta-band,.value-card{padding:28px 22px}
  .pdp-buy .btn{min-width:0}
  .blog-grid{grid-template-columns:1fr}
}

/* ===== Reduced motion ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .announce-track{animation:none}
  .reveal{opacity:1;transform:none}
}
