
/* ═══════════════════════════════════════════════════════════════
   BIOSOOP — DESIGN TOKENS
   ═══════════════════════════════════════════════════════════════ */
:root{
  /* Palette */
  --cream: #FAF8F3;
  --cream-2: #F2EDE2;
  --white: #FFFFFF;
  --ink: #0E3320;
  --ink-2: #1B5C2E;
  --ink-3: #5C6B62;
  --ink-4: #94A29A;
  --peach: #F8DDD0;
  --peach-2: #F2C9B3;
  --clay: #B6694A;
  --mint: #D4E8D9;
  --border: rgba(14, 51, 32, 0.08);
  --border-2: rgba(14, 51, 32, 0.18);

  /* Type — Fredoka (main display) + Nunito (body) + Helvetica (utility) */
  --display: 'Fredoka', system-ui, sans-serif;
  --body: 'Nunito', system-ui, sans-serif;
  --util: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  /* Aliases kept so legacy rules continue to work */
  --serif: var(--display);
  --sans: var(--body);
  --mono: var(--util);

  /* Motion */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --t1: 0.25s var(--ease);
  --t2: 0.45s var(--ease);

  /* Layout */
  --max: 1380px;
  --pad: 48px;
  --pad-sm: 22px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);
  font-size:15px;
  line-height:1.6;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
a{color:inherit;text-decoration:none;cursor:pointer;}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);}

/* ═══════════════════════════════════════════════════════════════
   IMAGE PLACEHOLDER SYSTEM
   White background + black border + "Image Loading" text
   ═══════════════════════════════════════════════════════════════ */
.ph{
  background:#fff;
  border:1px solid #000;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
  color:#000;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  text-align:center;
  flex-direction:column;
  gap:6px;
}
.ph::before{
  content:'';
  width:24px;
  height:24px;
  border:1.5px solid #000;
  border-top-color:transparent;
  border-radius:50%;
  animation:spin 1.2s linear infinite;
  opacity:0.4;
}
@keyframes spin{to{transform:rotate(360deg);}}
.ph-label{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.14em;
}
.ph-meta{
  position:absolute;
  bottom:10px;
  left:10px;
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:0.1em;
  opacity:0.5;
}
.ph-video::after{
  content:'▶ VIDEO';
  position:absolute;
  top:14px;
  left:14px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.14em;
  background:#000;
  color:#fff;
  padding:5px 10px;
}

/* Product image placeholder (slightly different) */
.ph-product{
  background:linear-gradient(180deg,#fbfaf6 0%,#f3eee2 100%);
  border:1px solid var(--border);
  color:var(--ink-3);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:14px;
  position:relative;
  overflow:hidden;
}
.ph-product img.prod-photo{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:18px;
  display:block;
  transition:transform var(--t2);
}
.bs-card:hover .prod-photo{transform:scale(1.04);}
.ph-product::before{content:none;}
.ph-product-bottle{
  width:48px;
  height:80px;
  background:var(--cream);
  border:1px solid var(--border-2);
  border-radius:8px 8px 4px 4px;
  position:relative;
}
.ph-product-bottle::after{
  content:'';
  position:absolute;
  top:-10px;
  left:50%;
  transform:translateX(-50%);
  width:18px;
  height:10px;
  background:var(--ink-2);
  border-radius:3px 3px 0 0;
}
.ph-product-name{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-3);
  text-align:center;
  padding:0 12px;
}

/* ═══════════════════════════════════════════════════════════════
   ANNOUNCEMENT BAR
   ═══════════════════════════════════════════════════════════════ */
.ann{
  background:var(--ink);
  color:var(--cream);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  text-align:center;
  padding:11px 22px;
  position:relative;
  z-index:60;
}
.ann a{text-decoration:underline;text-underline-offset:3px;}

/* ═══════════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════════ */
header{
  background:var(--cream);
  border-bottom:1px solid var(--border);
  position:sticky;
  top:0;
  z-index:50;
}
.nav{
  max-width:var(--max);
  margin:0 auto;
  padding:10px var(--pad);
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:32px;
}
.nav-l{display:flex;gap:32px;align-items:center;}
.nav-r{display:flex;gap:18px;align-items:center;justify-content:flex-end;}
.nav-link{
  font-family:var(--sans);
  font-size:13px;
  font-weight:500;
  letter-spacing:0.04em;
  color:var(--ink);
  position:relative;
  padding:8px 0;
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.nav-link::after{
  content:'';
  position:absolute;
  left:0;
  bottom:2px;
  height:1px;
  width:0;
  background:var(--ink-2);
  transition:width var(--t1);
}
.nav-link:hover::after,
.nav-link.active::after{width:100%;}
.nav-caret{
  width:8px;
  height:8px;
  border-right:1.5px solid currentColor;
  border-bottom:1.5px solid currentColor;
  transform:rotate(45deg) translate(-2px,-2px);
  opacity:0.5;
}
.logo{
  font-family:var(--display);
  font-size:36px;
  font-weight:500;
  letter-spacing:-0.01em;
  color:var(--ink);
  text-align:center;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  height:96px;
}
.logo img{height:96px;width:auto;display:block;object-fit:contain;transform:scale(1.15);transform-origin:center;}
.logo .logo-fallback em{color:var(--ink-2);font-style:normal;}
.nav-icon{
  width:38px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  transition:background var(--t1);
}
.nav-icon:hover{background:rgba(14,51,32,0.06);}
.nav-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.5;}
.cart-count{
  position:absolute;
  top:6px;
  right:6px;
  background:var(--ink-2);
  color:#fff;
  font-size:10px;
  width:16px;
  height:16px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:600;
}
.cart-wrap{position:relative;}

/* Dropdown */
.nav-dd{position:relative;}
.dd-menu{
  position:absolute;
  top:calc(100% + 8px);
  left:-20px;
  min-width:220px;
  background:var(--white);
  border:1px solid var(--border);
  padding:14px 0;
  opacity:0;
  visibility:hidden;
  transform:translateY(-6px);
  transition:opacity 0.18s,transform 0.18s,visibility 0.18s;
}
.nav-dd:hover .dd-menu{opacity:1;visibility:visible;transform:translateY(0);}
.dd-item{
  display:block;
  padding:10px 22px;
  font-size:13px;
  color:var(--ink);
  transition:background var(--t1),color var(--t1);
}
.dd-item:hover{background:var(--cream-2);color:var(--ink-2);}
.dd-item-eyebrow{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink-4);
  padding:8px 22px 4px;
}

/* Mobile menu */
.burger{display:none;width:38px;height:38px;align-items:center;justify-content:center;}
.burger span{width:18px;height:1.5px;background:var(--ink);position:relative;}
.burger span::before,.burger span::after{
  content:'';position:absolute;left:0;width:100%;height:1.5px;background:var(--ink);
}
.burger span::before{top:-6px;}
.burger span::after{top:6px;}

.mob-panel{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100vh;
  background:var(--cream);
  z-index:100;
  transform:translateX(-100%);
  transition:transform 0.35s var(--ease);
  padding:24px;
  overflow-y:auto;
}
.mob-panel.open{transform:translateX(0);}
.mob-close{position:absolute;top:24px;right:24px;width:38px;height:38px;font-size:24px;}
.mob-list{margin-top:60px;}
.mob-link{
  display:block;
  font-family:var(--serif);
  font-size:32px;
  padding:14px 0;
  border-bottom:1px solid var(--border);
}
.mob-sub{padding-left:18px;font-size:18px;font-family:var(--sans);font-weight:500;}

/* ═══════════════════════════════════════════════════════════════
   PAGES
   ═══════════════════════════════════════════════════════════════ */
.page{display:block;animation:fadeIn 0.5s var(--ease);}
.page.active{display:block;} /* legacy, all pages always visible in WP */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

/* Common section utilities */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad);}
.wrap-narrow{max-width:920px;margin:0 auto;padding:0 var(--pad);}
.eyebrow{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--ink-2);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:'';
  width:24px;
  height:1px;
  background:var(--ink-2);
}
.h1{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(40px,6vw,72px);
  line-height:1.05;
  letter-spacing:-0.02em;
  color:var(--ink);
}
.h1 em{font-style:normal;font-weight:400;color:var(--ink-2);}
.h2{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(30px,4.5vw,50px);
  line-height:1.1;
  letter-spacing:-0.015em;
}
.h2 em{font-style:normal;font-weight:400;color:var(--ink-2);}
.h3{
  font-family:var(--display);
  font-weight:500;
  font-size:23px;
  line-height:1.25;
  letter-spacing:-0.005em;
}
.body-lg{font-size:17px;line-height:1.65;color:var(--ink-3);}
.body{font-size:15px;line-height:1.7;color:var(--ink-3);}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:14px 26px;
  font-family:var(--sans);
  font-size:13px;
  font-weight:500;
  letter-spacing:0.06em;
  text-transform:uppercase;
  border:1px solid var(--ink);
  background:var(--ink);
  color:var(--cream);
  transition:all var(--t1);
}
.btn:hover{background:transparent;color:var(--ink);}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink);}
.btn-ghost:hover{background:var(--ink);color:var(--cream);}
.btn-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--sans);
  font-size:13px;
  font-weight:500;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:var(--ink);
  position:relative;
  padding-bottom:4px;
}
.btn-link::after{
  content:'';position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;
  transition:width var(--t1);
}
.btn-link:hover::after{width:60%;}
.btn-link svg{width:14px;height:14px;transition:transform var(--t1);}
.btn-link:hover svg{transform:translateX(4px);}

/* ═══════════════════════════════════════════════════════════════
   HOME — HERO (Video → Image slideshow)
   ═══════════════════════════════════════════════════════════════ */
.hero{
  position:relative;
  height:clamp(420px, 62vh, 620px);
  overflow:hidden;
}
.hero-slide{
  position:absolute;
  inset:0;
  opacity:0;
  transition:opacity 1.2s ease-in-out;
}
.hero-slide.active{opacity:1;}
.hero-slide .ph{height:100%;width:100%;border-radius:0;}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center;display:block;}

/* Hero placeholder gradients (used until high-quality photos provided) */
.hero-ph{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  overflow:hidden;
}
.hero-ph-1{background:linear-gradient(135deg, #D4E8D9 0%, #B6C9A8 45%, #1B5C2E 100%);}
.hero-ph-2{background:linear-gradient(135deg, #F8DDD0 0%, #F2C9B3 45%, #B6694A 100%);}
.hero-ph-3{background:linear-gradient(135deg, #FAF8F3 0%, #F2EDE2 45%, #B6C9A8 100%);}
.hero-ph-orb{
  position:absolute;
  top:50%;
  right:-10%;
  transform:translateY(-50%);
  width:60vmin;
  height:60vmin;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,0.5) 0%, transparent 60%);
  filter:blur(40px);
  pointer-events:none;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(14,51,32,0.35) 0%,transparent 50%,rgba(14,51,32,0.15) 100%);
  z-index:2;
  pointer-events:none;
}
.hero-content{
  position:absolute;
  inset:0;
  z-index:3;
  display:flex;
  align-items:center;
  padding:60px var(--pad);
  max-width:var(--max);
  margin:0 auto;
  left:0;right:0;
}
.hero-text{
  max-width:620px;
  color:#fff;
}
.hero-eyebrow{
  font-family:var(--util);
  font-weight:600;
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.85);
  margin-bottom:22px;
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.hero-eyebrow::before{
  content:'';width:30px;height:1px;background:var(--ink-2);
}
.hero h1{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(36px,5vw,60px);
  line-height:1.08;
  letter-spacing:-0.02em;
  margin-bottom:24px;
}
.hero h1 em{font-style:normal;font-weight:400;color:#F4E8C5;}
.hero-sub{
  font-size:17px;
  line-height:1.55;
  color:rgba(255,255,255,0.85);
  margin-bottom:24px;
  max-width:480px;
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;}
.hero .btn{background:#fff;color:var(--ink);border-color:#fff;}
.hero .btn:hover{background:transparent;color:#fff;}
.hero .btn-ghost{background:transparent;color:#fff;border-color:#fff;}
.hero .btn-ghost:hover{background:#fff;color:var(--ink);}

/* Slide indicators */
.hero-dots{
  position:absolute;
  bottom:32px;
  left:50%;
  transform:translateX(-50%);
  z-index:5;
  display:flex;
  gap:10px;
}
.hero-dot{
  width:40px;
  height:4px;
  background:rgba(255,255,255,0.35);
  cursor:pointer;
  border-radius:2px;
  transition:all var(--t1);
}
.hero-dot:hover{background:rgba(255,255,255,0.6);}
.hero-dot.active{background:#fff;width:60px;}

.hero-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:5;
  width:54px;
  height:54px;
  border-radius:50%;
  background:rgba(255,255,255,0.15);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.25);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  cursor:pointer;
  transition:all var(--t1);
}
.hero-arrow:hover{background:rgba(255,255,255,0.3);transform:translateY(-50%) scale(1.05);}
.hero-arrow svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;}
.hero-arrow.prev{left:24px;}
.hero-arrow.next{right:24px;}

/* ═══════════════════════════════════════════════════════════════
   HOME — PRODUCT INTRO STRIP
   ═══════════════════════════════════════════════════════════════ */
.prod-strip{
  padding:80px 0 60px;
  background:var(--cream);
}
.strip-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  margin-bottom:48px;
  gap:32px;
}
.strip-head h2{max-width:540px;}
.prod-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}
.prod-card{
  cursor:pointer;
  transition:transform var(--t2);
  display:block;
  text-decoration:none;
  color:inherit;
}
.prod-card:hover{transform:translateY(-4px);}
.prod-img{
  aspect-ratio:3/4;
  margin-bottom:18px;
  overflow:hidden;
  position:relative;
}
.prod-img .ph-product{height:100%;width:100%;}
.prod-tag{
  position:absolute;
  top:14px;
  left:14px;
  background:var(--ink);
  color:var(--cream);
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:0.16em;
  padding:5px 10px;
  text-transform:uppercase;
  z-index:2;
}
.prod-tag.gold{background:var(--ink-2);color:var(--cream);}
.prod-tag.peach{background:var(--peach);color:var(--ink);}
.prod-tag.clay{background:var(--clay);color:var(--cream);}
.prod-meta{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.16em;
  color:var(--ink-4);
  text-transform:uppercase;
  margin-bottom:8px;
}
.prod-name{
  font-family:var(--serif);
  font-size:20px;
  line-height:1.25;
  margin-bottom:6px;
  letter-spacing:-0.01em;
}
.prod-desc{
  font-size:13px;
  color:var(--ink-3);
  margin-bottom:14px;
  line-height:1.55;
}
.prod-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-top:1px solid var(--border);
  padding-top:14px;
}
.prod-price{
  font-family:var(--serif);
  font-size:18px;
  font-weight:400;
}
.prod-price-soon{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.16em;
  color:var(--ink-2);
  text-transform:uppercase;
}
.prod-add{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink);
  display:inline-flex;
  align-items:center;
  gap:6px;
  border-bottom:1px solid currentColor;
  padding-bottom:2px;
}

/* ═══════════════════════════════════════════════════════════════
   HOME — EDITORIAL 2-COLUMN BAND
   ═══════════════════════════════════════════════════════════════ */
.edit-band{
  padding:120px 0;
  background:var(--white);
}
.edit-band + .edit-band{padding-top:0;}
.edit-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.edit-row.reverse{direction:rtl;}
.edit-row.reverse > *{direction:ltr;}
.edit-img{
  aspect-ratio:5/6;
  overflow:hidden;
}
.edit-img .ph{height:100%;}
.edit-mascot-bg{
  background:linear-gradient(135deg, var(--peach) 0%, var(--mint) 100%);
  border-radius:8px;
}
.edit-copy h2{margin-bottom:24px;}
.edit-copy .body-lg{margin-bottom:32px;}
.edit-stats{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:20px;
  margin-bottom:32px;
  padding:24px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.edit-stat-num{
  font-family:var(--serif);
  font-size:32px;
  line-height:1;
  color:var(--ink-2);
  margin-bottom:4px;
  font-weight:400;
}
.edit-stat-lbl{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink-4);
}

/* ═══════════════════════════════════════════════════════════════
   HOME — INFLUENCER / UGC CAROUSEL
   ═══════════════════════════════════════════════════════════════ */
.ugc{
  background:var(--cream-2);
  padding:100px 0 80px;
  overflow:hidden;
  position:relative;
}
.ugc-head{text-align:center;margin-bottom:48px;padding:0 var(--pad);}
.ugc-head .eyebrow{justify-content:center;display:flex;}
.ugc-head .eyebrow::before{display:none;}
.ugc-head h2{margin-top:18px;max-width:680px;margin-left:auto;margin-right:auto;}
.ugc-carousel-wrap{position:relative;}
.ugc-track{
  display:flex;
  gap:20px;
  overflow-x:auto;
  padding:32px var(--pad);
  scrollbar-width:none;
  cursor:grab;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
}
.ugc-track.dragging{cursor:grabbing;scroll-behavior:auto;user-select:none;}
.ugc-track.dragging *{pointer-events:none;}
.ugc-track::-webkit-scrollbar{display:none;}
.ugc-clip{
  flex:0 0 240px;
  aspect-ratio:9/16;
  position:relative;
  border-radius:20px;
  overflow:hidden;
  transition:transform 0.4s ease, box-shadow 0.4s ease, opacity 0.4s ease;
  background:#000;
  text-decoration:none;
}
.ugc-clip.is-center{
  transform:scale(1.08);
  box-shadow:0 24px 50px rgba(14,51,32,0.25);
  z-index:2;
  opacity:1;
}
.ugc-clip:not(.is-center){opacity:0.6;}
.ugc-clip:not(.is-center):hover{opacity:0.85;}
.ugc-clip video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  pointer-events:none;
  background:#000;
}
.ugc-thumb{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,#fce5d6 0%,#f3a5b2 35%,#c47da0 70%,#7c5da6 100%);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  color:#fff;
}
.ugc-thumb-icon{width:42px;height:42px;margin-bottom:6px;opacity:0.9;}
.ugc-thumb-icon svg{width:100%;height:100%;}
.ugc-thumb-label{
  font-family:var(--util);
  font-size:11px;
  letter-spacing:0.12em;
  font-weight:600;
  opacity:0.85;
}
.ugc-thumb-play{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
}
.ugc-thumb-play-circle{
  width:60px;
  height:60px;
  border-radius:50%;
  background:rgba(255,255,255,0.25);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:2px solid rgba(255,255,255,0.6);
  display:flex;
  align-items:center;
  justify-content:center;
}
.ugc-thumb-play-circle::before{
  content:'';
  width:0;
  height:0;
  border-left:16px solid #fff;
  border-top:10px solid transparent;
  border-bottom:10px solid transparent;
  margin-left:4px;
}
.ugc-link-overlay{
  position:absolute;
  inset:0;
  z-index:5;
}
.ugc-handle{
  position:absolute;
  bottom:14px;
  left:14px;
  right:14px;
  background:rgba(14,51,32,0.88);
  color:#fff;
  padding:11px 14px;
  font-family:var(--util);
  font-weight:600;
  font-size:12px;
  letter-spacing:0.04em;
  z-index:6;
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-radius:100px;
  pointer-events:none;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.ugc-handle-platform{
  display:flex;
  align-items:center;
  gap:8px;
}
.ugc-handle-platform svg{
  width:14px;
  height:14px;
}
.ugc-handle-arrow{
  font-family:var(--display);
  font-size:14px;
  font-weight:500;
}
.ugc-arrows{
  display:flex;
  gap:14px;
  justify-content:center;
  margin-top:24px;
}
.ugc-arrow{
  width:48px;
  height:48px;
  border-radius:50%;
  border:1px solid var(--border-2);
  background:transparent;
  color:var(--ink);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all var(--t1);
}
.ugc-arrow:hover{
  background:var(--ink);
  color:var(--cream);
  border-color:var(--ink);
}
.ugc-arrow svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.5;}

/* ═══════════════════════════════════════════════════════════════
   HOME — REVIEWS / SOCIAL PROOF (Shopee verified reviews)
   ═══════════════════════════════════════════════════════════════ */
.reviews{
  padding:100px 0 120px;
  background:var(--cream);
  border-top:1px solid var(--border);
}
.rv-title-row{
  margin-bottom:48px;
}
.rv-summary{
  background:var(--white);
  border-radius:20px;
  padding:40px 48px;
  display:grid;
  grid-template-columns:300px 1fr;
  gap:48px;
  align-items:center;
  margin-bottom:48px;
}
.rv-score{
  border-right:1px solid var(--border);
  padding-right:32px;
}
.rv-score-line{
  display:flex;
  align-items:flex-end;
  gap:14px;
  margin-bottom:8px;
}
.rv-score-num{
  font-family:var(--display);
  font-size:64px;
  font-weight:600;
  color:var(--ink);
  line-height:1;
  letter-spacing:-0.02em;
}
.rv-score-stars{
  color:var(--ink-2);
  font-size:20px;
  letter-spacing:2px;
  line-height:1.2;
  padding-bottom:6px;
}
.rv-score-meta{
  font-family:var(--util);
  font-size:13px;
  color:var(--ink-3);
  letter-spacing:0.01em;
}
.rv-highlights{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.rv-highlight{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:12px;
  padding:24px 22px;
  text-align:left;
}
.rv-highlight-num{
  font-family:var(--display);
  font-weight:500;
  font-size:42px;
  letter-spacing:-0.02em;
  line-height:1;
  color:var(--ink);
  margin-bottom:10px;
}
.rv-highlight-label{
  font-family:var(--display);
  font-weight:500;
  font-size:15px;
  line-height:1.3;
  color:var(--ink);
}
.rv-highlight-label span{
  font-family:var(--util);
  font-weight:600;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-3);
  display:block;
  margin-top:4px;
}
.rv-carousel{
  position:relative;
}
.rv-track{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  margin-bottom:40px;
}
.rv-card{
  background:var(--white);
  border-radius:16px;
  padding:32px;
  display:flex;
  flex-direction:column;
  min-height:280px;
  transition:transform var(--t1), box-shadow var(--t1);
}
.rv-card:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(14, 51, 32, 0.06);
}
.rv-head{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:20px;
}
.rv-avatar{
  width:42px;
  height:42px;
  border-radius:50%;
  background:var(--ink);
  color:var(--cream);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--display);
  font-weight:600;
  font-size:14px;
  flex-shrink:0;
  letter-spacing:-0.02em;
}
.rv-head-info{
  flex:1;
  min-width:0;
}
.rv-name{
  font-family:var(--display);
  font-weight:600;
  font-size:16px;
  color:var(--ink);
  line-height:1.2;
}
.rv-product{
  font-family:var(--body);
  font-size:13px;
  color:var(--ink-3);
  margin-top:2px;
}
.rv-stars{
  color:var(--ink-2);
  font-size:14px;
  letter-spacing:1px;
  flex-shrink:0;
}
.rv-text{
  font-family:var(--body);
  font-size:15px;
  line-height:1.6;
  color:var(--ink);
  padding-left:14px;
  border-left:2px solid var(--peach);
  margin-bottom:24px;
  flex:1;
}
.rv-foot{
  font-family:var(--util);
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink-2);
  font-weight:500;
  padding-top:18px;
  border-top:1px solid var(--border);
  margin-top:auto;
}
.rv-foot::before{
  content:'✓ ';
}
.rv-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
}
.rv-arrow{
  width:44px;
  height:44px;
  border-radius:50%;
  border:1px solid var(--border-2);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--ink);
  background:transparent;
  transition:all var(--t1);
  cursor:pointer;
}
.rv-arrow svg{width:18px;height:18px;}
.rv-arrow:hover{
  background:var(--ink);
  color:var(--cream);
  border-color:var(--ink);
}
.rv-dots{
  display:flex;
  gap:8px;
  align-items:center;
}
.rv-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--cream-2);
  border:1px solid var(--border-2);
  transition:all var(--t2);
  cursor:pointer;
}
.rv-dot.active{
  background:var(--ink-2);
  border-color:var(--ink-2);
  width:24px;
  border-radius:4px;
}

/* ═══════════════════════════════════════════════════════════════
   HOME — TRUST BAR (logos, certifications)
   ═══════════════════════════════════════════════════════════════ */
.trust{
  padding:60px 0;
  background:var(--white);
  border-top:1px solid var(--border);
}
.trust-head{
  text-align:center;
  margin-bottom:56px;
}
.trust-head-eyebrow{
  font-family:var(--util);
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--ink-3);
  margin-bottom:14px;
}
.trust-head-text{
  font-family:var(--display);
  font-size:clamp(28px,3.5vw,40px);
  font-weight:500;
  letter-spacing:-0.015em;
  color:var(--ink);
  line-height:1.15;
}
.trust-head-text em{
  font-style:normal;
  font-weight:400;
  color:var(--ink-2);
}
.trust-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:24px;
  align-items:center;
}
.trust-item{
  aspect-ratio:2/1;
}
.tb-cert-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:32px 20px;
  align-items:start;
}
.tb-cert-item{
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:0;
}
.tb-cert-img{
  height:90px;
  width:auto;
  max-width:140px;
  object-fit:contain;
  margin-bottom:16px;
  display:block;
}
.tb-cert-text{
  height:90px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  margin-bottom:16px;
  border:2px solid var(--ink);
  border-radius:50%;
  width:90px;
  padding:6px;
}
.tb-cert-text-main{
  font-family:var(--display);
  font-weight:600;
  font-size:11px;
  letter-spacing:0;
  line-height:1.15;
  color:var(--ink);
}
.tb-cert-text-fb{
  height:90px;
  width:90px;
  border-radius:50%;
  background:var(--ink);
  color:var(--cream);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  margin-bottom:16px;
  font-family:var(--display);
  font-weight:700;
  font-size:18px;
}
.tb-cert-text-fb span{
  font-size:10px;
  letter-spacing:0.14em;
  opacity:0.75;
  font-weight:600;
  margin-top:2px;
}
.tb-cert-stamp{
  width:90px;
  height:90px;
  margin-bottom:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--ink);
}
.tb-cert-stamp svg{width:100%;height:100%;}
.tb-cert-name{
  font-family:var(--display);
  font-weight:600;
  font-size:15px;
  color:var(--ink);
  margin-bottom:6px;
}
.tb-cert-sub{
  font-family:var(--util);
  font-weight:600;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-3);
}
.tb-mark-label{
  font-family:var(--display);
  font-weight:700;
  font-size:13px;
  letter-spacing:0.04em;
  line-height:1;
  text-align:center;
}
.tb-mark-sub{
  font-family:var(--util);
  font-weight:600;
  font-size:9px;
  letter-spacing:0.18em;
  line-height:1;
  opacity:0.7;
}
.tb-mark-arabic{
  font-size:18px;
  font-weight:600;
  line-height:1;
  margin-bottom:2px;
}
.tb-mark-leaf{display:flex;align-items:center;justify-content:center;}
.tb-mark-leaf svg{width:22px;height:22px;}
.tb-mark-symbol{display:flex;align-items:center;justify-content:center;}
.tb-mark-symbol svg{width:28px;height:28px;}

/* When real logo image is present, hide fallback content */
.tb-mark-logo{
  background:var(--white);
  border:none;
  padding:6px;
  overflow:hidden;
}
.tb-mark-logo img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.tb-mark-logo .tb-mark-fb-content{display:none;}
/* When image fails to load (onerror triggers), revert to fallback design */
.tb-mark-logo.tb-mark-fallback{
  background:var(--white);
  border:2px solid var(--ink-2);
  padding:0;
}
.tb-mark-logo.tb-mark-fallback .tb-mark-fb-content{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:1px;
  width:100%;
  height:100%;
  color:var(--ink-2);
}
.tb-mark-bpom.tb-mark-fallback{background:var(--ink-2);color:var(--cream);border-color:var(--ink-2);}
.tb-mark-bpom.tb-mark-fallback .tb-mark-fb-content{color:var(--cream);}
.tb-mark-vegan.tb-mark-fallback{background:var(--mint);color:var(--ink-2);border-color:var(--ink-2);}
.tb-mark-cf.tb-mark-fallback{background:var(--peach);color:var(--ink-2);border-color:var(--ink-2);}
.tb-mark-ewg.tb-mark-fallback{background:var(--white);color:var(--ink-2);border-color:var(--ink-2);}
.tb-mark-derm.tb-mark-fallback{background:var(--cream-2);color:var(--ink-2);border-color:var(--ink-2);}

.tb-mark-bpom{background:var(--ink-2);color:var(--cream);border-color:var(--ink-2);}
.tb-mark-halal{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.tb-mark-vegan{background:var(--mint);color:var(--ink-2);border-color:var(--ink-2);}
.tb-mark-cf{background:var(--peach);color:var(--ink-2);border-color:var(--ink-2);}
.tb-mark-ewg{background:var(--white);color:var(--ink-2);border-color:var(--ink-2);}
.tb-mark-derm{background:var(--cream-2);color:var(--ink-2);border-color:var(--ink-2);}
.tb-cert-name{
  font-family:var(--display);
  font-size:14px;
  font-weight:600;
  color:var(--ink);
  margin-bottom:4px;
}
.tb-cert-sub{
  font-family:var(--util);
  font-size:10px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--ink-3);
}

/* ═══════════════════════════════════════════════════════════════
   ABOUT — BRAND STORY
   ═══════════════════════════════════════════════════════════════ */
.about-hero{
  padding:120px 0 80px;
  background:var(--cream);
  text-align:center;
}
.about-hero .eyebrow{justify-content:center;margin-bottom:24px;}
.about-hero .eyebrow::before{display:none;}
.about-hero h1{max-width:900px;margin:0 auto 28px;}
.about-hero .body-lg{max-width:640px;margin:0 auto;}

.brand-meaning{
  padding:100px 0;
  background:var(--white);
}
.bm-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
}
.bm-cell{
  background:var(--white);
  padding:48px 36px;
  text-align:center;
}
.bm-symbol{
  font-family:var(--display);
  font-size:72px;
  line-height:1;
  color:var(--ink-2);
  font-weight:400;
  margin-bottom:18px;
}
/* Logo pieces — Bio / Soop / . from separate image files */
.bm-logo-piece{
  height:100px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:28px;
}
.bm-logo-piece img{
  max-height:100%;
  max-width:200px;
  width:auto;
  object-fit:contain;
  display:block;
}
.bm-logo-piece-dot img{
  max-height:60%;
  max-width:60px;
}

/* OLD logo crop (kept for backward compat, no longer used) */
.bm-logo-crop{display:none;}

/* OLD bm-logo-mark fallback - kept in case needed */
.bm-logo-mark{
  width:140px;
  height:140px;
  margin:0 auto 24px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:var(--cream-2);
  border:2px solid var(--ink-2);
  overflow:hidden;
  position:relative;
}
.bm-logo-mark span{
  font-family:'Brush Script MT', 'Lucida Handwriting', cursive;
  font-size:54px;
  line-height:1;
  color:var(--ink-2);
  font-weight:500;
  letter-spacing:-0.01em;
  font-style:italic;
}
.bm-logo-mark.bm-dot span{
  font-size:120px;
  line-height:0.5;
  position:relative;
  top:-30px;
}
.bm-label{
  font-family:var(--util);
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--ink-2);
  margin-bottom:14px;
  font-weight:600;
}
.bm-text{
  font-family:var(--body);
  font-size:15px;
  line-height:1.65;
  color:var(--ink);
}

.story-band{
  padding:120px 0;
  background:var(--cream);
}
.story-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:80px;
  align-items:center;
}
.story-img{aspect-ratio:4/5;overflow:hidden;border-radius:4px;}
.story-img img{width:100%;height:100%;object-fit:cover;display:block;}
.story-img .ph{height:100%;}
.story-copy h2{margin-bottom:24px;}
.story-copy p{
  font-size:16px;
  line-height:1.7;
  color:var(--ink-3);
  margin-bottom:18px;
}
.story-signature{
  margin-top:32px;
  display:flex;
  align-items:center;
  gap:16px;
}
.story-sig-img{
  width:60px;
  height:60px;
  border-radius:50%;
  overflow:hidden;
}
.story-sig-img .ph{height:100%;}
.story-sig-mark{
  height:48px;
  width:auto;
  max-width:140px;
  object-fit:contain;
  display:block;
}
.story-sig-name{
  font-family:var(--display);
  font-size:16px;
  font-weight:500;
}
.story-sig-title{
  font-family:var(--util);
  font-size:10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink-4);
  font-weight:600;
  margin-top:4px;
}

/* 404 Page */
.not-found{
  padding:80px 0 120px;
  min-height:70vh;
  display:flex;
  align-items:center;
  background:linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 100%);
}
.nf-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:64px;
  align-items:center;
}
.nf-mascot{
  display:flex;
  align-items:center;
  justify-content:center;
}
.nf-mascot-bg{
  width:100%;
  max-width:420px;
  aspect-ratio:1/1;
  background:linear-gradient(135deg, var(--peach) 0%, var(--mint) 100%);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
}
.nf-mascot-bg .mascot-crop{
  width:88%;
  height:88%;
}
.nf-number{
  font-family:var(--display);
  font-weight:700;
  font-size:clamp(54px,8vw,96px);
  color:var(--ink-2);
  line-height:1;
  letter-spacing:-0.04em;
  opacity:0.4;
}
.nf-actions{
  display:flex;
  gap:14px;
  margin-top:32px;
  flex-wrap:wrap;
}

/* Product Highlight section (Calming Cream B16 on Quality page) */
.product-highlight{
  padding:100px 0;
  background:linear-gradient(180deg, var(--cream) 0%, var(--peach) 100%);
}
.ph-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}
.ph-image{
  aspect-ratio:1/1;
  background:var(--white);
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:40px;
  overflow:hidden;
}
.ph-image img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
}
.ph-copy h2{margin-bottom:0;}
.ph-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:24px;
}
.ph-tag{
  display:inline-flex;
  align-items:center;
  padding:7px 14px;
  background:var(--white);
  border:1px solid var(--border-2);
  border-radius:100px;
  font-family:var(--util);
  font-weight:600;
  font-size:11px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--ink-2);
}

/* Tests list section (Quality page) */
.tests-section{
  padding:100px 0;
  background:var(--cream);
}
.tests-head{text-align:center;margin-bottom:56px;}
.tests-grid{
  max-width:880px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.test-row{
  display:grid;
  grid-template-columns:32px 1fr auto;
  gap:20px;
  align-items:center;
  padding:22px 28px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:12px;
  transition:transform var(--t1);
}
.test-row:hover{
  transform:translateX(4px);
  border-color:var(--ink-2);
}
.test-check{
  width:32px;
  height:32px;
  border-radius:50%;
  background:var(--ink-2);
  color:var(--cream);
  display:flex;
  align-items:center;
  justify-content:center;
}
.test-check svg{width:16px;height:16px;}
.test-name{
  font-family:var(--display);
  font-weight:600;
  font-size:16px;
  color:var(--ink);
  margin-bottom:4px;
}
.test-desc{
  font-family:var(--body);
  font-size:13px;
  line-height:1.55;
  color:var(--ink-3);
}
.test-tag{
  font-family:var(--util);
  font-weight:600;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-3);
  padding:6px 12px;
  background:var(--cream-2);
  border-radius:100px;
  white-space:nowrap;
}
.tests-note{
  text-align:center;
  font-family:var(--util);
  font-size:13px;
  color:var(--ink-3);
  margin-top:40px;
}
.tests-note a{
  color:var(--ink);
  text-decoration:underline;
  text-underline-offset:3px;
}

/* === Quality Unified Section (Certifications + Tests merged) === */
.quality-unified{
  padding:100px 0 60px;
  background:var(--white);
}
.qu-head{text-align:center;margin-bottom:72px;}
.qu-block{
  max-width:980px;
  margin:0 auto 64px;
}
.qu-block:last-child{margin-bottom:0;}
.qu-block-label{
  display:flex;
  align-items:flex-start;
  gap:18px;
  padding-bottom:24px;
  margin-bottom:32px;
  border-bottom:1px solid var(--border);
}
.qu-block-num{
  font-family:var(--display);
  font-weight:300;
  font-size:42px;
  line-height:1;
  color:var(--ink-2);
  letter-spacing:-0.02em;
  flex-shrink:0;
}
.qu-block-title{
  font-family:var(--display);
  font-weight:600;
  font-size:22px;
  color:var(--ink);
  letter-spacing:-0.01em;
  margin-bottom:4px;
}
.qu-block-sub{
  font-family:var(--util);
  font-weight:600;
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink-3);
}

/* Certs row inside qu-block */
.qu-certs{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.qu-cert{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}
.qu-cert-img{
  height:100px;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:14px;
}
.qu-cert-img img{
  height:100px;
  width:auto;
  max-width:160px;
  object-fit:contain;
}
.qu-cert-name{
  font-family:var(--display);
  font-weight:600;
  font-size:15px;
  color:var(--ink);
  margin-bottom:4px;
}
.qu-cert-sub{
  font-family:var(--util);
  font-weight:600;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-3);
}

/* Tests grid inside qu-block */
.qu-tests{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.qu-test{
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:18px 22px;
  background:var(--cream);
  border:1px solid var(--border);
  border-radius:10px;
  transition:transform var(--t1), border-color var(--t1);
}
.qu-test:hover{
  transform:translateX(3px);
  border-color:var(--ink-2);
}
.qu-test-check{
  width:24px;
  height:24px;
  border-radius:50%;
  background:var(--ink-2);
  color:var(--cream);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  margin-top:2px;
}
.qu-test-check svg{width:14px;height:14px;}
.qu-test-name{
  font-family:var(--display);
  font-weight:600;
  font-size:14px;
  color:var(--ink);
  margin-bottom:4px;
}
.qu-test-desc{
  font-family:var(--body);
  font-size:12px;
  line-height:1.55;
  color:var(--ink-3);
}
.qu-note{
  text-align:center;
  font-family:var(--util);
  font-size:12px;
  color:var(--ink-3);
  margin-top:32px;
}
.qu-note a{
  color:var(--ink);
  text-decoration:underline;
  text-underline-offset:3px;
}

/* === How We Work Section (brand-side process, replaces qa-section) === */
.how-section{
  padding:100px 0;
  background:var(--cream);
}
.how-head{text-align:center;margin-bottom:64px;}
.how-steps{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:36px 32px;
  max-width:1100px;
  margin:0 auto;
}
.how-step{
  text-align:left;
  padding:32px 28px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:14px;
  transition:transform var(--t1), box-shadow var(--t1);
}
.how-step:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 28px rgba(14,51,32,0.06);
}
.how-step-num{
  font-family:var(--display);
  font-weight:300;
  font-size:36px;
  line-height:1;
  color:var(--peach-2);
  letter-spacing:-0.02em;
  margin-bottom:18px;
}
.how-step-icon{
  width:48px;
  height:48px;
  color:var(--ink-2);
  margin-bottom:20px;
}
.how-step-icon svg{width:100%;height:100%;}
.how-step-title{
  font-family:var(--display);
  font-weight:600;
  font-size:17px;
  color:var(--ink);
  margin-bottom:10px;
  letter-spacing:-0.005em;
}
.how-step-text{
  font-family:var(--body);
  font-size:13.5px;
  line-height:1.6;
  color:var(--ink-3);
}

/* === End Quality Unified + How sections === */

/* OLD docs section (kept for backward compatibility) */
.docs-section{display:none;}
.docs-head{text-align:center;margin-bottom:56px;}
.docs-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.doc-card{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:14px;
  padding:24px 22px;
  text-decoration:none;
  color:inherit;
  display:flex;
  flex-direction:column;
  gap:6px;
  transition:all var(--t1);
  cursor:pointer;
}
.doc-card:hover{
  border-color:var(--ink-2);
  transform:translateY(-2px);
  box-shadow:0 12px 24px rgba(14,51,32,0.08);
}
.doc-icon{
  width:36px;
  height:36px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--ink-2);
  margin-bottom:8px;
}
.doc-icon svg{width:100%;height:100%;}
.doc-tag{
  font-family:var(--util);
  font-weight:600;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-3);
}
.doc-name{
  font-family:var(--display);
  font-weight:600;
  font-size:15px;
  color:var(--ink);
  line-height:1.3;
  margin-top:2px;
}
.doc-sub{
  font-family:var(--util);
  font-size:11px;
  letter-spacing:0.04em;
  color:var(--ink-3);
  margin-bottom:auto;
  padding-bottom:14px;
}
.doc-cta{
  font-family:var(--util);
  font-weight:600;
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--ink-2);
  padding-top:12px;
  border-top:1px solid var(--border);
}

/* Bio Mascot — Meet Bio section */
.mascot-section{
  padding:120px 0;
  background:linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 100%);
}
.mascot-intro{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:64px;
  align-items:center;
  margin-bottom:64px;
}
.mascot-featured{
  display:flex;
  align-items:center;
  justify-content:center;
}
.mascot-featured-bg{
  width:100%;
  max-width:380px;
  aspect-ratio:1/1;
  background:linear-gradient(135deg, var(--peach) 0%, var(--mint) 100%);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
}
.mascot-featured-bg::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,0.4) 0%, transparent 60%);
  pointer-events:none;
}
.mascot-featured-bg .mascot-crop{
  width:88%;
  height:88%;
  position:relative;
  z-index:1;
}

/* Crop wrapper to hide Gemini watermark on bottom-right corner */
.mascot-crop{
  display:block;
  object-fit:contain;
  /* Crop bottom 8% to remove Gemini watermark */
  clip-path:inset(0 0 8% 0);
  /* Compensate vertical shift so the figure stays centered */
  margin-bottom:-8%;
}

.mascot-copy{
  display:flex;
  flex-direction:column;
  gap:0;
}
.mascot-copy h2 em{color:var(--ink-2);}
.mascot-traits{
  display:flex;
  gap:24px;
  margin-top:32px;
  flex-wrap:wrap;
}
.mascot-trait{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--display);
  font-weight:500;
  font-size:15px;
  color:var(--ink);
}
.mascot-trait-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--ink-2);
}
.mascot-trait:nth-child(2) .mascot-trait-dot{background:var(--clay);}
.mascot-trait:nth-child(3) .mascot-trait-dot{background:var(--peach-2);}

/* Mascot thumbnail row — smaller, cuter */
.mascot-thumb-row{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:14px;
  max-width:900px;
  margin:0 auto;
}
.mascot-thumb{
  aspect-ratio:1/1;
  background:var(--white);
  border-radius:16px;
  padding:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  transition:transform var(--t2);
  cursor:pointer;
}
.mascot-thumb:hover{
  transform:translateY(-4px) rotate(-2deg);
  background:var(--peach);
}
.mascot-thumb .mascot-crop{
  width:100%;
  height:100%;
}

/* Values grid */
.values{
  padding:120px 0;
  background:var(--white);
}
.values-head{text-align:center;margin-bottom:64px;}
.values-head .eyebrow{justify-content:center;}
.values-head .eyebrow::before{display:none;}
.values-head h2{margin-top:18px;}
.values-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
}
.val{
  background:var(--white);
  padding:36px 28px;
}
.val-num{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.16em;
  color:var(--ink-2);
  margin-bottom:18px;
}
.val-title{
  font-family:var(--serif);
  font-size:20px;
  margin-bottom:10px;
  letter-spacing:-0.01em;
}
.val-text{font-size:13px;color:var(--ink-3);line-height:1.6;}

/* ═══════════════════════════════════════════════════════════════
   ABOUT — QUALITY
   ═══════════════════════════════════════════════════════════════ */
.lab-hero{
  padding:90px 0 60px;
  background:var(--cream);
  text-align:center;
}
.lab-banner{
  margin:48px var(--pad) 0;
  height:380px;
  max-width:calc(var(--max) - var(--pad)*2);
  margin-left:auto;
  margin-right:auto;
  overflow:hidden;
  border-radius:8px;
  position:relative;
}
.lab-banner img{width:100%;height:100%;object-fit:cover;display:block;}
.cert-section{padding:100px 0;background:var(--white);}
.cert-head{text-align:center;margin-bottom:56px;}
.cert-head h2{max-width:720px;margin:18px auto 16px;}
.cert-head .body{max-width:580px;margin:0 auto;}
.cert-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}
.cert-card{text-align:center;}
.cert-img{
  aspect-ratio:3/4;
  margin-bottom:14px;
}
.cert-img .ph{height:100%;}
.cert-name{
  font-family:var(--serif);
  font-size:16px;
  margin-bottom:4px;
  letter-spacing:-0.01em;
}
.cert-en{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.12em;
  color:var(--ink-4);
  text-transform:uppercase;
}

/* QA Procedures */
.qa-section{padding:100px 0;background:var(--cream);}
.qa-head{text-align:center;margin-bottom:64px;}
.qa-banner{
  margin:0 auto 56px;
  height:280px;
  max-width:1100px;
}
.qa-steps{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-bottom:24px;
}
.qa-step{
  background:var(--white);
  padding:36px 28px;
  text-align:center;
  position:relative;
}
.qa-step::after{
  content:'';
  position:absolute;
  right:-16px;
  top:50%;
  transform:translateY(-50%);
  width:8px;
  height:8px;
  border-top:1.5px solid var(--ink-2);
  border-right:1.5px solid var(--ink-2);
  transform:translateY(-50%) rotate(45deg);
}
.qa-step:nth-child(3n)::after{display:none;}
.qa-step-num{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.22em;
  color:var(--ink-2);
  margin-bottom:16px;
}
.qa-step-icon{
  width:64px;
  height:64px;
  margin:0 auto 18px;
}
.qa-step-icon .ph{height:100%;border-radius:50%;}
.qa-step-title{
  font-family:var(--serif);
  font-size:18px;
  margin-bottom:8px;
}
.qa-step-text{font-size:12px;color:var(--ink-3);line-height:1.55;}
.qa-complete{
  background:var(--ink);
  color:var(--cream);
  padding:36px;
  text-align:center;
  font-family:var(--serif);
  font-size:24px;
  font-weight:400;
  letter-spacing:-0.01em;
}
.qa-complete::before{
  content:'✓';
  display:inline-block;
  margin-right:12px;
  color:var(--ink-2);
}

/* Certification badges */
.badges-section{padding:100px 0;background:var(--white);}
.badges-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:32px;
  text-align:center;
}
.badge{display:flex;flex-direction:column;align-items:center;gap:14px;}
.badge-img{width:88px;height:88px;}
.badge-img .ph{height:100%;border-radius:50%;}
.badge-name{
  font-family:var(--serif);
  font-size:14px;
  line-height:1.3;
  letter-spacing:-0.005em;
}
.badge-sub{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:0.14em;
  color:var(--ink-4);
  text-transform:uppercase;
}

/* ═══════════════════════════════════════════════════════════════
   ABOUT — STORE LOCATOR (Tubby Todd inspired)
   ═══════════════════════════════════════════════════════════════ */
.loc-hero{
  padding:60px 0 40px;
  background:var(--cream);
  text-align:center;
}
.loc-hero h1{margin-bottom:18px;}
.loc-hero .body-lg{max-width:520px;margin:0 auto;}

.loc-banner{
  height:380px;
  margin:40px var(--pad) 0;
  max-width:calc(var(--max) - var(--pad)*2);
  margin-left:auto;
  margin-right:auto;
  overflow:hidden;
  border-radius:8px;
  position:relative;
}
.loc-banner .ph{height:100%;}
.loc-banner img{width:100%;height:100%;object-fit:cover;display:block;}

.loc-search-section{
  padding:60px 0 100px;
  background:var(--cream);
}
.loc-search-row{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
  margin-bottom:32px;
  max-width:720px;
  margin-left:auto;margin-right:auto;
}
.loc-search-row.with-btn{
  grid-template-columns:1fr auto;
}
.loc-input{
  width:100%;
  padding:16px 22px;
  border:1px solid var(--border-2);
  background:var(--white);
  font-family:var(--body);
  font-size:15px;
  color:var(--ink);
  border-radius:6px;
}
.loc-input:focus{outline:none;border-color:var(--ink-2);}

/* Partner filter pills */
.loc-partners-section{
  padding:48px 0 120px;
}
.loc-partner-filter{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
  margin-bottom:32px;
}
.loc-pill{
  padding:10px 20px;
  border:1px solid var(--border-2);
  background:transparent;
  color:var(--ink);
  font-family:var(--util);
  font-weight:600;
  font-size:12px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  border-radius:100px;
  cursor:pointer;
  transition:all var(--t1);
}
.loc-pill:hover{background:var(--cream-2);}
.loc-pill.active{background:var(--ink);color:var(--cream);border-color:var(--ink);}

.loc-search-row{
  max-width:560px;
  margin:0 auto 40px;
}

/* Store cards grid */
.loc-stores-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.loc-store-card{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:14px;
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:8px;
  text-decoration:none;
  color:inherit;
  transition:all var(--t1);
  cursor:pointer;
}
.loc-store-card:hover{
  border-color:var(--ink-2);
  transform:translateY(-2px);
  box-shadow:0 12px 24px rgba(14,51,32,0.06);
}
.loc-store-card.hidden{display:none;}
.loc-store-tag{
  display:inline-block;
  align-self:flex-start;
  font-family:var(--util);
  font-weight:700;
  font-size:10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink-2);
  background:var(--cream-2);
  padding:5px 10px;
  border-radius:4px;
  margin-bottom:6px;
}
.loc-store-name{
  font-family:var(--display);
  font-weight:600;
  font-size:18px;
  letter-spacing:-0.01em;
  color:var(--ink);
  line-height:1.25;
}
.loc-store-addr{
  font-family:var(--body);
  font-size:13px;
  color:var(--ink-3);
  line-height:1.55;
  flex:1;
}
.loc-store-cta{
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid var(--border);
  font-family:var(--util);
  font-weight:600;
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--ink-2);
  transition:color var(--t1);
}
.loc-store-card:hover .loc-store-cta{color:var(--ink);}

.loc-empty{
  text-align:center;
  padding:48px 24px;
  background:var(--cream);
  border-radius:14px;
  font-family:var(--body);
  color:var(--ink-3);
}

.loc-cta-block{
  text-align:center;
  margin-top:64px;
  padding:48px 32px;
  background:var(--cream);
  border-radius:18px;
}
.loc-cta-block p{
  font-family:var(--display);
  font-size:22px;
  font-weight:500;
  color:var(--ink);
  margin-bottom:24px;
  letter-spacing:-0.01em;
}
.loc-cta-buttons{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
}

/* Legacy loc-list styles kept for backward compat (no longer used) */
.loc-list{display:none;}
.loc-map{display:none;}
.loc-layout{display:none;}

/* ═══════════════════════════════════════════════════════════════
   PRODUCTS — LIST PAGE (Evereden + The Ordinary)
   ═══════════════════════════════════════════════════════════════ */
.prod-hero{
  padding:80px 0 56px;
  background:var(--cream);
  text-align:center;
}
.prod-hero h1{margin-bottom:18px;}
.prod-hero .body-lg{max-width:540px;margin:0 auto 32px;}
.prod-filters{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:center;
}
.filter{
  padding:10px 18px;
  border:1px solid var(--border-2);
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-3);
  background:transparent;
  transition:all var(--t1);
}
.filter:hover{border-color:var(--ink);color:var(--ink);}
.filter.active{background:var(--ink);color:var(--cream);border-color:var(--ink);}

/* Bestsellers horizontal scroll (The Ordinary style) */
.bestsellers{
  padding:80px 0 100px;
  background:var(--white);
}
.bs-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  margin-bottom:36px;
}
.bs-track{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:16px;
}
.bs-card{
  cursor:pointer;
  transition:transform var(--t2);
}
.bs-card:hover{transform:translateY(-3px);}
.bs-card-link{
  display:block;
  text-decoration:none;
  color:inherit;
}
.bs-img{
  aspect-ratio:1/1;
  margin-bottom:14px;
  position:relative;
}
.bs-img .ph-product{height:100%;}
.bs-badge{
  position:absolute;
  top:10px;
  left:10px;
  background:var(--ink);
  color:var(--cream);
  font-family:var(--mono);
  font-size:8px;
  letter-spacing:0.16em;
  padding:4px 8px;
  text-transform:uppercase;
  z-index:2;
}
.bs-fav{
  position:absolute;
  top:10px;
  right:10px;
  width:32px;
  height:32px;
  background:#fff;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:2;
}
.bs-fav svg{width:14px;height:14px;stroke:var(--ink);fill:none;stroke-width:1.5;}
.bs-name{
  font-family:var(--serif);
  font-size:16px;
  margin-bottom:4px;
  letter-spacing:-0.01em;
  line-height:1.3;
}
.bs-size{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.14em;
  color:var(--ink-4);
  text-transform:uppercase;
  margin-bottom:8px;
}
.bs-rating{
  display:flex;
  align-items:center;
  gap:6px;
  margin-bottom:8px;
  font-size:12px;
  color:var(--ink-3);
}
.bs-stars{color:var(--ink-2);letter-spacing:1px;font-size:11px;}
.bs-foot{
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-top:1px solid var(--border);
  padding-top:12px;
  margin-top:8px;
}
.bs-price{font-family:var(--serif);font-size:16px;}
.bs-cart-btn{
  font-family:var(--util);
  font-weight:600;
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  padding:9px 14px;
  border:1px solid var(--ink);
  color:var(--ink);
  background:transparent;
  display:inline-flex;
  align-items:center;
  gap:6px;
  text-decoration:none;
  cursor:pointer;
  transition:all var(--t1);
  border-radius:4px;
}
.bs-cart-btn:hover{background:var(--ink);color:var(--cream);}
.bs-cart-btn .bs-cart-icon{
  width:12px;
  height:12px;
  display:inline-flex;
}

/* Full product grid (Evereden style) */
.all-products{
  padding:60px 0 120px;
  background:var(--cream);
}
.ap-head{
  margin-bottom:36px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:18px;
}
.ap-count{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.16em;
  color:var(--ink-3);
  text-transform:uppercase;
}
.ap-sort{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
}
.ap-sort select{
  background:transparent;
  border:1px solid var(--border-2);
  padding:8px 14px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink);
}
.ap-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}

/* ═══════════════════════════════════════════════════════════════
   BLOG (Tubby Todd inspired — featured + grid)
   ═══════════════════════════════════════════════════════════════ */
.blog-hero{
  padding:90px 0 60px;
  background:var(--cream);
  text-align:center;
}
.blog-hero h1{margin-bottom:18px;}
.blog-hero .body-lg{max-width:540px;margin:0 auto;}

.blog-featured{
  padding:60px 0 80px;
  background:var(--cream);
}
.bf-row{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:60px;
  align-items:center;
}
.bf-img{aspect-ratio:4/3;}
.bf-img .ph{height:100%;}
.bf-cat{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--ink-2);
  margin-bottom:18px;
}
.bf-title{
  font-family:var(--serif);
  font-size:clamp(28px,3.6vw,42px);
  line-height:1.15;
  letter-spacing:-0.02em;
  margin-bottom:18px;
}
.bf-excerpt{
  font-size:16px;
  line-height:1.65;
  color:var(--ink-3);
  margin-bottom:24px;
}
.bf-meta{
  display:flex;
  align-items:center;
  gap:14px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-4);
  margin-bottom:24px;
}
.bf-meta-dot{
  width:3px;
  height:3px;
  border-radius:50%;
  background:var(--ink-4);
}

.blog-grid-section{
  padding:80px 0 120px;
  background:var(--white);
}

/* === Blog category filter pills === */
.blog-cats{
  padding:0 0 20px;
  background:var(--cream);
  border-bottom:1px solid var(--border);
}
.blog-cats-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
  padding:20px 0;
}
.blog-cat-pill{
  font-family:var(--util);
  font-weight:600;
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:9px 18px;
  border-radius:100px;
  background:transparent;
  border:1px solid var(--border-2);
  color:var(--ink-2);
  cursor:pointer;
  transition:all var(--t1);
}
.blog-cat-pill:hover{border-color:var(--ink);color:var(--ink);}
.blog-cat-pill.active{
  background:var(--ink);
  color:var(--cream);
  border-color:var(--ink);
}

/* === Featured Hero Post v2 === */
.blog-featured-v2{
  padding:60px 0 80px;
  background:var(--cream);
}
.bfv2-card{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:48px;
  background:var(--white);
  border-radius:14px;
  overflow:hidden;
  text-decoration:none;
  color:inherit;
  cursor:pointer;
  transition:transform var(--t1), box-shadow var(--t1);
}
.bfv2-card:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 40px rgba(14,51,32,0.08);
}
.bfv2-img{position:relative;overflow:hidden;min-height:420px;}
.bfv2-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--t2);}
.bfv2-card:hover .bfv2-img img{transform:scale(1.04);}
.bfv2-body{padding:48px 44px 48px 0;display:flex;flex-direction:column;justify-content:center;}
.bfv2-cat{
  font-family:var(--util);
  font-weight:600;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--ink-2);
  margin-bottom:14px;
}
.bfv2-title{
  font-family:var(--display);
  font-weight:500;
  font-size:34px;
  line-height:1.15;
  letter-spacing:-0.02em;
  color:var(--ink);
  margin-bottom:18px;
}
.bfv2-excerpt{
  font-family:var(--body);
  font-size:15px;
  line-height:1.65;
  color:var(--ink-3);
  margin-bottom:24px;
  max-width:480px;
}
.bfv2-meta{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--util);
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--ink-4);
  margin-bottom:24px;
}
.bfv2-meta-author{font-weight:600;color:var(--ink-3);}
.bfv2-meta-dot{width:3px;height:3px;border-radius:50%;background:var(--ink-4);}
.bfv2-cta{
  font-family:var(--display);
  font-weight:500;
  font-size:15px;
  color:var(--ink);
  letter-spacing:-0.005em;
}

/* === Main blog layout (grid + sidebar) === */
.blog-main-section{
  padding:80px 0 120px;
  background:var(--white);
}
.blog-layout{
  display:grid;
  grid-template-columns:1fr 320px;
  gap:60px;
  align-items:start;
}
.blog-grid-col{min-width:0;}
.blog-search{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 16px;
  background:var(--cream);
  border:1px solid var(--border);
  border-radius:100px;
  min-width:240px;
}
.blog-search svg{width:16px;height:16px;color:var(--ink-3);flex-shrink:0;}
.blog-search input{
  border:none;background:transparent;outline:none;
  font-family:var(--body);font-size:13px;color:var(--ink);width:100%;
}
.blog-search input::placeholder{color:var(--ink-4);}

.bg-card.is-hidden{display:none;}

/* === Sidebar === */
.blog-sidebar{
  display:flex;
  flex-direction:column;
  gap:36px;
  position:sticky;
  top:140px;
}
.bs-widget{
  background:var(--cream);
  border:1px solid var(--border);
  border-radius:12px;
  padding:24px 22px;
}
.bs-widget-title{
  font-family:var(--display);
  font-weight:600;
  font-size:15px;
  color:var(--ink);
  padding-bottom:14px;
  margin-bottom:14px;
  border-bottom:1px solid var(--border);
  letter-spacing:-0.005em;
}
.bs-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;}
.bs-list li{display:flex;gap:14px;align-items:flex-start;}
.bs-list-num{
  font-family:var(--display);
  font-weight:300;
  font-size:22px;
  line-height:1;
  color:var(--peach-2);
  letter-spacing:-0.02em;
  flex-shrink:0;
  width:24px;
}
.bs-list li a{
  font-family:var(--body);
  font-size:13px;
  line-height:1.45;
  color:var(--ink);
  text-decoration:none;
  cursor:pointer;
  transition:color var(--t1);
}
.bs-list li a:hover{color:var(--ink-2);text-decoration:underline;text-underline-offset:3px;}

.bs-recent{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;}
.bs-recent li{padding:12px 0;border-bottom:1px solid var(--border);}
.bs-recent li:last-child{border-bottom:none;padding-bottom:0;}
.bs-recent li:first-child{padding-top:0;}
.bs-recent li a{display:flex;gap:14px;align-items:flex-start;text-decoration:none;cursor:pointer;}
.bs-recent-date{
  font-family:var(--util);
  font-weight:600;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-3);
  flex-shrink:0;
  width:48px;
  padding-top:2px;
}
.bs-recent-title{
  font-family:var(--body);
  font-size:13px;
  line-height:1.45;
  color:var(--ink);
  transition:color var(--t1);
}
.bs-recent li a:hover .bs-recent-title{color:var(--ink-2);text-decoration:underline;text-underline-offset:3px;}

.bs-tags{display:flex;flex-wrap:wrap;gap:6px;}
.bs-tag{
  font-family:var(--util);
  font-weight:600;
  font-size:10px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:6px 12px;
  background:var(--white);
  border:1px solid var(--border-2);
  border-radius:100px;
  color:var(--ink-2);
  cursor:pointer;
  text-decoration:none;
  transition:all var(--t1);
}
.bs-tag:hover{border-color:var(--ink);background:var(--ink);color:var(--cream);}

.bs-widget-news{background:var(--ink);border-color:var(--ink);color:var(--cream);}
.bs-news-title{
  font-family:var(--display);font-weight:500;font-size:18px;
  letter-spacing:-0.01em;margin-bottom:10px;
}
.bs-news-text{
  font-family:var(--body);font-size:13px;line-height:1.55;
  opacity:0.85;margin-bottom:16px;
}
.bs-news-input{
  width:100%;
  padding:11px 14px;
  background:rgba(255,255,255,0.1);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:100px;
  color:var(--cream);
  font-family:var(--body);
  font-size:13px;
  outline:none;
  margin-bottom:10px;
}
.bs-news-input::placeholder{color:rgba(250,248,243,0.55);}
.bs-news-input:focus{border-color:rgba(255,255,255,0.5);}
.bs-news-btn{
  width:100%;
  padding:11px 14px;
  background:var(--cream);
  color:var(--ink);
  border:none;
  border-radius:100px;
  font-family:var(--util);
  font-weight:600;
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  cursor:pointer;
  transition:opacity var(--t1);
}
.bs-news-btn:hover{opacity:0.85;}

@media (max-width: 1024px){
  .blog-layout{grid-template-columns:1fr;gap:48px;}
  .blog-sidebar{position:static;}
  .bfv2-card{grid-template-columns:1fr;gap:0;}
  .bfv2-img{min-height:280px;}
  .bfv2-body{padding:32px 28px;}
  .bfv2-title{font-size:26px;}
}
@media (max-width: 720px){
  .blog-cats-row{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding:14px 24px;}
  .blog-cat-pill{flex-shrink:0;font-size:11px;padding:8px 14px;}
  .bg-grid{grid-template-columns:1fr;gap:32px;}
  .blog-search{display:none;}
}

.bg-head{margin-bottom:48px;}
.bg-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
}
.bg-card{cursor:pointer;}
.bg-img{
  aspect-ratio:4/3;
  margin-bottom:20px;
  overflow:hidden;
  background:var(--cream-2);
  border-radius:6px;
  position:relative;
}
.bg-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform var(--t2);
  display:block;
}
.bg-img .ph{height:100%;transition:transform var(--t2);}
.bg-card:hover .bg-img img,
.bg-card:hover .bg-img .ph{transform:scale(1.03);}
.bg-cat{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--ink-2);
  margin-bottom:10px;
}
.bg-title{
  font-family:var(--serif);
  font-size:22px;
  line-height:1.25;
  letter-spacing:-0.01em;
  margin-bottom:10px;
}
.bg-excerpt{
  font-size:14px;
  color:var(--ink-3);
  line-height:1.6;
  margin-bottom:16px;
}
.bg-foot{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-top:14px;
  border-top:1px solid var(--border);
}
.bg-date{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-4);
}
.bg-read{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--ink);
  display:inline-flex;
  align-items:center;
  gap:4px;
}

/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
footer{
  background:var(--ink);
  color:var(--cream);
  padding:80px 0 32px;
  position:relative;
  overflow:hidden;
}
.foot-bio-peek{
  position:absolute;
  right:-20px;
  bottom:-30px;
  width:140px;
  height:140px;
  pointer-events:none;
  opacity:0.85;
  z-index:1;
}
.foot-bio-peek img{
  width:100%;
  height:100%;
  object-fit:contain;
  transform:rotate(8deg);
}
footer .wrap{position:relative;z-index:2;}
.foot-top{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;
  gap:48px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,0.1);
  margin-bottom:0;
}
.foot-brand-logo{
  font-family:var(--serif);
  font-size:32px;
  font-weight:400;
  margin-bottom:18px;
  letter-spacing:-0.02em;
}
.foot-brand-logo span{color:var(--ink-2);}
.foot-brand-text{
  font-size:13px;
  line-height:1.7;
  color:rgba(255,255,255,0.5);
  margin-bottom:24px;
  max-width:300px;
}
.foot-news-form{
  display:flex;
  gap:0;
  max-width:340px;
  border:1px solid rgba(255,255,255,0.2);
}
.foot-news-form input{
  flex:1;
  background:transparent;
  border:none;
  padding:13px 16px;
  font-family:var(--sans);
  font-size:13px;
  color:#fff;
}
.foot-news-form input::placeholder{color:rgba(255,255,255,0.4);}
.foot-news-form input:focus{outline:none;}
.foot-news-form button{
  background:var(--cream);
  color:var(--ink);
  padding:13px 22px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
}

.foot-col-h{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.5);
  margin-bottom:20px;
}
.foot-links{
  display:flex;
  flex-direction:column;
  gap:11px;
}
.foot-links a{
  font-size:13px;
  color:rgba(255,255,255,0.75);
  transition:color var(--t1);
}
.foot-links a:hover{color:#fff;}

.foot-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
}
.foot-copy{
  font-size:11px;
  color:rgba(255,255,255,0.4);
  font-family:var(--mono);
  letter-spacing:0.12em;
}
.foot-social{
  display:flex;
  gap:12px;
}
.foot-social a{
  width:32px;
  height:32px;
  border:1px solid rgba(255,255,255,0.2);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all var(--t1);
}
.foot-social a:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.4);}
.foot-social svg{width:14px;height:14px;fill:rgba(255,255,255,0.7);}
.foot-legal{
  display:flex;
  gap:18px;
  font-size:11px;
  font-family:var(--mono);
  letter-spacing:0.12em;
  text-transform:uppercase;
}
.foot-legal a{color:rgba(255,255,255,0.5);}
.foot-legal a:hover{color:#fff;}

/* ── Newsletter CTA (pre-footer hero) ── */
.news-cta{
  background:var(--ink);
  color:var(--cream);
  padding:80px 0;
  position:relative;
  overflow:hidden;
}
.news-cta::before{
  content:'';
  position:absolute;
  top:-100px;
  right:-100px;
  width:400px;
  height:400px;
  background:radial-gradient(circle, rgba(248, 221, 208, 0.08) 0%, transparent 70%);
  pointer-events:none;
}
.news-cta-inner{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:64px;
  align-items:center;
  position:relative;
}
.news-cta-sub{
  font-family:var(--body);
  font-size:15px;
  line-height:1.6;
  color:rgba(255,255,255,0.7);
  margin-top:20px;
  max-width:480px;
}
.news-cta-form{
  display:flex;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.18);
  border-radius:100px;
  padding:6px;
  margin-bottom:28px;
}
.news-cta-form input{
  flex:1;
  background:transparent;
  border:none;
  padding:14px 22px;
  font-family:var(--body);
  font-size:14px;
  color:#fff;
}
.news-cta-form input::placeholder{color:rgba(255,255,255,0.45);}
.news-cta-form input:focus{outline:none;}
.news-cta-form button{
  background:var(--cream);
  color:var(--ink);
  padding:13px 26px;
  font-family:var(--display);
  font-weight:600;
  font-size:14px;
  border-radius:100px;
  transition:all var(--t1);
  white-space:nowrap;
}
.news-cta-form button:hover{background:var(--peach);}
.news-cta-perks{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.perk{
  display:flex;
  align-items:center;
  gap:14px;
  font-family:var(--body);
  font-size:13px;
  color:rgba(255,255,255,0.85);
}
.perk-icon{
  font-size:22px;
  width:38px;
  height:38px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,0.06);
  border-radius:50%;
  flex-shrink:0;
}
.perk strong{
  display:block;
  color:#fff;
  font-weight:600;
  margin-bottom:1px;
}
.perk span{
  color:rgba(255,255,255,0.55);
  font-size:12px;
}

/* ── Footer brand block + contact ── */
.foot-brand-block .foot-brand-logo{
  display:flex;
  align-items:center;
  gap:6px;
}
.foot-brand-block .foot-brand-logo em{
  color:var(--peach);
  font-style:normal;
}
.foot-contact{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-top:28px;
}
.foot-contact-row{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:13px;
  color:rgba(255,255,255,0.65);
}
.foot-contact-row svg{
  width:14px;
  height:14px;
  flex-shrink:0;
  stroke:rgba(255,255,255,0.5);
}
.foot-contact-row a{color:inherit;transition:color var(--t1);}
.foot-contact-row a:hover{color:#fff;}

/* ── Footer trust strip (Payment + Shipping) ── */
.foot-trust{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
  padding:32px 0;
  margin-bottom:24px;
  border-top:1px solid rgba(255,255,255,0.08);
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.foot-trust-label{
  font-family:var(--util);
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.45);
  margin-bottom:14px;
}
.foot-trust-icons{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.pay-pill{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  color:rgba(255,255,255,0.85);
  font-family:var(--util);
  font-size:11px;
  font-weight:500;
  padding:6px 12px;
  border-radius:6px;
  letter-spacing:0.02em;
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1024px){
  :root{--pad:32px;}
  .nav-l .nav-link, .nav-r{display:none;}
  .nav-r .nav-icon.cart-wrap,
  .nav-r .nav-icon.search-only{display:inline-flex;}
  .nav-r{display:flex;}
  .burger{display:flex;}
  .prod-grid{grid-template-columns:repeat(2,1fr);}
  .bs-track{grid-template-columns:repeat(3,1fr);}
  .ap-grid{grid-template-columns:repeat(2,1fr);}
  .cert-grid{grid-template-columns:repeat(2,1fr);}
  .tb-cert-grid{grid-template-columns:repeat(2,1fr);gap:32px 24px;}
  .qa-steps{grid-template-columns:repeat(2,1fr);}
  .qa-step:nth-child(3n)::after{display:block;}
  .qa-step:nth-child(2n)::after{display:none;}
  .badges-grid{grid-template-columns:repeat(3,1fr);}
  .values-grid{grid-template-columns:repeat(2,1fr);}
  .bm-grid{grid-template-columns:1fr;}
  .docs-grid{grid-template-columns:repeat(3,1fr);}
  .qu-certs{grid-template-columns:repeat(3,1fr);gap:20px;}
  .qu-tests{grid-template-columns:1fr;}
  .how-steps{grid-template-columns:repeat(2,1fr);}
  .edit-row{grid-template-columns:1fr;gap:48px;}
  .edit-row.reverse{direction:ltr;}
  .story-grid{grid-template-columns:1fr;gap:48px;}
  .bf-row{grid-template-columns:1fr;}
  .bg-grid{grid-template-columns:repeat(2,1fr);}
  .loc-layout{grid-template-columns:1fr;}
  .loc-list{max-height:400px;}
  .foot-top{grid-template-columns:1fr 1fr;gap:40px 32px;}
  .trust-grid{grid-template-columns:repeat(2,1fr);}
  .tb-cert-grid{grid-template-columns:repeat(2,1fr);gap:32px 16px;}
  .news-cta-inner{grid-template-columns:1fr;gap:40px;}
  .foot-trust{grid-template-columns:1fr;gap:24px;}
  .loc-stores-grid{grid-template-columns:repeat(2,1fr);}
  .rv-summary{grid-template-columns:1fr;padding:32px;}
  .rv-score{border-right:none;border-bottom:1px solid var(--border);padding-right:0;padding-bottom:24px;}
  .rv-track{grid-template-columns:repeat(2,1fr);}
}
@media (max-width: 720px){
  :root{--pad:22px;}
  body{font-size:14px;}
  .ann{font-size:10px;letter-spacing:0.14em;padding:9px 14px;}
  .logo{font-size:24px;height:72px;}
  .logo img{height:72px;}
  .hero{min-height:380px;}
  .hero h1{font-size:34px;}
  .hero-sub{font-size:15px;}
  .hero-content{padding-bottom:56px;}
  .hero-dots{bottom:20px;}
  .prod-grid{grid-template-columns:1fr 1fr;gap:16px;}
  .prod-name{font-size:16px;}
  .strip-head{flex-direction:column;align-items:flex-start;}
  .edit-band{padding:80px 0;}
  .edit-stats{grid-template-columns:1fr;gap:14px;}
  .ugc-clip{flex-basis:240px;}
  .bm-cell{padding:36px 24px;}
  .bm-symbol{font-size:56px;}
  .bs-track{grid-template-columns:repeat(2,1fr);gap:14px;}
  .ap-grid{grid-template-columns:1fr 1fr;gap:14px;}
  .bs-name{font-size:14px;}
  .bs-price{font-size:14px;}
  .cert-grid{grid-template-columns:1fr 1fr;}
  .tb-cert-grid{grid-template-columns:1fr 1fr;gap:16px;}
  .qa-steps{grid-template-columns:1fr;}
  .qa-step::after{display:none !important;}
  .badges-grid{grid-template-columns:1fr 1fr;}
  .rv-track{grid-template-columns:1fr;}
  .rv-summary{padding:24px;gap:24px;}
  .rv-score-num{font-size:48px;}
  .reviews{padding:60px 0 80px;}
  .news-cta{padding:60px 0;}
  .news-cta-form{flex-direction:column;border-radius:16px;background:rgba(255,255,255,0.06);padding:14px;gap:10px;}
  .news-cta-form input{padding:10px 14px;}
  .news-cta-form button{padding:14px;}
  .foot-top{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:1fr;}
  .bg-grid{grid-template-columns:1fr;}
  .foot-top{grid-template-columns:1fr;}
  .trust-grid{grid-template-columns:repeat(2,1fr);}
  .h1{font-size:38px;}
  .h2{font-size:30px;}
  .about-hero{padding:80px 0 56px;}
  .lab-banner,.qa-banner,.loc-banner{height:200px;}
  .loc-stores-grid{grid-template-columns:1fr;}
  .loc-partner-filter{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:8px;}
  .loc-pill{flex-shrink:0;font-size:11px;padding:8px 14px;}
  .ph-grid{grid-template-columns:1fr;gap:32px;}
  .test-row{grid-template-columns:28px 1fr;gap:14px;padding:18px 20px;}
  .test-tag{grid-column:1/-1;justify-self:start;margin-left:42px;font-size:9px;}
  .docs-grid{grid-template-columns:1fr 1fr;gap:14px;}
  .qu-certs{grid-template-columns:1fr;gap:32px;}
  .qu-tests{grid-template-columns:1fr;gap:10px;}
  .qu-block-num{font-size:32px;}
  .qu-block-title{font-size:18px;}
  .how-steps{grid-template-columns:1fr;gap:18px;}
  .how-step{padding:24px 22px;}
  .mascot-intro{grid-template-columns:1fr;gap:32px;text-align:center;}
  .mascot-traits{justify-content:center;}
  .mascot-thumb-row{grid-template-columns:repeat(3,1fr);max-width:400px;}
  .nf-grid{grid-template-columns:1fr;gap:32px;text-align:center;}
  .nf-actions{justify-content:center;}
  .foot-bio-peek{width:90px;height:90px;bottom:-15px;right:-10px;}
}
/* ════════════════════════════════════════════════════════════
   PRODUCTS 페이지 제품명 — 최강 specificity 패치
   기존 v6 CSS 맨 아래에 통째 append
   ════════════════════════════════════════════════════════════ */


/* === 제품명 최강 강제 (body prefix + 모든 가능한 태그 조합) === */

html body .bs-card .bs-name,
html body .bs-card h1,
html body .bs-card h2,
html body .bs-card h3,
html body .bs-card h4,
html body .all-products .bs-card .bs-name,
html body .all-products .bs-card h1,
html body .all-products .bs-card h2,
html body .all-products .bs-card h3,
html body .all-products .bs-card h4,
html body .all-products h1,
html body .all-products h2,
html body .all-products h3,
html body .all-products .bs-name,
html body .bestsellers .bs-name,
html body .bestsellers h1,
html body .bestsellers h2,
html body .bestsellers h3,
html body section .bs-card .bs-name,
html body section .bs-card h1,
html body section .bs-card h2,
html body section .bs-card h3,
html body section[class*="product"] h1,
html body section[class*="product"] h2,
html body section[class*="product"] h3,
html body .page .bs-card .bs-name,
html body .page .bs-card h2,
html body .page .bs-card h3 {
  font-size: 18px !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
  letter-spacing: -0.005em !important;
  margin: 0 0 6px 0 !important;
  padding: 0 !important;
  color: #1a1a1a !important;
  font-family: 'Fredoka', system-ui, -apple-system, sans-serif !important;
  text-transform: none !important;
}


/* === 모바일 (≤768px) === */

@media (max-width: 768px) {
  html body .bs-card .bs-name,
  html body .bs-card h1,
  html body .bs-card h2,
  html body .bs-card h3,
  html body .bs-card h4,
  html body .all-products .bs-card .bs-name,
  html body .all-products .bs-card h1,
  html body .all-products .bs-card h2,
  html body .all-products .bs-card h3,
  html body .all-products h1,
  html body .all-products h2,
  html body .all-products h3,
  html body .all-products .bs-name,
  html body .bestsellers .bs-name,
  html body .bestsellers h2,
  html body .bestsellers h3,
  html body section .bs-card .bs-name,
  html body section .bs-card h2,
  html body section .bs-card h3,
  html body .page .bs-card .bs-name,
  html body .page .bs-card h2,
  html body .page .bs-card h3 {
    font-size: 14px !important;
    line-height: 1.25 !important;
    margin: 0 0 4px 0 !important;
  }
}