/* =========================================================
   TPC — Thai Pacific Containers
   Aesthetic: refined Apple-grade minimalism with a kraft-paper
   material identity. The corrugated "flute" wave is the motif.
   ========================================================= */

:root{
  --ink:        #1d1813;   /* warm near-black */
  --ink-soft:   #4a4138;
  --muted:      #7a6f62;
  --paper:      #f6f1e8;   /* warm off-white */
  --paper-2:    #efe7d8;
  --white:      #ffffff;
  --kraft:      #c47a3d;   /* corrugated amber */
  --kraft-deep: #8a4f21;
  --kraft-soft: #e7c79c;
  --line:       rgba(29,24,19,.10);
  --line-2:     rgba(29,24,19,.16);
  --shadow:     0 24px 60px -28px rgba(45,30,15,.35);
  --shadow-sm:  0 12px 30px -18px rgba(45,30,15,.35);
  --ease:       cubic-bezier(.22,.61,.36,1);
  --wrap:       1180px;

  --f-body: "Anuphan", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --f-head: "Bai Jamjuree", "Anuphan", -apple-system, sans-serif;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:84px; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-weight:400;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *{ animation:none !important; transition:none !important; }
}

a{ color:inherit; text-decoration:none; }
img,svg{ display:block; max-width:100%; }
h1,h2,h3,h4{ font-family:var(--f-head); font-weight:500; line-height:1.08; letter-spacing:-.015em; }

.wrap{ width:min(var(--wrap), 92vw); margin-inline:auto; }
.section{ padding:clamp(72px,11vw,140px) 0; position:relative; scroll-margin-top:84px; }

/* ---- grain / paper texture overlay ---- */
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.5;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.06'/%3E%3C/svg%3E");
}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  --bg:var(--ink); --fg:var(--white);
  display:inline-flex; align-items:center; justify-content:center; gap:.4em;
  font-family:var(--f-head); font-weight:500; font-size:.98rem; letter-spacing:0;
  padding:.82em 1.5em; border-radius:999px; border:1px solid transparent;
  cursor:pointer; white-space:nowrap;
  transition:transform .35s var(--ease), background .3s var(--ease), color .3s var(--ease), box-shadow .35s var(--ease), border-color .3s var(--ease);
}
.btn--solid{ background:var(--ink); color:var(--white); box-shadow:var(--shadow-sm); }
.btn--solid:hover{ transform:translateY(-2px); background:var(--kraft-deep); box-shadow:0 18px 36px -16px rgba(138,79,33,.6); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn--ghost:hover{ border-color:var(--ink); transform:translateY(-2px); }
.btn--lg{ font-size:1.06rem; padding:1em 2em; }
.btn--mini{ background:var(--ink); color:var(--white); padding:.62em 1.1em; font-size:.9rem; }
.btn--mini:hover{ background:var(--kraft-deep); }

.kicker{
  font-family:var(--f-head); font-weight:600; font-size:.78rem;
  letter-spacing:.22em; text-transform:uppercase; color:var(--kraft-deep);
  margin-bottom:1.1rem; display:flex; align-items:center; gap:.7em;
}
.kicker::before{ content:""; width:26px; height:2px; background:var(--kraft); border-radius:2px; }
.kicker--light{ color:var(--kraft-soft); }
.kicker--light::before{ background:var(--kraft-soft); }
.section__head{ max-width:760px; margin-bottom:clamp(40px,6vw,72px); }
.section__head h2{ font-size:clamp(1.9rem,4.4vw,3.1rem); }

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(246,241,232,.72);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom-color:var(--line);
}
.nav__inner{
  width:min(var(--wrap),94vw); margin-inline:auto;
  height:68px; display:flex; align-items:center; gap:1.5rem;
}
.brand{ display:flex; align-items:center; gap:.55rem; color:var(--ink); }
.brand__mark{ display:grid; place-items:center; }
.brand__word{ font-family:var(--f-head); font-weight:700; font-size:1.28rem; letter-spacing:.06em; }
.brand__logo{ height:32px; width:auto; }
.nav__links{ display:flex; gap:1.7rem; margin-left:1rem; margin-right:auto; }
.nav__links a{
  font-family:var(--f-head); font-weight:500; font-size:.96rem; color:var(--ink-soft);
  position:relative; padding:.3em 0; transition:color .25s var(--ease);
}
.nav__links a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px;
  background:var(--kraft); border-radius:2px; transition:right .3s var(--ease);
}
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after{ right:0; }
.nav__links a.is-active{ color:var(--ink); }
.nav__links a.is-active::after{ right:0; }

.nav__right{ display:flex; align-items:center; gap:.85rem; }
.lang{
  display:inline-flex; align-items:center; gap:.35em; background:transparent; border:none;
  font-family:var(--f-head); font-weight:500; font-size:.9rem; color:var(--muted); cursor:pointer;
  padding:.3em .2em;
}
.lang__opt{ transition:color .25s var(--ease); }
.lang__opt.is-on{ color:var(--ink); font-weight:600; }
.lang__sep{ opacity:.4; }

.burger{ display:none; width:34px; height:34px; background:transparent; border:none; cursor:pointer; position:relative; }
.burger span{ position:absolute; left:7px; right:7px; height:2px; background:var(--ink); border-radius:2px; transition:.3s var(--ease); }
.burger span:nth-child(1){ top:13px; } .burger span:nth-child(2){ bottom:13px; }
.burger.is-open span:nth-child(1){ top:16px; transform:rotate(45deg); }
.burger.is-open span:nth-child(2){ bottom:16px; transform:rotate(-45deg); }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; z-index:2;
  min-height:100svh; display:flex; flex-direction:column; justify-content:center;
  padding:120px 0 80px;
  width:min(var(--wrap),92vw); margin-inline:auto;
}
.hero__bg{ position:absolute; inset:-10% -40% 0; z-index:-1; overflow:hidden; }
.hero__glow{
  position:absolute; top:-10%; right:-5%; width:60vw; height:60vw; max-width:760px; max-height:760px;
  background:radial-gradient(circle at 50% 50%, rgba(196,122,61,.22), rgba(196,122,61,0) 62%);
  filter:blur(10px);
}
.hero__flute{ position:absolute; left:0; right:0; bottom:8%; width:100%; height:220px; }
.flute-path{ stroke-dasharray:6 0; animation:drift 9s var(--ease) infinite alternate; }
@keyframes drift{ to{ transform:translateX(-60px); } }

.hero__inner{ max-width:720px; }
.eyebrow{
  font-family:var(--f-head); font-weight:600; font-size:.86rem; letter-spacing:.04em;
  color:var(--kraft-deep); margin-bottom:1.4rem;
  display:inline-flex; align-items:center;
  background:rgba(196,122,61,.1); padding:.5em 1em; border-radius:999px;
}
.hero__title{
  font-size:clamp(2.6rem,6.6vw,5.2rem); font-weight:300; line-height:1.18; letter-spacing:-.02em;
  margin-bottom:1.9rem;
}
.hero__title span{ display:block; }
.hero__title .accent{
  font-weight:600; padding-bottom:.12em;   /* room for Thai lower vowels under the clipped gradient */
  background:linear-gradient(100deg,var(--kraft-deep),var(--kraft));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero__sub{ font-size:clamp(1.05rem,2vw,1.3rem); color:var(--ink-soft); max-width:640px; margin-bottom:2.4rem; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:.9rem; }

.hero__box{
  position:absolute; right:0; top:50%; transform:translateY(-50%);
  width:clamp(240px,23vw,330px); z-index:-1; opacity:.92;
  filter:drop-shadow(0 40px 50px rgba(120,70,25,.28));
  animation:float 6s ease-in-out infinite;
}
/* hide the floating box before it can collide with the headline */
@media (max-width:1100px){ .hero__box{ display:none; } }
@keyframes float{ 0%,100%{ transform:translateY(-50%); } 50%{ transform:translateY(-58%); } }

.hero__scroll{
  position:absolute; left:0; bottom:30px;
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--f-head); font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted);
}
.hero__scroll i{ width:22px; height:34px; border:1.5px solid var(--line-2); border-radius:12px; position:relative; }
.hero__scroll i::after{ content:""; position:absolute; left:50%; top:7px; width:3px; height:7px; border-radius:3px; background:var(--kraft); transform:translateX(-50%); animation:scroll 1.7s var(--ease) infinite; }
@keyframes scroll{ 0%{ opacity:0; transform:translate(-50%,0);} 40%{ opacity:1;} 80%{ opacity:0; transform:translate(-50%,12px);} 100%{opacity:0;} }

/* =========================================================
   STATS
   ========================================================= */
.stats{ position:relative; z-index:2; background:var(--white); color:var(--ink); border-block:1px solid var(--line); }
.stats__inner{
  width:min(var(--wrap),92vw); margin-inline:auto;
  display:grid; grid-template-columns:repeat(4,1fr);
  padding:clamp(44px,6vw,72px) 0;
}
.stat{ padding:0 1.6rem; border-left:1px solid var(--line); }
.stat:first-child{ border-left:none; }
.stat__num{
  font-family:var(--f-head); font-weight:300; font-size:clamp(2.6rem,5vw,3.8rem);
  line-height:1; letter-spacing:-.02em; color:var(--ink); display:flex; align-items:baseline; gap:.05em;
}
.stat__num em{ font-style:normal; font-size:.5em; color:var(--kraft-deep); font-weight:600; }
.stat__lbl{ margin-top:.7rem; font-size:.95rem; color:var(--muted); }

/* =========================================================
   PRODUCTS
   ========================================================= */
.cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.card{
  background:var(--white); border:1px solid var(--line); border-radius:22px;
  padding:1.8rem 1.6rem 2rem; transition:transform .45s var(--ease), box-shadow .45s var(--ease), border-color .45s var(--ease);
}
.card:hover{ transform:translateY(-8px); box-shadow:var(--shadow); border-color:transparent; }
.card__art{
  height:120px; display:grid; place-items:center; margin-bottom:1.2rem;
  background:radial-gradient(circle at 50% 35%, var(--paper-2), var(--white));
  border-radius:16px;
}
.card__art svg{ width:64%; transition:transform .5s var(--ease); }
.card:hover .card__art svg{ transform:translateY(-4px) scale(1.04); }
.card h3{ font-size:1.22rem; margin-bottom:.6rem; }
.card p{ color:var(--muted); font-size:.96rem; }
.products__note{
  margin-top:2.6rem; text-align:center; color:var(--ink-soft); font-size:1.06rem;
  max-width:640px; margin-inline:auto;
}

/* =========================================================
   PROCESS
   ========================================================= */
.steps{ list-style:none; display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; counter-reset:s; }
.step{ position:relative; padding-top:2.4rem; }
.step::before{ content:""; position:absolute; top:0; left:0; right:0; height:2px; background:var(--line-2); }
.step::after{ content:""; position:absolute; top:-3px; left:0; width:8px; height:8px; border-radius:50%; background:var(--kraft); }
.step__no{ font-family:var(--f-head); font-weight:600; font-size:.9rem; color:var(--kraft-deep); letter-spacing:.1em; }
.step h3{ font-size:1.35rem; margin:.5rem 0 .7rem; }
.step p{ color:var(--muted); font-size:.98rem; }

/* =========================================================
   QUALITY (dark)
   ========================================================= */
.quality{ background:var(--ink); color:var(--paper); overflow:hidden; }
.quality__flute{ position:absolute; top:0; left:0; right:0; height:80px; }
.quality__grid{ display:grid; grid-template-columns:1.3fr 1fr; gap:clamp(40px,6vw,80px); align-items:center; }
.quality__text h2{ font-size:clamp(1.9rem,4vw,3rem); color:var(--white); margin-bottom:1.4rem; }
.quality__text > p{ color:rgba(246,241,232,.72); font-size:1.08rem; }
.quality__points{ margin-top:2rem; display:grid; gap:1.3rem; }
.qp{ border-left:2px solid var(--kraft); padding-left:1.2rem; }
.qp strong{ display:block; font-family:var(--f-head); font-weight:600; color:var(--white); margin-bottom:.2rem; }
.qp span{ color:rgba(246,241,232,.6); font-size:.96rem; }

.quality__badge{ display:grid; place-items:center; }
.seal{ position:relative; width:min(300px,72vw); aspect-ratio:1; display:grid; place-items:center; }
.seal__arc{ font-family:var(--f-head); font-size:9.4px; letter-spacing:1.5px; fill:var(--kraft-soft); font-weight:600; }
.seal svg{ position:absolute; inset:0; animation:spin 40s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.seal__core{ text-align:center; z-index:2; }
.seal__iso{ display:block; font-family:var(--f-head); font-weight:300; font-size:1rem; letter-spacing:.5em; color:var(--kraft-soft); padding-left:.5em; }
.seal__num{ font-family:var(--f-head); font-weight:600; font-size:clamp(2.4rem,6vw,3.4rem); color:var(--white); letter-spacing:-.01em; }
.seal__num em{ font-style:normal; font-weight:300; color:var(--kraft-soft); font-size:.55em; }

/* =========================================================
   SERVICES
   ========================================================= */
.svc{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.svc__item{
  background:var(--white); border:1px solid var(--line); border-radius:22px; padding:2rem 1.8rem;
  transition:transform .45s var(--ease), box-shadow .45s var(--ease);
}
.svc__item:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.svc__ic{ width:60px; height:60px; border-radius:16px; background:var(--paper-2); display:grid; place-items:center; margin-bottom:1.3rem; }
.svc__ic svg{ width:30px; height:30px; }
.svc__item h3{ font-size:1.28rem; margin-bottom:.7rem; }
.svc__item p{ color:var(--muted); }

/* =========================================================
   CTA BANNER
   ========================================================= */
.cta{ position:relative; z-index:2; padding:clamp(64px,9vw,110px) 0; background:linear-gradient(135deg,var(--kraft-deep),var(--kraft)); color:var(--white); text-align:center; }
.cta__inner{ max-width:760px; }
.cta h2{ font-size:clamp(1.8rem,4.2vw,3rem); margin-bottom:1rem; }
.cta p{ color:rgba(255,255,255,.85); font-size:1.12rem; margin-bottom:2rem; }
.cta .btn--solid{ background:var(--white); color:var(--ink); }
.cta .btn--solid:hover{ background:var(--ink); color:var(--white); }

/* =========================================================
   CONTACT
   ========================================================= */
.contact__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,64px); align-items:stretch; }
.contact__info h2{ font-size:clamp(2rem,4.4vw,3rem); margin-bottom:2rem; }
.contact__list{ list-style:none; display:grid; gap:1.5rem; margin-bottom:2.2rem; }
.contact__list li{ display:flex; gap:1rem; }
.contact__ic{ flex:none; width:44px; height:44px; border-radius:12px; background:var(--white); border:1px solid var(--line); display:grid; place-items:center; color:var(--kraft-deep); }
.contact__ic svg{ width:22px; height:22px; }
.contact__list strong{ font-family:var(--f-head); font-weight:600; display:block; margin-bottom:.15rem; }
.contact__list p{ color:var(--ink-soft); font-size:1rem; }
.contact__list a:hover{ color:var(--kraft-deep); text-decoration:underline; }
.contact__actions{ display:flex; gap:.8rem; flex-wrap:wrap; }
.contact__map{ position:relative; border-radius:22px; overflow:hidden; border:1px solid var(--line); min-height:420px; box-shadow:var(--shadow-sm); }
.contact__map iframe{ width:100%; height:100%; min-height:420px; border:0; filter:grayscale(.2) contrast(1.02); }
.contact__maplink{
  position:absolute; left:14px; bottom:14px; z-index:2;
  font-family:var(--f-head); font-weight:600; font-size:.86rem; color:var(--ink);
  background:rgba(246,241,232,.92); backdrop-filter:blur(8px);
  padding:.55em 1em; border-radius:999px; border:1px solid var(--line);
  box-shadow:var(--shadow-sm); transition:transform .3s var(--ease), background .3s var(--ease);
}
.contact__maplink:hover{ transform:translateY(-2px); background:var(--white); color:var(--kraft-deep); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ position:relative; z-index:2; background:var(--ink); color:rgba(246,241,232,.7); padding:clamp(56px,7vw,84px) 0 0; }
.footer__grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:2.4rem; padding-bottom:3rem; }
.brand--foot{ color:var(--white); margin-bottom:1rem; }
.brand__logo--foot{ height:40px; }
.footer__brand p{ max-width:340px; font-size:.96rem; }
.footer__col h4{ font-family:var(--f-head); font-weight:600; color:var(--white); font-size:.96rem; letter-spacing:.06em; margin-bottom:1rem; }
.footer__col a{ display:block; font-size:.95rem; padding:.3em 0; transition:color .25s var(--ease); }
.footer__col a:hover{ color:var(--kraft-soft); }
.footer__bar{
  border-top:1px solid rgba(255,255,255,.1); padding:1.6rem 0;
  width:min(var(--wrap),92vw); margin-inline:auto;
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  font-size:.86rem; color:rgba(246,241,232,.5);
}

/* =========================================================
   HERO BOX IMAGE (real kraft box)
   ========================================================= */
.hero__box img{ width:100%; height:auto; }

/* =========================================================
   WHY TPC — feature cards
   ========================================================= */
.why__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.feature{
  background:var(--white); border:1px solid var(--line); border-radius:24px; padding:2.4rem 2rem;
  transition:transform .45s var(--ease), box-shadow .45s var(--ease);
}
.feature:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.feature__ic{ width:66px; height:66px; border-radius:18px; background:var(--paper-2); display:grid; place-items:center; margin-bottom:1.4rem; }
.feature__ic svg{ width:34px; height:34px; }
.feature h3{ font-size:1.34rem; margin-bottom:.6rem; }
.feature p{ color:var(--muted); font-size:1.02rem; }

/* =========================================================
   ABOUT — real factory image + quote
   ========================================================= */
/* wide banner */
.about__banner{ position:relative; border-radius:26px; overflow:hidden; box-shadow:var(--shadow); margin-bottom:clamp(28px,4vw,48px); }
.about__banner img{ width:100%; height:clamp(240px,36vw,420px); object-fit:cover; object-position:center 42%; display:block; transition:transform 1.4s var(--ease); }
.about__banner:hover img{ transform:scale(1.05); }
.about__banner::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg, rgba(29,24,19,0) 45%, rgba(45,30,15,.42) 100%),
             linear-gradient(120deg, rgba(196,122,61,.16), rgba(29,24,19,.04));
  mix-blend-mode:multiply;
}
.about__badge{
  position:absolute; top:20px; left:20px; z-index:2;
  display:flex; flex-direction:column; line-height:1;
  background:rgba(255,255,255,.94); backdrop-filter:blur(8px);
  border-radius:16px; padding:.75em 1.1em; box-shadow:var(--shadow-sm);
}
.about__badge strong{ font-family:var(--f-head); font-weight:700; font-size:1.7rem; color:var(--kraft-deep); }
.about__badge span{ font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-top:.45em; }
.about__banner figcaption{
  position:absolute; left:22px; bottom:18px; z-index:2; color:#fff;
  font-family:var(--f-head); font-weight:500; font-size:.92rem;
  text-shadow:0 1px 10px rgba(0,0,0,.55);
}
/* two-column story keeps the section compact */
.about__story{ columns:2; column-gap:clamp(32px,5vw,64px); }
.about__story p{ break-inside:avoid; margin-bottom:1.15rem; color:var(--ink-soft); font-size:1.06rem; }
.about__story p:last-child{ margin-bottom:0; }
/* highlighted pull-quote band */
.about__quote{
  margin-top:clamp(26px,4vw,44px); padding:1.5rem 1.9rem;
  border-left:4px solid var(--kraft); border-radius:0 18px 18px 0;
  background:linear-gradient(110deg, var(--paper-2), rgba(231,199,156,.28));
  font-family:var(--f-head); font-weight:500; font-style:normal;
  font-size:clamp(1.15rem,2vw,1.45rem); color:var(--ink); line-height:1.5;
}

/* =========================================================
   PRODUCTS & SERVICES — image cards
   ========================================================= */
.pcards{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.6rem; }
.pcard{
  background:var(--white); border:1px solid var(--line); border-radius:24px; overflow:hidden;
  display:flex; flex-direction:column;
  transition:transform .45s var(--ease), box-shadow .45s var(--ease), border-color .45s var(--ease);
}
.pcard:hover{ transform:translateY(-8px); box-shadow:var(--shadow); border-color:transparent; }
.pcard__media{ position:relative; height:265px; display:grid; place-items:center; overflow:hidden; }
.pcard__media img{ transition:transform .6s var(--ease); }
.pcard:hover .pcard__media img{ transform:scale(1.05); }
/* transparent product PNGs float on a soft paper stage */
.pcard__media--png{ background:radial-gradient(circle at 50% 32%, var(--paper-2), #fbf7f0 70%); }
.pcard__media--png img{ max-width:90%; max-height:90%; object-fit:contain; filter:drop-shadow(0 22px 26px rgba(120,70,25,.22)); }
.pcard__media--lg img{ max-width:96%; max-height:98%; }   /* the single kraft box reads bigger */
/* machinery photos sit on a light stage, contained so the whole machine fits the frame */
.pcard__media--photo{ background:#fcfaf6; }
.pcard__media--photo img{ width:100%; height:100%; object-fit:contain; object-position:center; }
.pcard__media--photo::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(125deg, rgba(196,122,61,.10), rgba(29,24,19,.04));
  mix-blend-mode:multiply;
}
.pcard__body{ padding:1.6rem 1.7rem 1.9rem; }
.pcard__body h3{ font-size:1.28rem; margin-bottom:.6rem; }
.pcard__body p{ color:var(--muted); font-size:.98rem; }

.contact__sub{ font-size:.86rem !important; color:var(--muted) !important; margin-top:.15rem; }

/* =========================================================
   SHOP / ORDER channels
   ========================================================= */
.shop__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.shop__card{
  background:var(--white); border:1px solid var(--line); border-radius:24px; padding:2rem 1.8rem;
  display:flex; flex-direction:column;
  transition:transform .45s var(--ease), box-shadow .45s var(--ease);
}
.shop__card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.shop__ic{ width:58px; height:58px; border-radius:16px; background:var(--paper-2); display:grid; place-items:center; margin-bottom:1.2rem; }
.shop__ic svg{ width:30px; height:30px; }
.shop__card h3{ font-size:1.24rem; margin-bottom:.55rem; }
.shop__card p{ color:var(--muted); font-size:.96rem; margin-bottom:1.4rem; }
.shop__btns{ display:flex; gap:.7rem; margin-top:auto; }
.shopbtn{
  flex:1; text-align:center; padding:.85em 1em; border-radius:13px;
  font-family:var(--f-head); font-weight:600; font-size:.96rem; color:#fff;
  transition:transform .3s var(--ease), filter .3s var(--ease), box-shadow .3s var(--ease);
}
.shopbtn:hover{ transform:translateY(-2px); filter:brightness(1.06); box-shadow:var(--shadow-sm); }
.shopbtn--lazada{ background:linear-gradient(135deg,#1a1f71,#3a1d8a); }
.shopbtn--shopee{ background:linear-gradient(135deg,#ee4d2d,#f86a3f); }
.shopbtn--call{ background:var(--ink); }
.shopbtn--call:hover{ background:var(--kraft-deep); }
.shop__tel{
  display:inline-flex; align-items:center; gap:.4rem; margin-top:1rem;
  font-family:var(--f-head); font-weight:600; font-size:.92rem; color:var(--kraft-deep);
}
.shop__tel::before{ content:"📞"; font-size:.9em; }
.shop__tel:hover{ text-decoration:underline; }

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); transition-delay:var(--d,0s); will-change:opacity,transform; }
.reveal.in{ opacity:1; transform:none; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1000px){
  .cards{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); row-gap:2.4rem; }
  .svc{ grid-template-columns:1fr; }
  .why__grid{ grid-template-columns:repeat(2,1fr); }
  .stats__inner{ grid-template-columns:repeat(2,1fr); row-gap:2rem; }
  .stat:nth-child(3){ border-left:none; }
}
@media (max-width:860px){
  .nav__links{ display:none; }
  .burger{ display:block; }
  .nav__links.is-open{
    display:flex; flex-direction:column; gap:.4rem;
    position:absolute; top:68px; left:0; right:0; margin:0; padding:1rem 6vw 1.6rem;
    background:rgba(246,241,232,.96); backdrop-filter:blur(18px);
    border-bottom:1px solid var(--line);
  }
  .nav__links.is-open a{ padding:.7em 0; font-size:1.05rem; border-bottom:1px solid var(--line); }
  .quality__grid, .contact__grid{ grid-template-columns:1fr; }
  .about__story{ columns:1; }
  .pcards{ grid-template-columns:1fr; }
  .shop__grid{ grid-template-columns:1fr; }
  .quality__badge{ order:-1; }
  .hero__box{ display:none; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){
  .cards{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .why__grid{ grid-template-columns:1fr; }
  .stats__inner{ grid-template-columns:1fr; }
  .stat{ border-left:none !important; border-top:1px solid var(--line); padding:1.4rem 0 0; }
  .stat:first-child{ border-top:none; padding-top:0; }
  .footer__grid{ grid-template-columns:1fr; }
  .nav__right .btn--mini{ display:none; }
  .hero__sub{ font-size:1.05rem; }
}

/* =========================================================
   HERO — full-bleed photographic variant (real factory photo)
   ========================================================= */
.hero--photo{
  width:100%; margin:0; padding:0;
  min-height:100svh; justify-content:center;
  overflow:hidden; color:var(--white);
}
.hero__media{ position:absolute; inset:0; z-index:-1; }
.hero__photo{
  width:100%; height:100%; object-fit:cover; object-position:center 42%;
  transform:scale(1.06); animation:heroZoom 16s var(--ease) forwards;
}
@keyframes heroZoom{ to{ transform:scale(1); } }
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(20,14,9,.88) 0%, rgba(20,14,9,.58) 44%, rgba(20,14,9,.18) 74%, rgba(20,14,9,.30) 100%),
    linear-gradient(0deg, rgba(20,14,9,.7) 0%, rgba(20,14,9,0) 40%);
}
.hero--photo .hero__inner{
  width:min(var(--wrap),92vw); margin-inline:auto;
  padding:120px 0 80px; max-width:none;
}
.hero--photo .hero__inner > *{ max-width:780px; }
.hero--photo .eyebrow{
  color:#fff; background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.22);
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);
}
.hero--photo .hero__title{ color:var(--white); font-weight:300; text-shadow:0 2px 34px rgba(0,0,0,.4); }
.hero--photo .hero__title .accent{
  background:linear-gradient(100deg,var(--kraft-soft),#fff);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  -webkit-text-fill-color:transparent;
}
.hero--photo .hero__sub{ color:rgba(255,255,255,.92); text-shadow:0 1px 18px rgba(0,0,0,.45); }

.btn--on-photo{
  color:#fff; border-color:rgba(255,255,255,.55); background:rgba(255,255,255,.06);
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);
}
.btn--on-photo:hover{ border-color:#fff; background:rgba(255,255,255,.16); transform:translateY(-2px); }
.btn--on-photo-solid{ background:var(--white); color:var(--ink); }
.btn--on-photo-solid:hover{ background:var(--kraft); color:#fff; }

.hero__chips{ list-style:none; display:flex; flex-wrap:wrap; gap:.6rem; margin-top:2.1rem; }
.hero__chips li{
  font-family:var(--f-head); font-weight:500; font-size:.86rem; color:rgba(255,255,255,.94);
  padding:.5em 1em; border-radius:999px;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  display:inline-flex; align-items:center; gap:.5em;
}
.hero__chips li::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--kraft-soft); }

.hero__scroll--light{
  color:rgba(255,255,255,.82);
  left:calc(max(4vw, (100vw - var(--wrap)) / 2));
}
.hero__scroll--light i{ border-color:rgba(255,255,255,.5); }
@media (max-width:860px){ .hero__scroll--light{ display:none; } }

/* product cards — full-cover photo media (replaces washed-out crops) */
.pcard__media--cover img{ width:100%; height:100%; object-fit:cover; object-position:center; }
.pcard__media--cover::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(125deg, rgba(196,122,61,.12), rgba(29,24,19,.06));
  mix-blend-mode:multiply;
}

/* =========================================================
   NAV — readable while floating over the dark hero photo
   ========================================================= */
.brand{ position:relative; }
.brand__logo{ transition:opacity .4s var(--ease); }
.brand__logo--light{
  position:absolute; left:0; top:50%; transform:translateY(-50%);
  pointer-events:none;
}
.nav:not(.is-stuck) .brand__logo--dark{ opacity:0; }
.nav.is-stuck  .brand__logo--light{ opacity:0; }
.nav:not(.is-stuck) .nav__links a{ color:rgba(255,255,255,.86); }
.nav:not(.is-stuck) .nav__links a:hover,
.nav:not(.is-stuck) .nav__links a.is-active{ color:#fff; }
.nav:not(.is-stuck) .lang{ color:rgba(255,255,255,.72); }
.nav:not(.is-stuck) .lang__opt.is-on{ color:#fff; }
.nav:not(.is-stuck) .burger span{ background:#fff; }
.nav:not(.is-stuck) .btn--mini{ background:var(--kraft); }
.nav:not(.is-stuck) .btn--mini:hover{ background:#fff; color:var(--ink); }
