
:root{
  --paper:#efe8d6;--paper-2:#e7dfca;--paper-3:#ddd3b7;
  --ink:#15130f;--ink-2:#2b2620;--muted:#6f675b;
  --line:#2a2620;--line-soft:#15130f1a;
  --forest:#1c3a2e;--forest-2:#244a3b;--moss:#b9c8a7;
  --clay:#c66a35;--clay-2:#a8541f;--clay-3:#e7a276;
  --cream:#f7f1df;--bubble:#d8e2c8;
  --green:#3aaa6c;--green-2:#108a4d;--green-soft:#dee9d3;
  --amber:#f1e1a8;--amber-deep:#6a4f12;
  --rose:#f3d7c5;--rose-deep:#a8541f;
  --plum:#5b3a4a;--plum-soft:#e8d5dc;
  --gold:#b08a3e;--gold-soft:#f0e3c0;
  --shadow:0 1px 0 #00000010,0 14px 30px -18px #14110e35;
  --serif:"Fraunces","Times New Roman",serif;
  --sans:"DM Sans",-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1000;opacity:.18;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.08 0 0 0 0 0.07 0 0 0 0 0.06 0 0 0 0.10 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
button{font:inherit;color:inherit;border:0;background:none;cursor:pointer}
.wrap{max-width:1320px;margin:0 auto;padding:0 32px;position:relative}
@media (max-width:680px){.wrap{padding:0 20px}}

.btn{display:inline-flex;align-items:center;gap:10px;height:46px;padding:0 22px;border-radius:999px;border:1px solid var(--ink);font-family:var(--sans);font-size:14.5px;font-weight:500;background:var(--ink);color:var(--paper);transition:transform .25s ease,background .25s ease}
.btn:hover{transform:translateY(-1px);background:var(--forest);border-color:var(--forest)}
.btn .arrow{display:inline-block;transition:transform .25s ease}
.btn:hover .arrow{transform:translate(3px,-3px)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}
.btn.clay{background:var(--clay);border-color:var(--clay);color:#fff8ee}
.btn.clay:hover{background:var(--clay-2);border-color:var(--clay-2)}
.btn.wa{background:var(--green-2);border-color:var(--green-2);color:#fff}
.btn.wa:hover{background:#0d6d3d;border-color:#0d6d3d}

.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:10px}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--clay);display:inline-block;box-shadow:0 0 0 4px #c66a3520}
.eyebrow.green .dot{background:var(--green);box-shadow:0 0 0 4px #3aaa6c20;animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}

/* =========== top bar =========== */
.bar{position:sticky;top:0;z-index:90;background:color-mix(in oklab,var(--paper) 85%,transparent);backdrop-filter:blur(10px) saturate(1.1);-webkit-backdrop-filter:blur(10px) saturate(1.1);border-bottom:1px solid var(--line-soft)}
.bar-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:22px;font-weight:420;letter-spacing:-.02em}
.brand .glyph{width:30px;height:30px;border-radius:8px;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-family:var(--mono);font-size:13px;font-weight:500;position:relative;overflow:hidden}
.brand .glyph::after{content:"";position:absolute;left:6px;bottom:-4px;width:8px;height:8px;background:var(--ink);transform:rotate(45deg)}
.nav{display:flex; gap:30px; font-size:14px; align-items:center}
.nav > .nav-item{position:relative}
.nav a, .nav button.nav-trigger{color:var(--ink-2); position:relative; background:none; border:0; padding:0; cursor:pointer; font:inherit; display:inline-flex; align-items:center; gap:6px}
.nav a:hover, .nav button.nav-trigger:hover, .nav-item:hover > .nav-trigger{color:var(--ink)}
.nav a::after, .nav button.nav-trigger::after{content:""; position:absolute; left:0; right:100%; bottom:-6px; height:1px; background:var(--ink); transition:right .3s ease}
.nav a:hover::after, .nav-item:hover > .nav-trigger::after{right:0}
.nav-trigger .caret{width:8px; height:8px; border-right:1.2px solid currentColor; border-bottom:1.2px solid currentColor; transform:rotate(45deg); margin-top:-3px; transition:transform .25s ease; opacity:.7}
.nav-item:hover .caret{transform:rotate(225deg); margin-top:2px}
.mega{position:absolute; left:50%; top:calc(100% + 18px); transform:translate(-50%, -6px); background:var(--cream); border:1px solid var(--line-soft); border-radius:18px; box-shadow:0 1px 0 #00000010, 0 30px 60px -28px #14110e40; padding:28px 30px 26px; min-width:600px; opacity:0; pointer-events:none; visibility:hidden; transition:opacity .25s ease, transform .25s ease, visibility .25s; z-index:80}
.nav-item:hover .mega, .nav-item:focus-within .mega{opacity:1; pointer-events:auto; visibility:visible; transform:translate(-50%, 0)}
.nav-item .mega::before{content:""; position:absolute; left:0; right:0; top:-18px; height:18px}
.mega-grid{display:grid; grid-template-columns: 1.4fr 1fr; gap:36px}
.mega-col h4{font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin:0 0 14px; font-weight:500; padding-bottom:10px; border-bottom:1px solid var(--line-soft)}
.mega-col ul{list-style:none; margin:0; padding:0; display:grid; gap:2px}
.mega-col.two-col ul{grid-template-columns:1fr 1fr; gap:2px 18px}
.mega-col a{display:block; padding:7px 10px; margin:0 -10px; border-radius:8px; font-size:14px; color:var(--ink-2); transition:background .15s ease, color .15s ease}
.mega-col a:hover{background:#efe7d0; color:var(--ink)}
.mega-col a.is-active{background:#efe7d0; color:var(--ink); font-weight:500}
.mega-col a::after{display:none}
.mega-foot{margin-top:22px; padding-top:18px; border-top:1px solid var(--line-soft); display:flex; justify-content:space-between; align-items:center; font-family:var(--mono); font-size:11px; color:var(--muted)}
.mega-foot a{font-family:var(--sans); font-size:13px; color:var(--clay); display:inline-flex; gap:6px; align-items:center}
.mega-foot a::after{display:none}
.dd{position:absolute; left:50%; top:calc(100% + 18px); transform:translate(-50%, -6px); background:var(--cream); border:1px solid var(--line-soft); border-radius:14px; box-shadow:0 1px 0 #00000010, 0 24px 50px -28px #14110e40; padding:10px; min-width:200px; opacity:0; pointer-events:none; visibility:hidden; transition:opacity .2s ease, transform .2s ease, visibility .2s; z-index:80}
.nav-item:hover .dd, .nav-item:focus-within .dd{opacity:1; pointer-events:auto; visibility:visible; transform:translate(-50%, 0)}
.nav-item .dd::before{content:""; position:absolute; left:0; right:0; top:-18px; height:18px}
.dd ul{list-style:none; margin:0; padding:0}
.dd a{display:block; padding:9px 12px; border-radius:8px; font-size:14px; color:var(--ink-2)}
.dd a:hover{background:#efe7d0; color:var(--ink)}
.dd a::after{display:none}
.bar-cta{display:flex;align-items:center;gap:14px}
.bar-cta .live{font-family:var(--mono);font-size:11px;color:var(--muted);display:flex;align-items:center;gap:8px}
.bar-cta .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px #3aaa6c20;animation:pulse 2s infinite}
.menu-toggle{display:none; width:42px; height:42px; border:1px solid var(--line-soft); border-radius:10px; background:transparent; align-items:center; justify-content:center; padding:0}
.menu-toggle span{display:block; width:18px; height:1.4px; background:var(--ink); position:relative}
.menu-toggle span::before, .menu-toggle span::after{content:""; position:absolute; left:0; right:0; height:1.4px; background:var(--ink)}
.menu-toggle span::before{top:-6px}
.menu-toggle span::after{top:6px}
@media (max-width:1080px){.nav,.bar-cta .live{display:none} .menu-toggle{display:inline-flex}}

/* ---------- Contextual sub-bar ---------- */
.subbar{position:sticky; top:72px; z-index:85; background:color-mix(in oklab, var(--paper) 92%, transparent); backdrop-filter:blur(10px) saturate(1.1); -webkit-backdrop-filter:blur(10px) saturate(1.1); border-bottom:1px solid var(--line-soft)}
.subbar-inner{display:flex; align-items:center; gap:0; height:46px; overflow-x:auto; scrollbar-width:none}
.subbar-inner::-webkit-scrollbar{display:none}
.subbar-section{font-family:var(--mono); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); display:inline-flex; align-items:center; gap:8px; padding-right:22px; margin-right:22px; border-right:1px solid var(--line-soft); white-space:nowrap; flex-shrink:0}
.subbar-section .dot{width:5px; height:5px; border-radius:50%; background:var(--clay)}
.subbar-links{display:flex; gap:4px; align-items:center; flex:1; min-width:0}
.subbar-links a{font-size:13px; color:var(--ink-2); padding:8px 14px; border-radius:8px; position:relative; white-space:nowrap; transition:background .15s ease, color .15s ease}
.subbar-links a:hover{background:#efe7d0; color:var(--ink)}
.subbar-links a.is-active{color:var(--ink); font-weight:500; background:transparent}
.subbar-links a.is-active::after{content:""; position:absolute; left:14px; right:14px; bottom:2px; height:1.5px; background:var(--clay)}
.subbar-tail{margin-left:auto; padding-left:22px; border-left:1px solid var(--line-soft); font-family:var(--mono); font-size:11px; color:var(--muted); display:flex; align-items:center; gap:6px; white-space:nowrap; flex-shrink:0}
.subbar-tail a{color:var(--clay); font-family:var(--sans); font-size:13px}
.subbar-tail a:hover{text-decoration:underline}
@media (max-width:900px){.subbar-section{padding-right:14px; margin-right:14px} .subbar-tail{display:none}}

/* =========== HERO =========== */
.hero{padding:30px 0 100px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
@media (max-width:1020px){.hero-grid{grid-template-columns:1fr;gap:50px}}
.hero-meta{display:flex;gap:20px;align-items:center;margin:46px 0 30px;flex-wrap:wrap}
.hero h1{font-family:var(--serif);font-weight:340;font-variation-settings:"opsz" 144,"SOFT" 50;font-size:clamp(54px,8vw,118px);letter-spacing:-.025em;line-height:.92;margin:0 0 30px;color:var(--ink)}
.hero h1 .l{display:block}
.hero h1 em{font-style:italic;font-weight:340;font-variation-settings:"opsz" 144,"SOFT" 100;color:var(--clay)}
.hero h1 .gn{font-style:italic;color:var(--forest);font-variation-settings:"opsz" 144,"SOFT" 100}
.hero h1 .pl{font-style:italic;color:var(--plum);font-variation-settings:"opsz" 144,"SOFT" 100}
.hero-sub{font-size:19px;max-width:560px;color:var(--ink-2);line-height:1.5;margin:0 0 36px}
.hero-sub b{color:var(--ink);font-weight:500}
.hero-sub em{font-style:italic;color:var(--clay);font-family:var(--serif);font-variation-settings:"opsz" 144,"SOFT" 100}
.hero-cta{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.ticker{margin-top:54px;padding-top:22px;border-top:1px solid var(--line-soft);display:flex;gap:36px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--muted)}
.ticker b{color:var(--ink);font-weight:500}

/* hero artwork: digital menu + KDS dual mockup */
.hero-art{position:relative;display:flex;justify-content:center;align-items:center;min-height:680px}
.menu-card{position:relative;width:340px;background:#fff8ee;border:1px solid var(--ink);border-radius:18px;padding:22px;box-shadow:14px 14px 0 0 var(--ink);z-index:3}
.menu-card .mc-h{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:16px;border-bottom:1px solid var(--line-soft);margin-bottom:16px}
.menu-card .mc-name{font-family:var(--serif);font-weight:300;font-style:italic;font-size:28px;line-height:1;letter-spacing:-.02em;color:var(--ink);font-variation-settings:"opsz" 144,"SOFT" 100}
.menu-card .mc-tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:5px}
.menu-card .table-pill{font-family:var(--mono);font-size:10px;letter-spacing:.1em;background:var(--ink);color:var(--paper);padding:5px 10px;border-radius:999px;flex-shrink:0}
.menu-section{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--clay);margin:18px 0 10px;display:flex;align-items:center;gap:10px}
.menu-section::after{content:"";flex:1;height:1px;background:var(--line-soft)}
.menu-section:first-child{margin-top:0}
.menu-item{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px dashed var(--line-soft)}
.menu-item:last-of-type{border-bottom:0}
.menu-item .it-name{font-family:var(--serif);font-style:italic;font-weight:380;font-size:15px;letter-spacing:-.005em;line-height:1.2}
.menu-item .it-name small{display:block;font-style:normal;font-family:var(--sans);font-size:11px;color:var(--muted);margin-top:2px;line-height:1.35}
.menu-item .pr{font-family:var(--mono);font-size:12px;color:var(--ink);flex-shrink:0;white-space:nowrap}
.menu-item.active{background:#f3d7c540;margin:0 -14px;padding:9px 14px;border-radius:8px;border-bottom:1px solid #e2bb9f}
.menu-item.active .pr{color:var(--clay-2);font-weight:500}
.menu-foot{margin-top:18px;padding-top:14px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10.5px;color:var(--muted)}
.menu-foot .ord{background:var(--clay);color:#fff8ee;padding:8px 14px;border-radius:999px;font-weight:500;letter-spacing:.06em;text-transform:uppercase}

/* arrow line */
.flow-line{position:absolute;width:120px;height:60px;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;pointer-events:none}
@media (max-width:1100px){.flow-line{display:none}}

/* KDS ticket */
.kds-ticket{position:absolute;right:-20px;bottom:30px;width:280px;background:var(--ink);color:var(--paper);border-radius:14px;padding:18px 18px 16px;box-shadow:0 24px 50px -20px #14110e60;z-index:4;border:1px solid var(--clay-3)}
.kds-h{display:flex;justify-content:space-between;align-items:center;padding-bottom:12px;border-bottom:1px dashed #ffffff20;margin-bottom:12px}
.kds-h .tk{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;color:var(--clay-3);text-transform:uppercase}
.kds-h .clock{font-family:var(--serif);font-style:italic;font-weight:340;font-size:16px;color:var(--cream);font-variation-settings:"opsz" 144,"SOFT" 100}
.kds-tbl{font-family:var(--serif);font-style:italic;font-weight:380;font-size:18px;letter-spacing:-.005em;color:var(--cream);margin-bottom:14px}
.kds-tbl small{display:block;font-style:normal;font-family:var(--mono);font-size:9.5px;color:#a8c2b6;margin-top:2px;letter-spacing:.06em;text-transform:uppercase}
.kds-list{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.kds-row{display:flex;gap:8px;align-items:flex-start;font-family:var(--mono);font-size:11px;color:#cce0d6;padding:5px 0;border-bottom:1px dashed #ffffff15}
.kds-row:last-child{border-bottom:0}
.kds-row .qty{font-weight:500;color:var(--clay-3);width:22px;flex-shrink:0}
.kds-row .nm{flex:1;line-height:1.35}
.kds-row .nm em{color:#7d9088;font-style:normal;display:block;font-size:9.5px;margin-top:1px;letter-spacing:.04em;text-transform:uppercase}
.kds-status{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase}
.kds-status .st{padding:3px 9px;border-radius:999px;background:var(--clay);color:#fff8ee;font-weight:500;animation:pulse 1.8s infinite}
.kds-status .by{color:#a8c2b6}

/* hero floating chips */
.hero-chip{position:absolute;background:var(--paper);border:1px solid var(--ink);border-radius:14px;padding:14px 16px;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);box-shadow:6px 6px 0 0 var(--ink);z-index:5;max-width:165px}
.hero-chip b{color:var(--ink);font-family:var(--serif);font-style:italic;font-weight:380;font-size:18px;letter-spacing:-.005em;display:block;text-transform:none;margin-bottom:2px;font-variation-settings:"opsz" 144,"SOFT" 100}
.hero-chip.tl{top:0;left:-30px}
.hero-chip.tr{top:30px;right:-10px}
.hero-chip.bl{bottom:60px;left:-40px}
@media (max-width:1100px){.hero-chip{display:none}}

/* =========== marquee =========== */
.marquee{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);background:var(--paper-2);overflow:hidden;padding:30px 0}
.marquee-head{display:flex;justify-content:space-between;align-items:baseline;padding:0 32px 14px;max-width:1320px;margin:0 auto;flex-wrap:wrap;gap:12px}
.marquee-head .label{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--muted)}
.marquee-head .count{font-family:var(--serif);font-size:30px;font-style:italic;font-weight:340;font-variation-settings:"opsz" 144,"SOFT" 100}
.marquee-head .count em{color:var(--clay)}
.track{display:flex;gap:64px;width:max-content;animation:scroll 40s linear infinite;align-items:center}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.track .logo{font-family:var(--serif);font-weight:380;font-size:24px;letter-spacing:.02em;color:var(--ink);opacity:.8;white-space:nowrap;display:flex;align-items:center;gap:14px}
.track .logo .sep{width:6px;height:6px;background:var(--clay);border-radius:50%}
.track .logo small{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* =========== sections =========== */
.section{padding:120px 0;position:relative}
.section.dark{background:var(--ink);color:var(--paper)}
.section.dark .eyebrow{color:#bbb1a0}
.section.forest{background:var(--forest);color:var(--cream)}
.section.forest .eyebrow{color:#a8c2b6}
.section.cream{background:var(--paper-2)}
.section.plum{background:var(--plum);color:var(--cream)}

.sec-head{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:end;margin-bottom:64px}
@media (max-width:880px){.sec-head{grid-template-columns:1fr;gap:24px}}
.sec-head .num{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.section.dark .sec-head .num,.section.forest .sec-head .num,.section.plum .sec-head .num{color:#bbb1a0}
.sec-head h2{font-family:var(--serif);font-weight:340;font-size:clamp(40px,5.6vw,72px);letter-spacing:-.02em;line-height:.96;margin:0;font-variation-settings:"opsz" 144,"SOFT" 50}
.sec-head h2 em{font-style:italic;color:var(--clay);font-variation-settings:"opsz" 144,"SOFT" 100}
.section.dark .sec-head h2 em,.section.forest .sec-head h2 em,.section.plum .sec-head h2 em{color:var(--clay-3)}
.sec-head .deck{font-size:17.5px;color:var(--ink-2);line-height:1.5;margin-top:20px;max-width:600px}
.section.dark .sec-head .deck,.section.forest .sec-head .deck,.section.plum .sec-head .deck{color:#bbb1a0}

/* =========== Chapter 01 — 1M guests + three pillars =========== */
.million-row{display:grid;grid-template-columns:1fr 1.6fr;gap:60px;align-items:center;margin-bottom:80px}
@media (max-width:980px){.million-row{grid-template-columns:1fr;gap:40px}}
.million-num{font-family:var(--serif);font-weight:300;font-size:clamp(140px,22vw,260px);line-height:.85;letter-spacing:-.04em;color:var(--ink);font-variation-settings:"opsz" 144}
.million-num em{font-style:italic;color:var(--clay);font-variation-settings:"opsz" 144,"SOFT" 100}
.million-deck{font-family:var(--serif);font-weight:340;font-size:clamp(26px,3.4vw,40px);line-height:1.2;letter-spacing:-.012em;font-variation-settings:"opsz" 144,"SOFT" 50}
.million-deck em{font-style:italic;color:var(--clay);font-variation-settings:"opsz" 144,"SOFT" 100}
.million-tag{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:24px}

.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:880px){.pillars-grid{grid-template-columns:1fr}}
.pillar{background:var(--paper);border:1px solid var(--ink);border-radius:20px;padding:36px 32px;box-shadow:8px 8px 0 0 var(--ink);position:relative;display:flex;flex-direction:column;min-height:380px}
.pillar .pix{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;display:flex;align-items:center;gap:10px;margin-bottom:18px}
.pillar .pn{font-family:var(--serif);font-style:italic;font-weight:300;font-size:38px;line-height:.9;color:var(--clay);font-variation-settings:"opsz" 144,"SOFT" 100}
.pillar h3{font-family:var(--serif);font-weight:340;font-size:34px;letter-spacing:-.02em;line-height:1;margin:0 0 16px;font-variation-settings:"opsz" 144,"SOFT" 50}
.pillar h3 em{font-style:italic;color:var(--clay)}
.pillar .blurb{font-size:14.5px;color:var(--muted);line-height:1.5;margin:0 0 24px}
.pillar ul{list-style:none;padding:0;margin:0 0 auto;display:grid;gap:10px;font-size:14.5px}
.pillar ul li{padding-left:24px;position:relative;color:var(--ink-2);line-height:1.4;font-family:var(--serif);font-style:italic;font-weight:380;letter-spacing:-.005em}
.pillar ul li::before{content:"";position:absolute;left:0;top:11px;width:14px;height:1px;background:var(--clay)}
.pillar .pf{margin-top:24px;padding-top:18px;border-top:1px dashed var(--line-soft);font-family:var(--mono);font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}

/* =========== Chapter 02 — Digital menu (Scan. Order. Serve.) =========== */
.flow-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;align-items:center;position:relative}
@media (max-width:980px){.flow-3{grid-template-columns:1fr;gap:30px}}
.flow-step{background:var(--paper);border:1px solid var(--line-soft);border-radius:20px;padding:32px;min-height:520px;display:flex;flex-direction:column;position:relative;box-shadow:var(--shadow)}
.flow-step .fs-h{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}
.flow-step .fs-num{font-family:var(--serif);font-style:italic;font-weight:300;font-size:54px;line-height:.85;color:var(--clay);font-variation-settings:"opsz" 144,"SOFT" 100;letter-spacing:-.02em}
.flow-step .fs-tag{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:4px 10px;border:1px solid var(--line-soft);border-radius:999px}
.flow-step h4{font-family:var(--serif);font-weight:340;font-size:28px;letter-spacing:-.018em;line-height:1.05;margin:0 0 10px;font-variation-settings:"opsz" 144,"SOFT" 50}
.flow-step h4 em{font-style:italic;color:var(--clay);font-variation-settings:"opsz" 144,"SOFT" 100}
.flow-step p{font-size:14px;color:var(--muted);line-height:1.5;margin:0 0 20px}
.flow-step .visual{margin-top:auto;padding-top:14px;flex:1;display:flex;align-items:flex-end;justify-content:center}
.flow-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-family:var(--mono);font-size:14px;z-index:2}
.flow-arrow.a1{left:calc(33.33% - 20px)}
.flow-arrow.a2{left:calc(66.66% - 20px)}
@media (max-width:980px){.flow-arrow{display:none}}

/* QR scan visual */
.qrscene{width:100%;height:240px;background:linear-gradient(135deg,#f3ebd5,#e7dfca);border-radius:14px;border:1px solid var(--line-soft);position:relative;display:grid;place-items:center;overflow:hidden}
.qrscene::after{content:"";position:absolute;inset:0;background-image:linear-gradient(transparent 95%,#15130f08 95%),linear-gradient(90deg,transparent 95%,#15130f08 95%);background-size:24px 24px;pointer-events:none}
.qrcode{width:120px;height:120px;background:#fff;border:1.5px solid var(--ink);border-radius:8px;padding:8px;box-shadow:6px 6px 0 0 var(--ink);position:relative;z-index:2}
.qr-scan{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:160px;height:160px;border:2px solid var(--clay);border-radius:14px;z-index:3;animation:scanPulse 2.4s ease-in-out infinite}
@keyframes scanPulse{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.85}50%{transform:translate(-50%,-50%) scale(1.05);opacity:.5}}
.qr-corner{position:absolute;width:20px;height:20px;border:2px solid var(--clay)}
.qr-corner.tl{top:-2px;left:-2px;border-right:0;border-bottom:0}
.qr-corner.tr{top:-2px;right:-2px;border-left:0;border-bottom:0}
.qr-corner.bl{bottom:-2px;left:-2px;border-right:0;border-top:0}
.qr-corner.br{bottom:-2px;right:-2px;border-left:0;border-top:0}

/* mini menu visual */
.mini-menu{width:100%;background:#fff8ee;border:1px solid var(--line-soft);border-radius:14px;padding:18px;box-shadow:var(--shadow)}
.mini-menu .mh{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:1px solid var(--line-soft);margin-bottom:10px}
.mini-menu .mh .nm{font-family:var(--serif);font-style:italic;font-weight:340;font-size:18px;letter-spacing:-.01em;font-variation-settings:"opsz" 144,"SOFT" 100}
.mini-menu .mh .tb{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;background:var(--ink);color:var(--paper);padding:3px 8px;border-radius:999px}
.mini-menu .mi{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--line-soft);font-size:13px;align-items:center}
.mini-menu .mi:last-child{border-bottom:0}
.mini-menu .mi .it{font-family:var(--serif);font-style:italic;font-weight:380;letter-spacing:-.005em;flex:1}
.mini-menu .mi .pr{font-family:var(--mono);font-size:11.5px;color:var(--ink-2)}
.mini-menu .mi .add{width:20px;height:20px;border-radius:50%;background:var(--clay);color:#fff8ee;display:grid;place-items:center;font-size:14px;line-height:1;margin-left:8px}
.mini-menu .mi.added{background:var(--green-soft);margin:0 -10px;padding:8px 10px;border-radius:6px}
.mini-menu .mi.added .add{background:var(--green-2)}
.mini-menu .mfoot{margin-top:14px;padding-top:12px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;align-items:center}
.mini-menu .mfoot .total{font-family:var(--serif);font-weight:380;font-size:16px;font-style:italic;letter-spacing:-.005em}
.mini-menu .mfoot .ord-btn{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;background:var(--clay);color:#fff8ee;padding:6px 12px;border-radius:999px;font-weight:500}

/* mini KDS visual */
.mini-kds{width:100%;background:var(--ink);color:var(--paper);border-radius:14px;padding:18px;border:1px solid var(--clay-3);position:relative;overflow:hidden}
.mini-kds::after{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--clay) 30%,transparent);animation:scanline 3s linear infinite}
@keyframes scanline{from{transform:translateX(-100%)}to{transform:translateX(100%)}}
.mini-kds .kh{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:1px dashed #ffffff20;margin-bottom:10px}
.mini-kds .kh .id{font-family:var(--mono);font-size:10px;color:var(--clay-3);letter-spacing:.14em;text-transform:uppercase}
.mini-kds .kh .clk{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--cream);font-variation-settings:"opsz" 144,"SOFT" 100}
.mini-kds .ktbl{font-family:var(--serif);font-style:italic;font-weight:380;font-size:15px;letter-spacing:-.005em;color:var(--cream);margin-bottom:10px}
.mini-kds .kitem{display:flex;gap:8px;font-family:var(--mono);font-size:10.5px;color:#cce0d6;padding:5px 0;border-bottom:1px dashed #ffffff15;align-items:flex-start}
.mini-kds .kitem:last-of-type{border-bottom:0}
.mini-kds .kitem .qty{color:var(--clay-3);font-weight:500;width:18px;flex-shrink:0}
.mini-kds .kitem em{color:#7d9088;font-style:normal;display:block;font-size:9px;margin-top:1px;letter-spacing:.04em;text-transform:uppercase}
.mini-kds .kfoot{margin-top:10px;padding-top:10px;border-top:1px dashed #ffffff20;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:9.5px;color:#a8c2b6;letter-spacing:.06em}
.mini-kds .kfoot .fr{padding:3px 8px;background:var(--clay);color:#fff8ee;border-radius:999px;font-weight:500;text-transform:uppercase;animation:pulse 1.8s infinite}

/* =========== Chapter 03 — KDS Full =========== */
.kds-full{background:var(--ink);border-radius:24px;padding:40px;box-shadow:0 30px 80px -30px #14110e60;position:relative;overflow:hidden}
@media (max-width:880px){.kds-full{padding:24px}}
.kds-full::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--clay-3) 30%,var(--clay-3) 70%,transparent)}
.kds-h-full{display:flex;justify-content:space-between;align-items:center;padding-bottom:24px;border-bottom:1px solid #ffffff15;margin-bottom:24px;flex-wrap:wrap;gap:14px}
.kds-h-full .ti{font-family:var(--serif);font-style:italic;font-weight:340;font-size:28px;color:var(--cream);letter-spacing:-.005em;font-variation-settings:"opsz" 144,"SOFT" 100}
.kds-h-full .ti em{color:var(--clay-3)}
.kds-h-full .meta{font-family:var(--mono);font-size:11px;color:#a8c2b6;letter-spacing:.06em;display:flex;gap:14px;align-items:center}
.kds-h-full .meta .lv{display:flex;gap:6px;align-items:center;color:var(--green-soft)}
.kds-h-full .meta .lv::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px #3aaa6c25;animation:pulse 1.8s infinite}

.kds-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media (max-width:1100px){.kds-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.kds-grid{grid-template-columns:1fr}}
.kds-col{background:#ffffff05;border:1px solid #ffffff10;border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:10px;min-height:420px}
.kds-col-h{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:1px dashed #ffffff15;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase}
.kds-col-h .nm{color:var(--cream);font-weight:500}
.kds-col-h .ct{padding:2px 7px;border-radius:999px;background:#ffffff10;color:#a8c2b6}
.kds-col.incoming .nm{color:var(--clay-3)}
.kds-col.fire .nm{color:#f1c142}
.kds-col.plate .nm{color:var(--moss)}
.kds-col.ready .nm{color:var(--green-soft)}

.k-card{background:#1f1d18;border:1px solid #ffffff15;border-radius:10px;padding:12px}
.k-card.urgent{border-color:var(--clay);background:#c66a3520}
.k-card .kc-h{display:flex;justify-content:space-between;align-items:center;padding-bottom:8px;border-bottom:1px dashed #ffffff15;margin-bottom:8px}
.k-card .kc-tbl{font-family:var(--serif);font-style:italic;font-weight:380;font-size:14px;color:var(--cream);letter-spacing:-.005em}
.k-card .kc-tbl small{display:block;font-style:normal;font-family:var(--mono);font-size:8.5px;color:#7d9088;margin-top:1px;letter-spacing:.06em;text-transform:uppercase}
.k-card .kc-clk{font-family:var(--mono);font-size:10px;color:#a8c2b6;letter-spacing:.06em}
.k-card.urgent .kc-clk{color:var(--clay-3);font-weight:500}
.k-card .kc-items{display:flex;flex-direction:column;gap:3px}
.k-card .kc-item{display:flex;gap:7px;font-family:var(--mono);font-size:10px;color:#cce0d6;line-height:1.4}
.k-card .kc-item .q{color:var(--clay-3);font-weight:500;width:16px;flex-shrink:0}
.k-card .kc-item.done{color:#7d9088}
.k-card .kc-item em{color:#7d9088;font-style:normal;font-size:8.5px;letter-spacing:.04em;text-transform:uppercase;display:block;margin-top:1px}

.k-card.in-prog{border-color:#f1c142;background:#f1c14215}
.k-card.in-prog .kc-clk{color:#f1c142;font-weight:500}
.k-card.plating{border-color:var(--moss);background:#b9c8a715}
.k-card.plating .kc-clk{color:var(--moss);font-weight:500}
.k-card.served{border-color:var(--green);background:#3aaa6c15}
.k-card.served .kc-clk{color:var(--green-soft);font-weight:500}

/* =========== Chapter 04 — Four feature cards (matching site) =========== */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media (max-width:880px){.feat-grid{grid-template-columns:1fr}}
.feat-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:20px;padding:36px;display:grid;grid-template-columns:1fr 220px;gap:36px;align-items:center;min-height:300px;transition:transform .3s ease,box-shadow .3s ease}
.feat-card:hover{transform:translateY(-3px);box-shadow:0 24px 50px -28px #14110e35}
@media (max-width:780px){.feat-card{grid-template-columns:1fr;text-align:left}}
.feat-card .fc-cat{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;margin-bottom:12px}
.feat-card .fc-tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;background:var(--ink);color:var(--paper);padding:4px 12px;border-radius:999px;margin-bottom:18px;text-transform:uppercase}
.feat-card.tap-go .fc-tag{background:var(--clay)}
.feat-card.minibar .fc-tag{background:var(--forest)}
.feat-card.kds .fc-tag{background:var(--ink)}
.feat-card.pos .fc-tag{background:var(--plum)}
.feat-card .fc-tag .lbl{font-family:var(--serif);font-style:italic;font-weight:380;font-size:13px;letter-spacing:-.005em;text-transform:none}
.feat-card h3{font-family:var(--serif);font-weight:340;font-size:32px;letter-spacing:-.018em;line-height:1.05;margin:0 0 12px;font-variation-settings:"opsz" 144,"SOFT" 50}
.feat-card h3 em{font-style:italic;color:var(--clay);font-variation-settings:"opsz" 144,"SOFT" 100}
.feat-card p{font-size:14.5px;color:var(--muted);margin:0;line-height:1.5}
.feat-card .integration-tag{margin-top:18px;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--clay);font-weight:500}
.feat-card .integration-tag.soon{color:var(--muted)}

/* feat-visual: tap-go (door card) */
.fvis{position:relative;width:100%;aspect-ratio:1/1;max-width:200px;justify-self:end;display:grid;place-items:center}
@media (max-width:780px){.fvis{justify-self:start}}

.tapgo-vis{width:100%;aspect-ratio:1/1;background:linear-gradient(135deg,var(--clay),var(--clay-2));border-radius:18px;position:relative;overflow:hidden;display:grid;place-items:center;color:#fff8ee}
.tapgo-vis::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 30% 30%,rgba(255,255,255,.2) 0%,transparent 40%)}
.tapgo-vis .card{width:60%;height:38%;background:#fff8ee;border-radius:8px;position:relative;box-shadow:0 12px 30px -10px #00000040;display:flex;align-items:flex-end;padding:10px;color:var(--ink)}
.tapgo-vis .card::before{content:"";position:absolute;top:8px;right:8px;width:18px;height:14px;background:repeating-linear-gradient(90deg,var(--clay) 0,var(--clay) 1px,transparent 1px,transparent 2px,var(--clay) 2px,var(--clay) 3px,transparent 3px,transparent 4px);border-radius:2px}
.tapgo-vis .card span{font-family:var(--serif);font-style:italic;font-size:10px;font-weight:380;letter-spacing:-.005em}
.tapgo-vis .ripple{position:absolute;border:2px solid #fff8ee;border-radius:50%;width:60px;height:60px;animation:ripple 2s ease-out infinite;opacity:0}
.tapgo-vis .ripple.r2{animation-delay:.5s}
.tapgo-vis .ripple.r3{animation-delay:1s}
@keyframes ripple{0%{transform:scale(0);opacity:.7}100%{transform:scale(2.5);opacity:0}}

/* feat-visual: mini-bar */
.minibar-vis{width:100%;aspect-ratio:1/1;background:linear-gradient(135deg,var(--forest),var(--forest-2));border-radius:18px;position:relative;overflow:hidden;padding:14px}
.minibar-vis::before{content:"MINI-BAR · 1218";position:absolute;top:12px;left:14px;font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;color:var(--moss);text-transform:uppercase}
.mb-grid{position:absolute;inset:30px 14px 14px;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(3,1fr);gap:5px}
.mb-item{background:#ffffff15;border:1px solid #ffffff20;border-radius:4px;display:grid;place-items:center;font-family:var(--mono);font-size:8.5px;color:var(--moss)}
.mb-item.taken{background:var(--clay-3);color:var(--ink)}
.mb-item.taken::after{content:"✓";font-size:10px;font-weight:500}
.mb-foot{position:absolute;bottom:14px;right:14px;font-family:var(--serif);font-style:italic;font-weight:380;font-size:14px;color:var(--cream);font-variation-settings:"opsz" 144,"SOFT" 100}
.mb-foot small{display:block;font-style:normal;font-family:var(--mono);font-size:8.5px;color:var(--moss);letter-spacing:.1em;margin-top:2px;text-align:right}

/* feat-visual: KDS */
.kds-vis{width:100%;aspect-ratio:1/1;background:var(--ink);border-radius:18px;padding:14px;position:relative;overflow:hidden;border:1px solid var(--clay-3)}
.kds-vis::before{content:"KDS · LIVE";position:absolute;top:12px;left:14px;font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;color:var(--clay-3);text-transform:uppercase}
.kds-vis::after{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--clay) 30%,transparent);animation:scanline 3s linear infinite}
.kv-list{position:absolute;left:14px;right:14px;top:32px;bottom:14px;display:flex;flex-direction:column;gap:5px}
.kv-row{background:#ffffff10;border-radius:4px;padding:5px 7px;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:8px;color:#cce0d6}
.kv-row.live{background:var(--clay);color:#fff8ee}
.kv-row.live::after{content:"";width:5px;height:5px;border-radius:50%;background:#fff8ee;animation:pulse 1.2s infinite}
.kv-row .num{font-weight:500}

/* feat-visual: POS */
.pos-vis{width:100%;aspect-ratio:1/1;background:linear-gradient(135deg,var(--plum),#3a2230);border-radius:18px;position:relative;overflow:hidden;display:grid;place-items:center;color:var(--cream)}
.pos-vis::before{content:"POS · INTEGRATION";position:absolute;top:12px;left:14px;font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;color:var(--plum-soft);text-transform:uppercase}
.pos-screen{width:70%;height:55%;background:#fff8ee;border-radius:6px;position:relative;color:var(--ink);padding:8px;font-family:var(--mono);font-size:7px;display:flex;flex-direction:column;justify-content:space-between}
.pos-screen .pl{display:flex;justify-content:space-between;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:6.5px}
.pos-screen .pl b{color:var(--ink);font-family:var(--serif);font-style:italic;font-size:9px;text-transform:none;letter-spacing:0;font-weight:400}
.pos-screen .pi{display:flex;justify-content:space-between;font-size:6.5px;color:var(--muted)}
.pos-screen .pt{font-family:var(--serif);font-style:italic;font-size:14px;text-align:right;letter-spacing:-.005em;color:var(--clay-2)}
.pos-soon{position:absolute;bottom:14px;left:14px;font-family:var(--serif);font-style:italic;font-weight:380;font-size:13px;color:var(--clay-3);font-variation-settings:"opsz" 144,"SOFT" 100}

/* =========== Chapter 05 — Multi-outlet analytics =========== */
.outlet-wrap{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:start}
@media (max-width:980px){.outlet-wrap{grid-template-columns:1fr;gap:40px}}
.outlet-side h3{font-family:var(--serif);font-weight:340;font-size:clamp(36px,4.6vw,56px);line-height:.98;letter-spacing:-.02em;margin:0 0 22px;font-variation-settings:"opsz" 144,"SOFT" 50}
.outlet-side h3 em{font-style:italic;color:var(--clay);font-variation-settings:"opsz" 144,"SOFT" 100}
.outlet-side .deck{font-size:16.5px;color:var(--ink-2);line-height:1.55;margin:0 0 22px;max-width:480px}

.outlet-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:20px;padding:30px;box-shadow:var(--shadow)}
.oc-h{display:flex;justify-content:space-between;align-items:center;padding-bottom:18px;border-bottom:1px solid var(--line-soft);margin-bottom:20px;flex-wrap:wrap;gap:14px}
.oc-h h4{font-family:var(--serif);font-style:italic;font-weight:340;font-size:22px;margin:0;letter-spacing:-.005em;font-variation-settings:"opsz" 144,"SOFT" 100}
.oc-h .meta{font-family:var(--mono);font-size:10.5px;color:var(--muted);letter-spacing:.06em}

.outlet-list{display:flex;flex-direction:column;gap:10px}
.outlet-row{display:grid;grid-template-columns:1fr 1fr 1fr 100px;gap:18px;padding:16px;border:1px solid var(--line-soft);border-radius:12px;background:var(--paper-2);align-items:center}
@media (max-width:780px){.outlet-row{grid-template-columns:1fr 1fr;gap:14px}}
.outlet-row .ot-name{font-family:var(--serif);font-weight:380;font-size:18px;letter-spacing:-.005em;font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 100}
.outlet-row .ot-name small{display:block;font-style:normal;font-family:var(--mono);font-size:9.5px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:3px}
.outlet-row .stat-block{display:flex;flex-direction:column;gap:2px}
.outlet-row .sv{font-family:var(--serif);font-weight:340;font-size:22px;line-height:1;letter-spacing:-.015em;font-variation-settings:"opsz" 144}
.outlet-row .sv em{font-style:italic;color:var(--clay)}
.outlet-row .sl{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.outlet-row .util{display:flex;align-items:center;gap:8px}
.outlet-row .util-bar{flex:1;height:6px;background:var(--paper-3);border-radius:3px;overflow:hidden;position:relative}
.outlet-row .util-bar i{display:block;height:100%;background:var(--green-2);border-radius:3px}
.outlet-row .util-bar.high i{background:var(--clay)}
.outlet-row .util-bar.med i{background:var(--amber-deep)}
.outlet-row .util-pct{font-family:var(--mono);font-size:11px;color:var(--ink);font-weight:500;width:40px;text-align:right}

.outlet-aggregate{margin-top:24px;padding-top:18px;border-top:1px dashed var(--line-soft);display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:780px){.outlet-aggregate{grid-template-columns:repeat(2,1fr)}}
.oa-cell .v{font-family:var(--serif);font-weight:340;font-size:32px;line-height:1;letter-spacing:-.018em;font-variation-settings:"opsz" 144}
.oa-cell .v em{font-style:italic;color:var(--clay)}
.oa-cell .l{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:6px}

/* =========== Stats =========== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid #ffffff20;border-bottom:1px solid #ffffff20}
@media (max-width:900px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat-cell{padding:50px 30px;border-right:1px solid #ffffff20}
.stat-cell:last-child{border-right:0}
@media (max-width:900px){.stat-cell:nth-child(2){border-right:0}.stat-cell{border-bottom:1px solid #ffffff20}}
.stat-num{font-family:var(--serif);font-weight:300;font-size:clamp(54px,7.5vw,96px);line-height:.9;letter-spacing:-.03em;font-variation-settings:"opsz" 144}
.stat-num em{font-style:italic;color:var(--clay-3)}
.stat-num .plus{color:var(--clay-3)}
.stat-cap{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#bbb1a0;margin-top:14px}
.stat-sub{font-size:13.5px;color:#e6dec3;margin-top:12px;line-height:1.5}

/* =========== Quote =========== */
.quote{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:center}
@media (max-width:880px){.quote{grid-template-columns:1fr}}
.quote-mark{font-family:var(--serif);font-size:clamp(120px,18vw,240px);line-height:.7;color:var(--clay);font-style:italic;font-weight:300;font-variation-settings:"opsz" 144,"SOFT" 100}
.quote-body{font-family:var(--serif);font-weight:340;font-size:clamp(24px,3.2vw,38px);line-height:1.18;letter-spacing:-.01em;font-variation-settings:"opsz" 144,"SOFT" 50}
.quote-body em{font-style:italic;color:var(--clay)}
.quote-attr{margin-top:30px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:flex;gap:10px;align-items:center}
.quote-attr .av{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--clay),var(--forest))}

/* =========== Integrations + compliance =========== */
.int-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:start}
@media (max-width:980px){.int-grid{grid-template-columns:1fr;gap:40px}}
.int-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:18px;padding:34px;box-shadow:var(--shadow)}
.int-card h4{font-family:var(--serif);font-weight:380;font-size:24px;letter-spacing:-.01em;margin:0 0 8px}
.int-card h4 em{font-style:italic;color:var(--clay)}
.int-card .meta{font-size:14px;color:var(--muted);margin:0 0 24px;line-height:1.5}
.int-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.int-row{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--line-soft);border-radius:12px;background:var(--paper-2)}
.int-row .l{font-family:var(--serif);font-style:italic;font-weight:380;font-size:15px;letter-spacing:-.005em}
.int-row .l small{display:block;font-family:var(--mono);font-size:9.5px;color:var(--muted);font-style:normal;letter-spacing:.1em;text-transform:uppercase;margin-top:2px}
.int-row .ck{width:18px;height:18px;border-radius:50%;background:var(--green-2);color:#fff;display:grid;place-items:center;font-size:10px;flex-shrink:0;margin-left:auto}
.int-row .ck.soon{background:var(--clay);font-size:8.5px;letter-spacing:.04em;width:auto;height:auto;border-radius:999px;padding:3px 8px;font-family:var(--mono);text-transform:uppercase}

.compliance{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.cb{display:flex;gap:14px;align-items:center;padding:18px;border:1px solid var(--line-soft);border-radius:14px;background:var(--paper)}
.cb .b-mark{width:46px;height:46px;border-radius:50%;border:1.4px solid var(--ink);display:grid;place-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.04em;flex-shrink:0;font-weight:500}
.cb h5{font-family:var(--serif);font-weight:400;font-size:17px;margin:0 0 2px;letter-spacing:-.005em}
.cb p{font-family:var(--mono);font-size:10px;color:var(--muted);margin:0;letter-spacing:.1em;text-transform:uppercase}

/* =========== FAQ =========== */
.faq{display:grid;gap:0;max-width:1080px}
.faq details{border-top:1px solid var(--line-soft);padding:24px 0;cursor:pointer}
.faq details:last-child{border-bottom:1px solid var(--line-soft)}
.faq summary{list-style:none;display:flex;justify-content:space-between;align-items:center;font-family:var(--serif);font-size:clamp(20px,2.4vw,28px);font-weight:380;letter-spacing:-.01em;outline:none;gap:24px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pl{font-family:var(--mono);font-size:24px;font-weight:300;color:var(--clay);transition:transform .3s ease;flex-shrink:0}
.faq details[open] summary .pl{transform:rotate(45deg)}
.faq details p{margin:14px 0 0;color:var(--ink-2);font-size:15.5px;line-height:1.55;max-width:780px}

/* =========== Final CTA =========== */
.cta-card{background:var(--paper);border:1.5px solid var(--ink);border-radius:24px;padding:60px;box-shadow:14px 14px 0 0 var(--ink);display:grid;grid-template-columns:1.1fr 1fr;gap:50px;align-items:center;position:relative;overflow:hidden}
@media (max-width:880px){.cta-card{grid-template-columns:1fr;padding:40px;box-shadow:8px 8px 0 0 var(--ink)}}
.cta-card h2{font-family:var(--serif);font-weight:340;font-size:clamp(38px,5.4vw,68px);letter-spacing:-.022em;line-height:.94;margin:0;font-variation-settings:"opsz" 144,"SOFT" 50}
.cta-card h2 em{font-style:italic;color:var(--clay);font-variation-settings:"opsz" 144,"SOFT" 100}
.cta-card .meta{margin-top:22px;font-family:var(--mono);font-size:11.5px;color:var(--muted);letter-spacing:.06em;line-height:1.7}
.cta-actions{display:flex;flex-direction:column;gap:12px;align-items:flex-start}
.cta-line{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.deco-num{position:absolute;right:32px;top:34px;font-family:var(--serif);font-style:italic;font-weight:300;font-size:140px;line-height:1;color:#15130f10;pointer-events:none;font-variation-settings:"opsz" 144,"SOFT" 100}

/* =========== Footer =========== */
footer{background:var(--ink);color:var(--paper);padding:80px 0 36px;position:relative;overflow:hidden}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:36px;padding-bottom:60px;border-bottom:1px solid #ffffff15}
@media (max-width:900px){.foot-grid{grid-template-columns:1fr 1fr;gap:30px}}
.foot-brand .glyph{background:var(--paper);color:var(--ink)}
.foot-brand .brand{color:var(--paper)}
.foot-brand p{color:#bbb1a0;font-size:13.5px;margin:18px 0 24px;max-width:340px;line-height:1.5}
.foot-col h5{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#bbb1a0;margin:0 0 16px;font-weight:500}
.foot-col ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.foot-col a{color:var(--paper);font-size:14px}
.foot-col a:hover{color:var(--clay)}
.foot-col a.current{color:var(--clay)}
.foot-bottom{display:flex;justify-content:space-between;padding-top:30px;font-family:var(--mono);font-size:11px;color:#7d7568;flex-wrap:wrap;gap:16px}
.foot-mark{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(80px,16vw,220px);line-height:.85;letter-spacing:-.04em;color:#1f1c17;margin-top:60px;user-select:none;pointer-events:none;white-space:nowrap;overflow:hidden;font-variation-settings:"opsz" 144,"SOFT" 100}

.fade-up{opacity:0;transform:translateY(18px);transition:opacity .8s ease,transform .8s ease}
.fade-up.in{opacity:1;transform:none}

/* ---------- Mobile menu drawer ---------- */
.mobile-menu{
  position:fixed; left:0; right:0; top:72px; bottom:0;
  background:var(--paper);
  z-index:95;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding:28px 20px 56px;
  visibility:hidden; opacity:0; transform:translateY(-8px);
  transition:opacity .22s ease, transform .22s ease, visibility .22s;
  border-top:1px solid var(--line-soft);
}
body.menu-open .mobile-menu{visibility:visible; opacity:1; transform:translateY(0)}
body.menu-open{overflow:hidden}
.mobile-menu-inner{display:flex; flex-direction:column; gap:26px; max-width:560px; margin:0 auto}
.mm-section h4{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); margin:0 0 10px; font-weight:500;
  padding-bottom:10px; border-bottom:1px solid var(--line-soft);
}
.mm-section ul{list-style:none; margin:0; padding:0; display:grid; gap:2px}
.mm-section a{
  display:block; padding:10px 12px; margin:0 -12px; border-radius:8px;
  font-size:15px; color:var(--ink-2);
}
.mm-section a:active, .mm-section a:hover{background:#efe7d0; color:var(--ink)}
.mm-cta{display:flex; flex-direction:column; gap:10px; margin-top:8px}
.mm-cta .btn{justify-content:center; width:100%; height:50px; font-size:15px}
@media (min-width:1081px){.mobile-menu{display:none}}

/* Hamburger -> X animation */
.menu-toggle span, .menu-toggle span::before, .menu-toggle span::after{
  transition:transform .22s ease, background .22s ease, top .22s ease;
}
body.menu-open .menu-toggle span{background:transparent}
body.menu-open .menu-toggle span::before{top:0; transform:rotate(45deg)}
body.menu-open .menu-toggle span::after{top:0; transform:rotate(-45deg)}

/* Mobile: drop sticky + transparency. Bar fixes only when menu is open. */
@media (max-width:1080px){
  .bar, .subbar{
    position:static; top:auto;
    background:var(--paper);
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
  }
  body.menu-open .bar{
    position:fixed; top:0; left:0; right:0; z-index:96;
  }
}

