:root{
  --ink:#0E0E0C; --ink-2:#16160F; --paper:#F4EFE6; --paper-2:#ECE5D6;
  --gold:#C8A24B; --gold-soft:#D9BE83; --olive:#3A4A2F; --ivory:#FBF8F1;
  --line:rgba(200,162,75,.28); --line-dark:rgba(244,239,230,.16);
  --serif:"Cormorant Garamond","Noto Serif Thai",Georgia,serif;
  --serif-th:"Noto Serif Thai","Cormorant Garamond",Georgia,serif;
  --sans:"Jost","Helvetica Neue",sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--paper);font-family:var(--sans);font-weight:300;line-height:1.8;overflow-x:hidden;-webkit-font-smoothing:antialiased;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}
input,textarea,select,[contenteditable]{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}
img{-webkit-user-drag:none;user-drag:none;-webkit-touch-callout:none}
html[lang="th"] h1,html[lang="th"] h2,html[lang="th"] h3,html[lang="th"] .kahn{font-family:var(--serif-th)}
html[lang="th"] .lede,html[lang="th"] .tier li,html[lang="th"] p{font-family:var(--serif-th)}
img{max-width:100%;display:block}
.serif{font-family:var(--serif)}
html[lang="th"] .serif{font-family:var(--serif-th)}
.latin{font-family:var(--serif)!important}
.gold{color:var(--gold)}
.eyebrow{font-family:var(--sans);font-weight:400;letter-spacing:.34em;text-transform:uppercase;font-size:.72rem;color:var(--gold)}
html[lang="th"] .eyebrow{letter-spacing:.05em;font-family:var(--serif-th);text-transform:none;font-size:.92rem}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.12;letter-spacing:.01em}
.wrap{max-width:1180px;margin:0 auto;padding:0 32px}
a{color:inherit;text-decoration:none}

nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:18px 40px;transition:.5s var(--ease)}
nav.solid{background:rgba(14,14,12,.78);backdrop-filter:blur(14px);padding:12px 40px;border-bottom:1px solid var(--line-dark)}
#nav .nav-right{transition:opacity .3s ease}
#nav.nav-boot .nav-right{opacity:0}
.brand{font-family:var(--serif);font-size:1.4rem;letter-spacing:.07em;font-weight:500;color:#fff}
@keyframes wzSlide{from{opacity:0;transform:translateX(26px)}to{opacity:1;transform:none}}
#mStep{width:100%;max-width:560px;margin:0 auto 14px;padding:0 6px;box-sizing:border-box}
.wzstep{padding:0}
.ovgrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
@media(max-width:560px){.ovgrid{grid-template-columns:minmax(0,1fr)}}
input[type=number]{-moz-appearance:textfield;appearance:textfield}
input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.brand small{display:block;font-family:var(--serif-th);font-size:.56rem;letter-spacing:.14em;color:var(--gold-soft);margin-top:3px;text-align:center}
.nav-right{display:flex;align-items:center;gap:28px}
.nav-links{display:flex;align-items:center;gap:30px;border-right:1px solid var(--line-dark);padding-right:30px}
.nav-links a{position:relative;display:flex;align-items:center;min-height:42px;line-height:1;font-family:var(--sans);font-size:.82rem;letter-spacing:.08em;color:#fff;opacity:.78;transition:.3s}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:8px;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:center;transition:transform .32s var(--ease,ease)}
.nav-links a:hover::after{transform:scaleX(1)}
html[lang="th"] .nav-links a{font-family:var(--serif-th);font-size:.98rem}
.nav-links a:hover{opacity:1;color:var(--gold2)}
.nav-cta{font-size:.74rem;letter-spacing:.16em;border:1px solid var(--gold);color:var(--gold)!important;background:rgba(200,162,75,.06);padding:10px 22px;border-radius:8px;opacity:1!important}
.nav-cta::after{display:none}
.nav-cta:hover{background:var(--gold);color:var(--ink)!important}
html[lang="th"] .nav-cta{font-family:var(--serif-th);font-size:.95rem}
html[lang="th"] .lang{font-family:var(--serif-th);font-size:.92rem;letter-spacing:.04em}
.nav-cta:hover{background:var(--gold);color:var(--ink)!important}
.lang{display:inline-flex;align-items:center;gap:7px;font-family:var(--sans);font-size:.74rem;letter-spacing:.12em;cursor:pointer;border:1px solid var(--line-dark);border-radius:8px;padding:9px 14px;color:var(--gold-soft);background:transparent;transition:.25s}
.lang-opt{display:block;width:100%;text-align:left;background:transparent;border:none;border-radius:8px;padding:9px 12px;color:var(--paper,#F4EFE6);font-family:var(--serif-th);font-size:.95rem;cursor:pointer;transition:.18s}
.lang-opt:hover{background:rgba(200,162,75,.12)}
.lang-opt.on{background:rgba(200,162,75,.18);color:var(--gold-soft)}
.lang:hover{border-color:var(--gold);color:var(--gold)}
.lang:hover{border-color:var(--gold);color:var(--gold)}
.lang b{color:var(--gold)}
.cart-btn{position:relative;border:none;padding:0;background:transparent;font-family:var(--sans);font-size:.82rem;letter-spacing:.08em;color:#fff;opacity:.82}
.cart-btn:hover{color:var(--gold);opacity:1;border:none}
html[lang="th"] .cart-btn{font-family:var(--serif-th);font-size:.98rem}
.cart-count{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 4px;border-radius:999px;background:linear-gradient(180deg,#e24b3b,#b6281b);color:#fff;font-family:var(--sans);font-size:.66rem;font-weight:600;margin-left:2px}
.menu-btn{display:none;background:none;border:none;color:#fff;font-size:1.4rem;cursor:pointer}

.dots{position:fixed;right:26px;top:50%;transform:translateY(-50%);z-index:90;display:flex;flex-direction:column;gap:14px}
.dots button{width:9px;height:9px;border-radius:50%;border:1px solid rgba(200,162,75,.6);background:transparent;cursor:pointer;padding:0;transition:.3s;position:relative}
.dots button.on{background:var(--gold);transform:scale(1.3)}
.dots button span{position:absolute;right:20px;top:50%;transform:translateY(-50%);white-space:nowrap;font-family:var(--serif-th);font-size:.74rem;letter-spacing:.04em;color:var(--gold);opacity:0;pointer-events:none;transition:.3s}
.dots button:hover span{opacity:1}
@media(max-width:900px){.dots{display:none}}

.hero{position:relative;height:100vh;min-height:640px;overflow:hidden;display:grid;place-items:center;text-align:center}
.hero .sky{position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 120%,#26301c 0%,#14160e 42%,#0b0c08 100%),linear-gradient(180deg,#1a2415 0%,#0e0e0c 70%)}
.hero .hero-stage{position:absolute;inset:0;z-index:2;animation:heroKB 28s ease-in-out infinite alternate;will-change:transform}
.hero .hero-bg{position:absolute;inset:0;background:#070d06 url("hero-bg-main.jpg?v=3") center center/cover no-repeat}
/* เลเยอร์แกว่ง — ใบไม้ + ทุเรียน แยกออกจากพื้นหลังแล้ว (กิ่ง/ต้นไม้อยู่ในพื้นหลัง = นิ่ง) ซ้อนทับให้ไหว/แกว่งตามลม ไม่มีเงาซ้อน */
.hero .hero-foliage{position:absolute;inset:0;background:url("hero-bg-main.png?v=2") center center/cover no-repeat;transform-origin:84% 6%;animation:breeze 4.3s ease-in-out infinite alternate-reverse;will-change:transform;pointer-events:none}
.hero .hero-durian-layer{position:absolute;inset:0;background:url("hero-durian-c2.png?v=1") center center/cover no-repeat;transform-origin:80.4% 26.6%;animation:durianSway 7s ease-in-out infinite alternate;will-change:transform;pointer-events:none}
@keyframes durianSway{0%{transform:rotate(-0.7deg)}100%{transform:rotate(0.7deg)}}
@keyframes breeze{0%{transform:rotate(-0.8deg)}100%{transform:rotate(0.85deg)}}
.hero .hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,11,6,.58) 0%,rgba(5,11,6,.14) 24%,rgba(5,11,6,.10) 52%,rgba(5,11,6,.40) 82%,rgba(5,11,6,.66) 100%),radial-gradient(120% 78% at 50% 48%,rgba(5,11,6,.42),transparent 62%)}
@keyframes heroKB{0%{transform:scale(1.02) translate(0,0)}100%{transform:scale(1.1) translate(-1.2%,-0.8%)}}
.hero .hero-particles{position:absolute;inset:0;z-index:3;pointer-events:none}
@media(prefers-reduced-motion:reduce){.hero .hero-durian-layer,.hero .hero-foliage{animation:none}}
.hero .sun{position:absolute;left:50%;top:62%;width:520px;height:520px;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,rgba(216,190,131,.5),rgba(200,162,75,.12) 45%,transparent 70%);filter:blur(6px);animation:sun 14s var(--ease) infinite alternate}
@keyframes sun{from{transform:translate(-50%,-46%) scale(1)}to{transform:translate(-50%,-52%) scale(1.08)}}
.ridge{position:absolute;left:0;right:0;bottom:0;width:100%}
.ridge svg{display:block;width:100%;height:auto}
.fog{position:absolute;left:-10%;right:-10%;height:240px;background:linear-gradient(180deg,transparent,rgba(244,239,230,.07) 60%,rgba(244,239,230,.12));filter:blur(22px)}
.fog.f1{bottom:60px;animation:drift 26s linear infinite}
.fog.f2{bottom:140px;opacity:.5;animation:drift 38s linear infinite reverse}
@keyframes drift{from{transform:translateX(-6%)}to{transform:translateX(6%)}}
.hero-inner{position:relative;z-index:5;padding:0 24px;opacity:0;transform:translateY(20px);animation:rise 1.6s var(--ease) .3s forwards}
@keyframes rise{to{opacity:1;transform:none}}
.hero h1{font-size:clamp(3rem,8vw,6.4rem);color:#fff;letter-spacing:.04em;text-shadow:0 8px 40px rgba(0,0,0,.4);font-family:var(--serif)}
.hero .lead{font-size:clamp(1.1rem,2.3vw,1.5rem);font-weight:400;color:var(--gold-soft);margin-top:18px;letter-spacing:.04em}
html[lang="th"] .hero .lead{font-family:var(--serif-th)}
.hero .eyebrow{margin-bottom:22px;display:inline-block}
.scrollcue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:6;font-family:var(--serif-th);font-size:.86rem;letter-spacing:.08em;color:var(--gold-soft);opacity:.85}
.scrollcue::after{content:"";display:block;width:1px;height:46px;margin:12px auto 0;background:linear-gradient(var(--gold),transparent);animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

section{position:relative}
.chapter{padding:130px 0}
.light{background:var(--paper);color:var(--ink)}
.light .eyebrow{color:#9a7d2e}
.dark{background:var(--ink)}
.dark-2{background:linear-gradient(180deg,#0e0e0c,#14160e)}
.dark-3{background:linear-gradient(160deg,#0e0e0c,#1a1408)}
.dark-4{background:linear-gradient(160deg,#0e0e0c,#11150d)}
.lede{font-weight:400;font-size:1.16rem;line-height:1.95;color:inherit;opacity:.86}
.kahn{font-size:clamp(2.1rem,4.6vw,3.5rem);margin:16px 0 8px}
.rule{width:54px;height:1px;background:var(--gold);margin:26px 0}
.center{text-align:center}
.center .rule{margin:26px auto}

.reveal{opacity:0;transform:translateY(34px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}.reveal.d2{transition-delay:.24s}.reveal.d3{transition-delay:.36s}

.split{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.scene{position:relative;height:440px;border-radius:3px;overflow:hidden;background:linear-gradient(180deg,#243018,#11140d)}
.scene .glow{position:absolute;inset:0;background:radial-gradient(80% 60% at 70% 20%,rgba(216,190,131,.35),transparent 60%)}
.facts{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:34px;border-top:1px solid var(--line)}
.facts div{padding:18px 0;border-bottom:1px solid var(--line)}
.facts .k{font-family:var(--sans);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;opacity:.6}
html[lang="th"] .facts .k{font-family:var(--serif-th);text-transform:none;font-size:.86rem}
.facts .v{font-family:var(--serif);font-size:1.5rem}
html[lang="th"] .facts .v{font-family:var(--serif-th)}

.sig{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.viewer{height:480px;border-radius:3px;background:radial-gradient(60% 60% at 50% 40%,#22180a,#0c0b07);display:grid;place-items:center;position:relative;overflow:hidden;cursor:grab}
.viewer:active{cursor:grabbing}
.viewer .durian{font-size:14rem;filter:drop-shadow(0 40px 60px rgba(200,162,75,.35));transition:transform .05s linear;user-select:none}
.viewer .hint{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);font-family:var(--serif-th);font-size:.82rem;letter-spacing:.04em;color:var(--gold-soft);opacity:.85}
.taste{margin-top:24px}
.taste .row{display:flex;align-items:center;gap:16px;margin:13px 0}
.taste .row span{width:130px;font-family:var(--serif-th);font-size:.92rem;letter-spacing:.04em;opacity:.8}
.tbar{flex:1;height:1px;background:var(--line-dark);position:relative}
.tbar i{position:absolute;left:0;top:-2px;height:5px;background:linear-gradient(90deg,var(--gold-soft),var(--gold));width:0;transition:width 1.4s var(--ease)}
.sig-stats{display:flex;gap:40px;margin-top:30px}
.sig-stats b{font-family:var(--serif);font-size:1.9rem;display:block;color:var(--gold-soft)}
html[lang="th"] .sig-stats b{font-family:var(--serif-th)}
.sig-stats small{font-family:var(--serif-th);font-size:.82rem;letter-spacing:.04em;opacity:.65}

.craft{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:60px;border-top:1px solid var(--line-dark)}
.step{padding:34px 22px;border-right:1px solid var(--line-dark);position:relative}
.step:last-child{border-right:none}
.step .no{font-family:var(--serif);font-size:2.6rem;color:var(--gold);opacity:.5}
.step h3{font-size:1.3rem;margin:8px 0 10px}
.step p{font-size:.98rem;opacity:.72;line-height:1.7}

.trace-box{max-width:560px;margin:40px auto 0;display:flex;gap:10px}
.trace-box input{flex:1;background:transparent;border:1px solid var(--line);color:var(--paper);padding:15px 18px;font-family:var(--serif-th);letter-spacing:.04em;border-radius:2px}
.trace-box input::placeholder{color:rgba(244,239,230,.4)}
.trace-box button,.btn{font-family:var(--serif-th);letter-spacing:.04em;font-size:.98rem;cursor:pointer;border:1px solid var(--gold);background:var(--gold);color:var(--ink);padding:14px 26px;border-radius:12px;transition:.3s}
html[lang="en"] .trace-box button,html[lang="en"] .btn{font-family:var(--sans);letter-spacing:.14em;text-transform:uppercase;font-size:.76rem}
.btn.ghost{background:transparent;color:var(--gold)}
.btn:hover{background:var(--gold-soft);border-color:var(--gold-soft)}
.btn.ghost:hover{background:var(--gold);color:var(--ink)}
.cta-all{padding:17px 46px;font-size:1.08rem;letter-spacing:.02em;box-shadow:0 12px 34px rgba(200,162,75,.28);position:relative}
.cta-all:hover{transform:translateY(-2px);box-shadow:0 16px 44px rgba(200,162,75,.46)}
.cert{max-width:620px;margin:34px auto 0;border:1px solid var(--line);border-radius:3px;padding:30px;display:none;background:rgba(216,190,131,.04)}
.cert.show{display:block;animation:rise 1s var(--ease)}
.cert .seal{font-size:2.2rem}
.timeline{margin-top:18px;padding-left:24px;position:relative}
.timeline::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:1px;background:var(--line)}
.tl{position:relative;padding:9px 0}
.tl::before{content:"";position:absolute;left:-22px;top:14px;width:9px;height:9px;border-radius:50%;background:var(--ink);border:1px solid var(--gold)}
.tl.done::before{background:var(--gold)}
.tl b{font-family:var(--serif-th);font-size:1.08rem;font-weight:500}
.tl small{display:block;font-family:var(--sans);font-size:.72rem;letter-spacing:.06em;opacity:.6}

.coll{display:grid;grid-template-columns:1fr 1fr;min-height:420px}
.coll:nth-child(even) .coll-art{order:2}
.coll-art{display:grid;place-items:center;font-size:9rem;position:relative;overflow:hidden}
.coll-txt{display:grid;align-content:center;padding:70px}
.coll-txt .vname{font-size:clamp(2rem,4vw,3rem);font-family:var(--serif)}
.coll-txt .vth{font-family:var(--serif-th);color:var(--gold);font-size:1.65rem;font-weight:500;letter-spacing:.03em;margin-bottom:6px}
.coll-meta{display:flex;margin-top:20px;flex-wrap:wrap}
.coll-meta b{font-family:var(--serif-th);font-size:1.3rem;display:block}
.coll-meta small{font-family:var(--serif-th);font-size:.98rem;letter-spacing:.02em;opacity:.85;display:block;margin-bottom:2px}
.coll-meta>div{padding:0 28px}
.coll-meta>div:first-child{padding-left:0}
.coll-meta>div+div{border-left:1px solid rgba(200,162,75,.5)}
@media(max-width:560px){
  .coll-txt{padding:32px 20px}
  .coll-meta{flex-wrap:nowrap}
  .coll-meta>div{padding:0 9px}
  .coll-meta b{font-size:1rem}
  .coll-meta small{font-size:.68rem;white-space:nowrap}
  .coll-cta{justify-content:center}
}

/* กล่องสถิติ: 3 ช่องบนจอใหญ่ · 2 ช่องบนมือถือ (ไม่ให้ตัวหนังสือเบียด) */
.statbox-grid{grid-template-columns:repeat(3,1fr)}
@media(max-width:600px){.statbox-grid{grid-template-columns:repeat(2,1fr)}}

/* GI / GAP certifications */
.cert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:22px;max-width:880px;margin:0 auto}
.cert-card{position:relative;border:1px solid var(--line);border-radius:18px;padding:34px 30px 30px;background:linear-gradient(165deg,rgba(200,162,75,.07),rgba(255,255,255,.02));display:flex;flex-direction:column;align-items:center;text-align:center;gap:13px;transition:.4s var(--ease)}
.cert-card:hover{transform:translateY(-6px);border-color:var(--gold)}
.cert-seal{width:116px;height:116px;filter:drop-shadow(0 7px 16px rgba(0,0,0,.5));transition:transform .4s var(--ease)}
.cert-card:hover .cert-seal{transform:rotate(-4deg) scale(1.04)}
.cert-seal-svg{width:100%;height:100%;display:block}
.cert-logo{border-radius:50%;background:radial-gradient(circle at 50% 40%,#fffdf7,#f1ead9);border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 7px 16px rgba(0,0,0,.5),inset 0 0 14px rgba(160,124,54,.16)}
.cert-logo img{width:88%;height:88%;object-fit:contain;transition:transform .3s var(--ease)}
.cert-card h3{font-family:var(--serif-th);font-size:1.28rem;font-weight:600;color:var(--gold-soft);margin:2px 0 0;line-height:1.35}
.cert-card p{font-size:.96rem;line-height:1.7;opacity:.84;margin:0;max-width:34ch}
.cert-view-btn{margin-top:6px;display:inline-flex;align-items:center;gap:7px;padding:10px 22px;border:1px solid var(--gold);border-radius:999px;background:transparent;color:var(--gold-soft);font-family:var(--serif-th);font-size:.95rem;letter-spacing:.02em;cursor:pointer;transition:.3s var(--ease)}
.cert-view-btn:hover{background:var(--gold);color:#1a1709}
.cvb-ic{width:16px;height:16px;flex:none;display:block}
.cert-modal{position:fixed;inset:0;z-index:200;background:rgba(8,8,5,.88);display:flex;align-items:center;justify-content:center;padding:28px;backdrop-filter:blur(4px);overscroll-behavior:contain}
.modal,.drawer{overscroll-behavior:contain}
.cert-modal-inner{position:relative;max-width:760px;width:100%;max-height:90vh;display:flex;flex-direction:column;align-items:center}
.cert-modal-inner img{max-width:100%;max-height:80vh;border-radius:12px;border:1px solid rgba(200,162,75,.4);box-shadow:0 30px 70px rgba(0,0,0,.6);object-fit:contain}
.cert-modal-cap{margin-top:14px;font-family:var(--serif-th);font-size:1.05rem;color:var(--gold-soft);text-align:center}
.cert-modal-x{position:absolute;top:-44px;right:0;width:38px;height:38px;border-radius:50%;border:1px solid rgba(200,162,75,.5);background:rgba(0,0,0,.4);color:var(--gold-soft);font-size:1rem;cursor:pointer;transition:.3s var(--ease)}
.cert-modal-x:hover{background:var(--gold);color:#1a1709}

.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px}
.tier{border:1px solid var(--line);border-radius:3px;padding:40px 32px;background:rgba(216,190,131,.03);transition:.4s var(--ease)}
.tier:hover{transform:translateY(-8px);border-color:var(--gold)}
.tier .tn{font-family:var(--serif);font-size:1.7rem;letter-spacing:.16em}
.tier .tp{font-family:var(--serif-th);font-size:.88rem;letter-spacing:.04em;opacity:.65;margin:6px 0 22px}
.tier ul{list-style:none}
.tier li{font-size:1rem;padding:9px 0;border-bottom:1px solid var(--line-dark);opacity:.88}
.tier.black{background:linear-gradient(180deg,#16160f,#0c0c08);border-color:var(--gold)}
.tier .mark{color:var(--gold);margin-right:8px}

.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px}
.res-card{border:1px solid var(--line);border-radius:3px;padding:42px 32px;text-align:center;transition:.4s var(--ease);cursor:pointer}
.res-card:hover{transform:translateY(-8px);border-color:var(--gold)}
.res-card .ic{font-size:2rem;color:var(--gold)}
.res-card h3{font-size:1.5rem;margin:14px 0 8px;font-family:var(--serif)}
.res-card p{opacity:.72;font-size:.98rem}

.jgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:54px}
.jcard{cursor:pointer}
.jcard .jart{height:230px;border-radius:3px;overflow:hidden;position:relative;margin-bottom:16px}
.jcard .tag{font-family:var(--serif-th);font-size:.8rem;letter-spacing:.04em;color:#9a7d2e}
.jcard h3{font-size:1.45rem;margin:8px 0;transition:.3s;font-family:var(--serif)}
.jcard:hover h3{color:#9a7d2e}
.jcard p{opacity:.72;font-size:.98rem}

footer{background:var(--ink);border-top:1px solid var(--line-dark);padding:24px 0 18px;text-align:center}
footer .brand{font-size:1.8rem;color:#fff;display:inline-block;letter-spacing:.04em}
.foot-links{display:flex;gap:30px;justify-content:center;flex-wrap:wrap;margin:34px 0}
.foot-links a{font-family:var(--serif-th);font-size:.98rem;letter-spacing:.04em;opacity:.75}
.foot-links a:hover{color:var(--gold);opacity:1}
.foot-bottom{font-family:var(--sans);font-size:.7rem;letter-spacing:.1em;opacity:.4;margin-top:30px}
.foot-contact{display:flex;gap:13px 28px;justify-content:center;flex-wrap:wrap;margin:30px auto 6px;max-width:780px}
.fc-item{display:inline-flex;align-items:center;gap:9px;font-family:var(--serif-th);font-size:.96rem;letter-spacing:.02em;color:var(--gold-soft);opacity:.9;transition:.25s}
a.fc-item:hover{opacity:1;color:#fff}
.fc-item svg{flex:none;color:var(--gold)}
.fc-sep{width:140px;height:1px;margin:8px auto 0;background:linear-gradient(90deg,transparent,rgba(200,162,75,.5),transparent)}
.fab-wrap{position:fixed;right:22px;bottom:22px;z-index:280;display:flex;flex-direction:column;align-items:flex-end;gap:13px}
.fab-menu{display:flex;flex-direction:column;align-items:flex-end;gap:11px;opacity:0;pointer-events:none;transform:translateY(10px) scale(.96);transform-origin:bottom right;transition:.26s var(--ease)}
.fab-menu.open{opacity:1;pointer-events:auto;transform:none}
.fab-item{display:inline-flex;align-items:center;gap:9px;background:var(--c,#06C755);color:#fff;border-radius:999px;padding:10px 17px 10px 14px;font-family:var(--serif-th);font-size:.95rem;box-shadow:0 8px 22px rgba(0,0,0,.45);white-space:nowrap;transition:.2s}
.fab-item:hover{transform:translateX(-3px);filter:brightness(1.08)}
.fab-item svg{width:19px;height:19px;flex:none}
.line-float{position:relative;width:58px;height:58px;border-radius:50%;background:#06C755;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(6,199,85,.45),0 4px 12px rgba(0,0,0,.3);transition:.3s;color:#fff;border:none;cursor:pointer;align-self:flex-end}
.line-float:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 16px 40px rgba(6,199,85,.55)}
.line-float svg{width:31px;height:31px;position:relative;z-index:1;transition:transform .3s}
.fab-wrap.open .line-float svg{transform:rotate(90deg)}
.line-float .lf-pulse{position:absolute;inset:0;border-radius:50%;border:2px solid #06C755;animation:lfp 2.4s ease-out infinite;pointer-events:none}
.fab-wrap.open .line-float .lf-pulse{display:none}
@keyframes lfp{0%{transform:scale(1);opacity:.65}100%{transform:scale(1.7);opacity:0}}
@media(max-width:560px){.fab-wrap{right:16px;bottom:16px}.line-float{width:52px;height:52px}.line-float svg{width:28px;height:28px}.foot-contact{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 14px;max-width:380px;margin:24px auto 6px}footer .brand{font-size:1.25rem;line-height:1.3}.fc-item{font-size:.74rem;gap:5px;white-space:nowrap}.fc-item svg{width:13px;height:13px}}

.drawer-mask{position:fixed;inset:0;z-index:210;background:rgba(8,8,6,.6);backdrop-filter:blur(5px);display:none;opacity:0;transition:.4s}
.drawer-mask.open{display:block;opacity:1}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,94vw);z-index:211;background:#181610;color:var(--paper);border-left:1px solid var(--gold);box-shadow:-20px 0 60px rgba(0,0,0,.4);transform:translateX(105%);transition:transform .45s var(--ease);display:flex;flex-direction:column}
.drawer.open{transform:none}
.drawer-h{padding:26px 28px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.drawer-h b{font-family:var(--serif-th);font-size:1.4rem;font-weight:500}
.drawer-h .x{cursor:pointer;font-size:1.2rem;background:none;border:none;color:var(--paper);opacity:.6}
.drawer-b{flex:1;overflow:auto;padding:14px 28px}
.drawer-f{padding:22px 28px;border-top:1px solid var(--line)}
.cart-item{display:flex;gap:14px;align-items:center;padding:16px 0;border-bottom:1px solid var(--line)}
.cart-item .ci-thumb{width:52px;height:52px;border-radius:6px;display:grid;place-items:center;font-size:1.7rem;flex:none}
.cart-item .ci-info{flex:1;min-width:0}
.cart-item h4{font-family:var(--serif);font-size:1.1rem;font-weight:500}
html[lang="th"] .cart-item h4{font-family:var(--serif-th)}
.cart-item .ci-sub{font-family:var(--serif-th);font-size:.84rem;opacity:.6}
.qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;overflow:hidden;margin-top:6px}
.qty button{width:28px;height:28px;border:none;background:transparent;color:var(--gold-soft);cursor:pointer;font-size:1.05rem;line-height:1}
.qty span{min-width:30px;text-align:center;font-family:var(--serif-th);font-size:.95rem}
.ci-price{font-family:var(--serif-th);font-weight:500;white-space:nowrap}
.cart-empty{text-align:center;opacity:.55;font-family:var(--serif-th);padding:60px 0}
.cart-total{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px;font-family:var(--serif-th)}
.cart-total b{font-size:1.5rem;color:var(--gold-soft)}

.mask{position:fixed;inset:0;z-index:300;background:rgba(8,8,6,.8);backdrop-filter:blur(8px);display:none;flex-direction:column;align-items:center;justify-content:center;padding:24px;opacity:0;transition:.4s}
.mask.open{display:flex;opacity:1}
.modal{width:100%;max-width:560px;background:#181610;color:var(--paper);border-radius:18px;border:1px solid var(--gold);max-height:88vh;overflow:auto;transform:translateY(20px);transition:.4s var(--ease);scrollbar-width:thin;scrollbar-color:var(--gold) transparent}
.modal::-webkit-scrollbar{width:11px}
.modal::-webkit-scrollbar-track{background:transparent;margin:10px 0}
.modal::-webkit-scrollbar-thumb{background:var(--gold);border-radius:10px;border:3px solid transparent;background-clip:padding-box}
.modal::-webkit-scrollbar-thumb:hover{background:var(--gold-soft);border:2px solid transparent;background-clip:padding-box}
.mask.open .modal{transform:none}
.modal-h{padding:28px 34px 0;display:flex;justify-content:space-between;align-items:flex-start}
.modal-h h3{font-size:1.7rem;font-family:var(--serif-th)}
.modal-h .x{cursor:pointer;font-size:1.3rem;background:none;border:none;color:var(--paper);opacity:.6}
.modal-b{padding:18px 34px 32px}
.modal-b .lede{font-size:1.05rem}
.field{margin:14px 0}
.field label{font-family:var(--serif-th);font-size:.84rem;letter-spacing:.04em;opacity:.7;display:block;margin-bottom:7px}
.field input,.field select{width:100%;padding:13px 15px;border:1px solid var(--line);background:#100f0a;color:var(--paper);font-family:var(--serif-th);border-radius:11px}
.modal ::placeholder{color:rgba(244,239,230,.4)}
.modal-b input:focus,.modal-b select:focus,.modal-b textarea:focus,.field input:focus,.field select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(200,162,75,.18)}
.steps{display:flex;gap:8px;margin-bottom:14px}
.steps i{flex:1;height:2px;background:var(--line);border-radius:2px}
.steps i.on{background:var(--gold)}
.modal .btn{color:var(--ink)}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}

@media(max-width:900px){
  .split,.sig,.coll{grid-template-columns:1fr;gap:34px}
  .coll{min-height:0}
  .coll:nth-child(even) .coll-art{order:0}
  .coll-art{min-height:280px;font-size:7rem}
  .coll-txt{padding:44px 32px}
  .craft{grid-template-columns:1fr 1fr}
  .tiers,.res-grid,.jgrid{grid-template-columns:1fr}
  .scene,.viewer{height:300px}
  .viewer .durian{font-size:8rem}
  .sig-stats{gap:26px}
}
/* iPad / แท็บเล็ตแนวตั้ง — เพิ่มขนาด คงลำดับ Kan Yao > ก้านยาว > แถวการจอง */
@media(min-width:681px) and (max-width:900px){
  .coll-txt .vname{font-size:2.7rem}
  .coll-txt .vth{font-size:1.95rem;margin-bottom:8px}
  .coll-meta b{font-size:1.55rem}
  .coll-meta small{font-size:1.12rem;margin-bottom:3px}
}
@media(max-width:680px){
  .menu-btn{display:grid;place-items:center}
  .nav-links{display:none;position:absolute;top:58px;right:0;left:auto;width:min(74vw,260px);flex-direction:column;align-items:stretch;gap:5px;background:#16160F;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:13px 15px;box-shadow:0 22px 50px rgba(0,0,0,.55);z-index:130}
  .nav-links.open{display:flex}
  .nav-links a{min-height:40px;width:100%;white-space:nowrap}
  nav{padding:12px 16px}
  .brand{font-size:1.08rem;letter-spacing:.18em}
  .wrap{padding:0 20px}
  .chapter{padding:74px 0}
  .craft{grid-template-columns:1fr}
  .kahn{font-size:clamp(1.7rem,7vw,2.4rem)}
  .coll{gap:0;scroll-snap-align:center}
  html{scroll-snap-type:y proximity;scroll-padding-top:56px}
  .coll-art{min-height:208px}
  .coll-txt{padding:14px 22px 34px;align-content:start;text-align:center;justify-items:center}
  .coll-txt .vth{margin-top:0}
  .coll-meta{justify-content:center}
  .coll-txt .vname::after{content:"";display:block;width:34px;height:1px;background:var(--gold);margin:12px auto 0}
}

/* account dropdown menu */
.nav-right{position:relative}
.acct-menu{position:absolute;top:calc(100% + 12px);right:0;width:340px;max-width:88vw;max-height:74vh;overflow:auto;background:#16160F;color:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:0 26px 64px rgba(0,0,0,.62);padding:18px 18px 16px;display:none;z-index:200}
.acct-menu.open{display:block}
.acct-menu .lede{color:var(--paper)}

/* slip file picker — make it clearly visible */
#slipFile{display:block;width:100%;padding:11px 13px;border:1px solid rgba(200,162,75,.5);border-radius:12px;background:#e8dcc0;color:#7a5a10;cursor:pointer;font-family:var(--serif-th);font-size:.9rem;transition:.2s}
#slipFile:hover{border-color:var(--gold)}
#slipFile::file-selector-button{font-family:var(--serif-th);font-weight:500;background:#7a5a10;color:#f3e6c8;border:none;padding:9px 18px;border-radius:9px;margin-right:14px;cursor:pointer;font-size:.9rem;transition:.2s}
#slipFile::file-selector-button:hover{filter:brightness(1.12)}
#slipFile::-webkit-file-upload-button{font-family:var(--serif-th);font-weight:500;background:#7a5a10;color:#f3e6c8;border:none;padding:9px 18px;border-radius:9px;margin-right:14px;cursor:pointer;font-size:.9rem}

/* nav icon buttons */
.lang svg{color:var(--gold-soft);transition:.3s}
.lang:hover svg{color:var(--gold)}
.cart-btn svg,.cart-btn:hover svg{color:var(--gold-soft)}

/* clear separation: order CTA becomes its own full-width band */
#collList .coll:last-child .coll-art::after{content:"";position:absolute;left:0;right:0;bottom:0;height:64%;background:linear-gradient(180deg,transparent,var(--ink));pointer-events:none;z-index:2}
.order-band{position:relative;background:linear-gradient(180deg,#100f0b,#0a0a07);border-top:1px solid rgba(200,162,75,.32);box-shadow:inset 0 34px 64px -36px rgba(0,0,0,.95);padding:72px 0 80px;margin-top:2px}
.order-band::before{content:"";position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:120px;height:3px;border-radius:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
#order{position:relative}

#aboutLangBtn{display:none}
@media(max-width:900px){
  #aboutLangBtn{display:inline-flex}
  #aboutSplit.about-th #aboutColEn{display:none}
  #aboutSplit.about-en #aboutColTh{display:none}
}

@media(max-width:560px){
  #siteAboutBox, #aboutColEn > div{ margin-left:-20px; margin-right:-20px; border-radius:0 }
}
