/* ========================================================================
   VANNESSASIA — Bangkok Editorial Pop
   Design system for the production site (12 pages).
   ======================================================================== */

:root{
  --paper:#FFFFFF;
  --paper-2:#F7F7F4;
  --ink:#0E1238;
  --ink-soft:#3A3F66;
  --ink-mute:#7A7E96;
  --pink:#FF3D7F;
  --mango:#FFB627;
  --lime:#C5FF3D;
  --sky:#4ECDFF;
  --line:rgba(14,18,56,0.12);

  --ff-disp:'Bricolage Grotesque','Zen Kaku Gothic New',sans-serif;
  --ff-serif:'Fraunces',serif;
  --ff-jp:'Zen Kaku Gothic New','Bricolage Grotesque',sans-serif;
  --ff-mono:'DM Mono',ui-monospace,monospace;

  --max-w:1280px;
  --max-w-narrow:880px;
  --header-h:72px;
}

*,*::before,*::after{box-sizing:border-box;-webkit-font-smoothing:antialiased;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--ff-jp);font-weight:500;font-size:17px;line-height:1.7;
  letter-spacing:0.01em;
  word-break:keep-all;overflow-wrap:break-word;line-break:strict;
}
a{color:inherit;text-decoration:none;transition:.15s;}
a:hover{opacity:.75;}
button{font-family:inherit;cursor:pointer;}
img,svg{max-width:100%;height:auto;display:block;}
ul,ol{list-style:none;padding:0;margin:0;}
h1,h2,h3,h4,h5{margin:0;font-weight:800;line-height:1.1;letter-spacing:-0.02em;}

[lang="th"] body{font-family:'IBM Plex Sans Thai','Zen Kaku Gothic New',sans-serif;}
[lang="en"] body{font-family:'Bricolage Grotesque',sans-serif;}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--max-w);margin:0 auto;padding:0 32px;}
.container-narrow{max-width:var(--max-w-narrow);margin:0 auto;padding:0 32px;}
.section{padding:120px 0;border-bottom:1.5px solid var(--ink);}
.section.alt{background:var(--paper-2);}
@media(max-width:768px){.section{padding:80px 0;}}

/* ---------- Header ---------- */
.site-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;border-bottom:1.5px solid var(--ink);
  background:var(--paper);position:sticky;top:0;z-index:50;
}
.site-logo{
  font-family:var(--ff-disp);font-weight:800;font-variation-settings:"wdth" 105;
  font-size:20px;letter-spacing:-0.01em;display:flex;align-items:center;gap:10px;
}
.site-logo .dot{
  width:14px;height:14px;background:var(--pink);border-radius:50%;
  display:inline-block;box-shadow:3px 3px 0 var(--ink);
}
.site-logo .city{
  font-family:var(--ff-mono);font-size:10px;letter-spacing:.18em;
  background:var(--ink);color:var(--paper);padding:3px 7px;border-radius:3px;
}
.site-nav{display:flex;align-items:center;gap:6px;}
.site-nav a{
  font-family:var(--ff-mono);font-size:12px;letter-spacing:.06em;
  padding:8px 14px;border-radius:999px;text-transform:uppercase;
}
.site-nav a:hover{background:var(--ink);color:var(--paper);opacity:1;}
.lang-switch{
  margin-left:6px;display:inline-flex;border:1.5px solid var(--ink);border-radius:999px;
  overflow:hidden;font-family:var(--ff-mono);font-size:11px;
}
.lang-switch button{
  background:transparent;border:0;padding:6px 10px;letter-spacing:.06em;color:var(--ink);
}
.lang-switch button.active{background:var(--ink);color:var(--paper);}
.menu-toggle{
  display:none;background:transparent;border:1.5px solid var(--ink);border-radius:8px;
  padding:6px 12px;font-family:var(--ff-mono);font-size:11px;letter-spacing:.1em;
}
@media(max-width:1024px){
  .site-nav a{display:none;}
  .lang-switch{display:none;}
  .menu-toggle{display:inline-block;}
  .site-nav.is-open{
    display:flex;flex-direction:column;align-items:flex-start;gap:8px;
    position:absolute;top:100%;left:0;right:0;background:var(--paper);
    padding:18px 32px;border-bottom:1.5px solid var(--ink);
  }
  .site-nav.is-open a, .site-nav.is-open .lang-switch{display:flex;}
  .site-nav.is-open a{font-size:14px;padding:10px 12px;width:100%;border-radius:6px;}
}

/* ---------- HERO (Top) ---------- */
.hero{position:relative;padding:80px 36px 110px;overflow:hidden;border-bottom:1.5px solid var(--ink);background:var(--paper);}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(14,18,56,0.18) 1px, transparent 1.6px);
  background-size:24px 24px;
  mask-image:linear-gradient(180deg, transparent 0%, #000 30%, #000 80%, transparent 100%);
  -webkit-mask-image:linear-gradient(180deg, transparent 0%, #000 30%, #000 80%, transparent 100%);
  opacity:.55;pointer-events:none;
}
.hero-inner{max-width:var(--max-w);margin:0 auto;position:relative;z-index:2;}
.tagline{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--ff-mono);font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;margin-bottom:32px;
}
.tagline .marker{
  width:10px;height:10px;background:var(--lime);border:1.5px solid var(--ink);border-radius:50%;
  box-shadow:2px 2px 0 var(--ink);
}
.tagline .slash{opacity:.4;}

h1.headline{
  font-family:var(--ff-disp);font-weight:800;font-variation-settings:"wdth" 88;
  font-size:clamp(44px, 7.6vw, 116px);line-height:1.0;letter-spacing:-0.035em;
  margin:0;max-width:1180px;
  word-break:keep-all;overflow-wrap:normal;text-wrap:balance;
}
.headline .line{display:block;white-space:nowrap;}
.headline .nowrap{white-space:nowrap;}
.headline .jp{font-family:var(--ff-jp);font-weight:900;letter-spacing:-0.015em;line-height:1.05;font-size:clamp(40px,6.8vw,108px);}
.headline .arrow{
  display:inline-block;font-family:var(--ff-serif);font-style:italic;font-weight:400;
  color:var(--ink);opacity:.55;transform:translateY(-0.06em);padding:0 0.18em 0 0;font-size:0.78em;
}
.headline mark{background:var(--mango);color:var(--ink);padding:0 0.14em 0.05em;display:inline-block;line-height:1;border-radius:4px;}
.headline .hi{
  background:var(--pink);color:var(--paper);padding:0 0.16em 0.05em;border-radius:6px;
  display:inline-block;line-height:1;box-shadow:5px 5px 0 var(--ink);
}
.headline .ital{
  font-family:var(--ff-serif);font-style:italic;font-weight:900;
  font-variation-settings:"opsz" 144;letter-spacing:-0.01em;
}
@media(max-width:900px){.headline .line{white-space:normal;} .headline .nowrap{white-space:nowrap;}}

.hero-bottom{margin-top:56px;display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:end;}
@media(max-width:900px){.hero-bottom{grid-template-columns:1fr;}}
.hero-lead{
  font-size:18px;line-height:1.95;max-width:520px;color:var(--ink);text-wrap:pretty;
  padding-left:160px;position:relative;z-index:4;
}
@media(max-width:900px){.hero-lead{padding-left:0;}}
.hero-lead .drop{
  float:left;font-family:var(--ff-serif);font-style:italic;font-weight:900;
  font-variation-settings:"opsz" 144;
  font-size:78px;line-height:0.85;padding:6px 12px 0 0;color:var(--pink);
}
.hero-cta{display:flex;flex-direction:column;align-items:flex-end;gap:18px;}
@media(max-width:900px){.hero-cta{align-items:flex-start;}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:18px 28px;font-family:var(--ff-mono);font-size:13px;letter-spacing:.1em;
  text-transform:uppercase;border-radius:999px;border:1.5px solid var(--ink);
  background:var(--ink);color:var(--paper);transition:.15s;font-weight:500;
  box-shadow:6px 6px 0 var(--ink);
}
.btn:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--ink);opacity:1;}
.btn.alt{background:var(--lime);color:var(--ink);}
.btn.pink{background:var(--pink);color:var(--paper);}
.btn.ghost{background:transparent;color:var(--ink);}
.btn .arr{font-family:var(--ff-serif);font-style:italic;font-size:18px;}
.hero-meta{font-family:var(--ff-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);opacity:.7;}
.hero-meta b{color:var(--pink);font-weight:500;}

/* ---------- Sticker stamps ---------- */
.stamp{
  position:absolute;width:128px;height:128px;border-radius:50%;
  background:var(--paper);border:2px solid var(--ink);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-disp);font-size:14px;font-weight:800;
  text-align:center;line-height:1.1;letter-spacing:0.02em;
  box-shadow:6px 6px 0 var(--ink);z-index:3;transform:rotate(-12deg);
}
.stamp.s1{top:84px;right:7%;background:var(--lime);}
.stamp.s2{bottom:96px;left:6%;background:var(--pink);color:var(--paper);transform:rotate(8deg);}
.stamp .stroke{position:absolute;inset:8px;border:1.2px dashed var(--ink);border-radius:50%;pointer-events:none;}
@media(max-width:900px){.stamp{width:100px;height:100px;font-size:12px;}.stamp.s1{top:24px;right:24px;}.stamp.s2{display:none;}}

/* ---------- Marquee tapes ---------- */
.tape{
  background:var(--ink);color:var(--paper);
  padding:22px 0;overflow:hidden;border-bottom:1.5px solid var(--ink);
}
.tape .track{display:inline-flex;gap:46px;white-space:nowrap;animation:scroll 38s linear infinite;}
.tape .track span{
  font-family:var(--ff-serif);font-style:italic;font-weight:700;
  font-variation-settings:"opsz" 144;
  font-size:42px;letter-spacing:-0.01em;display:inline-flex;align-items:center;gap:46px;
}
.tape .track .ast{color:var(--mango);font-style:normal;font-family:var(--ff-disp);font-weight:800;font-size:34px;}
.tape2{
  background:var(--lime);color:var(--ink);
  padding:18px 0;overflow:hidden;border-top:1.5px solid var(--ink);border-bottom:1.5px solid var(--ink);
}
.tape2 .track{display:inline-flex;gap:36px;white-space:nowrap;animation:scroll 30s linear infinite;}
.tape2 span{font-family:var(--ff-mono);font-size:14px;letter-spacing:.16em;text-transform:uppercase;display:inline-flex;align-items:center;gap:36px;}
.tape2 .ast{font-family:var(--ff-disp);font-size:18px;color:var(--pink);}
@keyframes scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ---------- Section heads / Page headers ---------- */
.section-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:24px;
  margin-bottom:64px;flex-wrap:wrap;
}
.kicker{
  font-family:var(--ff-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  display:flex;align-items:center;gap:10px;
}
.kicker .num{color:var(--pink);font-weight:500;}
.kicker .bar{display:inline-block;width:38px;height:2px;background:var(--ink);}
.section-title{
  font-family:var(--ff-disp);font-weight:800;font-variation-settings:"wdth" 95;
  font-size:clamp(36px,5vw,68px);line-height:1.1;letter-spacing:-0.02em;
  margin:14px 0 0;max-width:780px;
  word-break:keep-all;text-wrap:balance;
}
.section-title .it{
  font-family:var(--ff-serif);font-style:italic;font-weight:900;
  font-variation-settings:"opsz" 144;
}
.section-aside{
  font-family:var(--ff-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  text-align:right;line-height:1.7;color:var(--ink);opacity:.7;
}
.section-lead{
  font-size:17px;line-height:1.95;max-width:680px;color:var(--ink-soft);
  margin-top:24px;text-wrap:pretty;
}

/* Page header (used on inner pages) */
.page-header{
  position:relative;padding:80px 36px 70px;border-bottom:1.5px solid var(--ink);
  background:var(--paper);overflow:hidden;
}
.page-header::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(14,18,56,0.16) 1px, transparent 1.6px);
  background-size:22px 22px;
  mask-image:linear-gradient(180deg, transparent 0%, #000 50%, transparent 100%);
  -webkit-mask-image:linear-gradient(180deg, transparent 0%, #000 50%, transparent 100%);
  opacity:.55;pointer-events:none;
}
.page-header__inner{max-width:var(--max-w);margin:0 auto;position:relative;z-index:2;}
.page-header__title{
  font-family:var(--ff-disp);font-weight:800;font-variation-settings:"wdth" 92;
  font-size:clamp(44px,7vw,96px);line-height:1.0;letter-spacing:-0.03em;
  margin:14px 0 18px;max-width:1100px;
  word-break:keep-all;text-wrap:balance;
}
.page-header__title .it{
  font-family:var(--ff-serif);font-style:italic;font-weight:900;
  font-variation-settings:"opsz" 144;
}
.page-header__title mark{background:var(--mango);color:var(--ink);padding:0 0.14em 0.05em;display:inline-block;border-radius:4px;line-height:1;}
.page-header__title .hi{background:var(--pink);color:var(--paper);padding:0 0.14em 0.05em;border-radius:6px;display:inline-block;line-height:1;box-shadow:5px 5px 0 var(--ink);}
.page-header__lead{
  font-size:17px;line-height:1.9;max-width:680px;color:var(--ink-soft);
  text-wrap:pretty;margin-top:18px;
}

/* ---------- CHAIN rows (used on Top + About + Story support) ---------- */
.chain-rows .row{
  display:grid;grid-template-columns:140px 1fr 1fr;gap:32px;
  align-items:center;padding:36px 0;border-top:1.5px dashed var(--line);
}
.chain-rows .row:last-child{border-bottom:1.5px dashed var(--line);}
.chain-rows .row .num{
  font-family:var(--ff-serif);font-style:italic;font-weight:900;
  font-variation-settings:"opsz" 144;
  font-size:108px;line-height:1;color:var(--ink);
}
.chain-rows .row .word{
  font-family:var(--ff-jp);font-weight:900;
  font-size:clamp(48px,7vw,104px);line-height:1.05;letter-spacing:-0.015em;
  word-break:keep-all;text-wrap:balance;
}
.chain-rows .row .word .hl-pink{color:var(--pink);}
.chain-rows .row .word .hl-mango{background:var(--mango);padding:0 0.12em;display:inline-block;}
.chain-rows .row .word .hl-lime{background:var(--lime);padding:0 0.12em;display:inline-block;border:2px solid var(--ink);box-shadow:5px 5px 0 var(--ink);}
.chain-rows .row .body{
  font-family:var(--ff-jp);font-weight:500;font-size:16px;line-height:1.85;
  color:var(--ink);max-width:380px;text-wrap:pretty;
}
.chain-rows .row .body .micro{
  display:block;font-family:var(--ff-mono);font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-mute);margin-bottom:8px;
}
@media(max-width:900px){
  .chain-rows .row{grid-template-columns:80px 1fr;gap:18px;padding:30px 0;}
  .chain-rows .row .num{font-size:60px;}
  .chain-rows .row .body{grid-column:1 / -1;}
  .chain-rows .row .word{font-size:48px;}
}

/* ---------- Pull quote ---------- */
.quote{
  padding:120px 36px;background:var(--ink);color:var(--paper);
  border-bottom:1.5px solid var(--ink);position:relative;overflow:hidden;
}
.quote::before{
  content:"”";position:absolute;font-family:var(--ff-serif);font-style:italic;font-weight:900;
  font-size:560px;line-height:0.7;color:var(--mango);
  top:-60px;left:-30px;opacity:.18;
}
.quote-inner{max-width:1100px;margin:0 auto;position:relative;z-index:2;}
.quote p{
  font-family:var(--ff-serif);font-style:italic;font-weight:700;
  font-variation-settings:"opsz" 144;
  font-size:clamp(34px,5.2vw,72px);line-height:1.3;letter-spacing:-0.012em;margin:0;
  word-break:keep-all;text-wrap:balance;
}
.quote p em{font-style:normal;color:var(--lime);font-family:var(--ff-jp);font-weight:900;}
.quote .by{
  margin-top:36px;font-family:var(--ff-mono);font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mango);
}

/* ---------- Products grid (Top + Products listing) ---------- */
.prod-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border:1.5px solid var(--ink);background:var(--ink);
}
.tile{
  position:relative;padding:48px 40px 40px;background:var(--paper);
  border:0.75px solid var(--ink);
  display:flex;flex-direction:column;gap:18px;min-height:360px;
  transition:.2s;overflow:hidden;text-decoration:none;color:inherit;
}
.tile:hover{transform:scale(0.99);opacity:1;}
.tile-num{
  position:absolute;top:24px;right:32px;
  font-family:var(--ff-serif);font-style:italic;font-weight:900;
  font-variation-settings:"opsz" 144;
  font-size:72px;line-height:1;opacity:.2;
}
.tile-mark{
  width:64px;height:64px;border:2px solid var(--ink);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-disp);font-weight:800;font-size:32px;background:var(--paper);
}
.tile.koete{background:var(--pink);color:var(--paper);}
.tile.koete .tile-mark{background:var(--paper);color:var(--pink);}
.tile.koete .tile-num{color:var(--paper);}
.tile.hello{background:var(--mango);}
.tile.hello .tile-mark{background:var(--ink);color:var(--mango);}
.tile.jeeb{background:var(--lime);}
.tile.jeeb .tile-mark{background:var(--ink);color:var(--lime);}
.tile.ks{background:var(--sky);}
.tile.ks .tile-mark{background:var(--paper);color:var(--ink);}
.tile-tag{font-family:var(--ff-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;}
.tile-name{
  font-family:var(--ff-disp);font-weight:800;font-variation-settings:"wdth" 90;
  font-size:54px;line-height:0.95;letter-spacing:-0.025em;margin:4px 0;
}
.tile-name .ks-apo{font-family:var(--ff-serif);font-style:italic;}
.tile-catch{font-family:var(--ff-jp);font-weight:500;font-size:16px;line-height:1.7;max-width:380px;}
.tile-foot{
  margin-top:auto;padding-top:18px;
  display:flex;justify-content:space-between;align-items:center;
  border-top:1.5px dashed currentColor;font-family:var(--ff-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
}
.tile-arrow{font-family:var(--ff-serif);font-style:italic;font-size:24px;}
@media(max-width:900px){.prod-grid{grid-template-columns:1fr;}.tile{min-height:300px;padding:36px 28px;}.tile-name{font-size:42px;}}

/* ---------- Stats strip ---------- */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;}
.stat{border-top:2px solid var(--ink);padding-top:18px;}
.stat .n{
  font-family:var(--ff-disp);font-weight:800;font-variation-settings:"wdth" 95;
  font-size:64px;line-height:1;letter-spacing:-0.03em;
}
.stat .n .it{font-family:var(--ff-serif);font-style:italic;font-weight:900;font-size:.85em;}
.stat .l{font-family:var(--ff-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-top:10px;}
.stat:nth-child(1) .n{color:var(--pink);}
@media(max-width:900px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:32px;}}

/* ---------- Big CTA ---------- */
.cta-block{
  padding:140px 36px;background:var(--paper);border-bottom:1.5px solid var(--ink);
  position:relative;overflow:hidden;
}
.cta-block::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(135deg, transparent 0 22px, rgba(14,18,56,0.06) 22px 23px);
  pointer-events:none;
}
.cta-inner{max-width:1100px;margin:0 auto;text-align:center;position:relative;z-index:2;}
.cta-inner h2{
  font-family:var(--ff-disp);font-weight:800;font-variation-settings:"wdth" 90;
  font-size:clamp(44px,8vw,120px);line-height:1.05;letter-spacing:-0.03em;margin:0;
  word-break:keep-all;text-wrap:balance;
}
.cta-inner h2 .ital{font-family:var(--ff-serif);font-style:italic;font-weight:900;font-variation-settings:"opsz" 144;}
.cta-inner h2 .hl{background:var(--pink);color:var(--paper);padding:0 0.1em;display:inline-block;box-shadow:8px 8px 0 var(--ink);}
.cta-sub{font-family:var(--ff-mono);font-size:13px;letter-spacing:.16em;text-transform:uppercase;margin:32px 0 36px;color:var(--ink);}
.cta-sub b{color:var(--pink);font-weight:500;}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:var(--paper);padding:80px 36px 28px;}
.site-footer a:hover{color:var(--lime);opacity:1;}
.foot-inner{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;}
.foot-brand{
  font-family:var(--ff-disp);font-weight:800;font-size:42px;letter-spacing:-0.02em;
  font-variation-settings:"wdth" 95;
}
.foot-brand .dot{color:var(--mango);}
.foot-addr{font-family:var(--ff-mono);font-size:11px;line-height:1.9;letter-spacing:.04em;color:rgba(255,255,255,0.7);margin-top:18px;}
.foot-h{font-family:var(--ff-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mango);margin-bottom:14px;}
.foot ul{display:grid;gap:8px;font-family:var(--ff-jp);font-size:14px;}
.foot-bottom{
  max-width:var(--max-w);margin:60px auto 0;padding-top:24px;
  border-top:1px solid rgba(255,255,255,0.18);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.55);
}
@media(max-width:900px){.foot-inner{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.foot-inner{grid-template-columns:1fr;}}

/* ---------- Inline elements / utilities ---------- */
.coming-soon-tag{
  display:inline-block;padding:4px 10px;border:1px solid var(--line);border-radius:999px;
  font-size:11px;letter-spacing:.15em;color:var(--ink-mute);
  font-family:var(--ff-mono);text-transform:uppercase;
}
.placeholder-img{
  background:repeating-linear-gradient(135deg, #F2F0EA 0 14px, #FFFFFF 14px 28px);
  border:1.5px dashed var(--ink);
  aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-mono);font-size:12px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--ink-mute);
}

/* ---------- Info / spec table ---------- */
.info-table{width:100%;border-collapse:collapse;margin-top:28px;}
.info-table th,.info-table td{
  padding:18px 16px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top;
  font-size:15px;line-height:1.7;
}
.info-table th{
  width:240px;font-weight:500;color:var(--ink-mute);
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  padding-top:22px;
}
.info-table td{color:var(--ink);}
@media(max-width:640px){
  .info-table th,.info-table td{display:block;width:100%;padding:6px 0;border-bottom:0;}
  .info-table tr{display:block;padding:14px 0;border-bottom:1px solid var(--line);}
}

/* ---------- Pillar cards (used on product detail Value section) ---------- */
.pillar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;}
.pillar-card{
  background:var(--paper);border:1.5px solid var(--ink);
  padding:32px 28px;box-shadow:6px 6px 0 var(--ink);
  display:flex;flex-direction:column;gap:14px;
}
.pillar-card .num{
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--pink);
}
.pillar-card .title{
  font-family:var(--ff-disp);font-weight:800;font-size:22px;letter-spacing:-0.01em;line-height:1.3;
}
.pillar-card .desc{font-size:15px;line-height:1.85;color:var(--ink-soft);text-wrap:pretty;}
@media(max-width:900px){.pillar-grid{grid-template-columns:1fr;}}

/* ---------- News list ---------- */
.news-list{margin-top:24px;}
.news-list__item{
  display:grid;grid-template-columns:160px 1fr auto;gap:32px;
  padding:28px 0;border-bottom:1.5px dashed var(--line);align-items:baseline;
  transition:.15s;
}
.news-list__item:hover{transform:translateX(4px);opacity:1;}
.news-list__date{
  font-family:var(--ff-mono);font-size:13px;letter-spacing:.12em;color:var(--pink);
}
.news-list__title{font-family:var(--ff-jp);font-size:18px;font-weight:500;color:var(--ink);line-height:1.6;}
.news-list__arrow{font-family:var(--ff-serif);font-style:italic;font-size:24px;}
@media(max-width:640px){.news-list__item{grid-template-columns:1fr;gap:6px;}.news-list__arrow{display:none;}}

/* ---------- Forms ---------- */
.form-grid{display:grid;gap:28px;margin-top:36px;}
.form-row{display:grid;gap:8px;}
.form-row label{
  font-family:var(--ff-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-mute);
}
.form-row input,.form-row select,.form-row textarea{
  border:0;border-bottom:1.5px solid var(--ink);
  padding:14px 0;font-size:16px;background:transparent;color:var(--ink);
  font-family:var(--ff-jp);transition:border-color .15s;border-radius:0;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{
  outline:0;border-bottom-color:var(--pink);
}
.form-row textarea{min-height:160px;resize:vertical;}

/* ---------- Long-form prose (Story / News article) ---------- */
.prose{font-size:17px;line-height:2;color:var(--ink-soft);text-wrap:pretty;}
.prose p{margin:0 0 1.2em;}
.prose .lead-stanza{
  font-family:var(--ff-jp);font-weight:900;color:var(--ink);
  font-size:clamp(22px,3vw,32px);line-height:1.65;letter-spacing:-0.01em;
  margin-bottom:2em;text-wrap:balance;word-break:keep-all;
}
.prose .lead-stanza .ital{font-family:var(--ff-serif);font-style:italic;font-weight:900;}

/* ---------- Notice bar (used at top of pages we want to flag e.g. samples) ---------- */
.notice-bar{
  background:var(--ink);color:var(--paper);
  padding:8px 24px;font-family:var(--ff-mono);font-size:11px;letter-spacing:.12em;
  text-align:center;text-transform:uppercase;
}
.notice-bar a{color:var(--mango);text-decoration:underline;text-underline-offset:3px;}

/* ---------- Misc ---------- */
.text-center{text-align:center;}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.tag{
  display:inline-block;background:var(--ink);color:var(--paper);
  padding:5px 11px;font-family:var(--ff-mono);font-size:10px;letter-spacing:.16em;
  text-transform:uppercase;border-radius:3px;
}
.tag.pink{background:var(--pink);}
.tag.lime{background:var(--lime);color:var(--ink);}
.tag.mango{background:var(--mango);color:var(--ink);}
