
/* ---------- Tokens (shared) ---------- */
: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;--moss-2:#9fb89a;--moss-3:#7d9a6f;
  --clay:#c66a35;--clay-2:#a8541f;--clay-3:#e7a276;
  --cream:#f7f1df;--bubble:#d8e2c8;
  --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,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;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1000;opacity:.20;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{max-width:100%;display:block}
button{font:inherit;color:inherit}

/* ---------- Layout primitives (shared) ---------- */
.wrap{max-width:1320px;margin:0 auto;padding:0 32px;position:relative}
@media (max-width:680px){.wrap{padding:0 20px}}

.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:#3aaa6c;box-shadow:0 0 0 4px #3aaa6c20;animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}

.h-display{font-family:var(--serif);font-weight:340;font-variation-settings:"opsz" 144,"SOFT" 50;letter-spacing:-0.025em;line-height:.95;color:var(--ink)}
.italic{font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 100}

.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);border-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)}

/* ---------- Top bar (shared) ---------- */
.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:#3aaa6c;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:80px 0 110px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1fr 0.85fr;gap:60px;align-items:start}
.hero-grid > *{min-width:0}
@media (max-width:1080px){.hero-grid{grid-template-columns:1fr;gap:40px}}
.hero-meta{display:flex;gap:24px;align-items:center;margin-bottom:34px;flex-wrap:wrap}
.hero h1{font-size:clamp(56px,9vw,128px);margin:0 0 30px}
.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-sub{font-size:19px;max-width:520px;color:var(--ink-2);line-height:1.45;margin:0 0 36px}
.hero-cta{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.rail{position:absolute;left:-2px;top:120px;bottom:0;width:120px;pointer-events:none;display:flex;flex-direction:column;justify-content:flex-start;gap:32px}
.rail .tick{font-family:var(--mono);font-size:11px;color:var(--muted);display:flex;align-items:center;gap:10px}
.rail .tick::before{content:"";width:18px;height:1px;background:var(--ink)}
.rail .tick.active{color:var(--ink)}
.rail .tick.active::before{background:var(--clay);width:24px;height:2px}
@media (max-width:1180px){.rail{display:none}}
.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: phone with QR + guest hub ---------- */
.hero-stage{
  position:relative;
  display:flex; justify-content:center; align-items:flex-start;
  padding:20px 0;
}
@media (max-width:1080px){.hero-stage{flex-direction:column; align-items:center; gap:20px}}

/* Decorative QR card behind phone */
.qr-card{
  position:absolute; left:0; top:30px;
  background:var(--paper); border:1px solid var(--ink); border-radius:18px;
  padding:18px 18px 16px; width:200px;
  box-shadow:6px 6px 0 0 var(--ink);
  z-index:1; transform:rotate(-4deg);
}
.qr-card .lab{font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:10px}
.qr-card .lab b{color:var(--ink); font-weight:500}
.qr-svg{width:100%; aspect-ratio:1; background:#fff; border-radius:8px; padding:8px; display:block}
.qr-card .cap{font-family:var(--serif); font-size:13px; font-style:italic; color:var(--ink); margin-top:10px; line-height:1.2}
.qr-card .cap small{display:block; font-family:var(--mono); font-size:9.5px; color:var(--muted); letter-spacing:.06em; font-style:normal; margin-top:3px; text-transform:uppercase}
@media (max-width:1080px){.qr-card{position:relative; left:auto; top:auto; margin:0 auto 30px; transform:none}}
@media (max-width:1080px){.phone{margin-left:auto; margin-right:auto}}

/* Sofitel screenshot inside iPhone mockup */
.phone-shot{
  display:block; width:100%; height:auto;
  /* Warm tint so the screenshot harmonises with the cream page palette */
  filter: sepia(0.25) saturate(0.85) hue-rotate(-6deg) brightness(1.02) contrast(0.96);
}
.hub-bottom-strip{
  margin:10px 18px 14px; padding-top:10px;
  border-top:1px solid var(--line-soft);
  display:flex; justify-content:center; gap:14px;
  font-family:var(--mono); font-size:9.5px; color:var(--muted); letter-spacing:.06em;
}

/* Phone frame */
.phone{
  position:relative; z-index:2;
  width:340px; max-width:100%;
  border-radius:42px;
  background:linear-gradient(180deg, #1f1c17, #15130f);
  padding:14px 12px;
  box-shadow: 0 30px 60px -28px #14110e60, 0 6px 18px -10px #14110e40;
  margin-left:auto;
}
.phone::before{
  content:""; position:absolute; left:50%; top:18px; transform:translateX(-50%);
  width:90px; height:24px; background:#000; border-radius:14px; z-index:5;
}
.phone-screen{
  background:var(--paper); border-radius:32px; overflow:hidden; min-height:580px;
  position:relative;
}
.status-bar{
  display:flex; justify-content:space-between; align-items:center;
  padding:14px 22px 8px; font-family:var(--mono); font-size:11px; color:var(--ink); font-weight:500;
}
.status-bar .right{display:flex; gap:5px; align-items:center; font-size:9px}
.status-bar .right .bars{display:inline-flex; gap:1.5px; align-items:flex-end; height:9px}
.status-bar .right .bars span{width:2px; background:var(--ink); border-radius:1px}
.status-bar .right .bars span:nth-child(1){height:3px}
.status-bar .right .bars span:nth-child(2){height:5px}
.status-bar .right .bars span:nth-child(3){height:7px}
.status-bar .right .bars span:nth-child(4){height:9px}
.status-bar .right .batt{
  width:18px; height:9px; border:1px solid var(--ink); border-radius:2px; padding:1px; position:relative;
}
.status-bar .right .batt::after{content:""; position:absolute; right:-3px; top:50%; transform:translateY(-50%); width:1.5px; height:4px; background:var(--ink); border-radius:0 1px 1px 0}
.status-bar .right .batt::before{content:""; display:block; width:75%; height:100%; background:var(--ink); border-radius:1px}

.url-bar{
  margin:6px 18px 14px; padding:6px 12px;
  background:var(--paper-2); border:1px solid var(--line-soft); border-radius:999px;
  font-family:var(--mono); font-size:10.5px; color:var(--muted); display:flex; gap:8px; align-items:center;
}
.url-bar::before{content:"⌂"; color:var(--forest); font-size:11px}
.url-bar b{color:var(--ink); font-weight:500}

/* hotel hub content */
.hub{padding:0 18px 18px}
.hub-hero{
  position:relative; height:130px; border-radius:14px; overflow:hidden;
  background:
    radial-gradient(ellipse at 30% 30%, #d4a566 0%, transparent 55%),
    radial-gradient(ellipse at 70% 70%, #6b4422 0%, transparent 50%),
    linear-gradient(135deg, #2b2620, #1c3a2e);
  margin-bottom:14px;
}
.hub-hero .text{
  position:absolute; left:14px; bottom:12px; right:14px;
  color:#fff8ee;
}
.hub-hero .text .br{font-family:var(--serif); font-style:italic; font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:#e7a276; margin-bottom:2px}
.hub-hero .text h6{font-family:var(--serif); font-weight:380; font-size:18px; margin:0; line-height:1.05; letter-spacing:-.005em}
.hub-hero .greet{
  position:absolute; right:12px; top:12px; padding:3px 8px; background:#ffffff20; backdrop-filter:blur(4px); border-radius:999px;
  font-family:var(--mono); font-size:8.5px; color:#fff8ee; letter-spacing:.12em; text-transform:uppercase;
}

.hub-tile-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:14px}
.hub-tile{
  aspect-ratio:1; background:var(--paper-2); border:1px solid var(--line-soft); border-radius:12px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:5px;
  padding:8px;
}
.hub-tile.dark{background:var(--ink); color:var(--paper); border-color:var(--ink)}
.hub-tile.clay{background:var(--clay); color:#fff8ee; border-color:transparent}
.hub-tile.forest{background:var(--forest); color:var(--cream); border-color:transparent}
.hub-tile .ic{
  width:28px; height:28px; border-radius:8px; background:#ffffff80; display:grid; place-items:center;
}
.hub-tile.dark .ic, .hub-tile.clay .ic, .hub-tile.forest .ic{background:#ffffff20}
.hub-tile .ic svg{width:14px; height:14px}
.hub-tile .name{font-family:var(--serif); font-size:10.5px; font-weight:380; line-height:1; letter-spacing:-.005em; text-align:center}

.hub-msg-strip{
  display:flex; gap:8px; align-items:center; padding:9px 11px;
  background:#dee9d3; border-radius:10px; border:1px solid #b9c8a7;
}
.hub-msg-strip .av{
  width:26px; height:26px; border-radius:50%; background:linear-gradient(135deg, var(--clay), var(--forest)); flex-shrink:0;
}
.hub-msg-strip .body{flex:1; min-width:0}
.hub-msg-strip .body .from{font-family:var(--mono); font-size:8.5px; color:#2a5a3a; letter-spacing:.06em; text-transform:uppercase}
.hub-msg-strip .body .preview{font-size:11.5px; color:var(--ink); line-height:1.2; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-top:1px}
.hub-msg-strip .badge{
  font-family:var(--mono); font-size:8.5px; padding:2px 6px; background:var(--forest); color:var(--cream); border-radius:999px; flex-shrink:0;
}

.hub-bottom{margin-top:12px; display:flex; justify-content:center; gap:14px; padding-top:10px; border-top:1px solid var(--line-soft); font-family:var(--mono); font-size:9.5px; color:var(--muted); letter-spacing:.06em}

.side-note{position:absolute;z-index:3;font-family:var(--mono);font-size:10.5px;color:var(--muted);display:flex;align-items:center;gap:8px}
.side-note .ln{width:34px;height:1px;background:var(--ink);opacity:.4}
.side-note.tl{left:-22px;top:80px;transform:rotate(-90deg);transform-origin:left top}
@media (max-width:1080px){.side-note.tl{display:none}}

/* ---------- Section wrappers (shared) ---------- */
.section{padding:110px 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)}
.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{color:#bbb1a0}
.sec-head h2{font-family:var(--serif);font-weight:340;font-size:clamp(42px,6vw,76px);letter-spacing:-.02em;line-height:.96;margin:0}
.sec-head h2 em{font-style:italic;color:var(--clay)}
.section.dark .sec-head h2 em{color:#e7a276}
.section.forest .sec-head h2 em{color:#e7a276}

/* ---------- Three doors ---------- */
.doors{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
@media (max-width:980px){.doors{grid-template-columns:1fr}}
.door{
  background:var(--paper); border:1px solid var(--line-soft); border-radius:18px;
  padding:30px; min-height:440px; display:flex; flex-direction:column; gap:18px;
  position:relative; overflow:hidden;
}
.door .pn{font-family:var(--mono); font-size:10.5px; color:var(--muted); letter-spacing:.16em; text-transform:uppercase; display:flex; align-items:center; gap:10px}
.door .pn::after{content:""; flex:1; height:1px; background:var(--line-soft); opacity:.6}
.door h3{font-family:var(--serif); font-weight:340; font-size:34px; line-height:.98; letter-spacing:-.018em; margin:0}
.door h3 em{font-style:italic; color:var(--clay)}
.door p{font-size:14px; color:var(--muted); margin:0; line-height:1.5}
.door .demo{margin-top:auto; padding-top:14px}

/* WhatsApp door */
.wa-mini{
  background:#0c1411; border-radius:14px; padding:14px; box-shadow:inset 0 1px 0 #ffffff10;
}
.wa-mini .head{display:flex; align-items:center; gap:10px; padding-bottom:10px; border-bottom:1px solid #ffffff10}
.wa-mini .head .av{width:28px; height:28px; border-radius:50%; background:linear-gradient(135deg, var(--clay), var(--forest))}
.wa-mini .head .name{color:#e6dfca; font-size:13px; font-weight:500}
.wa-mini .head .meta{color:#7d7568; font-size:9.5px; font-family:var(--mono); margin-top:1px}
.wa-mini .head .ic{margin-left:auto; color:#7d7568; font-size:14px}
.wa-mini .thread{display:flex; flex-direction:column; gap:6px; margin-top:10px}
.wa-bub{padding:7px 10px; border-radius:10px; font-size:11.5px; line-height:1.35; max-width:88%}
.wa-bub.in{background:#1f2a26; color:#e6dfca; align-self:flex-start; border-radius:10px 10px 10px 3px}
.wa-bub.out{background:#108a4d; color:#fff; align-self:flex-end; border-radius:10px 10px 3px 10px}
.wa-bub .tm{font-size:8.5px; opacity:.6; margin-top:3px; text-align:right; font-family:var(--mono)}

/* QR door */
.qr-demo{
  display:flex; flex-direction:column; align-items:center; gap:12px;
  padding:18px; background:var(--paper-2); border-radius:14px; border:1px solid var(--line-soft);
}
.qr-demo .qr-svg-mini{width:120px; aspect-ratio:1; background:#fff; padding:8px; border-radius:8px; box-shadow:0 4px 14px -8px #14110e30}
.qr-demo .label{font-family:var(--mono); font-size:10px; color:var(--ink); letter-spacing:.12em; text-transform:uppercase}
.qr-demo .arrow{font-family:var(--mono); font-size:9.5px; color:var(--muted)}

/* Webchat door */
.wc-mini{
  background:#fff; border-radius:14px 14px 14px 4px; box-shadow:0 6px 18px -10px #14110e30; border:1px solid #00000010;
  display:flex; flex-direction:column;
}
.wc-mini .wc-head{
  background:var(--ink); color:var(--paper); padding:10px 14px; border-radius:14px 14px 0 0;
  font-family:var(--serif); font-size:13px; font-weight:380; letter-spacing:-.005em;
  display:flex; justify-content:space-between; align-items:center;
}
.wc-mini .wc-head .x{font-family:var(--mono); font-size:14px; opacity:.6}
.wc-mini .wc-body{padding:12px 14px}
.wc-msg{
  font-size:12px; padding:7px 10px; border-radius:10px; max-width:88%; line-height:1.35;
  background:var(--paper-2); color:var(--ink); margin-bottom:6px;
}
.wc-msg.you{background:var(--moss); border-radius:10px 10px 4px 10px; margin-left:auto}
.wc-input{margin:8px 14px 14px; padding:8px 12px; background:var(--paper-2); border-radius:999px; font-family:var(--sans); font-size:11.5px; color:var(--muted); border:1px solid var(--line-soft); display:flex; justify-content:space-between; align-items:center}
.wc-input::after{content:"➤"; color:var(--forest)}

/* ---------- WhatsApp Business deep dive ---------- */
.wa-deep{
  display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center;
}
@media (max-width:1080px){.wa-deep{grid-template-columns:1fr}}
.wa-copy h3{font-family:var(--serif); font-weight:340; font-size:clamp(40px, 5vw, 62px); line-height:1; letter-spacing:-.02em; margin:18px 0 18px}
.wa-copy h3 em{font-style:italic; color:#e7a276}
.wa-copy p{font-size:16px; color:#bbb1a0; line-height:1.55; margin:0 0 16px; max-width:480px}
.wa-copy p b{color:var(--cream); font-weight:500}
.wa-copy .meta-badge{
  display:inline-flex; align-items:center; gap:8px;
  background:#1c2a3a; color:#9bc4ff; border:1px solid #ffffff20;
  padding:6px 12px; border-radius:999px; font-family:var(--mono); font-size:11px; letter-spacing:.06em; margin-top:10px;
}
.wa-copy .meta-badge::before{content:""; width:8px; height:8px; background:#5b6cff; border-radius:50%}
.wa-copy ul{list-style:none; padding:0; margin:18px 0 0; display:grid; gap:0}
.wa-copy ul li{display:grid; grid-template-columns:auto 180px 1fr; column-gap:16px; align-items:start; font-size:14px; color:#bccdc1; line-height:1.5; padding:12px 0; border-bottom:1px dashed #ffffff15}
.wa-copy ul li:last-child{border-bottom:0}
.wa-copy ul li::before{content:""; width:6px; height:6px; border-radius:50%; background:#3aaa6c; margin-top:7px}
.wa-copy ul li b{color:var(--cream); font-weight:500}
.wa-copy ul li span{min-width:0}
@media (max-width:720px){.wa-copy ul li{grid-template-columns:auto 1fr; row-gap:4px} .wa-copy ul li b{grid-column:2} .wa-copy ul li span{grid-column:2}}

/* WhatsApp full-thread phone */
.wa-thread{
  background:#0c1411; border-radius:24px; padding:18px; box-shadow:0 30px 60px -28px #14110e60;
  border:1px solid #ffffff10; max-width:380px; margin:0 auto;
}
.wa-thread .head{
  display:flex; align-items:center; gap:12px; padding:6px 8px 14px; border-bottom:1px solid #ffffff10;
}
.wa-thread .head .av{width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg, var(--clay), var(--forest)); display:grid; place-items:center; color:#fff; font-family:var(--mono); font-size:12px}
.wa-thread .head .info .name{color:#e6dfca; font-size:14px; font-weight:500}
.wa-thread .head .info .status{color:#7d9a6f; font-size:10px; font-family:var(--mono); margin-top:2px}
.wa-thread .head .icons{margin-left:auto; display:flex; gap:14px; color:#7d7568; font-size:13px}
.wa-thread .body{padding:12px 4px 4px; display:flex; flex-direction:column; gap:8px}
.wa-thread .day{font-family:var(--mono); font-size:9.5px; color:#7d7568; text-align:center; letter-spacing:.16em; text-transform:uppercase; margin:6px 0}
.wa-thread .b{padding:8px 12px; border-radius:10px; font-size:13px; line-height:1.4; max-width:78%}
.wa-thread .b.in{background:#1f2a26; color:#e6dfca; align-self:flex-start; border-radius:10px 10px 10px 3px}
.wa-thread .b.out{background:#108a4d; color:#fff; align-self:flex-end; border-radius:10px 10px 3px 10px}
.wa-thread .b .tm{font-size:9px; opacity:.6; margin-top:4px; text-align:right; font-family:var(--mono)}
.wa-thread .b .tm .ck{color:#5be4d4}
.wa-thread .quick-replies{display:flex; flex-wrap:wrap; gap:6px; margin-top:4px}
.wa-thread .quick-replies .q{
  background:#0c1411; border:1px solid #1f2a26; color:#9bc4a7;
  padding:6px 10px; border-radius:14px; font-size:11px; font-family:var(--sans);
}
.wa-thread .input{
  margin-top:14px; padding:10px 14px; background:#1f2a26; border-radius:999px; color:#7d7568; font-size:12px;
  display:flex; justify-content:space-between; align-items:center;
}

/* ---------- Scan to dine ---------- */
.dine-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-bottom:50px; justify-items:center; align-items:start}
.dine-grid > div{display:flex; flex-direction:column; align-items:center; width:100%}
@media (max-width:980px){.dine-grid{grid-template-columns:1fr; gap:40px; max-width:380px; margin:0 auto 50px}}
.dine-phone{
  position:relative;
  width:100%;
  max-width:280px; /* iPhone proportions instead of iPad */
  border-radius:38px;
  background:linear-gradient(180deg, #1f1c17, #15130f);
  padding:10px 8px;
  box-shadow:0 30px 60px -36px #14110e50, 0 4px 14px -10px #14110e30;
}
.dine-phone::before{
  content:""; position:absolute; left:50%; top:14px; transform:translateX(-50%);
  width:70px; height:18px; background:#000; border-radius:10px; z-index:5;
}
.dine-screen{
  background:var(--paper); border-radius:30px; overflow:hidden;
  display:flex; flex-direction:column;
}
.dine-screen .ph-status{
  display:flex; justify-content:space-between; padding:14px 22px 8px 22px;
  font-family:var(--mono); font-size:9.5px; color:var(--ink); font-weight:500;
  flex-shrink:0;
}

/* Real screenshots inside dine phones — cream-blended */
.dine-shot{
  display:block; width:100%; height:auto;
  /* extra warm tint via CSS so the screenshots harmonise with the cream palette */
  filter: sepia(0.20) saturate(0.88) hue-rotate(-6deg) brightness(1.02) contrast(0.96);
}

/* Phone 1: Home page */
.menu-head{padding:8px 16px 12px; border-bottom:1px solid var(--line-soft)}
.menu-head .br{font-family:var(--mono); font-size:9px; color:var(--muted); letter-spacing:.16em; text-transform:uppercase}
.menu-head h6{font-family:var(--serif); font-weight:340; font-size:22px; margin:2px 0 0; letter-spacing:-.012em; line-height:1}
.menu-head h6 em{font-style:italic; color:var(--clay)}
.menu-cats{display:flex; gap:6px; padding:10px 16px; overflow-x:auto}
.menu-cats .c{flex-shrink:0; padding:5px 10px; border-radius:999px; font-family:var(--mono); font-size:9px; letter-spacing:.06em; text-transform:uppercase; background:var(--paper-2); border:1px solid var(--line-soft); color:var(--ink)}
.menu-cats .c.active{background:var(--ink); color:var(--paper); border-color:var(--ink)}

.menu-feature{
  margin:6px 16px 12px; border-radius:12px; overflow:hidden; position:relative;
  background:radial-gradient(ellipse at 30% 30%, #d4a566 0%, transparent 50%), linear-gradient(135deg, #6b4422, #2b2620);
  height:120px; padding:14px;
  color:#fff8ee; display:flex; flex-direction:column; justify-content:flex-end;
}
.menu-feature .lab{font-family:var(--mono); font-size:8.5px; letter-spacing:.16em; text-transform:uppercase; color:#e7a276}
.menu-feature .ti{font-family:var(--serif); font-style:italic; font-size:18px; font-weight:340; line-height:1.05; margin-top:3px; max-width:80%}

.menu-items{padding:0 16px 16px; display:flex; flex-direction:column; gap:8px}
.menu-item{
  display:grid; grid-template-columns:auto 1fr auto; gap:10px; align-items:center;
  padding:8px; background:var(--paper-2); border-radius:10px; border:1px solid var(--line-soft);
}
.menu-item .ph{
  width:36px; height:36px; border-radius:8px; flex-shrink:0;
  background:linear-gradient(135deg, #b9c8a7, #1c3a2e);
}
.menu-item .ph.b{background:linear-gradient(135deg, #d4a566, #6b4422)}
.menu-item .ph.c{background:linear-gradient(135deg, #c66a35, #a8541f)}
.menu-item .ph.d{background:linear-gradient(135deg, #c4d4d8, #5a7585)}
.menu-item .info .n{font-family:var(--serif); font-size:12px; font-weight:380; line-height:1.15; letter-spacing:-.005em}
.menu-item .info .desc{font-size:9.5px; color:var(--muted); margin-top:1px; line-height:1.2}
.menu-item .price{font-family:var(--mono); font-size:11px; font-weight:500; color:var(--ink); white-space:nowrap}

/* Phone 2: Detailed */
.dish-hero{
  height:160px; position:relative; overflow:hidden;
  background:radial-gradient(ellipse at 60% 40%, #d4a566 0%, transparent 50%), linear-gradient(135deg, #c66a35, #2b2620);
}
.dish-hero::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 50%, #00000060)}
.dish-hero .back{position:absolute; top:12px; left:12px; width:28px; height:28px; border-radius:50%; background:#ffffff20; backdrop-filter:blur(4px); display:grid; place-items:center; color:#fff; font-size:14px; z-index:2}
.dish-info{padding:14px 16px}
.dish-info .lab{font-family:var(--mono); font-size:8.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--clay)}
.dish-info h6{font-family:var(--serif); font-weight:380; font-size:20px; margin:4px 0 6px; line-height:1.05; letter-spacing:-.012em}
.dish-info p{font-size:11.5px; color:var(--muted); margin:0; line-height:1.4}
.dish-info .tags{display:flex; gap:5px; flex-wrap:wrap; margin-top:10px}
.dish-info .tags .t{font-family:var(--mono); font-size:9px; padding:3px 7px; border-radius:999px; background:var(--paper-2); color:var(--ink); letter-spacing:.06em; text-transform:uppercase; border:1px solid var(--line-soft)}
.dish-info .tags .t.warn{background:#f1e1a8; color:#6a4f12; border-color:transparent}
.dish-options{padding:10px 16px 14px; border-top:1px solid var(--line-soft); margin-top:14px}
.dish-options h7{font-family:var(--serif); font-size:13px; font-weight:380; display:block; margin-bottom:8px}
.dish-opt{
  display:flex; gap:10px; align-items:center; padding:7px 0; border-bottom:1px dashed var(--line-soft);
  font-size:11px; line-height:1.2;
}
.dish-opt:last-child{border-bottom:0}
.dish-opt .rd{
  width:14px; height:14px; border-radius:50%; border:1.5px solid var(--ink); flex-shrink:0;
  display:grid; place-items:center;
}
.dish-opt.on .rd::after{content:""; width:7px; height:7px; border-radius:50%; background:var(--clay)}
.dish-opt .price{font-family:var(--mono); font-size:10.5px; font-weight:500; margin-left:auto; color:var(--ink)}

.dine-cta{
  padding:12px 16px; border-top:1px solid var(--line-soft); margin-top:auto; display:flex; gap:10px; align-items:center;
}
.dine-cta .qty{font-family:var(--mono); font-size:11px; padding:6px 10px; background:var(--paper-2); border:1px solid var(--line-soft); border-radius:999px}
.dine-cta .add{
  flex:1; padding:8px 14px; background:var(--ink); color:var(--paper); border-radius:999px;
  display:flex; justify-content:space-between; align-items:center; font-size:12px; font-weight:500;
}

/* Phone 3: Checkout */
.checkout-head{padding:14px 16px 10px}
.checkout-head .br{font-family:var(--mono); font-size:9px; color:var(--muted); letter-spacing:.16em; text-transform:uppercase}
.checkout-head h6{font-family:var(--serif); font-weight:340; font-size:22px; margin:2px 0 0; letter-spacing:-.012em; line-height:1}
.checkout-head h6 em{font-style:italic; color:var(--clay)}

.order-list{padding:0 16px; display:flex; flex-direction:column; gap:6px; margin:8px 0}
.order-row{display:grid; grid-template-columns:auto 1fr auto; gap:10px; align-items:center; padding:6px 8px; border-radius:8px; background:var(--paper-2)}
.order-row .qy{font-family:var(--mono); font-size:11px; padding:1px 6px; border-radius:4px; background:var(--ink); color:var(--paper); flex-shrink:0}
.order-row .nm{font-family:var(--serif); font-size:12px; font-weight:380; letter-spacing:-.005em; line-height:1.2; min-width:0}
.order-row .nm small{display:block; font-family:var(--mono); font-size:9px; color:var(--muted); letter-spacing:.06em; margin-top:1px}
.order-row .pr{font-family:var(--mono); font-size:11px; font-weight:500}

.detail-list{padding:14px 16px; display:flex; flex-direction:column; gap:8px; border-top:1px dashed var(--line-soft); margin-top:6px}
.det-row{display:flex; justify-content:space-between; font-family:var(--mono); font-size:11px; color:var(--muted)}
.det-row.total{font-family:var(--serif); font-size:14px; color:var(--ink); font-weight:500; padding-top:8px; border-top:1px solid var(--line-soft); margin-top:4px}
.det-row.total b{font-style:italic; font-weight:340}

.bill-options{padding:10px 16px 14px}
.bill-row{
  display:flex; align-items:center; gap:10px; padding:9px 12px;
  background:var(--paper-2); border:1px solid var(--line-soft); border-radius:10px;
  font-family:var(--mono); font-size:10.5px; color:var(--ink); margin-bottom:6px;
}
.bill-row.on{background:var(--moss); border-color:var(--moss-3)}
.bill-row .rd{width:14px; height:14px; border-radius:50%; border:1.5px solid var(--ink); flex-shrink:0; display:grid; place-items:center}
.bill-row.on .rd::after{content:""; width:7px; height:7px; border-radius:50%; background:var(--ink)}

/* Phone caption */
.dine-cap{
  margin-top:18px; padding:0 4px;
  text-align:center;
}
.dine-cap .num{font-family:var(--mono); font-size:10.5px; color:var(--muted); letter-spacing:.16em; text-transform:uppercase}
.dine-cap h5{font-family:var(--serif); font-weight:380; font-size:18px; margin:6px 0 4px; letter-spacing:-.005em}
.dine-cap h5 em{font-style:italic; color:var(--clay)}
.dine-cap p{font-size:13px; color:var(--muted); margin:0; line-height:1.45}

.dine-tagline{
  background:var(--ink); color:var(--paper); border-radius:18px;
  padding:30px 36px; display:flex; gap:30px; align-items:center; justify-content:space-between; flex-wrap:wrap;
}
.dine-tagline h4{font-family:var(--serif); font-weight:340; font-size:32px; margin:0; line-height:1.05; letter-spacing:-.015em}
.dine-tagline h4 em{font-style:italic; color:#e7a276}
.dine-tagline .stats{display:flex; gap:32px; font-family:var(--mono); font-size:11px; color:#bbb1a0; letter-spacing:.06em}
.dine-tagline .stats b{display:block; font-family:var(--serif); font-style:italic; font-size:24px; color:var(--paper); font-weight:340; margin-bottom:2px}

/* ---------- Unified Communication Hub ---------- */
.hub-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
@media (max-width:1020px){.hub-grid{grid-template-columns:1fr}}
.hub-card{
  background:var(--paper); border:1px solid var(--line-soft); border-radius:18px;
  padding:30px; min-height:460px; display:flex; flex-direction:column; gap:18px; position:relative; overflow:hidden;
}
.hub-card.dark{background:var(--ink); color:var(--paper); border-color:var(--ink)}
.hub-card.dark p{color:#bbb1a0}
.hub-card .pn{font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted)}
.hub-card.dark .pn{color:#bbb1a0}
.hub-card h3{font-family:var(--serif); font-weight:340; font-size:30px; line-height:1.05; letter-spacing:-.015em; margin:0}
.hub-card h3 em{font-style:italic; color:var(--clay)}
.hub-card.dark h3 em{color:#e7a276}
.hub-card p{font-size:14px; color:var(--muted); margin:0; line-height:1.5}
.hub-card .demo{margin-top:auto; padding-top:14px}

/* translation demo */
.tr-msg{
  background:#fff; border:1px solid var(--line-soft); border-radius:10px; padding:10px 12px; margin-bottom:8px;
}
.hub-card.dark .tr-msg{background:#1f1c17; border-color:#2c2820}
.tr-msg .from{font-family:var(--mono); font-size:9.5px; color:var(--muted); letter-spacing:.06em; margin-bottom:4px; display:flex; gap:8px; align-items:center}
.tr-msg .from .flag{font-size:11px}
.tr-msg .original{font-size:13px; color:var(--ink); line-height:1.35}
.hub-card.dark .tr-msg .original{color:var(--paper)}
.tr-msg .translated{font-size:12px; color:var(--muted); line-height:1.35; margin-top:6px; padding-top:6px; border-top:1px dashed var(--line-soft); font-style:italic}
.tr-msg .translated::before{content:"→ EN · "; font-style:normal; font-family:var(--mono); font-size:9.5px; color:var(--clay); letter-spacing:.04em}

/* queue transfer demo */
.qt-list{display:flex; flex-direction:column; gap:8px}
.qt-row{
  display:grid; grid-template-columns:auto 1fr auto; gap:10px; align-items:center;
  padding:10px 12px; background:#fff; border:1px solid var(--line-soft); border-radius:10px; font-size:12px;
}
.hub-card.clay .qt-row{background:#ffffff15; border-color:#ffffff25; color:var(--cream)}
.qt-row .av{
  width:24px; height:24px; border-radius:6px;
  display:grid; place-items:center; flex-shrink:0; font-family:var(--mono); font-size:9.5px; color:#fff;
}
.qt-row .av.fb{background:var(--clay)}
.qt-row .av.hk{background:var(--moss-3)}
.qt-row .av.eng{background:var(--forest)}
.qt-row .av.cc{background:var(--ink)}
.qt-row .desc small{display:block; font-family:var(--mono); font-size:9px; color:var(--muted); letter-spacing:.06em; margin-top:1px}
.hub-card.clay .qt-row .desc small{color:#fae6d2}
.qt-row .arr{font-family:var(--mono); font-size:11px; color:var(--clay)}
.hub-card.clay .qt-row .arr{color:#fff8ee}
.hub-card.clay{background:var(--clay); color:var(--cream)}
.hub-card.clay p, .hub-card.clay .pn{color:#fae6d2}
.hub-card.clay h3 em{color:#1c3a2e}

/* templates demo */
.tmpl-list{display:flex; flex-direction:column; gap:6px}
.tmpl-row{
  display:flex; align-items:center; gap:10px;
  padding:10px 12px; background:var(--paper-2); border:1px solid var(--line-soft); border-radius:10px;
  font-size:12.5px; line-height:1.35;
}
.tmpl-row .key{
  font-family:var(--mono); font-size:10px; padding:2px 6px; background:var(--ink); color:var(--paper); border-radius:4px; flex-shrink:0;
}
.tmpl-row .text{flex:1; min-width:0; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.tmpl-row .lang{font-family:var(--mono); font-size:9px; color:var(--muted); letter-spacing:.06em; flex-shrink:0}

/* ---------- CTA + Footer (shared) ---------- */
.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(40px,6vw,72px);letter-spacing:-.02em;line-height:.95;margin:0}
.cta-card h2 em{font-style:italic;color:var(--clay)}
.cta-card .meta{margin-top:22px;font-family:var(--mono);font-size:11.5px;color:var(--muted);letter-spacing:.06em}
.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:50px;font-family:var(--serif);font-style:italic;font-weight:300;font-size:140px;line-height:1;color:#15130f12;pointer-events:none}

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-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(120px,22vw,320px);line-height:.85;letter-spacing:-.04em;color:#1f1c17;margin-top:60px;user-select:none;pointer-events:none;white-space:nowrap;overflow:hidden}

.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;
  }
}

