/* =========================================================
   Mom's Organic — Allbirds-style layout
   Brand: Mocha #8B6B65 + Gold #C9A020 + Botanical
   ========================================================= */

:root{
  --mocha:#8B6B65;
  --mocha-dark:#3A2E2A;
  --gold:#C9A020;
  --gold-light:#D4B030;
  --gold-tint:#FDF8E8;
  --pink:#B8958D;
  --rose:#A07870;
  --blush:#EEE2DC;
  --ivory:#FAF6EE;
  --cream:#F4ECDF;
  --line:#E3D8CB;
  --soft:#9C8A82;
  --white:#fff;
}

*{box-sizing:border-box;margin:0;padding:0;}
html,body{background:var(--ivory);}
body{
  font-family:'Quicksand','Noto Sans Thai',sans-serif;
  color:var(--mocha-dark);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}
html[data-lang="th"] body{font-family:'Noto Sans Thai','Quicksand',sans-serif;}
/* TH mode: force Noto Sans Thai on ALL headings/text (Quicksand has no Thai glyphs → falls back to system fonts) */
html[data-lang="th"] h1,
html[data-lang="th"] h2,
html[data-lang="th"] h3,
html[data-lang="th"] h4,
html[data-lang="th"] h5,
html[data-lang="th"] h6,
html[data-lang="th"] p,
html[data-lang="th"] span,
html[data-lang="th"] a,
html[data-lang="th"] li,
html[data-lang="th"] div,
html[data-lang="th"] button,
html[data-lang="th"] input,
html[data-lang="th"] textarea,
html[data-lang="th"] [data-lang-th]{
  font-family:'Noto Sans Thai','Quicksand',sans-serif !important;
}
/* But keep the LOGO/brand wordmark as Kalam (per brand guideline — Kalam = logo only, applied via .bb-logo if used) */
html[data-lang="th"] .bb-logo,
html[data-lang="th"] .logo,
html[data-lang="th"] .brand-mark{font-family:'Kalam',cursive !important;}

img{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}

/* App shell — full bleed on desktop (Allbirds style) */
.app{width:100%;min-height:100vh;background:var(--ivory);overflow-x:hidden;}

/* Language switch */
[data-lang-en],[data-lang-th]{display:none;}
html[data-lang="th"] [data-lang-th]{display:initial;}
html[data-lang="en"] [data-lang-en]{display:initial;}
html[data-lang="th"] p[data-lang-th],html[data-lang="th"] h1[data-lang-th],
html[data-lang="th"] h2[data-lang-th],html[data-lang="th"] h3[data-lang-th],
html[data-lang="th"] div[data-lang-th]{display:block;}
html[data-lang="en"] p[data-lang-en],html[data-lang="en"] h1[data-lang-en],
html[data-lang="en"] h2[data-lang-en],html[data-lang="en"] h3[data-lang-en],
html[data-lang="en"] div[data-lang-en]{display:block;}

/* =========================================================
   TOP PROMO BAR — Allbirds thin announcement
   ========================================================= */
.promo{background:var(--mocha-dark);color:var(--ivory);
  font-size:12px;letter-spacing:.08em;text-align:center;
  padding:9px 16px;font-weight:500;}
.promo a{text-decoration:underline;margin-left:6px;}

/* =========================================================
   HEADER
   ========================================================= */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(250,246,238,.97);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  padding:14px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.logo{display:flex;align-items:center;flex-shrink:0;}
.logo img{height:42px;width:auto;}

nav.menu{display:none;gap:32px;flex:1;justify-content:center;}
nav.menu a{font-size:13px;font-weight:600;color:var(--mocha-dark);
  letter-spacing:.08em;text-transform:uppercase;padding:6px 4px;
  border-bottom:2px solid transparent;transition:border-color .2s;}
nav.menu a:hover,nav.menu a.on{border-bottom-color:var(--gold);}

.header-tools{display:flex;align-items:center;gap:6px;}
.lang-toggle{display:flex;background:var(--cream);border-radius:18px;padding:2px;
  font-size:10.5px;font-weight:700;letter-spacing:.06em;margin-right:6px;}
.lang-toggle button{padding:4px 10px;border-radius:16px;color:var(--soft);transition:all .15s;}
.lang-toggle button.on{background:var(--mocha);color:var(--ivory);}
.icon-btn{width:38px;height:38px;display:flex;align-items:center;
  justify-content:center;border-radius:50%;color:var(--mocha-dark);font-size:22px;}
.icon-btn .ph-thin{font-weight:100;}
.icon-btn:hover{background:var(--blush);}
.hamburger-btn{display:flex;}

@media (min-width:980px){
  header{padding:16px 48px;}
  .logo img{height:52px;}
  nav.menu{display:flex;}
  .hamburger-btn{display:none;}
}

/* Mobile drawer */
.drawer{position:fixed;inset:0;background:rgba(58,46,42,.4);z-index:60;
  opacity:0;pointer-events:none;transition:opacity .2s;}
.drawer.open{opacity:1;pointer-events:auto;}
.drawer-panel{position:absolute;top:0;right:0;height:100%;width:78%;max-width:340px;
  background:var(--ivory);padding:32px 28px;transform:translateX(100%);
  transition:transform .25s ease;display:flex;flex-direction:column;gap:6px;}
.drawer.open .drawer-panel{transform:translateX(0);}
.drawer a{font-size:18px;font-weight:600;color:var(--mocha-dark);
  padding:14px 6px;border-bottom:1px solid var(--line);letter-spacing:.04em;}

/* =========================================================
   HERO — Allbirds full-bleed style
   ========================================================= */
.hero{position:relative;background:var(--cream);overflow:hidden;}
.hero-img{width:100%;height:78vh;min-height:540px;position:relative;}
.hero-img img{width:100%;height:100%;object-fit:cover;object-position:center 28%;}
.hero-overlay{position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,.05) 0%,rgba(0,0,0,.0) 35%,rgba(58,46,42,.42) 100%);}
.hero-text{position:absolute;left:0;right:0;bottom:0;
  padding:0 26px 60px;color:var(--ivory);max-width:1400px;margin:0 auto;}
.hero-eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  font-weight:600;margin-bottom:14px;opacity:.92;}
.hero h1{font-family:'Quicksand',serif;font-weight:300;font-size:38px;
  line-height:1.05;letter-spacing:-.015em;margin-bottom:18px;max-width:580px;}
.hero h1 em{font-style:normal;font-weight:600;}
.hero p.tagline{font-size:14.5px;line-height:1.6;max-width:440px;
  opacity:.94;margin-bottom:26px;}
.hero-btn-row{display:flex;flex-wrap:wrap;gap:10px;}

.btn-primary{display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;background:var(--ivory);color:var(--mocha-dark);
  font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  border-radius:0;transition:background .2s,transform .15s;
  border:1.5px solid var(--ivory);}
.btn-primary:hover{background:transparent;color:var(--ivory);}
.btn-primary .arrow{transition:transform .2s;display:inline-block;}
.btn-primary:hover .arrow{transform:translateX(4px);}

.btn-ghost{display:inline-flex;align-items:center;gap:10px;padding:13px 26px;
  border:1.5px solid var(--ivory);color:var(--ivory);font-size:12px;
  font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  transition:all .2s;}
.btn-ghost:hover{background:var(--ivory);color:var(--mocha-dark);}

.btn-dark{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;
  background:var(--mocha-dark);color:var(--ivory);font-size:12px;
  font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  border:1.5px solid var(--mocha-dark);transition:all .2s;}
.btn-dark:hover{background:transparent;color:var(--mocha-dark);}

.btn-line{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;
  border:1.5px solid var(--mocha-dark);color:var(--mocha-dark);
  font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  transition:all .2s;}
.btn-line:hover{background:var(--mocha-dark);color:var(--ivory);}

@media (min-width:900px){
  .hero-img{height:86vh;min-height:640px;}
  .hero-text{padding:0 56px 80px;}
  .hero h1{font-size:62px;line-height:1.0;}
  .hero p.tagline{font-size:16px;max-width:520px;margin-bottom:32px;}
}

/* =========================================================
   BRAND MARK — Cotton illust + full logo + statement
   ========================================================= */
.brand-mark{position:relative;background:var(--ivory);
  padding:90px 26px 100px;text-align:center;overflow:hidden;}
.brand-mark .cotton-ornament{position:absolute;width:240px;opacity:.12;
  top:-30px;right:-50px;pointer-events:none;transform:rotate(8deg);}
.brand-mark-inner{position:relative;max-width:680px;margin:0 auto;}
.logo-full{display:block;width:260px;max-width:78%;height:auto;margin:0 auto 28px;}
.brand-statement{font-size:16px;line-height:1.85;color:var(--mocha-dark);
  font-weight:300;letter-spacing:.01em;max-width:540px;margin:0 auto;}

@media (min-width:900px){
  .brand-mark{padding:130px 40px 140px;}
  .brand-mark .cotton-ornament{width:340px;opacity:.14;
    top:-40px;right:-60px;}
  .logo-full{width:340px;margin-bottom:36px;}
  .brand-statement{font-size:18px;}
}

/* =========================================================
   COTTON DIVIDER — botanical section break
   ========================================================= */
.cotton-divider{display:flex;justify-content:center;align-items:center;
  padding:48px 24px;background:var(--ivory);position:relative;}
.cotton-divider::before,.cotton-divider::after{
  content:"";flex:1;max-width:140px;height:1px;
  background:var(--line);margin:0 22px;}
.cotton-divider img{width:90px;height:auto;opacity:.88;}

@media (min-width:760px){
  .cotton-divider{padding:64px 24px;}
  .cotton-divider::before,.cotton-divider::after{max-width:240px;}
  .cotton-divider img{width:120px;}
}

/* =========================================================
   DUAL FEATURE — Split feature blocks
   ========================================================= */
.dual-feature{display:grid;grid-template-columns:1fr;gap:0;}
.feat-card{position:relative;aspect-ratio:4/5;overflow:hidden;
  background:var(--blush);display:block;}
.feat-card img{width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease;}
.feat-card:hover img{transform:scale(1.04);}
.feat-card .feat-overlay{position:absolute;inset:0;
  background:linear-gradient(to top,rgba(58,46,42,.55),rgba(58,46,42,0) 55%);}
.feat-card .feat-text{position:absolute;left:0;right:0;bottom:0;
  padding:38px 32px;color:var(--ivory);}
.feat-card .feat-text .ftxt-eyebrow{font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;font-weight:600;opacity:.94;margin-bottom:8px;}
.feat-card .feat-text h2{font-size:32px;font-weight:300;line-height:1.1;
  margin-bottom:14px;letter-spacing:-.01em;}
.feat-card .feat-text h2 em{font-style:normal;font-weight:600;}
.feat-card .feat-text .ftxt-meta{font-size:13px;opacity:.86;margin-bottom:18px;}
.feat-card .feat-text .btn-primary{padding:11px 22px;font-size:11px;}

@media (min-width:760px){
  .dual-feature{grid-template-columns:1fr 1fr;}
  .feat-card{aspect-ratio:1/1.18;}
  .feat-card .feat-text h2{font-size:42px;}
  .feat-card .feat-text{padding:46px 44px;}
}

/* =========================================================
   SECTION HEADER
   ========================================================= */
.section{padding:80px 0;background:var(--ivory);}
.section.alt{background:var(--cream);}
.section.dark{background:var(--mocha-dark);color:var(--ivory);}
.section-h{max-width:1280px;margin:0 auto;padding:0 26px 36px;}
.section-h .eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:10px;}
.section.dark .section-h .eyebrow{color:var(--gold-light);}
.section-h h2{font-size:30px;font-weight:300;line-height:1.15;
  letter-spacing:-.01em;color:var(--mocha-dark);max-width:760px;}
.section.dark .section-h h2{color:var(--ivory);}
.section-h h2 em{font-style:normal;font-weight:600;color:var(--mocha);}
.section.dark .section-h h2 em{color:var(--gold-light);}
.section-h p{color:var(--soft);font-size:14.5px;margin-top:14px;max-width:560px;line-height:1.7;}
.section.dark .section-h p{color:rgba(250,246,238,.74);}

@media (min-width:900px){
  .section{padding:120px 0;}
  .section-h{padding:0 56px 48px;}
  .section-h h2{font-size:46px;}
}

/* =========================================================
   CATEGORY GRID — Allbirds 4-up pattern
   ========================================================= */
.cat-grid{max-width:1400px;margin:0 auto;padding:0 18px;
  display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.cat-card{position:relative;aspect-ratio:4/5;overflow:hidden;
  background:var(--blush);display:block;border-radius:0;}
.cat-card img{width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;}
.cat-card:hover img{transform:scale(1.05);}
.cat-card .cat-label{position:absolute;left:0;right:0;bottom:0;
  padding:18px 20px;color:var(--ivory);
  background:linear-gradient(to top,rgba(58,46,42,.62),rgba(58,46,42,0) 75%);}
.cat-card .cat-name{font-size:16px;font-weight:600;letter-spacing:.02em;
  margin-bottom:3px;}
.cat-card .cat-meta{font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  opacity:.86;}

@media (min-width:760px){
  .cat-grid{grid-template-columns:repeat(3,1fr);gap:16px;padding:0 30px;}
}
@media (min-width:1100px){
  .cat-grid{grid-template-columns:repeat(6,1fr);padding:0 40px;gap:18px;}
}

/* =========================================================
   BESTSELLERS — horizontal scroll (Allbirds carousel)
   ========================================================= */
.scroll-row{display:flex;gap:14px;padding:0 26px;
  overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;-ms-overflow-style:none;}
.scroll-row::-webkit-scrollbar{display:none;}
.prod-card{flex:0 0 72%;scroll-snap-align:start;
  background:var(--ivory);border-radius:0;overflow:hidden;
  display:block;transition:transform .2s;}
.prod-card:hover{transform:translateY(-4px);}
.prod-card .img{aspect-ratio:1/1.1;background:var(--blush);overflow:hidden;}
.prod-card .img img{width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;}
.prod-card:hover .img img{transform:scale(1.04);}
.prod-card .info{padding:16px 4px 0;}
.prod-card .info .tag{font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--rose);font-weight:600;margin-bottom:6px;}
.prod-card .info .name{font-size:15px;color:var(--mocha-dark);
  font-weight:500;margin-bottom:6px;line-height:1.3;}
.prod-card .info .name-sub{font-size:12px;color:var(--soft);margin-bottom:10px;}
.prod-card .info .price{font-size:15px;font-weight:600;color:var(--mocha-dark);}
.prod-card .info .price .currency{font-size:11px;opacity:.7;margin-right:2px;}
.prod-card .dots{display:flex;gap:5px;margin-top:8px;}
.prod-card .dot{width:11px;height:11px;border-radius:50%;border:1px solid rgba(0,0,0,.08);}
.dot.bear{background:#A6826C;}
.dot.coco{background:#7E5B4D;}
.dot.star{background:#C8A876;}

@media (min-width:680px){
  .scroll-row{padding:0 40px;gap:20px;}
  .prod-card{flex:0 0 40%;}
}
@media (min-width:1100px){
  .scroll-row{padding:0 56px;gap:24px;}
  .prod-card{flex:0 0 23.4%;}
}

.section-cta{display:flex;justify-content:center;margin-top:44px;}

/* =========================================================
   MATERIAL STORY — Allbirds "Made better" editorial
   ========================================================= */
.story{padding:0;background:var(--ivory);}
.story-grid{max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:1fr;align-items:stretch;}
.story-img{aspect-ratio:4/5;overflow:hidden;background:var(--cream);}
.story-img img{width:100%;height:100%;object-fit:cover;}
.story-text{padding:56px 28px;display:flex;flex-direction:column;justify-content:center;}
.story-text .eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:14px;}
.story-text h2{font-size:32px;font-weight:300;line-height:1.18;
  margin-bottom:22px;letter-spacing:-.01em;}
.story-text h2 em{font-style:normal;font-weight:600;color:var(--mocha);}
.story-text p{color:var(--soft);font-size:14.5px;line-height:1.85;margin-bottom:18px;}

.story-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  margin-top:30px;padding-top:30px;border-top:1px solid var(--line);}
.stat .stat-num{font-size:28px;font-weight:300;color:var(--mocha);
  font-feature-settings:"tnum";line-height:1;}
.stat .stat-label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--soft);margin-top:6px;font-weight:600;}

@media (min-width:900px){
  .story-grid{grid-template-columns:1.05fr 1fr;}
  .story-img{aspect-ratio:auto;}
  .story-text{padding:80px 70px;}
  .story-text h2{font-size:42px;}
}
.story-reverse .story-grid{direction:rtl;}
.story-reverse .story-text{direction:ltr;}
.story-reverse .story-img{direction:ltr;}

/* =========================================================
   PATTERN LOOKBOOK — 3-card row
   ========================================================= */
.lookbook{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);}
.look-card{position:relative;background:var(--cream);overflow:hidden;
  aspect-ratio:4/5;}
.look-card img{width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease;}
.look-card:hover img{transform:scale(1.04);}
.look-card .look-text{position:absolute;left:0;right:0;bottom:0;
  padding:32px 28px;color:var(--ivory);
  background:linear-gradient(to top,rgba(58,46,42,.58),rgba(58,46,42,0) 60%);}
.look-card .look-pattern{font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;font-weight:600;opacity:.92;margin-bottom:6px;}
.look-card .look-name{font-size:26px;font-weight:300;line-height:1.1;
  margin-bottom:8px;}
.look-card .look-name em{font-style:normal;font-weight:600;}
.look-card .look-meta{font-size:12px;opacity:.84;letter-spacing:.06em;}

@media (min-width:760px){
  .lookbook{grid-template-columns:repeat(3,1fr);}
}

/* =========================================================
   REVIEWS / PRESS STRIP
   ========================================================= */
.reviews{background:var(--ivory);padding:80px 26px;}
.review-grid{max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:32px;}
.review{padding:32px 28px;background:var(--cream);position:relative;}
.review .stars{color:var(--gold);font-size:14px;letter-spacing:.1em;margin-bottom:14px;}
.review p.text{font-size:15px;color:var(--mocha-dark);line-height:1.7;
  font-weight:300;margin-bottom:18px;}
.review .author{font-size:12px;color:var(--soft);letter-spacing:.06em;}
.review .author strong{color:var(--mocha);font-weight:600;}

@media (min-width:760px){
  .review-grid{grid-template-columns:repeat(3,1fr);gap:24px;}
}

.press-strip{max-width:1100px;margin:60px auto 0;padding-top:50px;
  border-top:1px solid var(--line);display:flex;flex-wrap:wrap;
  justify-content:center;align-items:center;gap:36px;}
.press-strip .label{font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--soft);font-weight:600;width:100%;text-align:center;margin-bottom:6px;}
.press-strip .name{font-family:'Quicksand',serif;font-size:18px;
  font-weight:400;color:var(--mocha-dark);letter-spacing:.04em;}

/* =========================================================
   ORGANIC PROMISE / VALUE STRIP
   ========================================================= */
.promise{background:var(--mocha-dark);color:var(--ivory);padding:60px 26px;}
.promise-grid{max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(2,1fr);gap:32px;}
.promise-item{display:flex;gap:16px;align-items:flex-start;}
.promise-item .ico{font-size:34px;color:var(--gold-light);flex-shrink:0;margin-top:-4px;width:38px;text-align:center;line-height:1;}
.promise-item .ico .ph-thin{font-weight:100;}
.promise-item .p-name{font-size:13px;font-weight:600;letter-spacing:.04em;}
.promise-item .p-sub{font-size:11.5px;opacity:.72;margin-top:5px;line-height:1.55;}

@media (min-width:760px){
  .promise-grid{grid-template-columns:repeat(4,1fr);gap:34px;}
}

/* =========================================================
   NEWSLETTER — Allbirds-style centered
   ========================================================= */
.newsletter{padding:96px 26px;background:var(--cream);text-align:center;}
.newsletter h2{font-size:30px;font-weight:300;color:var(--mocha-dark);
  margin-bottom:12px;letter-spacing:-.01em;}
.newsletter h2 em{font-style:normal;font-weight:600;color:var(--mocha);}
.newsletter p{color:var(--soft);font-size:14px;margin-bottom:26px;
  max-width:440px;margin-left:auto;margin-right:auto;line-height:1.7;}
.news-form{display:flex;gap:0;max-width:440px;margin:0 auto;
  background:var(--ivory);border:1px solid var(--line);}
.news-form input{flex:1;padding:14px 22px;border:none;background:transparent;
  font-family:inherit;font-size:14px;color:var(--mocha-dark);outline:none;}
.news-form button{padding:13px 28px;background:var(--mocha-dark);color:var(--ivory);
  font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;}

/* =========================================================
   FOOTER — Allbirds extensive footer
   ========================================================= */
footer{background:var(--ivory);border-top:1px solid var(--line);
  padding:64px 26px 32px;}
.footer-inner{max-width:1400px;margin:0 auto;display:grid;
  grid-template-columns:1fr;gap:40px;}
.foot-brand{max-width:340px;}
.foot-brand img{height:auto;width:200px;max-width:100%;margin-bottom:18px;}
.logo-full-foot{width:220px !important;}
.foot-brand p{font-size:13px;color:var(--soft);line-height:1.7;}
.foot-col h4{font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--mocha-dark);margin-bottom:18px;font-weight:700;}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:12px;}
.foot-col a{font-size:13px;color:var(--soft);}
.foot-col a:hover{color:var(--mocha);}
.socials{display:flex;gap:10px;margin-top:22px;}
.socials a{width:38px;height:38px;border-radius:50%;background:var(--cream);
  display:flex;align-items:center;justify-content:center;font-size:18px;
  color:var(--mocha);}
.socials a .ph-thin{font-weight:100;}
.socials a:hover{background:var(--mocha);color:var(--ivory);}

.foot-bottom{max-width:1400px;margin:48px auto 0;padding-top:24px;
  border-top:1px solid var(--line);display:flex;
  justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:11.5px;color:var(--soft);}
.foot-bottom .links a{margin-right:18px;}

@media (min-width:900px){
  .footer-inner{grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:40px;}
  footer{padding:96px 56px 40px;}
  .foot-bottom{padding-top:32px;}
}

/* =========================================================
   SHOP PAGE
   ========================================================= */
.page-hero{padding:60px 26px 30px;text-align:center;background:var(--ivory);}
.page-hero .eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:14px;}
.page-hero h1{font-size:36px;font-weight:300;color:var(--mocha-dark);letter-spacing:-.01em;}
.page-hero h1 em{font-style:normal;font-weight:600;color:var(--mocha);}
.page-hero p{color:var(--soft);font-size:14px;max-width:540px;margin:14px auto 0;}

.filters{position:sticky;top:67px;z-index:40;background:rgba(250,246,238,.96);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
  padding:14px 22px;display:flex;gap:8px;overflow-x:auto;align-items:center;
  scrollbar-width:none;}
.filters::-webkit-scrollbar{display:none;}
.filter-chip{padding:8px 16px;border-radius:0;font-size:11.5px;
  font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--soft);background:transparent;border:1px solid var(--line);
  white-space:nowrap;transition:all .15s;
  display:inline-flex;align-items:center;gap:8px;}
.filter-chip .dot{vertical-align:middle;}
.filter-chip.on{background:var(--mocha-dark);color:var(--ivory);border-color:var(--mocha-dark);}
.filter-chip:hover:not(.on){border-color:var(--mocha);color:var(--mocha);}
.filter-divider{width:1px;height:24px;background:var(--line);margin:0 6px;flex-shrink:0;}
.filter-label{font-size:10.5px;color:var(--soft);font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;margin-right:4px;flex-shrink:0;}

.shop-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
  padding:36px 22px 80px;max-width:1400px;margin:0 auto;}
.shop-grid .prod-card{flex:none;background:var(--ivory);}
.shop-grid .prod-card .img{aspect-ratio:1/1.15;}

@media (min-width:700px){
  .shop-grid{grid-template-columns:repeat(3,1fr);gap:20px;padding:50px 30px 100px;}
}
@media (min-width:1100px){
  .shop-grid{grid-template-columns:repeat(4,1fr);gap:24px;padding:60px 56px 120px;}
  .page-hero{padding:96px 26px 40px;}
  .page-hero h1{font-size:50px;}
}

/* =========================================================
   MOBILE OPTIMIZATIONS (≤ 760px) — compact, breathing, scannable
   ========================================================= */
@media (max-width:760px){

  /* Header — tighter */
  header{padding:10px 14px;gap:8px;}
  .logo img{height:34px;}
  .lang-toggle{font-size:10px;padding:2px;margin-right:2px;}
  .lang-toggle button{padding:4px 8px;}
  .icon-btn{width:34px;height:34px;font-size:21px;}
  /* Hide search on mobile — saves space; user can still hit shop */
  .header-tools .icon-btn[aria-label="search"]{display:none;}

  /* Promo bar — compact, single line if possible */
  .promo{font-size:11px;padding:8px 14px;letter-spacing:.04em;}
  .promo a{margin-left:8px;}

  /* Hero — SPLIT layout on mobile: full baby photo + text section below */
  .hero{background:var(--ivory);}
  .hero-img{height:auto;min-height:0;aspect-ratio:4/5;width:100%;}
  .hero-img img{object-position:center 30%;}
  .hero-overlay{display:none;} /* No overlay — baby photo stands alone */
  .hero-text{position:static;color:var(--mocha-dark);
    padding:34px 22px 48px;background:var(--ivory);max-width:none;}
  .hero-eyebrow{font-size:10px;letter-spacing:.28em;margin-bottom:10px;
    color:var(--gold);opacity:1;}
  .hero h1{font-size:30px;line-height:1.1;margin-bottom:14px;
    letter-spacing:-.005em;color:var(--mocha-dark);}
  .hero h1 em{color:var(--mocha);}
  .hero p.tagline{font-size:13.5px;line-height:1.65;margin-bottom:22px;
    max-width:90%;color:var(--soft);opacity:1;}
  .hero-btn-row{gap:8px;flex-wrap:wrap;}
  /* Buttons need contrast against light bg on mobile */
  .hero .btn-primary{background:var(--mocha-dark);color:var(--ivory);
    border-color:var(--mocha-dark);padding:12px 22px;font-size:11px;letter-spacing:.14em;}
  .hero .btn-primary:hover{background:transparent;color:var(--mocha-dark);}
  .hero .btn-ghost{border-color:var(--mocha-dark);color:var(--mocha-dark);
    padding:12px 22px;font-size:11px;letter-spacing:.14em;}
  .hero .btn-ghost:hover{background:var(--mocha-dark);color:var(--ivory);}

  /* Brand mark — compact */
  .brand-mark{padding:62px 22px 70px;}
  .brand-mark .cotton-ornament{width:170px;top:-25px;right:-45px;opacity:.10;}
  .logo-full{width:220px;margin-bottom:24px;}
  .brand-statement{font-size:14.5px;line-height:1.75;}

  /* Dual feature — landscape, less vertical */
  .feat-card{aspect-ratio:16/11;}
  .feat-card .feat-text{padding:24px 22px;}
  .feat-card .feat-text .ftxt-eyebrow{font-size:10px;letter-spacing:.22em;margin-bottom:6px;}
  .feat-card .feat-text h2{font-size:26px;line-height:1.05;margin-bottom:10px;}
  .feat-card .feat-text .ftxt-meta{font-size:12px;margin-bottom:14px;}

  /* Section spacing — compact */
  .section{padding:60px 0;}
  .section-h{padding:0 22px 24px;}
  .section-h .eyebrow{font-size:10px;letter-spacing:.28em;margin-bottom:8px;}
  .section-h h2{font-size:25px;line-height:1.2;}
  .section-h p{font-size:13.5px;margin-top:10px;}

  /* Category grid — 2 col but shorter cards */
  .cat-grid{gap:8px;padding:0 12px;}
  .cat-card{aspect-ratio:3/4;}
  .cat-card .cat-label{padding:14px 14px;}
  .cat-card .cat-name{font-size:14px;}
  .cat-card .cat-meta{font-size:9.5px;letter-spacing:.12em;}

  /* Bestsellers scroll */
  .scroll-row{padding:0 18px;gap:12px;}
  .prod-card{flex:0 0 70%;}
  .prod-card .info{padding:14px 4px 0;}
  .prod-card .info .name{font-size:13.5px;}
  .prod-card .info .name-sub{font-size:11px;margin-bottom:8px;}
  .prod-card .info .price{font-size:14px;}
  .section-cta{margin-top:32px;}
  .btn-line{padding:12px 22px;font-size:11px;}

  /* Story split — stack and compact */
  .story-text{padding:50px 22px;}
  .story-text h2{font-size:26px;line-height:1.18;}
  .story-text p{font-size:14px;line-height:1.75;}
  .story-stats{gap:12px;margin-top:24px;padding-top:24px;}
  .stat .stat-num{font-size:22px;}
  .stat .stat-label{font-size:10px;letter-spacing:.12em;}

  /* Cotton divider */
  .cotton-divider{padding:32px 22px;}
  .cotton-divider img{width:72px;}
  .cotton-divider::before,.cotton-divider::after{max-width:80px;margin:0 14px;}

  /* Lookbook — landscape */
  .look-card{aspect-ratio:16/13;}
  .look-card .look-text{padding:22px 20px;}
  .look-card .look-pattern{font-size:10px;letter-spacing:.22em;margin-bottom:5px;}
  .look-card .look-name{font-size:22px;}
  .look-card .look-meta{font-size:11px;}

  /* Reviews */
  .reviews{padding:64px 22px;}
  .review-grid{gap:14px;}
  .review{padding:24px 22px;}
  .review p.text{font-size:14px;line-height:1.65;}
  .review .stars{font-size:13px;margin-bottom:12px;}
  .press-strip{gap:22px;margin-top:42px;padding-top:36px;}
  .press-strip .label{font-size:10px;letter-spacing:.2em;}
  .press-strip .name{font-size:15px;letter-spacing:.06em;}

  /* Promise strip */
  .promise{padding:48px 22px;}
  .promise-grid{gap:20px;}
  .promise-item{gap:12px;}
  .promise-item .ico{font-size:28px;width:32px;margin-top:-2px;}
  .promise-item .p-name{font-size:12.5px;}
  .promise-item .p-sub{font-size:11px;line-height:1.5;}

  /* Newsletter — form fixed for mobile */
  .newsletter{padding:72px 22px;}
  .newsletter h2{font-size:25px;line-height:1.2;}
  .newsletter p{font-size:13.5px;margin-bottom:22px;}
  .news-form{flex-direction:column;background:transparent;border:none;gap:8px;padding:0;}
  .news-form input{background:var(--ivory);border:1px solid var(--line);
    padding:13px 18px;font-size:13.5px;width:100%;}
  .news-form button{padding:13px 18px;font-size:11px;width:100%;}

  /* Footer */
  footer{padding:48px 22px 24px;}
  .footer-inner{gap:32px;}
  .foot-brand img,.foot-brand .logo-full-foot{width:190px !important;}
  .foot-brand p{font-size:12.5px;}
  .foot-col h4{font-size:10.5px;letter-spacing:.2em;margin-bottom:14px;}
  .foot-col a{font-size:12.5px;}
  .foot-col ul{gap:10px;}
  .socials{margin-top:18px;}
  .socials a{width:36px;height:36px;font-size:17px;}
  .foot-bottom{margin-top:34px;padding-top:20px;font-size:10.5px;gap:8px;}
  .foot-bottom .links a{margin-right:14px;}

  /* Shop page mobile fixes */
  .filters{top:60px;padding:12px 18px;gap:6px;}
  .filter-chip{padding:7px 13px;font-size:10.5px;}
  .filter-label{font-size:10px;letter-spacing:.12em;}
  .filter-chip .dot{width:9px;height:9px;}
  .shop-grid{gap:10px;padding:30px 14px 70px;}
  .page-hero{padding:48px 22px 26px;}
  .page-hero h1{font-size:30px;}
  .page-hero p{font-size:13.5px;}
}

/* Even smaller phones */
@media (max-width:380px){
  .hero h1{font-size:26px;}
  .hero p.tagline{font-size:12.5px;}
  .section-h h2{font-size:23px;}
  .feat-card .feat-text h2{font-size:23px;}
  .brand-mark .cotton-ornament{width:140px;}
  .logo-full{width:200px;}
}

/* =========================================================
   HERO SLIDER CONTROLS (Option 1 — matching Bamboo polish)
   ========================================================= */
.hero .hero-img img{transition:opacity .35s ease;}
.hero-counter{position:absolute;right:32px;bottom:34px;
  font-size:11.5px;letter-spacing:.22em;color:var(--ivory);
  font-weight:700;font-variant-numeric:tabular-nums;
  opacity:.92;z-index:3;
  text-shadow:0 1px 2px rgba(0,0,0,.3);}
.hero-controls{position:absolute;left:0;right:0;bottom:24px;z-index:3;
  display:flex;justify-content:center;align-items:center;gap:14px;}
.hero-dots{display:flex;gap:7px;}
.hero-dot{width:9px;height:9px;border-radius:50%;
  background:rgba(255,255,255,.4);transition:all .25s;cursor:pointer;
  border:none;}
.hero-dot.on{background:var(--ivory);width:26px;border-radius:8px;}
.hero-arrow{width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.16);backdrop-filter:blur(8px);
  color:var(--ivory);font-size:14px;display:flex;align-items:center;
  justify-content:center;border:1px solid rgba(255,255,255,.32);
  cursor:pointer;transition:all .2s;}
.hero-arrow:hover{background:var(--ivory);color:var(--mocha-dark);
  border-color:var(--ivory);}
.hero-arrow .ph-thin{font-weight:100;}

@media (max-width:760px){
  .hero-counter{right:22px;bottom:54px;font-size:10.5px;}
  .hero-controls{bottom:18px;gap:10px;}
  .hero-arrow{width:34px;height:34px;font-size:13px;}
  .hero-dot{width:7px;height:7px;}
  .hero-dot.on{width:20px;}
}

/* =========================================================
   LIFESTYLE GALLERY — dedicated baby photo showcase
   (separate from product cards — for editorial baby moments)
   ========================================================= */
.lifestyle-gallery{padding:0;background:var(--ivory);overflow:hidden;}
.gallery-h{max-width:1280px;margin:0 auto;padding:80px 26px 36px;text-align:center;}
.gallery-h .eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:10px;}
.gallery-h h2{font-size:30px;font-weight:300;color:var(--mocha-dark);
  letter-spacing:-.01em;line-height:1.2;}
.gallery-h h2 em{font-style:normal;font-weight:600;color:var(--mocha);}
.gallery-h p{color:var(--soft);font-size:14.5px;margin-top:12px;
  max-width:520px;margin-left:auto;margin-right:auto;line-height:1.7;}

/* Mosaic — 1 large + 4 small (desktop) / vertical stack (mobile) */
.gallery-mosaic{display:grid;grid-template-columns:1fr;gap:8px;padding:0 8px 80px;}
.g-item{position:relative;overflow:hidden;background:var(--cream);}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.g-item:hover img{transform:scale(1.04);}
.g-tag{position:absolute;left:18px;bottom:18px;color:var(--ivory);
  font-size:10.5px;letter-spacing:.28em;font-weight:600;text-transform:uppercase;
  text-shadow:0 1px 3px rgba(0,0,0,.35);}
.g-tag::before{content:"";display:inline-block;width:14px;height:1px;
  background:var(--ivory);margin-right:8px;vertical-align:middle;}

/* Aspect ratios per slot */
.g-1{aspect-ratio:3/4;}
.g-2,.g-3,.g-4,.g-5{aspect-ratio:1/1;}

@media (min-width:760px){
  .gallery-mosaic{
    grid-template-columns:repeat(4,1fr);
    grid-template-rows:auto auto;
    gap:10px;padding:0 18px 100px;
  }
  .g-1{grid-column:1/3; grid-row:1/3; aspect-ratio:auto;}
  .g-2{grid-column:3/4; grid-row:1/2;}
  .g-3{grid-column:4/5; grid-row:1/2;}
  .g-4{grid-column:3/4; grid-row:2/3;}
  .g-5{grid-column:4/5; grid-row:2/3;}
}
@media (min-width:1200px){
  .gallery-mosaic{padding:0 30px 120px;gap:12px;}
  .gallery-h{padding-top:110px;}
  .gallery-h h2{font-size:42px;}
}
@media (max-width:760px){
  .gallery-h{padding:48px 22px 24px;}
  .gallery-h h2{font-size:24px;}
  .gallery-mosaic{padding:0 6px 50px;}
}

/* =========================================================
   LANG VISIBILITY FIX — hero buttons specificity
   (.btn-primary / .btn-ghost win over [data-lang] by default
    so we force hide inactive lang button explicitly)
   ========================================================= */
.hero a[data-lang-th],
.hero a[data-lang-en]{display:none !important;}
html[data-lang="th"] .hero a[data-lang-th]{display:inline-flex !important;}
html[data-lang="en"] .hero a[data-lang-en]{display:inline-flex !important;}

/* Newsletter input/button language */
.news-form input[data-lang-th],
.news-form input[data-lang-en],
.news-form button[data-lang-th],
.news-form button[data-lang-en]{display:none !important;}
html[data-lang="th"] .news-form input[data-lang-th]{display:block !important;flex:1;}
html[data-lang="en"] .news-form input[data-lang-en]{display:block !important;flex:1;}
html[data-lang="th"] .news-form button[data-lang-th]{display:inline-block !important;}
html[data-lang="en"] .news-form button[data-lang-en]{display:inline-block !important;}

/* Dual feature card lang span buttons */
.feat-text [data-lang-th],
.feat-text [data-lang-en]{display:none !important;}
html[data-lang="th"] .feat-text [data-lang-th]{display:revert !important;}
html[data-lang="en"] .feat-text [data-lang-en]{display:revert !important;}
html[data-lang="th"] .feat-text span.btn-primary[data-lang-th],
html[data-lang="en"] .feat-text span.btn-primary[data-lang-en]{display:inline-flex !important;}
