*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { overflow-x: hidden; scrollbar-width: none; }
html::-webkit-scrollbar { display: none; }

:root {
  --gap:     clamp(6px,  1.8vw, 16px);
  --cpx:     clamp(10px, 2.8vw, 22px);
  --cpy:     clamp(10px, 2.8vw, 22px);
  --r:       clamp(14px, 3.5vw, 26px);
  --apx:     clamp(12px, 4vw,   40px);
  --apt:     clamp(22px, 5vw,   52px);
  --f-giant: clamp(30px, 9.5vw, 58px);
  --f-aed:   clamp(24px, 7.5vw, 46px);
  --f-xl:    clamp(17px, 5.2vw, 34px);
  --f-lg:    clamp(14px, 4.2vw, 28px);
  --f-md:    clamp(12px, 3.5vw, 22px);
  --f-base:  clamp(10px, 2.8vw, 15px);
  --f-sm:    clamp(9px,  2.4vw, 13px);
  --f-xs:    clamp(7.5px,1.9vw, 11px);
  --bsz:     clamp(22px, 5.5vw, 34px);
  --asz:     clamp(36px, 8vw,   50px);
  --dsz:     clamp(6px,  1.5vw, 9px);
  --safe-top:    env(safe-area-inset-top, 0px);
  --safe-right:  env(safe-area-inset-right, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left:   env(safe-area-inset-left, 0px);
}

body { background:#111; color:#f0ede6; font-family:'Inter',-apple-system,sans-serif; min-height:100vh; min-height:100dvh; overflow-x:hidden; }

/* ── HOME ── */
#home { min-height:100vh; min-height:100dvh; }
.app {
  width:100%;
  padding-top: calc(var(--apt) + var(--safe-top));
  padding-left: max(var(--apx), var(--safe-left));
  padding-right: max(var(--apx), var(--safe-right));
  padding-bottom: max(clamp(40px,8vw,80px), calc(clamp(40px,8vw,80px) + var(--safe-bottom)));
}
@media(min-width:560px)  { .app { max-width:600px;  margin:0 auto; } }
@media(min-width:768px)  { .app { max-width:860px;  } }
@media(min-width:1024px) { .app { max-width:1060px; } }

.header { display:flex; justify-content:space-between; align-items:center; margin-bottom:clamp(18px,4vw,28px); }
.loc { display:flex; align-items:center; gap:clamp(5px,1.5vw,9px); font-size:var(--f-xs); font-weight:500; letter-spacing:.1em; color:#888; text-transform:uppercase; }
.loc-dot { width:var(--dsz); height:var(--dsz); border-radius:50%; background:#4caf50; box-shadow:0 0 0 2px rgba(76,175,80,.25); flex-shrink:0; }
.avatar { width:var(--asz); height:var(--asz); border-radius:50%; background:#c9a227; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:clamp(15px,4vw,20px); color:#fff; flex-shrink:0; cursor:pointer; }

.greeting { font-family:'Playfair Display',Georgia,serif; font-size:clamp(28px,8vw,54px); font-weight:700; line-height:1.15; margin-bottom:clamp(18px,4vw,30px); color:#f0ede6; }
.greeting .name { font-style:italic; color:#c9a227; }

.search { background:#1e1e1e; border:1px solid #2a2a2a; border-radius:50px; padding:clamp(11px,2.8vw,16px) clamp(14px,3.5vw,22px); display:flex; align-items:center; gap:clamp(8px,2vw,14px); margin-bottom:clamp(14px,3.5vw,22px); }
.search svg { color:#666; flex-shrink:0; width:clamp(14px,3.5vw,18px); height:clamp(14px,3.5vw,18px); }
.search input { flex:1; background:none; border:none; outline:none; color:#999; font-size:clamp(12px,3vw,16px); font-family:'Inter',sans-serif; }
.search input::placeholder { color:#555; }

.grid { display:flex; gap:var(--gap); align-items:flex-start; }
.col  { flex:1; display:flex; flex-direction:column; gap:var(--gap); min-width:0; }

.card { border-radius:var(--r); padding:var(--cpy) var(--cpx); position:relative; overflow:hidden; cursor:pointer; transition:transform .15s ease; }
.card:hover  { transform:scale(.97); }
.card:active { transform:scale(.95); }

.navy   { background:#1b2d52; }
.coral  { background:#bf4e3a; }
.gold   { background:#c9a227; }
.cream  { background:#e8dfcc; color:#1a1a1a; }
.ivory  { background:#f4efe4; color:#1a1a1a; }
.dark   { background:#1c1c1c; }
.wine   { background:#3c1020; }
.forest { background:#2b4530; }
.aviation { background:#c8102e; }
.indigo { background:#283593; }
.slate  { background:#37474f; }
.emerald{ background:#2e7d32; }
.amber  { background:#ff8f00; color:#111; }
.rose   { background:#ad1457; }
.teal   { background:#00695c; }
.purple { background:#6a1b9a; }
.clay   { background:#6d4c41; }
.steel  { background:#455a64; }
.plum   { background:#4527a0; }
.sand   { background:#d4c4a8; color:#1a1a1a; }
.orange { background:#d84315; }
.magenta{ background:#880e4f; }
.peach  { background:#ffab91; color:#1a1a1a; }
.copper { background:#bf360c; }
.berry  { background:#880e4f; }
.ocean  { background:#0277bd; }
.charcoal{ background:#263238; }
.mint   { background:#e0f2f1; color:#1a1a1a; }
.bronze { background:#8d6e63; }
.midnight{ background:#102027; }
.terracotta{ background:#a1887f; }
.sage   { background:#c8e6c9; color:#1a1a1a; }
.aubergine{ background:#311b92; }
.sky    { background:#e1f5fe; color:#1a1a1a; }
.blush  { background:#fce4ec; color:#1a1a1a; }
.ember  { background:#e65100; }
.moss   { background:#33691e; }
.honey  { background:#fff8e1; color:#1a1a1a; }
.lilac  { background:#f3e5f5; color:#1a1a1a; }
.olive  { background:#558b2f; }
.rust   { background:#bf360c; }
.plum   { background:#4527a0; }
.midnight{ background:#102027; }

.f-giant { font-family:'Inter',sans-serif; font-weight:800; font-size:var(--f-giant); line-height:1; letter-spacing:-.02em; }
.f-aed   { font-family:'Inter',sans-serif; font-weight:800; font-size:var(--f-aed);   line-height:1; letter-spacing:-.02em; }
.f-xl    { font-family:'Playfair Display',serif; font-style:italic; font-weight:800; font-size:var(--f-xl); line-height:1.05; }
.f-xl-b  { font-family:'Playfair Display',serif; font-weight:900; font-size:var(--f-xl); line-height:1.05; }
.f-lg    { font-family:'Playfair Display',serif; font-style:italic; font-weight:800; font-size:var(--f-lg); line-height:1.05; }
.f-lg-b  { font-family:'Playfair Display',serif; font-weight:900; font-size:var(--f-lg); line-height:1.05; }
.f-md    { font-family:'Playfair Display',serif; font-style:italic; font-weight:800; font-size:var(--f-md); line-height:1.05; }
.f-base  { font-size:var(--f-base); font-weight:600; }
.f-sm    { font-size:var(--f-sm); }
.f-xs    { font-size:var(--f-xs); }

.tag { font-size:var(--f-xs); font-weight:600; letter-spacing:.13em; text-transform:uppercase; opacity:.65; margin-bottom:clamp(3px,1vw,6px); }
.tag.dt { color:#1a1a1a; }
.row { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:clamp(3px,1vw,5px); }
.dot { width:var(--dsz); height:var(--dsz); border-radius:50%; flex-shrink:0; margin-top:2px; }
.dot-red  { background:#e05040; }
.dot-gold { background:#c9a227; }
.cbtn { width:var(--bsz); height:var(--bsz); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:clamp(10px,2.5vw,14px); flex-shrink:0; }
.cb-dark  { background:#111; color:#fff; }
.cb-gold  { background:#c9a227; color:#111; font-weight:700; }
.cb-light { background:rgba(255,255,255,.18); color:#fff; }
.cb-black { background:rgba(0,0,0,.25); color:rgba(255,255,255,.8); }
.sub  { font-size:var(--f-xs); opacity:.6; margin-top:clamp(2px,.8vw,4px); }
.meta { font-size:var(--f-xs); font-weight:500; letter-spacing:.1em; text-transform:uppercase; opacity:.45; margin-top:clamp(4px,1.2vw,8px); }

.pill-btn { display:inline-flex; align-items:center; gap:clamp(4px,1.2vw,7px); background:#c9a227; color:#111; border-radius:50px; padding:clamp(5px,1.5vw,9px) clamp(8px,2.2vw,14px); font-size:var(--f-xs); font-weight:700; letter-spacing:.1em; text-transform:uppercase; margin-top:clamp(8px,2vw,14px); }
.pill-btn .bd { width:clamp(4px,1vw,6px); height:clamp(4px,1vw,6px); border-radius:50%; background:#111; }

.toggle-pill { display:flex; align-items:center; justify-content:space-between; background:rgba(0,0,0,.28); border-radius:50px; padding:clamp(6px,1.8vw,10px) clamp(8px,2vw,12px); margin-top:clamp(8px,2vw,12px); }
.toggle-pill span { font-size:var(--f-xs); font-weight:500; color:rgba(255,255,255,.9); }
.toggle { width:clamp(26px,6.5vw,38px); height:clamp(15px,3.8vw,22px); border-radius:50px; position:relative; flex-shrink:0; }
.toggle::after { content:''; position:absolute; right:2px; top:2px; width:clamp(11px,2.8vw,18px); height:clamp(11px,2.8vw,18px); border-radius:50%; background:#fff; }
.t-blue   { background:#007aff; }
.t-purple { background:#9b59b6; }

.data-row { display:flex; justify-content:space-between; font-size:var(--f-xs); margin-bottom:clamp(1px,.5vw,3px); }
.data-row .lbl { opacity:.6; }
.data-row .val { font-weight:600; }

.dot-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:clamp(3px,.8vw,5px); margin:clamp(6px,1.8vw,10px) 0; }
.dg { aspect-ratio:1; border-radius:50%; background:rgba(0,0,0,.18); }
.dg.hi { background:#c05040; }

.arch { width:clamp(38px,10vw,64px); height:clamp(44px,12vw,76px); border:clamp(3px,.8vw,6px) solid rgba(0,0,0,.2); border-radius:100px 100px 0 0; margin:clamp(6px,1.8vw,10px) auto clamp(2px,.6vw,4px); }
.wm { position:absolute; bottom:-14px; right:-4px; font-family:'Playfair Display',serif; font-weight:900; font-size:clamp(60px,18vw,110px); opacity:.07; line-height:1; pointer-events:none; }
.mini-av { width:clamp(26px,6.5vw,38px); height:clamp(26px,6.5vw,38px); border-radius:50%; background:#2e2e2e; display:flex; align-items:center; justify-content:center; font-weight:600; font-size:clamp(12px,3vw,17px); }
.dewa-oval { width:clamp(32px,8.5vw,52px); height:clamp(22px,5.5vw,34px); border-radius:50%; background:#c0392b; margin:clamp(5px,1.5vw,9px) 0 clamp(3px,1vw,5px); }
.express { display:inline-block; background:rgba(0,0,0,.3); border-radius:50px; padding:clamp(4px,1.2vw,7px) clamp(7px,1.8vw,12px); font-size:var(--f-xs); font-weight:600; margin-top:clamp(6px,1.8vw,11px); color:rgba(255,255,255,.85); }
.dial { width:clamp(34px,8.5vw,54px); height:clamp(34px,8.5vw,54px); border-radius:50%; background:radial-gradient(circle at 38% 32%,#4a4a4a,#1a1a1a); border:2px solid #333; margin:clamp(6px,1.8vw,10px) auto 0; }
.topup-btn { display:flex; align-items:center; justify-content:space-between; background:rgba(0,0,0,.2); border-radius:50px; padding:clamp(6px,1.8vw,10px) clamp(10px,2.5vw,16px); margin-top:clamp(8px,2vw,13px); font-size:var(--f-sm); font-weight:600; color:#1a1a1a; }
.damac-d { position:absolute; top:6px; left:10px; font-family:'Playfair Display',serif; font-weight:900; font-size:clamp(50px,14vw,90px); color:rgba(255,255,255,.1); line-height:1; pointer-events:none; }
.damac-i { position:absolute; bottom:clamp(36px,9vw,54px); left:clamp(14px,3.5vw,22px); font-family:'Playfair Display',serif; font-style:italic; font-weight:400; font-size:clamp(22px,6vw,38px); color:rgba(255,255,255,.06); pointer-events:none; }
@media(max-width:339px) { .grid{gap:5px;} .card{padding:9px 8px;} }

/* Layout-only: breaks medium-height runs (no color/type changes) */
#home .card.card-layout-tall:not([style*="min-height"]) {
  min-height:clamp(100px, 26vw, 150px);
}

/* ══ SLIDE VIEWS ══════════════════════════════ */
.sview {
  position:fixed; inset:0; background:#111;
  overflow-y:auto; -webkit-overflow-scrolling:touch;
  transform:translateX(100%);
  transition:transform .3s cubic-bezier(0.4,0,0.2,1);
  will-change:transform;
  visibility: hidden;
}
#biz  { z-index:50; }
#chat { z-index:100; display:flex; flex-direction:column; overflow:hidden; }
.sview.open { transform:translateX(0); visibility: visible; }

/* ── iOS / PWA safe area — business & chat slide views ── */
#biz.sview:not(.mushrif-biz) {
  padding-top: var(--safe-top);
  box-sizing: border-box;
}
#chat.sview {
  padding-top: var(--safe-top);
  box-sizing: border-box;
}

/* Sticky top bars — stay below notch when scrolling */
#biz.sview .nbar {
  top: var(--safe-top);
}

/* ── NAV BAR ── */
.nbar {
  position:sticky; top:var(--safe-top); z-index:10;
  display:flex; align-items:center; gap:12px;
  padding:12px max(clamp(14px,3.5vw,20px), var(--safe-left)) 12px max(clamp(14px,3.5vw,20px), var(--safe-right));
  background:rgba(17,17,17,.93);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.07);
}
.back { display:flex; align-items:center; gap:4px; color:#c9a227; font-size:clamp(13px,3.2vw,15px); font-weight:600; cursor:pointer; flex-shrink:0; }

/* ── BUSINESS PAGE ── */
.biz-hero { padding:clamp(28px,7vw,44px) clamp(16px,4vw,28px) clamp(24px,6vw,36px); position:relative; overflow:hidden; }
.biz-cat  { font-size:9.5px; font-weight:700; letter-spacing:.15em; text-transform:uppercase; opacity:.55; margin-bottom:10px; }
.biz-name { font-family:'Playfair Display',serif; font-style:italic; font-weight:800; font-size:clamp(32px,8.5vw,54px); line-height:1.05; margin-bottom:8px; }
.biz-line { font-size:clamp(12px,3vw,14px); opacity:.6; line-height:1.5; }
.biz-deco { position:absolute; bottom:-22px; right:-8px; font-family:'Playfair Display',serif; font-weight:900; font-size:clamp(100px,28vw,160px); opacity:.08; line-height:1; pointer-events:none; }

.opts-hd { padding:clamp(16px,4vw,22px) clamp(14px,3.5vw,20px) clamp(8px,2vw,12px); font-size:9.5px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; opacity:.38; }
.opts-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(8px,2vw,12px);
  padding:0 clamp(14px,3.5vw,48px) clamp(40px,10vw,60px);
  max-width:min(1280px, 100%);
  margin:0 auto;
  width:100%;
}

@media(min-width:600px) {
  .opts-grid { grid-template-columns:repeat(3, 1fr); }
}

@media(min-width:900px) {
  .opts-grid { grid-template-columns:repeat(4, 1fr); }
}
.opt-card { background:#1a1a1a; border:1px solid rgba(255,255,255,.06); border-radius:clamp(16px,4vw,22px); padding:clamp(14px,3.5vw,22px) clamp(12px,3vw,18px); cursor:pointer; transition:transform .14s ease,background .14s; }
.opt-card:hover  { background:#1f1f1f; }
.opt-card:active { transform:scale(.95); }
.opt-icon  { font-size:clamp(22px,5.5vw,32px); margin-bottom:clamp(8px,2vw,12px); line-height:1; }
.opt-label { font-size:clamp(12px,3vw,15px); font-weight:700; margin-bottom:4px; color:#f0ede6; }
.opt-desc  { font-size:clamp(10px,2.5vw,12px); opacity:.45; line-height:1.45; color:#f0ede6; }

/* ════════════════════════════════════════════
   CHAT UI — Professional
════════════════════════════════════════════ */

/* ── Chat nav bar ── */
.chat-nbar { justify-content:space-between; }

.chat-back-btn {
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.06); border:none;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:#aaa; flex-shrink:0;
  transition:background .15s, color .15s;
}
.chat-back-btn:hover { background:rgba(255,255,255,.1); color:#f0ede6; }

.chat-new-btn {
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.06); border:none;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:#aaa; flex-shrink:0;
  transition:background .15s, color .15s;
}
.chat-new-btn:hover { background:rgba(255,255,255,.1); color:#f0ede6; }

/* ── Recent chats panel ── */
.rc-panel {
  position:absolute; top:0; right:0; bottom:0;
  width:min(320px,100%);
  background:#161616;
  border-left:1px solid rgba(255,255,255,.08);
  z-index:20;
  display:flex; flex-direction:column;
  animation:rcSlideIn .2s ease;
}
@keyframes rcSlideIn {
  from { transform:translateX(100%); opacity:0; }
  to   { transform:translateX(0);    opacity:1; }
}
.rc-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 16px 12px;
  border-bottom:1px solid rgba(255,255,255,.06);
  flex-shrink:0;
}
.rc-title { font-size:14px; font-weight:700; color:#f0ede6; letter-spacing:.04em; }
.rc-close {
  width:30px; height:30px; border-radius:50%;
  background:rgba(255,255,255,.06); border:none;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:#aaa; transition:background .15s,color .15s;
}
.rc-close:hover { background:rgba(255,255,255,.1); color:#f0ede6; }
.rc-list { overflow-y:auto; flex:1; }
.rc-row {
  padding:13px 16px;
  border-bottom:1px solid rgba(255,255,255,.04);
  cursor:pointer; transition:background .15s;
}
.rc-row:hover { background:rgba(255,255,255,.05); }
.rc-row.rc-active { background:rgba(255,255,255,.03); }
.rc-row-top { display:flex; align-items:center; gap:8px; margin-bottom:4px; }
.rc-date { font-size:11px; color:#666; letter-spacing:.02em; }
.rc-badge {
  font-size:9px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  background:rgba(0,180,120,.14); color:#00b478;
  padding:2px 6px; border-radius:4px;
}
.rc-preview { font-size:13px; color:#bbb; line-height:1.4; margin-bottom:3px; }
.rc-count { font-size:11px; color:#555; }
.rc-empty { padding:32px 16px; text-align:center; font-size:13px; color:#555; }

.chat-agent-info {
  display:flex; align-items:center; gap:10px; flex:1; min-width:0; margin:0 10px;
}
.ag-av {
  width:clamp(36px,9vw,44px); height:clamp(36px,9vw,44px);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:clamp(12px,3vw,15px); font-weight:700; flex-shrink:0;
}
.ag-text { min-width:0; }
.ag-name {
  font-size:clamp(13px,3.5vw,16px); font-weight:700;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.ag-status-row { display:flex; align-items:center; gap:5px; margin-top:2px; }
.ag-online-dot {
  width:6px; height:6px; border-radius:50%; background:#4caf50;
  box-shadow:0 0 0 2px rgba(76,175,80,.25); flex-shrink:0;
}
.ag-status-label { font-size:10px; color:#4caf50; font-weight:600; }

/* ── Input-area mic button ── */
.cin-mic-btn {
  width: 42px; height: 42px; border-radius: 50%;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0; color: #888;
  transition: background .15s, color .15s, transform .12s;
}
.cin-mic-btn:hover  { background: rgba(255,255,255,.1); color: #f0ede6; }
.cin-mic-btn:active { transform: scale(.9); }
.cin-mic-btn.recording {
  background: rgba(201,162,39,.15); border-color: rgba(201,162,39,.5);
  color: #c9a227;
  animation: mic-ring 1.1s ease-in-out infinite;
}
@keyframes mic-ring {
  0%,100% { box-shadow: 0 0 0 0 rgba(201,162,39,.4); }
  55%      { box-shadow: 0 0 0 10px rgba(201,162,39,0); }
}

/* ── Input-area call button ── */
.cin-call-btn {
  width: 42px; height: 42px; border-radius: 50%;
  background: #4caf50; border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0; color: #fff;
  box-shadow: 0 2px 10px rgba(76,175,80,.4);
  transition: background .15s, transform .12s, box-shadow .15s;
}
.cin-call-btn:hover  { background: #43a047; box-shadow: 0 4px 14px rgba(76,175,80,.55); }
.cin-call-btn:active { transform: scale(.9); }
.cin-call-btn.recording {
  background: #e05040;
  box-shadow: 0 2px 10px rgba(224,80,64,.4);
  animation: call-ring 1.2s ease-in-out infinite;
}
@keyframes call-ring {
  0%,100% { box-shadow: 0 0 0 0 rgba(224,80,64,.4); }
  50%      { box-shadow: 0 0 0 10px rgba(224,80,64,0); }
}

/* ── Chat messages ── */
.chat-msgs {
  flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch;
  padding:clamp(14px,3.5vw,22px) clamp(12px,3vw,18px);
  display:flex; flex-direction:column; gap:clamp(6px,1.5vw,10px);
}

/* ── Message bubbles ── */
.mwrap { display:flex; flex-direction:column; }
.mwrap.user  { align-items:flex-end; }
.mwrap.agent { align-items:flex-start; }
.mbub {
  max-width:80%;
  padding:clamp(10px,2.5vw,13px) clamp(13px,3.2vw,18px);
  font-size:clamp(13px,3.2vw,15px); line-height:1.55; word-wrap:break-word;
}
.mbub.agent {
  background:#1c1c1c; color:#e8e5de;
  border-radius:4px 18px 18px 18px;
  border:1px solid rgba(255,255,255,.06);
}
.mbub.user {
  background:linear-gradient(135deg,#1b2d52 0%,#152040 100%);
  color:#f0ede6; border-radius:18px 4px 18px 18px;
}
.mtime { font-size:9px; opacity:.28; margin-top:3px; padding:0 3px; letter-spacing:.02em; }

/* ── Human agent bubble ── */
.human-agent-label {
  font-size:9px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:#a78bfa; margin-bottom:3px; padding-left:3px;
}
.mbub.human-agent-bub {
  background:rgba(109,40,217,.18);
  border-color:rgba(109,40,217,.3);
  color:#ede9fe;
}
.agent-quote {
  background:rgba(255,255,255,.08);
  border-left:3px solid #a78bfa;
  border-radius:5px;
  padding:.25rem .5rem;
  margin-bottom:.4rem;
}
.agent-quote-label {
  font-size:.6rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.06em; color:#c4b5fd; margin-bottom:.1rem;
}
.agent-quote-text {
  font-size:.75rem; color:#ddd6fe;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}

/* ── Typing dots ── */
.twrap { display:flex; gap:5px; align-items:center; padding:13px 16px; background:#1c1c1c; border-radius:4px 18px 18px 18px; width:fit-content; border:1px solid rgba(255,255,255,.06); }
.tdot  { width:6px; height:6px; border-radius:50%; background:#555; animation:tdot 1.3s infinite ease-in-out; }
.tdot:nth-child(2) { animation-delay:.18s; }
.tdot:nth-child(3) { animation-delay:.36s; }
@keyframes tdot { 0%,60%,100%{transform:translateY(0);opacity:.35;} 30%{transform:translateY(-6px);opacity:1;} }

/* ── Quick chips ── */
.chips {
  display:flex; gap:7px;
  padding:10px clamp(12px,3vw,18px);
  overflow-x:auto; -webkit-overflow-scrolling:touch;
  border-top:1px solid rgba(255,255,255,.05);
}
.chips::-webkit-scrollbar { display:none; }
.chip {
  white-space:nowrap; background:#181818;
  border:1px solid rgba(255,255,255,.09); border-radius:50px;
  padding:7px 14px; font-size:12px; font-weight:500; color:#888;
  cursor:pointer; flex-shrink:0; font-family:'Inter',sans-serif;
  transition:background .12s, color .12s, border-color .12s;
}
.chip:hover  { background:#202020; color:#f0ede6; border-color:rgba(255,255,255,.16); }
.chip:active { transform:scale(.95); }

/* ── Input bar ── */
.cibar {
  display:flex; gap:8px; align-items:center;
  padding:clamp(8px,2vw,12px) max(clamp(12px,3vw,18px), var(--safe-right)) calc(clamp(14px,3.5vw,20px) + var(--safe-bottom)) max(clamp(12px,3vw,18px), var(--safe-left));
  background:#111;
  border-top:1px solid rgba(255,255,255,.05);
}
.cin {
  flex:1; background:#1a1a1a; border:1px solid #252525;
  border-radius:24px;
  padding:clamp(10px,2.5vw,12px) clamp(16px,4vw,20px);
  color:#f0ede6; font-size:clamp(13px,3.2vw,15px);
  font-family:'Inter',sans-serif; outline:none;
  transition:border-color .2s;
}
.cin::placeholder { color:#444; }
.cin:focus { border-color:#333; }
.sbtn {
  width:clamp(40px,10vw,48px); height:clamp(40px,10vw,48px);
  border-radius:50%; background:#c9a227; border:none;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  flex-shrink:0; color:#111;
  transition:transform .12s ease, background .15s;
}
.sbtn:hover:not(:disabled)  { background:#d4ab2e; }
.sbtn:active { transform:scale(.9); }
.sbtn:disabled { opacity:.35; cursor:not-allowed; transform:none; }

/* ── Streaming cursor ── */
.mbub.streaming::after { content:'▌'; animation:blink .65s infinite; opacity:.6; font-size:.8em; margin-left:2px; }
@keyframes blink { 0%,100%{opacity:.6;} 50%{opacity:0;} }

/* ── Reply chips ── */
.reply-chips { display:flex; flex-wrap:wrap; gap:6px; margin-top:10px; }
.reply-chip {
  display:inline-flex; align-items:center; gap:5px;
  background:rgba(201,162,39,.1); border:1px solid rgba(201,162,39,.3);
  border-radius:50px; padding:5px 12px;
  font-size:clamp(10px,2.4vw,12px); font-weight:600; color:#c9a227;
  cursor:pointer; transition:background .15s, transform .1s;
  user-select:none; font-family:'Inter',sans-serif;
}
.reply-chip:hover  { background:rgba(201,162,39,.2); }
.reply-chip:active { transform:scale(.94); }
.reply-chip .chip-arrow { opacity:.5; font-size:.85em; }
.chip-skeleton {
  height:28px; border-radius:50px;
  background:linear-gradient(90deg,rgba(201,162,39,.06) 25%,rgba(201,162,39,.16) 50%,rgba(201,162,39,.06) 75%);
  background-size:200% 100%; animation:chipShimmer 1.4s infinite;
}
@keyframes chipShimmer { 0%{background-position:200% 0;} 100%{background-position:-200% 0;} }
.reply-chips.loaded { animation:chipsFadeIn .3s ease; }
@keyframes chipsFadeIn { from{opacity:0;transform:translateY(4px);} to{opacity:1;transform:none;} }
.voice-reply-chips {
  display:flex; flex-wrap:wrap; gap:7px; margin-top:10px;
  opacity:0; transform:translateY(8px);
  transition:opacity .22s ease, transform .22s cubic-bezier(.34,1.56,.64,1);
}
.voice-reply-chips.loaded { opacity:1; transform:translateY(0); }
.voice-reply-chips .reply-chip { font-size:clamp(11px,2.6vw,13px); }

/* ════════════════════════════════════════════
   VOICE CALL CARD — Professional redesign
   Inspired by modern realtime voice UIs
════════════════════════════════════════════ */

.vb-card {
  background: #161616;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 18px;
  padding: 14px 16px 16px;
  margin: 6px auto;
  max-width: 340px;
  width: 100%;
  animation: vb-enter .3s cubic-bezier(.34,1.56,.64,1);
  transition: border-color .4s;
}
@keyframes vb-enter {
  from { opacity:0; transform:translateY(8px) scale(.98); }
  to   { opacity:1; transform:none; }
}

/* ── Top row: dot + name/status + hang-up ── */
.vb-top {
  display: flex;
  align-items: center;
  gap: 11px;
  margin-bottom: 14px;
}

/* State indicator dot */
.vb-dot-wrap {
  width: 32px; height: 32px;
  border-radius: 50%;
  flex-shrink: 0;
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.vb-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: #444;
  transition: background .35s;
  z-index: 1;
}
.vb-dot-ring {
  position: absolute; inset: 0; border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,.08);
  transition: border-color .35s;
}

/* Meta text */
.vb-meta { flex: 1; min-width: 0; }
.vb-title {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; font-weight: 700; color: #f0ede6;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.vb-live-badge {
  font-size: 8.5px; font-weight: 800; letter-spacing: .08em;
  color: #e05040; flex-shrink: 0;
  animation: live-pip 1.8s ease-in-out infinite;
}
@keyframes live-pip { 0%,100%{opacity:1;} 50%{opacity:.3;} }
.vb-sub {
  font-size: 11px; color: #555; margin-top: 3px;
  font-weight: 500; transition: color .3s;
}
.vb-timer {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: .04em;
  color: #444;
  margin-left: auto;
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}
.vb-keepgoing {
  display: inline-block;
  padding: 1px 9px;
  border-radius: 20px;
  border: 1px solid rgba(201,162,39,.35);
  background: rgba(201,162,39,.08);
  color: #c9a227;
  font-size: 10px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  vertical-align: middle;
  margin-left: 5px;
  transition: background .15s;
}
.vb-keepgoing:hover  { background: rgba(201,162,39,.2); }
.vb-keepgoing:active { transform: scale(.94); }

/* Hang-up button — always inside the card */
.vb-hang {
  width: 38px; height: 38px; border-radius: 50%;
  background: #e05040; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: #fff; flex-shrink: 0;
  box-shadow: 0 3px 10px rgba(224,80,64,.45);
  transition: background .15s, transform .12s;
}
.vb-hang:hover  { background: #c04030; }
.vb-hang:active { transform: scale(.88); }

/* ── Waveform bars ── */
.vb-wave {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  height: 40px;
}
.vb-b {
  width: 3px;
  min-height: 3px;
  border-radius: 100px;
  background: #2a2a2a;
  transform-origin: center bottom;
  transition: background .3s;
  /* default: flat/idle */
  height: 3px;
}

/* ─────────────────────────────────────
   STATE MACHINE — data-voice-state
───────────────────────────────────── */

/* CONNECTING — amber dot spinning, bars ripple slowly */
#chat[data-voice-state="connecting"] .vb-card   { border-color: rgba(201,162,39,.25); }
#chat[data-voice-state="connecting"] .vb-dot     { background: #c9a227; }
#chat[data-voice-state="connecting"] .vb-dot-ring { border-color: transparent; border-top-color: rgba(201,162,39,.6); animation: dot-spin .9s linear infinite; }
#chat[data-voice-state="connecting"] .vb-sub     { color: #c9a227; }
#chat[data-voice-state="connecting"] .vb-b       { background: #2a2a2a; animation: bar-idle 1.6s ease-in-out infinite alternate; animation-delay: calc(var(--i) * 0.1s); }

/* LISTENING — green dot pulse, bars respond to mic */
#chat[data-voice-state="listening"] .vb-card    { border-color: rgba(76,175,80,.25); }
#chat[data-voice-state="listening"] .vb-dot     { background: #4caf50; animation: dot-breathe 1.6s ease-in-out infinite; }
#chat[data-voice-state="listening"] .vb-dot-ring { border-color: rgba(76,175,80,.3); animation: ring-ripple 1.6s ease-in-out infinite; }
#chat[data-voice-state="listening"] .vb-sub     { color: #4caf50; }
#chat[data-voice-state="listening"] .vb-b       {
  background: #4caf50;
  /* --live is set by JS from real mic data; fallback to gentle animation */
  height: calc(3px + var(--live, 0) * 34px);
  animation: bar-listen 1.4s ease-in-out infinite alternate;
  animation-delay: calc(var(--i) * 0.09s);
}

/* THINKING — amber dot spin, bars in loading sweep */
#chat[data-voice-state="thinking"] .vb-card    { border-color: rgba(201,162,39,.25); }
#chat[data-voice-state="thinking"] .vb-dot     { background: #c9a227; animation: dot-pulse-beat .7s ease-in-out infinite alternate; }
#chat[data-voice-state="thinking"] .vb-dot-ring { border-color: transparent; border-top-color: rgba(201,162,39,.7); animation: dot-spin .55s linear infinite; }
#chat[data-voice-state="thinking"] .vb-sub     { color: #c9a227; }
#chat[data-voice-state="thinking"] .vb-b       { background: #c9a227; animation: bar-think 0.9s ease-in-out infinite alternate; animation-delay: calc(var(--i) * 0.06s); }

/* SPEAKING — blue dot ripple, bars dance energetically */
#chat[data-voice-state="speaking"] .vb-card    { border-color: rgba(126,181,240,.25); }
#chat[data-voice-state="speaking"] .vb-dot     { background: #7eb5f0; animation: dot-breathe .7s ease-in-out infinite; }
#chat[data-voice-state="speaking"] .vb-dot-ring { border-color: rgba(126,181,240,.35); animation: ring-ripple .7s ease-in-out infinite; }
#chat[data-voice-state="speaking"] .vb-sub     { color: #7eb5f0; }
#chat[data-voice-state="speaking"] .vb-b       { background: #7eb5f0; animation: bar-speak .55s ease-in-out infinite alternate; animation-delay: calc(var(--i) * 0.05s); }

/* YOUR TURN — gold dot steady, bars settle */
#chat[data-voice-state="chips"] .vb-card    { border-color: rgba(201,162,39,.2); }
#chat[data-voice-state="chips"] .vb-dot     { background: #c9a227; }
#chat[data-voice-state="chips"] .vb-dot-ring { border-color: rgba(201,162,39,.25); }
#chat[data-voice-state="chips"] .vb-sub     { color: #c9a227; }
#chat[data-voice-state="chips"] .vb-b       { background: #3a3a2a; height: 3px; animation: none; }

/* TOOL_CALL — purple dot, bars do a left-to-right scan sweep */
#chat[data-voice-state="tool_call"] .vb-card    { border-color: rgba(180,120,255,.2); }
#chat[data-voice-state="tool_call"] .vb-dot     { background: #b478ff; animation: dot-pulse-beat .6s ease-in-out infinite alternate; }
#chat[data-voice-state="tool_call"] .vb-dot-ring { border-color: transparent; border-top-color: rgba(180,120,255,.7); animation: dot-spin .5s linear infinite; }
#chat[data-voice-state="tool_call"] .vb-sub     { color: #b478ff; }
#chat[data-voice-state="tool_call"] .vb-b       {
  background: #b478ff;
  animation: bar-scan 1.1s ease-in-out infinite;
  animation-delay: calc(var(--i) * 0.055s);
}

/* ── Bar keyframes ── */
@keyframes bar-scan {
  0%   { height: 3px;  opacity: .35; }
  50%  { height: 22px; opacity: 1;   }
  100% { height: 3px;  opacity: .35; }
}
@keyframes bar-idle {
  from { height: 3px; }
  to   { height: 10px; }
}
@keyframes bar-listen {
  from { height: 4px; }
  to   { height: 18px; }
}
@keyframes bar-think {
  from { height: 4px; }
  to   { height: 26px; }
}
@keyframes bar-speak {
  0%   { height: 4px; }
  30%  { height: 36px; }
  60%  { height: 20px; }
  100% { height: 8px; }
}

/* ── Dot / ring keyframes ── */
@keyframes dot-spin     { to { transform: rotate(360deg); } }
@keyframes dot-breathe  { 0%,100%{transform:scale(1);} 50%{transform:scale(1.4);} }
@keyframes dot-pulse-beat { from{transform:scale(.75);opacity:.6;} to{transform:scale(1.1);opacity:1;} }
@keyframes ring-ripple  { 0%,100%{transform:scale(1);opacity:.5;} 50%{transform:scale(1.6);opacity:0;} }

/* ── QR SCANNER FAB (mobile only) ── */
.qr-fab {
  position: fixed;
  right: max(16px, env(safe-area-inset-right, 16px));
  bottom: max(20px, env(safe-area-inset-bottom, 20px));
  z-index: 120;
  width: clamp(52px, 13vw, 58px);
  height: clamp(52px, 13vw, 58px);
  border-radius: 50%;
  border: 1px solid rgba(201, 162, 39, .35);
  background: linear-gradient(145deg, #1e1e1e 0%, #141414 100%);
  color: #c9a227;
  cursor: pointer;
  display: none !important;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .45), 0 0 0 1px rgba(255, 255, 255, .04) inset;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
@media (max-width: 767px) {
  .qr-fab.qr-fab--show { display: flex !important; }
}
.qr-fab:hover {
  background: linear-gradient(145deg, #252525 0%, #1a1a1a 100%);
  box-shadow: 0 6px 28px rgba(0, 0, 0, .55), 0 0 0 1px rgba(201, 162, 39, .2) inset;
  transform: translateY(-2px);
}
.qr-fab:active { transform: scale(.94); }
.qr-fab[hidden] { display: none !important; }
.qr-fab svg { width: 26px; height: 26px; }

.qr-overlay {
  position: fixed;
  inset: 0;
  z-index: 9500;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(16px, env(safe-area-inset-top, 16px)) max(16px, env(safe-area-inset-right, 16px)) max(16px, env(safe-area-inset-bottom, 16px)) max(16px, env(safe-area-inset-left, 16px));
  background: rgba(8, 8, 8, .72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  opacity: 0;
  transition: opacity .28s ease;
}
.qr-overlay[hidden] { display: none; }
.qr-overlay.open { opacity: 1; }

.qr-sheet {
  width: min(420px, 100%);
  max-height: min(90vh, 640px);
  overflow-y: auto;
  background: #161616;
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 20px;
  padding: 20px 18px 18px;
  box-shadow: 0 24px 60px rgba(0, 0, 0, .55);
  transform: scale(.94);
  opacity: 0;
  transition: transform .28s cubic-bezier(0.4, 0, 0.2, 1), opacity .28s ease;
}
.qr-overlay.open .qr-sheet {
  transform: scale(1);
  opacity: 1;
}

.qr-sheet-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.qr-sheet-title {
  font-size: 15px;
  font-weight: 700;
  color: #f0ede6;
  letter-spacing: .02em;
}
.qr-close {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .1);
  background: rgba(255, 255, 255, .04);
  color: #aaa;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  line-height: 1;
  transition: background .15s, color .15s;
}
.qr-close:hover { background: rgba(255, 255, 255, .1); color: #f0ede6; }

#qr-reader {
  border-radius: 14px;
  overflow: hidden;
  background: #0a0a0a;
  min-height: 260px;
}
#qr-reader video { border-radius: 14px; }
#qr-reader img { display: none; }
#qr-reader__scan_region { background: #0a0a0a !important; }
#qr-reader__dashboard_section { display: none !important; }
#qr-reader__header_message { display: none !important; }

.qr-status {
  min-height: 18px;
  margin: 12px 0 10px;
  font-size: 12px;
  color: #888;
  text-align: center;
  line-height: 1.4;
}
.qr-status--ok { color: #4caf50; }
.qr-status--err { color: #e05040; }

.qr-upload-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 11px 14px;
  border-radius: 10px;
  border: 1px dashed rgba(255, 255, 255, .14);
  background: rgba(255, 255, 255, .03);
  color: #bbb;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
}
.qr-upload-btn:hover {
  background: rgba(201, 162, 39, .08);
  border-color: rgba(201, 162, 39, .35);
  color: #f0ede6;
}

/* ── IN-STORE PRODUCT SCANNER ── */
.ps-fab {
  position: fixed;
  right: max(16px, env(safe-area-inset-right, 16px));
  bottom: max(84px, calc(20px + env(safe-area-inset-bottom, 20px) + 64px));
  z-index: 121;
  width: clamp(52px, 13vw, 58px);
  height: clamp(52px, 13vw, 58px);
  padding: 0;
  border-radius: 50%;
  -webkit-appearance: none;
  appearance: none;
  border: 1px solid color-mix(in srgb, var(--ps-accent, #1e4a3d) 55%, transparent);
  background: linear-gradient(145deg, #1e4a3d 0%, #163a30 100%);
  color: #f5efe6;
  cursor: pointer;
  display: none !important;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .45);
  transition: transform .15s ease, box-shadow .15s ease;
}
@media (max-width: 767px) {
  .ps-fab.ps-fab--show { display: flex !important; }
}
.ps-fab:hover { transform: translateY(-2px); box-shadow: 0 6px 28px rgba(0, 0, 0, .55); }
.ps-fab:active { transform: scale(.94); }
.ps-fab[hidden] { display: none !important; }
.ps-fab svg.ps-icon,
.ps-fab .ps-icon {
  width: 30px;
  height: 30px;
  flex-shrink: 0;
  display: block;
}
.ps-fab .ps-icon-frame {
  stroke: currentColor;
  fill: none;
}
.ps-fab .ps-icon-fill {
  fill: currentColor;
  stroke: none;
}

.ps-overlay {
  position: fixed;
  inset: 0;
  z-index: 9600;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(16px, env(safe-area-inset-top, 16px)) max(16px, env(safe-area-inset-right, 16px)) max(16px, env(safe-area-inset-bottom, 16px)) max(16px, env(safe-area-inset-left, 16px));
  background: rgba(8, 8, 8, .78);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  opacity: 0;
  transition: opacity .28s ease;
}
.ps-overlay[hidden] { display: none; }
.ps-overlay.open { opacity: 1; }

.ps-sheet {
  width: min(440px, 100%);
  max-height: min(92vh, 720px);
  overflow-y: auto;
  background: #161616;
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 20px;
  padding: 20px 18px 18px;
  box-shadow: 0 24px 60px rgba(0, 0, 0, .55);
  transform: scale(.94);
  opacity: 0;
  transition: transform .28s cubic-bezier(0.4, 0, 0.2, 1), opacity .28s ease;
}
.ps-overlay.open .ps-sheet { transform: scale(1); opacity: 1; }

.ps-sheet-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.ps-sheet-title {
  font-size: 15px;
  font-weight: 700;
  color: #f0ede6;
  letter-spacing: .02em;
}
.ps-close {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .1);
  background: rgba(255, 255, 255, .04);
  color: #aaa;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  line-height: 1;
}
.ps-close:hover { background: rgba(255, 255, 255, .1); color: #f0ede6; }

#ps-reader {
  border-radius: 14px;
  overflow: hidden;
  background: #0a0a0a;
  min-height: 220px;
}
#ps-reader video { border-radius: 14px; }
#ps-reader img { display: none; }
#ps-reader__scan_region { background: #0a0a0a !important; }
#ps-reader__dashboard_section { display: none !important; }
#ps-reader__header_message { display: none !important; }

.ps-status {
  min-height: 18px;
  margin: 12px 0 8px;
  font-size: 12px;
  color: #888;
  text-align: center;
  line-height: 1.4;
}
.ps-status--ok { color: #4caf50; }
.ps-status--err { color: #e05040; }

.ps-result { margin-bottom: 12px; }
.ps-result[hidden] { display: none; }

.ps-product {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 12px;
  padding: 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, .04);
  border: 1px solid rgba(255, 255, 255, .08);
}
.ps-product-img {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  background: color-mix(in srgb, var(--ps-accent) 18%, #111);
  min-height: 96px;
}
.ps-product-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ps-product-fallback {
  width: 100%;
  height: 96px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 800;
  color: var(--ps-accent);
}
.ps-product-badge {
  position: absolute;
  top: 6px;
  left: 6px;
  padding: 2px 7px;
  border-radius: 999px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: var(--ps-accent);
  color: #fff;
}
.ps-product-cat {
  margin: 0 0 4px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #777;
}
.ps-product-name {
  margin: 0 0 6px;
  font-size: 14px;
  font-weight: 700;
  color: #f0ede6;
  line-height: 1.3;
}
.ps-product-price {
  margin: 0 0 6px;
  font-size: 16px;
  font-weight: 800;
  color: var(--ps-accent);
}
.ps-product-codes {
  margin: 0 0 10px;
  font-size: 10px;
  color: #666;
  line-height: 1.4;
}
.ps-product-chat {
  width: 100%;
  padding: 8px 10px;
  border: none;
  border-radius: 8px;
  background: var(--ps-accent);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}

.ps-samples { margin: 8px 0 12px; }
.ps-samples-title {
  margin: 0 0 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #666;
}
.ps-samples-hint {
  margin: 0 0 10px;
  font-size: 12px;
  line-height: 1.45;
  color: #999;
}
.ps-samples-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 160px;
  overflow-y: auto;
}
.ps-sample {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2px 8px;
  width: 100%;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, .08);
  background: rgba(255, 255, 255, .03);
  color: #ccc;
  text-align: left;
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.ps-sample:hover {
  background: color-mix(in srgb, var(--ps-accent, #1e4a3d) 12%, transparent);
  border-color: color-mix(in srgb, var(--ps-accent, #1e4a3d) 35%, transparent);
}
.ps-sample-type {
  grid-row: span 2;
  align-self: center;
  padding: 3px 6px;
  border-radius: 6px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: .08em;
  background: rgba(255, 255, 255, .08);
  color: #aaa;
}
.ps-sample-label {
  font-size: 12px;
  font-weight: 600;
  color: #f0ede6;
}
.ps-sample-code {
  grid-column: 2;
  font-size: 10px;
  font-family: ui-monospace, monospace;
  color: #777;
  word-break: break-all;
}

.ps-manual {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
}
.ps-manual-input {
  flex: 1;
  min-width: 0;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, .1);
  background: #0e0e0e;
  color: #f0ede6;
  font-size: 13px;
  outline: none;
}
.ps-manual-input:focus { border-color: color-mix(in srgb, var(--ps-accent, #1e4a3d) 60%, transparent); }
.ps-manual-btn {
  padding: 10px 14px;
  border: none;
  border-radius: 10px;
  background: color-mix(in srgb, var(--ps-accent, #1e4a3d) 85%, #000);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
}

.ps-upload-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 11px 14px;
  border-radius: 10px;
  border: 1px dashed rgba(255, 255, 255, .14);
  background: rgba(255, 255, 255, .03);
  color: #bbb;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}
.ps-upload-btn:hover {
  background: color-mix(in srgb, var(--ps-accent, #1e4a3d) 10%, transparent);
  border-color: color-mix(in srgb, var(--ps-accent, #1e4a3d) 35%, transparent);
  color: #f0ede6;
}

/* ── NOT-CONFIGURED BANNER ── */
.config-banner {
  position:fixed; top:0; left:0; right:0; z-index:9999;
  background:#c05040; color:#fff;
  padding:calc(10px + var(--safe-top)) max(20px, var(--safe-right)) 10px max(20px, var(--safe-left));
  font-size:clamp(11px,2.8vw,13px); font-weight:500; font-family:'Inter',sans-serif;
  text-align:center; line-height:1.5;
}
.config-banner code {
  background:rgba(0,0,0,.25); border-radius:4px;
  padding:1px 6px; font-family:monospace; font-size:.95em;
}

/* ════════════════════════════════════════════
   EMIRATES AIRLINE — Custom business page
════════════════════════════════════════════ */
#biz.emirates-biz {
  background:#b8c9d8;
  color:#1a2b4a;
  overflow-x:hidden;
}

.ek-page {
  display:flex;
  flex-direction:column;
  min-height:100vh;
  background:linear-gradient(180deg, #9eb5cc 0%, #b8c9d8 42%, #c5d4e0 100%);
  padding-bottom:clamp(20px, 4vw, 40px);
}

/* ── Hero banner ── */
.ek-hero {
  position:relative;
  flex-shrink:0;
  height:clamp(300px, 48vh, 440px);
  overflow:hidden;
  isolation:isolate;
}

.ek-hero-bg {
  position:absolute;
  inset:0;
  background:#9eb5cc url('../images/emirates-hero.png') 62% 42% / cover no-repeat;
}

.ek-hero-overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(
    95deg,
    rgba(255, 248, 238, 0.92) 0%,
    rgba(255, 248, 238, 0.5) 36%,
    rgba(255, 255, 255, 0) 58%
  ),
  linear-gradient(180deg, transparent 50%, rgba(184, 201, 216, 0.4) 100%);
}

.ek-hero-shine {
  position:absolute;
  top:-20%;
  left:-10%;
  width:55%;
  height:70%;
  background:radial-gradient(ellipse at 30% 40%, rgba(255, 220, 160, 0.35) 0%, transparent 70%);
  pointer-events:none;
  z-index:1;
}

.ek-back {
  position:absolute;
  top:clamp(14px, 3vw, 22px);
  left:clamp(16px, 4vw, 28px);
  z-index:4;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:10px 14px 10px 10px;
  border:1px solid rgba(255, 255, 255, 0.65);
  border-radius:14px;
  background:rgba(255, 255, 255, 0.55);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  color:#1a2b4a;
  font-family:'Inter', sans-serif;
  font-size:clamp(14px, 3.2vw, 15px);
  font-weight:600;
  cursor:pointer;
  box-shadow:0 4px 20px rgba(26, 43, 74, 0.08);
  transition:transform .15s ease, box-shadow .15s ease;
  -webkit-tap-highlight-color:transparent;
}
.ek-back:hover {
  box-shadow:0 6px 24px rgba(26, 43, 74, 0.12);
}
.ek-back:active { transform:scale(0.97); }
.ek-back svg { flex-shrink:0; }

.ek-hero-inner {
  position:relative;
  z-index:2;
  height:100%;
  max-width:1140px;
  margin:0 auto;
  padding:clamp(52px, 11vw, 72px) clamp(20px, 4vw, 40px) clamp(28px, 6vw, 48px);
  display:flex;
  align-items:flex-end;
  justify-content:flex-start;
}

.ek-hero-glass,
.ek-hero-content {
  max-width:min(520px, 100%);
  text-align:left;
}

.ek-hero-pills {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
}

.ek-pill {
  display:inline-flex;
  align-items:center;
  padding:6px 12px;
  font-family:'Inter', sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:.04em;
  color:#1a2b4a;
  background:rgba(255, 255, 255, 0.7);
  border:1px solid rgba(255, 255, 255, 0.9);
  border-radius:999px;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}

.ek-hero-label {
  font-size:11px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#c8102e;
  margin:0 0 10px;
}

.ek-hero-title {
  font-family:'Playfair Display', Georgia, serif;
  font-style:italic;
  font-weight:800;
  font-size:clamp(44px, 11vw, 72px);
  line-height:1.02;
  color:#c8102e;
  margin:0 0 14px;
  letter-spacing:-.01em;
}

.ek-hero-tagline {
  font-family:'Inter', sans-serif;
  font-size:clamp(15px, 3.6vw, 18px);
  font-weight:500;
  color:#3d4f66;
  line-height:1.5;
  margin:0 0 2px;
  max-width:22em;
}

.ek-hero-sub {
  font-family:'Inter', sans-serif;
  font-size:clamp(15px, 3.6vw, 18px);
  font-weight:500;
  color:#3d4f66;
  margin:0;
  line-height:1.5;
}

/* ── U-shaped body shell (side arms + rounded content tray) ── */
.ek-u-shell {
  position:relative;
  z-index:10;
  flex:1;
  width:100%;
  max-width:1180px;
  margin:clamp(-48px, -7vw, -64px) auto 0;
  padding:0 clamp(10px, 2.8vw, 28px);
}

.ek-u-body {
  position:relative;
  background:#f4f6f9;
  border-radius:clamp(28px, 5vw, 44px);
  box-shadow:
    0 -4px 32px rgba(26, 43, 74, 0.08),
    0 16px 48px rgba(26, 43, 74, 0.1);
  overflow:hidden;
}

/* Soft U crown — dips at sides, rises in center */
.ek-u-crown {
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:clamp(20px, 4vw, 32px);
  background:
    radial-gradient(ellipse 18% 100% at 8% 0%, transparent 99%, #f4f6f9 100%),
    radial-gradient(ellipse 18% 100% at 92% 0%, transparent 99%, #f4f6f9 100%),
    linear-gradient(180deg, #f4f6f9 0%, #f4f6f9 100%);
  pointer-events:none;
  z-index:1;
}

.ek-u-body::before {
  content:'';
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:min(92%, 1000px);
  height:clamp(14px, 3vw, 22px);
  background:#f4f6f9;
  border-radius:0 0 50% 50% / 0 0 100% 100%;
  box-shadow:0 4px 0 #f4f6f9;
  z-index:2;
}

/* ── Main content inside U tray ── */
.ek-main {
  position:relative;
  z-index:3;
  width:100%;
  max-width:1060px;
  margin:0 auto;
  padding:clamp(28px, 5vw, 44px) clamp(16px, 3.5vw, 36px) clamp(24px, 4vw, 40px);
  background:transparent;
}

.ek-section-head {
  text-align:center;
  margin-bottom:clamp(32px, 5vw, 48px);
  padding-top:clamp(8px, 2vw, 16px);
}

.ek-section-label {
  font-size:11px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#c8102e;
  margin:0 0 10px;
}

.ek-section-title {
  font-family:'Inter', sans-serif;
  font-size:clamp(24px, 5vw, 34px);
  font-weight:700;
  color:#1a2b4a;
  margin:0;
  line-height:1.2;
  letter-spacing:-.02em;
}
.ek-section-title em {
  font-family:'Playfair Display', Georgia, serif;
  font-style:italic;
  font-weight:700;
  color:#c8102e;
}

.ek-section-rule {
  width:48px;
  height:3px;
  margin:16px auto 0;
  border-radius:999px;
  background:linear-gradient(90deg, #c8102e, #d4a017);
}

.ek-sheet-handle {
  display:none;
}

.ek-quick-actions {
  display:none;
}

.ek-features-label {
  display:none;
}

@keyframes ek-rise {
  from {
    opacity:0;
    transform:translateY(14px);
  }
  to {
    opacity:1;
    transform:translateY(0);
  }
}

@keyframes ek-sheet-up {
  from {
    opacity:0;
    transform:translateY(28px);
  }
  to {
    opacity:1;
    transform:translateY(0);
  }
}

/* ── Service cards — 3×2 grid ── */
.ek-cards-grid {
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(14px, 2.5vw, 22px);
  margin-bottom:clamp(32px, 5vw, 48px);
}

@media (min-width: 600px) {
  .ek-cards-grid {
    grid-template-columns:repeat(2, 1fr);
  }
}

@media (min-width: 960px) {
  .ek-cards-grid {
    grid-template-columns:repeat(3, 1fr);
  }
}

.ek-card {
  position:relative;
  display:flex;
  align-items:flex-start;
  gap:14px;
  width:100%;
  min-height:clamp(118px, 22vw, 132px);
  text-align:left;
  padding:20px 20px 48px;
  background:#fff;
  border:1px solid rgba(26, 43, 74, 0.06);
  border-bottom:3px solid var(--ek-accent, #c8102e);
  border-radius:14px;
  box-shadow:0 2px 16px rgba(26, 43, 74, 0.06);
  cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease;
  font-family:'Inter', sans-serif;
}

.ek-card:hover {
  transform:translateY(-3px);
  box-shadow:0 10px 28px rgba(26, 43, 74, 0.1);
}

.ek-card:active {
  transform:translateY(-1px) scale(.99);
}

.ek-card-icon {
  display:flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  border-radius:50%;
  background:var(--ek-icon-bg, rgba(200, 16, 46, 0.1));
  color:var(--ek-accent, #c8102e);
  flex-shrink:0;
}
.ek-card-icon svg {
  width:24px;
  height:24px;
}

.ek-card-body {
  display:flex;
  flex-direction:column;
  gap:5px;
  min-width:0;
  flex:1;
  padding-top:2px;
  padding-right:8px;
}

.ek-card-title {
  font-size:16px;
  font-weight:700;
  color:#1a2b4a;
  line-height:1.3;
}

.ek-card-desc {
  font-size:13px;
  font-weight:400;
  color:#6b7c93;
  line-height:1.45;
}

.ek-card-arrow {
  position:absolute;
  right:16px;
  bottom:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border-radius:50%;
  background:var(--ek-accent, #c8102e);
  color:#fff;
  flex-shrink:0;
  box-shadow:0 2px 8px rgba(0, 0, 0, 0.08);
}

.ek-card--red {
  --ek-accent: #d41428;
  --ek-icon-bg: #fce8eb;
}
.ek-card--gold {
  --ek-accent: #d4a017;
  --ek-icon-bg: #fef6e0;
}
.ek-card--green {
  --ek-accent: #2a9d4a;
  --ek-icon-bg: #e6f6ec;
}
.ek-card--blue {
  --ek-accent: #2563b8;
  --ek-icon-bg: #e8f0fc;
}
.ek-card--purple {
  --ek-accent: #7c3aed;
  --ek-icon-bg: #f0e8ff;
}
.ek-card--teal {
  --ek-accent: #0d9488;
  --ek-icon-bg: #e0f5f3;
}

/* ── Bottom feature pill ── */
.ek-features {
  display:flex;
  flex-direction:column;
  background:#fff;
  border-radius:999px;
  border:1px solid rgba(26, 43, 74, 0.06);
  box-shadow:0 4px 24px rgba(26, 43, 74, 0.08);
  overflow:hidden;
  max-width:100%;
  margin:0 auto;
}

@media (min-width: 768px) {
  .ek-hero-glass {
    padding:0;
    background:transparent;
    border:none;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    box-shadow:none;
  }

  .ek-features {
    flex-direction:row;
    align-items:stretch;
    max-width:960px;
  }
  .ek-feature {
    flex:1;
    border-bottom:none !important;
    border-right:1px solid #e8ecf1;
  }
  .ek-feature:last-child {
    border-right:none;
  }
}

.ek-feature {
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:14px;
  padding:18px 24px;
  border-bottom:1px solid #e8ecf1;
}

.ek-feature:last-child {
  border-bottom:none;
}

.ek-feature-icon {
  flex-shrink:0;
  width:26px;
  height:26px;
  color:#c8102e;
}
.ek-feature-icon svg {
  width:100%;
  height:100%;
}

.ek-feature-text {
  display:flex;
  flex-direction:column;
  gap:3px;
  min-width:0;
  text-align:left;
}

.ek-feature-text strong {
  font-size:14px;
  font-weight:700;
  color:#1a2b4a;
  line-height:1.3;
}

.ek-feature-text span {
  font-size:12px;
  font-weight:400;
  color:#6b7c93;
  line-height:1.35;
}

/* ── Emirates: advanced mobile UI (≤767px) ── */
@media (max-width: 767px) {
  #biz.emirates-biz {
    background:#a8bccf;
  }

  .ek-page {
    padding-bottom:max(24px, env(safe-area-inset-bottom));
  }

  .ek-hero {
    height:clamp(340px, 56vh, 420px);
  }

  .ek-hero-bg {
    background-position:72% 38%;
  }

  .ek-hero-overlay {
    background:linear-gradient(
      180deg,
      rgba(255, 252, 245, 0.15) 0%,
      rgba(255, 252, 245, 0) 28%
    ),
    linear-gradient(
      90deg,
      rgba(255, 248, 238, 0.94) 0%,
      rgba(255, 248, 238, 0.55) 42%,
      transparent 68%
    ),
    linear-gradient(180deg, transparent 42%, rgba(168, 188, 207, 0.55) 100%);
  }

  .ek-back {
    top:max(12px, env(safe-area-inset-top));
    left:max(14px, env(safe-area-inset-left));
    padding:10px;
    min-width:44px;
    min-height:44px;
    justify-content:center;
    border-radius:50%;
  }
  .ek-back-label { display:none; }

  .ek-hero-inner {
    align-items:flex-end;
    padding:max(56px, calc(env(safe-area-inset-top) + 48px)) 16px 20px;
  }

  .ek-hero-glass {
    width:100%;
    max-width:none;
    padding:18px 18px 16px;
    border-radius:22px;
    background:rgba(255, 255, 255, 0.78);
    border:1px solid rgba(255, 255, 255, 0.95);
    backdrop-filter:blur(20px) saturate(1.2);
    -webkit-backdrop-filter:blur(20px) saturate(1.2);
    box-shadow:
      0 8px 32px rgba(26, 43, 74, 0.1),
      inset 0 1px 0 rgba(255, 255, 255, 0.9);
  }

  .ek-hero-title {
    font-size:clamp(40px, 10.5vw, 52px);
    margin-bottom:8px;
  }

  .ek-hero-tagline {
    font-size:14px;
    line-height:1.45;
  }

  .ek-hero-sub { display:none; }

  .ek-hero-pills { margin-top:12px; }

  .ek-pill {
    font-size:10px;
    padding:5px 10px;
    background:rgba(255, 255, 255, 0.85);
  }

  .ek-u-shell {
    margin-top:clamp(-56px, -10vw, -72px);
    padding:0 8px;
    animation:ek-sheet-up .5s cubic-bezier(.22, 1, .36, 1) backwards;
    animation-delay:.08s;
  }

  .ek-u-body {
    border-radius:28px 28px 22px 22px;
    box-shadow:
      0 -2px 0 rgba(255, 255, 255, 0.6) inset,
      0 -12px 40px rgba(26, 43, 74, 0.12),
      0 24px 48px rgba(26, 43, 74, 0.1);
  }

  .ek-sheet-handle {
    display:block;
    width:40px;
    height:4px;
    margin:12px auto 0;
    border-radius:999px;
    background:rgba(26, 43, 74, 0.12);
    position:relative;
    z-index:4;
  }

  .ek-main {
    padding:8px 16px max(28px, env(safe-area-inset-bottom));
  }

  .ek-quick-actions {
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin-bottom:22px;
  }

  .ek-quick {
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:8px;
    min-height:72px;
    padding:12px 10px;
    border-radius:18px;
    font-family:'Inter', sans-serif;
    font-size:12px;
    font-weight:700;
    line-height:1.2;
    cursor:pointer;
    border:none;
    transition:transform .12s ease, box-shadow .12s ease;
    -webkit-tap-highlight-color:transparent;
  }
  .ek-quick svg {
    width:22px;
    height:22px;
  }
  .ek-quick:active { transform:scale(0.97); }

  .ek-quick--primary {
    color:#fff;
    background:linear-gradient(145deg, #d41428 0%, #a80d1e 100%);
    box-shadow:0 6px 20px rgba(200, 16, 46, 0.35);
  }

  .ek-quick--ghost {
    color:#1a2b4a;
    background:rgba(255, 255, 255, 0.95);
    border:1px solid rgba(26, 43, 74, 0.08);
    box-shadow:0 4px 16px rgba(26, 43, 74, 0.06);
  }
  .ek-quick--ghost svg { color:#c8102e; }

  .ek-section-head {
    text-align:left;
    margin-bottom:18px;
    padding-top:4px;
  }

  .ek-section-label {
    font-size:10px;
    margin-bottom:6px;
  }

  .ek-section-title {
    font-size:clamp(21px, 5.5vw, 26px);
    max-width:16em;
  }

  .ek-section-rule {
    margin:12px 0 0;
  }

  .ek-cards-grid {
    gap:10px;
    margin-bottom:22px;
  }

  .ek-card {
    align-items:center;
    min-height:84px;
    padding:14px 52px 14px 16px;
    border-radius:20px;
    border-bottom-width:0;
    border-left:4px solid var(--ek-accent, #c8102e);
    box-shadow:
      0 2px 12px rgba(26, 43, 74, 0.06),
      0 1px 0 rgba(255, 255, 255, 0.8) inset;
    animation:ek-rise .45s cubic-bezier(.22, 1, .36, 1) backwards;
    animation-delay:calc(.06s * var(--ek-i, 0) + .15s);
    -webkit-tap-highlight-color:transparent;
  }

  .ek-card:hover {
    transform:none;
    box-shadow:0 2px 12px rgba(26, 43, 74, 0.06);
  }

  .ek-card:active {
    transform:scale(0.985);
    box-shadow:0 1px 8px rgba(26, 43, 74, 0.1);
  }

  .ek-card-icon {
    width:52px;
    height:52px;
  }
  .ek-card-icon svg {
    width:26px;
    height:26px;
  }

  .ek-card-title { font-size:15px; }
  .ek-card-desc { font-size:12px; }

  .ek-card-arrow {
    right:14px;
    top:50%;
    bottom:auto;
    transform:translateY(-50%);
    width:36px;
    height:36px;
  }

  .ek-features-label {
    display:block;
    font-size:10px;
    font-weight:700;
    letter-spacing:.14em;
    text-transform:uppercase;
    color:#6b7c93;
    margin:0 0 10px 4px;
  }

  .ek-features {
    flex-direction:row;
    flex-wrap:nowrap;
    gap:0;
    border-radius:20px;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    background:transparent;
    border:none;
    box-shadow:none;
    padding-bottom:4px;
  }
  .ek-features::-webkit-scrollbar { display:none; }

  .ek-feature {
    flex:0 0 min(88%, 300px);
    scroll-snap-align:start;
    margin-right:10px;
    padding:16px 18px;
    border-bottom:none;
    border-radius:18px;
    background:rgba(255, 255, 255, 0.95);
    border:1px solid rgba(26, 43, 74, 0.06);
    box-shadow:0 4px 20px rgba(26, 43, 74, 0.07);
  }
  .ek-feature:last-child {
    margin-right:0;
  }

  .ek-feature-icon {
    width:32px;
    height:32px;
    padding:6px;
    border-radius:12px;
    background:linear-gradient(145deg, #fce8eb, #fff);
    color:#c8102e;
    box-sizing:border-box;
  }
}

@media (max-width: 767px) and (prefers-reduced-motion: reduce) {
  .ek-u-shell,
  .ek-card {
    animation:none;
  }
}

/* ════════════════════════════════════════════
   CHICKING — Custom business page
════════════════════════════════════════════ */
#biz.chicking-biz {
  background:#faf8f5;
  color:#2d2d2d;
  overflow-x:hidden;
}

.ck-page {
  display:flex;
  flex-direction:column;
  min-height:100vh;
  background:#faf8f5;
}

/* ── Hero (red + wave) ── */
.ck-hero {
  position:relative;
  flex-shrink:0;
  background:linear-gradient(165deg, #d41e28 0%, #b81820 55%, #a0141c 100%);
  padding-bottom:0;
  overflow:hidden;
}

.ck-back {
  position:absolute;
  top:clamp(14px, 3vw, 22px);
  left:clamp(16px, 4vw, 28px);
  z-index:5;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 16px;
  border:2px solid rgba(255, 255, 255, 0.9);
  border-radius:999px;
  background:#fff;
  color:#c41e24;
  font-family:'Inter', sans-serif;
  font-size:clamp(13px, 3vw, 14px);
  font-weight:600;
  cursor:pointer;
  transition:transform .15s, box-shadow .15s;
  box-shadow:0 2px 12px rgba(0, 0, 0, 0.12);
}
.ck-back:hover {
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(0, 0, 0, 0.15);
}
.ck-back svg { flex-shrink:0; }

.ck-hero-grid {
  position:relative;
  z-index:2;
  max-width:1140px;
  margin:0 auto;
  padding:clamp(44px, 8vw, 56px) clamp(20px, 4vw, 40px) clamp(20px, 4vw, 28px);
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(12px, 2.5vw, 20px);
  align-items:center;
}

@media (min-width: 768px) {
  .ck-hero-grid {
    grid-template-columns:1fr 1fr;
    gap:24px;
  }
}

.ck-hero-text {
  text-align:center;
  order:1;
}

@media (min-width: 768px) {
  .ck-hero-text {
    text-align:left;
    order:0;
  }
}

.ck-welcome {
  font-family:'Dancing Script', cursive;
  font-size:clamp(22px, 4.5vw, 32px);
  font-weight:600;
  color:#fff;
  margin:0 0 2px;
  line-height:1.1;
  text-shadow:0 1px 8px rgba(0, 0, 0, 0.15);
}

.ck-logo {
  font-family:'Playfair Display', Georgia, serif;
  font-weight:800;
  font-size:clamp(40px, 10vw, 64px);
  line-height:0.95;
  color:#fff;
  margin:0 0 10px;
  letter-spacing:-.02em;
}

.ck-tagline {
  font-family:'Inter', sans-serif;
  font-size:clamp(14px, 3vw, 16px);
  font-weight:500;
  color:rgba(255, 255, 255, 0.95);
  margin:0 auto 6px;
  line-height:1.45;
  max-width:22em;
}

@media (min-width: 768px) {
  .ck-tagline { margin-left:0; margin-right:auto; }
}

.ck-sub {
  font-family:'Inter', sans-serif;
  font-size:clamp(12px, 2.6vw, 14px);
  font-weight:400;
  color:rgba(255, 255, 255, 0.82);
  margin:0 auto;
  line-height:1.4;
  max-width:24em;
}

@media (min-width: 768px) {
  .ck-sub { margin-left:0; margin-right:auto; }
}

.ck-hero-visual {
  order:2;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  width:min(100%, 420px);
  height:clamp(150px, 30vw, 220px);
  margin:0 auto;
  overflow:hidden;
  pointer-events:none;
  user-select:none;
}

@media (min-width: 768px) {
  .ck-hero-visual {
    margin:0 0 0 auto;
    justify-content:flex-end;
    width:min(52%, 480px);
    height:clamp(170px, 24vw, 240px);
    -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 16%);
    mask-image:linear-gradient(to right, transparent 0%, #000 16%);
  }
}

.ck-hero-img {
  display:block;
  width:100%;
  height:100%;
  max-width:100%;
  object-fit:contain;
  object-position:center bottom;
  filter:drop-shadow(0 10px 28px rgba(0, 0, 0, 0.22));
}

.ck-hero-wave {
  position:relative;
  z-index:3;
  width:100%;
  height:clamp(32px, 5vw, 48px);
  margin-top:-1px;
  line-height:0;
}
.ck-hero-wave svg {
  width:100%;
  height:100%;
  display:block;
}

/* ── Main (dot pattern) ── */
.ck-main {
  position:relative;
  flex:1;
  width:100%;
  max-width:1140px;
  margin:0 auto;
  padding:clamp(12px, 3vw, 24px) clamp(20px, 4vw, 40px) clamp(28px, 5vw, 48px);
  background-color:#faf8f5;
  background-image:radial-gradient(circle, rgba(196, 30, 36, 0.06) 1px, transparent 1px);
  background-size:18px 18px;
}

.ck-section-head {
  text-align:center;
  margin-bottom:clamp(28px, 5vw, 40px);
  padding-top:clamp(4px, 1vw, 12px);
}

.ck-section-deco {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:clamp(12px, 3vw, 20px);
  flex-wrap:wrap;
}

.ck-deco-line {
  display:block;
  width:clamp(28px, 6vw, 48px);
  height:3px;
  border-radius:2px;
  background:linear-gradient(90deg, transparent, #f5c518, transparent);
  flex-shrink:0;
}

.ck-section-title {
  font-family:'Inter', sans-serif;
  font-size:clamp(18px, 4.2vw, 26px);
  font-weight:800;
  color:#3a3a3a;
  margin:0;
  line-height:1.25;
  letter-spacing:.02em;
  text-transform:uppercase;
}

.ck-section-title .ck-help {
  color:#c41e24;
}

.ck-squiggle {
  display:block;
  width:min(100px, 28vw);
  height:12px;
  margin:8px auto 0;
}

/* ── Service cards ── */
.ck-cards-grid {
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(14px, 2.5vw, 20px);
  margin-bottom:clamp(28px, 5vw, 40px);
}

@media (min-width: 600px) {
  .ck-cards-grid {
    grid-template-columns:repeat(2, 1fr);
  }
}

@media (min-width: 960px) {
  .ck-cards-grid {
    grid-template-columns:repeat(3, 1fr);
  }
}

.ck-card {
  position:relative;
  display:flex;
  align-items:center;
  gap:14px;
  width:100%;
  min-height:clamp(110px, 20vw, 128px);
  text-align:left;
  padding:18px 52px 18px 16px;
  background:#fff;
  border:none;
  border-radius:18px;
  box-shadow:0 4px 20px rgba(45, 45, 45, 0.08);
  cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease;
  font-family:'Inter', sans-serif;
}

.ck-card:hover {
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(45, 45, 45, 0.12);
}

.ck-card:active {
  transform:translateY(-1px) scale(.99);
}

/* Card icons: emoji thumb on desktop, SVG on mobile */
.ck-card-icon {
  display:none;
}

.ck-card-thumb {
  display:flex;
  align-items:center;
  justify-content:center;
  width:clamp(56px, 14vw, 72px);
  height:clamp(56px, 14vw, 72px);
  flex-shrink:0;
  font-size:clamp(32px, 8vw, 44px);
  line-height:1;
  border-radius:14px;
  background:rgba(255, 255, 255, 0.65);
}

/* Section headings: desktop vs mobile copy */
.ck-section-mobile { display:none; }
.ck-section-desktop { display:block; }
.ck-sub--mobile { display:none; }
.ck-sub--desktop { display:block; }

.ck-card-body {
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:0;
  flex:1;
}

.ck-card-title {
  font-size:clamp(15px, 3.5vw, 17px);
  font-weight:700;
  color:#2d2d2d;
  line-height:1.25;
}

.ck-card-desc {
  font-size:clamp(12px, 2.8vw, 13px);
  font-weight:400;
  color:#666;
  line-height:1.4;
}

.ck-card-arrow {
  position:absolute;
  right:14px;
  bottom:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  width:32px;
  height:32px;
  border-radius:50%;
  background:#c41e24;
  color:#fff;
  flex-shrink:0;
  box-shadow:0 2px 10px rgba(196, 30, 36, 0.35);
}

/* Pastel card backgrounds */
.ck-card--orange { background:linear-gradient(135deg, #fff5eb 0%, #ffe8d4 100%); }
.ck-card--yellow { background:linear-gradient(135deg, #fffbeb 0%, #fff3c4 100%); }
.ck-card--green  { background:linear-gradient(135deg, #ecfdf3 0%, #d1fae0 100%); }
.ck-card--purple { background:linear-gradient(135deg, #f5f0ff 0%, #e9deff 100%); }
.ck-card--blue   { background:linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%); }
.ck-card--mint   { background:linear-gradient(135deg, #ecfdf5 0%, #ccfbf1 100%); }

/* ── Footer stats bar ── */
.ck-footer {
  display:flex;
  flex-direction:column;
  background:#fff;
  border-radius:16px;
  border:1px solid rgba(45, 45, 45, 0.06);
  box-shadow:0 4px 24px rgba(45, 45, 45, 0.06);
  overflow:hidden;
}

@media (min-width: 640px) {
  .ck-footer {
    flex-direction:row;
    align-items:stretch;
  }
}

.ck-footer-item {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  flex:1;
  padding:18px 16px;
  text-align:center;
  border-bottom:1px solid #eee;
}

@media (min-width: 640px) {
  .ck-footer-item {
    border-bottom:none;
    border-right:1px solid #eee;
  }
  .ck-footer-item:last-child {
    border-right:none;
  }
}

.ck-footer-item:last-child {
  border-bottom:none;
}

.ck-footer-icon {
  display:flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  color:#c41e24;
}
.ck-footer-icon svg {
  width:100%;
  height:100%;
}

.ck-footer-label {
  font-family:'Inter', sans-serif;
  font-size:clamp(12px, 2.8vw, 13px);
  font-weight:600;
  color:#3a3a3a;
  line-height:1.2;
}

/* ── Chicking: mobile-only UI (desktop unchanged at 768px+) ── */
@media (max-width: 767px) {
  .ck-section-mobile { display:block; }
  .ck-section-desktop { display:none; }

  .ck-sub--mobile { display:block; }
  .ck-sub--desktop { display:none; }

  .ck-back {
    padding:10px;
    min-width:40px;
    min-height:40px;
    justify-content:center;
    border-radius:12px;
    backdrop-filter:blur(8px);
    background:rgba(255, 255, 255, 0.95);
  }
  .ck-back-label { display:none; }

  .ck-hero-grid {
    padding:48px 0 12px;
    gap:0;
  }

  .ck-hero-text {
    order:2;
    text-align:center;
    padding:0 20px 4px;
  }

  .ck-hero-visual {
    order:1;
    width:100%;
    max-width:none;
    height:clamp(160px, 38vw, 200px);
    margin:0;
    padding:0 8px;
  }

  .ck-hero-img {
    object-position:center bottom;
    filter:drop-shadow(0 8px 24px rgba(0, 0, 0, 0.28));
  }

  .ck-welcome { font-size:26px; }
  .ck-logo { font-size:44px; margin-bottom:8px; }
  .ck-tagline { font-size:14px; }
  .ck-sub { font-size:12px; opacity:0.88; }

  .ck-main {
    padding:8px 16px 32px;
    background-size:14px 14px;
  }

  .ck-section-head {
    text-align:left;
    margin-bottom:20px;
    padding-top:4px;
  }

  .ck-section-eyebrow {
    font-family:'Dancing Script', cursive;
    font-size:22px;
    color:#c41e24;
    margin:0 0 4px;
    line-height:1.2;
  }

  .ck-section-title-mobile {
    font-family:'Inter', sans-serif;
    font-size:22px;
    font-weight:800;
    color:#2d2d2d;
    margin:0;
    line-height:1.25;
    letter-spacing:-.02em;
    text-transform:none;
  }

  .ck-section-title-mobile .ck-help { color:#c41e24; }

  .ck-cards-grid {
    gap:10px;
    margin-bottom:24px;
  }

  .ck-card {
    align-items:center;
    gap:14px;
    min-height:76px;
    padding:14px 14px 14px 16px;
    border-radius:20px;
    box-shadow:0 2px 12px rgba(45, 45, 45, 0.06);
    border:1px solid rgba(255, 255, 255, 0.7);
    -webkit-tap-highlight-color:transparent;
  }

  .ck-card:hover {
    transform:none;
    box-shadow:0 2px 12px rgba(45, 45, 45, 0.06);
  }

  .ck-card:active {
    transform:scale(0.98);
    box-shadow:0 1px 8px rgba(45, 45, 45, 0.08);
  }

  .ck-card-thumb { display:none; }

  .ck-card-icon {
    display:flex;
    align-items:center;
    justify-content:center;
    width:48px;
    height:48px;
    flex-shrink:0;
    border-radius:14px;
    background:rgba(255, 255, 255, 0.85);
    color:var(--ck-accent, #c41e24);
    box-shadow:0 2px 8px rgba(0, 0, 0, 0.06);
  }
  .ck-card-icon svg {
    width:26px;
    height:26px;
  }

  .ck-card--orange { --ck-accent:#e85d04; }
  .ck-card--yellow { --ck-accent:#ca8a04; }
  .ck-card--green  { --ck-accent:#16a34a; }
  .ck-card--purple { --ck-accent:#7c3aed; }
  .ck-card--blue   { --ck-accent:#2563eb; }
  .ck-card--mint   { --ck-accent:#0d9488; }

  .ck-card-body { gap:3px; padding-right:4px; }

  .ck-card-title {
    font-size:16px;
    font-weight:700;
    letter-spacing:-.01em;
  }

  .ck-card-desc {
    font-size:12px;
    color:#5c5c5c;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }

  .ck-card-arrow {
    position:static;
    width:36px;
    height:36px;
    margin-left:auto;
    flex-shrink:0;
    background:rgba(196, 30, 36, 0.1);
    color:#c41e24;
    box-shadow:none;
  }
  .ck-card-arrow svg { width:18px; height:18px; }

  .ck-footer {
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:0;
    border-radius:20px;
    box-shadow:0 4px 20px rgba(45, 45, 45, 0.07);
  }

  .ck-footer-item {
    flex-direction:row;
    justify-content:flex-start;
    gap:12px;
    padding:16px;
    text-align:left;
    border-bottom:1px solid #eee;
    border-right:1px solid #eee;
  }

  .ck-footer-item:nth-child(2n) { border-right:none; }
  .ck-footer-item:nth-child(n+3) { border-bottom:none; }

  .ck-footer-icon {
    width:40px;
    height:40px;
    border-radius:12px;
    background:linear-gradient(135deg, #fff0f0 0%, #ffe4e4 100%);
    color:#c41e24;
    flex-shrink:0;
  }

  .ck-footer-label {
    font-size:13px;
    font-weight:700;
    line-height:1.3;
  }
}

/* ═══════════════════════════════════════════════════════
   DATA CARD — base animation for all renderUICard cards
═══════════════════════════════════════════════════════ */
/* ── Skeleton card — shown while tool is executing ── */
.sk-card {
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .18s ease, transform .18s ease;
  padding: 12px 14px !important;
  min-width: 180px;
}
.sk-card--visible {
  opacity: 1;
  transform: none;
}
.sk-label {
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .06em;
  color: #b478ff;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.sk-label::before {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #b478ff;
  animation: sk-dot-blink .8s ease-in-out infinite alternate;
}
@keyframes sk-dot-blink { from { opacity: .3; } to { opacity: 1; } }
.sk-lines { display: flex; flex-direction: column; gap: 7px; }
.sk-line {
  height: 9px;
  border-radius: 6px;
  background: linear-gradient(90deg,
    rgba(255,255,255,.04) 0%,
    rgba(255,255,255,.12) 40%,
    rgba(255,255,255,.04) 80%
  );
  background-size: 250% 100%;
  animation: sk-shimmer 1.4s ease-in-out infinite;
}
.sk-short { width: 55%; }
@keyframes sk-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -50% 0; }
}

/* ── Tool error card — shown when a tool returns an error ── */
.tool-err-card {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 9px 13px !important;
  background: rgba(224,80,64,.08) !important;
  border: 1px solid rgba(224,80,64,.2) !important;
  font-size: 11px;
}
.tool-err-icon { color: #e05040; font-size: 13px; flex-shrink: 0; }
.tool-err-text { color: #c08070; font-weight: 500; }

.data-card {
  position: relative;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .22s ease, transform .22s cubic-bezier(.34,1.56,.64,1);
}
.data-card--visible {
  opacity: 1;
  transform: none;
}

/* ── Card lifecycle states ── */
.data-card--active {
  opacity: 1;
}
.data-card--dimmed {
  opacity: .48;
  transform: scale(.984);
  transition: opacity .35s ease, transform .35s ease;
  cursor: pointer;
}
.data-card--dimmed:hover {
  opacity: .72;
}
.data-card--collapsed {
  opacity: .38;
  cursor: pointer;
  transition: opacity .25s ease;
}
.data-card--collapsed:hover {
  opacity: .58;
}
.data-card--collapsed .dc-body {
  display: none;
}
.data-card--collapsed .dc-summary {
  display: flex;
}

/* Summary bar — always in DOM, visible only when collapsed */
.dc-summary {
  display: none;
  align-items: center;
  gap: 8px;
  padding: 9px 13px;
  background: #1c1c1c;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 12px;
}
.dc-sum-text {
  font-size: 11px;
  font-weight: 500;
  color: #666;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dc-sum-chevron {
  font-size: 14px;
  color: #444;
  flex-shrink: 0;
  line-height: 1;
  transform: rotate(0deg);
  transition: color .2s;
}
.data-card--collapsed:hover .dc-sum-chevron {
  color: #777;
}

/* Interrupted badge — shown when barge-in cancelled the response */
.data-card--interrupted::after {
  content: 'interrupted';
  position: absolute;
  top: 8px;
  right: 10px;
  font-size: 8px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  background: rgba(201,162,39,.1);
  color: #c9a227;
  border: 1px solid rgba(201,162,39,.22);
  border-radius: 50px;
  padding: 2px 8px;
  pointer-events: none;
}

/* ═══════════════════════════════════════════════════════
   IMAGE CATALOG — interactive clickable menu/product grid
   Used by: Chicking menu, and any future company catalog
═══════════════════════════════════════════════════════ */
.ict-wrap {
  font-family: 'Inter', sans-serif;
  background: #161616;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px;
  padding: 14px 14px 10px;
}

/* Header row */
.ict-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.ict-title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #555;
}
.ict-count {
  font-size: 10px;
  color: #444;
}

/* Category filter tabs */
.ict-tabs {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,.05);
  -webkit-overflow-scrolling: touch;
}
.ict-tabs::-webkit-scrollbar { display: none; }
.ict-tab {
  flex-shrink: 0;
  padding: 5px 14px;
  border-radius: 50px;
  font-size: 12px;
  font-weight: 600;
  border: 1.5px solid rgba(255,255,255,.1);
  background: transparent;
  color: #666;
  cursor: pointer;
  white-space: nowrap;
  transition: all .12s ease;
}
.ict-tab--active {
  /* accent color applied dynamically per company — see renderer.js */
  font-weight: 700;
}
.ict-tab:hover:not(.ict-tab--active) {
  border-color: rgba(255,255,255,.2);
  color: #aaa;
}

/* Item grid */
.ict-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
@media (min-width: 400px) {
  .ict-grid { grid-template-columns: repeat(3, 1fr); }
}

/* Horizontal scroll carousel — real estate & tall-image catalogs */
.ict-grid--scroll {
  display: flex;
  overflow-x: auto;
  gap: 10px;
  padding-bottom: 6px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  scroll-snap-type: x mandatory;
}
.ict-grid--scroll::-webkit-scrollbar { display: none; }
.ict-grid--scroll .ict-item {
  flex-shrink: 0;
  width: 185px;
  scroll-snap-align: start;
}
.ict-grid--scroll .ict-img { aspect-ratio: 4 / 3; }
.ict-desc { font-size: 10px; color: #555; line-height: 1.4; margin-top: 3px; }

/* Individual item tile — entire card is clickable */
.ict-item {
  background: #1c1c1c;
  border-radius: 11px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.06);
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.ict-item:hover {
  transform: translateY(-3px);
  border-color: rgba(255,255,255,.16);
  box-shadow: 0 6px 20px rgba(0,0,0,.35);
}
.ict-item:active { transform: scale(.96); }
.ict-item--selected {
  /* border-color and box-shadow applied dynamically per company — see renderer.js */
}

/* Image zone */
.ict-img {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.ict-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Fallback shown when image missing / errors */
.ict-fallback {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  font-weight: 800;
  color: rgba(255,255,255,.18);
  font-family: 'Playfair Display', serif;
}

/* Popular badge */
.ict-badge {
  position: absolute;
  top: 6px;
  left: 6px;
  color: #fff;
  font-size: 8.5px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: 10px;
}

/* Checkmark overlay — appears on click */
.ict-select-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(196,30,36,.55);
  color: #fff;
  font-size: 28px;
  font-weight: 800;
  opacity: 0;
  transition: opacity .15s ease;
  pointer-events: none;
}
.ict-item--selected .ict-select-overlay { opacity: 1; }

/* Text info */
.ict-info { padding: 8px 9px 10px; flex: 1; }
.ict-name {
  font-size: 11.5px;
  font-weight: 600;
  color: #e0ddd6;
  line-height: 1.35;
  margin-bottom: 3px;
}
.ict-price {
  font-size: 12px;
  font-weight: 700;
}

/* ════════════════════════════════════════════
   THE BRAND TAXI — Custom business page
════════════════════════════════════════════ */
#biz.brand-taxi-biz {
  background:#fff;
  color:#111;
  overflow-x:hidden;
}

.bt-page {
  --bt-yellow:#ffd400;
  --bt-black:#111111;
  --bt-gray:#5c5c5c;
  --bt-purple:#e8e0f5;
  --bt-cyan:#d4f4f7;
  --bt-blue:#dce8fc;
  position:relative;
  display:flex;
  flex-direction:column;
  min-height:100vh;
  background:#fff;
  padding-left:clamp(20px, 4vw, 32px);
}

/* Taxi checker stripe */
.bt-checker {
  position:fixed;
  left:0;
  top:0;
  bottom:0;
  width:clamp(14px, 3.2vw, 22px);
  z-index:30;
  background:
    repeating-linear-gradient(
      180deg,
      var(--bt-black) 0,
      var(--bt-black) 14px,
      var(--bt-yellow) 14px,
      var(--bt-yellow) 28px
    );
  pointer-events:none;
}

/* ── Hero ── */
.bt-hero {
  position:relative;
  flex-shrink:0;
  padding:clamp(16px, 3vw, 28px) clamp(16px, 4vw, 40px) clamp(8px, 2vw, 16px);
  background:#fff;
}

.bt-back {
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-bottom:clamp(16px, 3vw, 24px);
  padding:8px 12px 8px 8px;
  border:2px solid var(--bt-black);
  border-radius:10px;
  background:#fff;
  color:var(--bt-black);
  font-family:'Inter', sans-serif;
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  transition:background .15s, transform .12s;
  -webkit-tap-highlight-color:transparent;
}
.bt-back:hover { background:#f5f5f5; }
.bt-back:active { transform:scale(0.98); }

.bt-hero-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(20px, 4vw, 48px);
  align-items:center;
  max-width:1200px;
  margin:0 auto;
}

.bt-eyebrow {
  display:inline-flex;
  align-items:center;
  gap:0;
  margin-bottom:clamp(20px, 4vw, 32px);
}

.bt-eyebrow-mark {
  display:flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  background:var(--bt-black);
  color:var(--bt-yellow);
  flex-shrink:0;
}

.bt-eyebrow-pill {
  display:inline-flex;
  align-items:center;
  padding:0 18px;
  height:36px;
  background:var(--bt-yellow);
  color:var(--bt-black);
  font-family:'Inter', sans-serif;
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.bt-headline {
  margin:0 0 clamp(16px, 3vw, 24px);
  font-family:'Inter', sans-serif;
  font-weight:800;
  line-height:0.95;
  letter-spacing:-.03em;
}

.bt-headline-solid {
  display:block;
  font-size:clamp(40px, 8vw, 72px);
  color:var(--bt-black);
}

.bt-headline-outline {
  display:block;
  font-size:clamp(40px, 8vw, 72px);
  color:transparent;
  -webkit-text-stroke:2.5px var(--bt-black);
  text-stroke:2.5px var(--bt-black);
  paint-order:stroke fill;
}

.bt-tagline {
  margin:0;
  max-width:28em;
  font-family:'Inter', sans-serif;
  font-size:clamp(15px, 2.2vw, 18px);
  font-weight:400;
  line-height:1.55;
  color:var(--bt-gray);
}

.bt-hero-visual {
  display:flex;
  align-items:center;
  justify-content:center;
}

.bt-hero-img {
  width:100%;
  max-width:560px;
  height:auto;
  object-fit:contain;
}

/* ── Main / cards ── */
.bt-main {
  flex:1;
  padding:clamp(8px, 2vw, 16px) clamp(16px, 4vw, 40px) clamp(32px, 6vw, 56px);
  max-width:1200px;
  margin:0 auto;
  width:100%;
  box-sizing:border-box;
}

.bt-cards-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:clamp(14px, 2.5vw, 22px);
}

.bt-card {
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  min-height:clamp(160px, 22vw, 200px);
  padding:22px 20px 56px;
  text-align:left;
  background:#fff;
  border:none;
  border-radius:16px;
  box-shadow:0 4px 24px rgba(17, 17, 17, 0.08);
  cursor:pointer;
  font-family:'Inter', sans-serif;
  transition:transform .18s ease, box-shadow .18s ease;
  -webkit-tap-highlight-color:transparent;
  overflow:hidden;
}

.bt-card:hover {
  transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(17, 17, 17, 0.12);
}

.bt-card:active {
  transform:translateY(-1px) scale(0.99);
}

.bt-card-dots {
  position:absolute;
  top:14px;
  right:14px;
  width:44px;
  height:44px;
  background-image:radial-gradient(circle, var(--bt-yellow) 2px, transparent 2px);
  background-size:8px 8px;
  opacity:0.85;
}

.bt-card-icon {
  display:flex;
  align-items:center;
  justify-content:center;
  width:52px;
  height:52px;
  border-radius:12px;
  margin-bottom:16px;
  flex-shrink:0;
}
.bt-card-icon svg {
  width:26px;
  height:26px;
}

.bt-card--yellow .bt-card-icon {
  background:var(--bt-yellow);
  color:var(--bt-black);
}
.bt-card--purple .bt-card-icon {
  background:var(--bt-purple);
  color:#5b4d8a;
}
.bt-card--cyan .bt-card-icon {
  background:var(--bt-cyan);
  color:#0d6b7a;
}
.bt-card--blue .bt-card-icon {
  background:var(--bt-blue);
  color:#1e4a8c;
}

.bt-card-body {
  display:flex;
  flex-direction:column;
  gap:8px;
  flex:1;
  padding-right:8px;
}

.bt-card-title {
  font-size:clamp(14px, 2vw, 16px);
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--bt-black);
  line-height:1.25;
}

.bt-card-desc {
  font-size:13px;
  font-weight:400;
  color:var(--bt-gray);
  line-height:1.45;
}

.bt-card-arrow {
  position:absolute;
  right:18px;
  bottom:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border-radius:50%;
  background:var(--bt-black);
  color:#fff;
  flex-shrink:0;
}

/* ── Tablet ── */
@media (max-width: 960px) {
  .bt-cards-grid {
    grid-template-columns:repeat(2, 1fr);
  }

  .bt-hero-grid {
    grid-template-columns:1fr;
    gap:24px;
  }

  .bt-hero-img {
    max-width:100%;
    max-height:280px;
  }
}

/* ── Mobile ── */
@media (max-width: 600px) {
  .bt-page {
    padding-left:clamp(18px, 5vw, 24px);
  }

  .bt-checker {
    width:12px;
  }

  .bt-hero {
    padding:12px 16px 8px;
  }

  .bt-back {
    margin-bottom:12px;
    padding:10px;
    min-width:44px;
    min-height:44px;
    justify-content:center;
    border-radius:12px;
  }
  .bt-back-label { display:none; }

  .bt-eyebrow {
    margin-bottom:16px;
  }

  .bt-eyebrow-mark {
    width:32px;
    height:32px;
  }

  .bt-eyebrow-pill {
    height:32px;
    padding:0 14px;
    font-size:10px;
  }

  .bt-headline-solid,
  .bt-headline-outline {
    font-size:clamp(36px, 11vw, 48px);
    -webkit-text-stroke-width:2px;
    text-stroke-width:2px;
  }

  .bt-tagline {
    font-size:14px;
  }

  .bt-hero-img {
    max-height:220px;
  }

  .bt-main {
    padding:8px 16px 32px;
  }

  .bt-cards-grid {
    grid-template-columns:1fr;
    gap:12px;
  }

  .bt-card {
    min-height:0;
    flex-direction:row;
    align-items:center;
    gap:14px;
    padding:16px 56px 16px 16px;
  }

  .bt-card-dots {
    top:10px;
    right:10px;
    width:32px;
    height:32px;
    background-size:6px 6px;
  }

  .bt-card-icon {
    width:48px;
    height:48px;
    margin-bottom:0;
    flex-shrink:0;
  }

  .bt-card-body {
    gap:4px;
    min-width:0;
  }

  .bt-card-title {
    font-size:13px;
  }

  .bt-card-desc {
    font-size:12px;
  }

  .bt-card-arrow {
    top:50%;
    bottom:auto;
    right:14px;
    transform:translateY(-50%);
  }

  .bt-card:hover {
    transform:none;
    box-shadow:0 4px 24px rgba(17, 17, 17, 0.08);
  }
}

/* ════════════════════════════════════════════
   KIA UAE — Custom business page
════════════════════════════════════════════ */
#biz.kia-biz {
  background:#f6f6f5;
  color:#111;
  overflow-x:hidden;
}

.kia-page {
  min-height:100vh;
  background:#f6f6f5;
}

.kia-hero {
  position:relative;
  max-width:1180px;
  margin:0 auto;
  padding:18px clamp(14px, 3.5vw, 30px) 14px;
}

.kia-back {
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:#c9a227;
  background:transparent;
  border:none;
  font-size:clamp(12px, 2.8vw, 14px);
  font-weight:600;
  cursor:pointer;
  margin-bottom:10px;
  min-height:40px;
  padding:6px 4px;
}

.kia-hero-split {
  position:relative;
  display:grid;
  grid-template-columns:1fr;
  border-radius:0 0 24px 24px;
  overflow:hidden;
  background:#fff;
}

.kia-hero-left {
  padding:20px 18px 16px;
  background:#fff;
  position:relative;
  z-index:2;
}

.kia-eyebrow {
  font-size:11px;
  font-weight:700;
  letter-spacing:.2em;
  color:#9b9b9b;
  margin:0 0 8px;
}

.kia-title {
  margin:0;
  font-family:'Inter', sans-serif;
  font-size:clamp(44px, 10vw, 74px);
  line-height:.95;
  letter-spacing:-.03em;
  color:#111827;
  font-weight:300;
}

.kia-title span {
  font-weight:800;
}

.kia-title-rule {
  width:44px;
  height:3px;
  border-radius:999px;
  background:#d4a017;
  margin:10px 0 12px;
}

.kia-sub {
  margin:0;
  max-width:30ch;
  font-size:clamp(13px, 2.1vw, 19px);
  line-height:1.45;
  color:#2e3642;
}

.kia-hero-right {
  min-height:220px;
  background:
    linear-gradient(145deg, rgba(5,20,31,.12), rgba(5,20,31,.5)),
    url('../images/kia-ev9-banner.png') center/cover no-repeat;
}

.kia-trust {
  margin-top:-26px;
  position:relative;
  z-index:3;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:#16293a;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 8px 30px rgba(5,20,31,.24);
}

.kia-trust-item {
  background:linear-gradient(180deg,#102334 0%, #0d1f2f 100%);
  padding:14px 12px;
  display:flex;
  align-items:flex-start;
  gap:10px;
}

.kia-trust-icon {
  width:18px;
  height:18px;
  color:#d4a017;
  flex-shrink:0;
}
.kia-trust-icon svg { width:100%; height:100%; }

.kia-trust-text strong {
  display:block;
  color:#f6f8fb;
  font-size:13px;
  line-height:1.25;
  font-weight:700;
}
.kia-trust-text span {
  display:block;
  color:rgba(236,242,250,.72);
  font-size:11px;
  margin-top:2px;
  line-height:1.35;
}

.kia-main {
  max-width:1180px;
  margin:0 auto;
  padding:22px clamp(14px, 3.5vw, 30px) 40px;
}

.kia-section-head {
  position:relative;
  margin-bottom:18px;
}

.kia-section-label {
  margin:0 0 10px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.2em;
  color:#b6a777;
}

.kia-section-title {
  margin:0;
  font-size:clamp(38px, 6.8vw, 54px);
  line-height:.98;
  letter-spacing:-.03em;
  font-weight:700;
  color:#111827;
  max-width:8ch;
}

.kia-dot-grid {
  position:absolute;
  right:0;
  top:8px;
  width:90px;
  height:80px;
  background-image:radial-gradient(circle, rgba(17,24,39,.12) 1.4px, transparent 1.4px);
  background-size:12px 12px;
}

.kia-cards-grid {
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}

.kia-card {
  display:flex;
  align-items:center;
  gap:14px;
  width:100%;
  border:none;
  text-align:left;
  padding:16px 14px;
  border-radius:12px;
  cursor:pointer;
  transition:transform .12s ease, box-shadow .2s ease;
  box-shadow:0 1px 0 rgba(0,0,0,.03), 0 8px 20px rgba(17,24,39,.04);
}
.kia-card:hover { transform:translateY(-1px); }

.kia-card-icon {
  width:42px;
  height:42px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  color:#1f2937;
  background:rgba(255,255,255,.65);
}
.kia-card-icon svg { width:22px; height:22px; }

.kia-card-body {
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:0;
  flex:1;
}

.kia-card-title {
  font-size:clamp(18px, 3.5vw, 24px);
  line-height:1.05;
  letter-spacing:-.02em;
  font-weight:700;
  color:#111827;
}

.kia-card-desc {
  font-size:clamp(12px, 2.2vw, 14px);
  color:#374151;
  line-height:1.4;
  max-width:30ch;
}

.kia-card-arrow {
  width:clamp(32px, 5vw, 38px);
  height:clamp(32px, 5vw, 38px);
  border-radius:50%;
  background:#fff;
  color:#1f2937;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.kia-card--sand { background:#f6f1e5; }
.kia-card--night {
  background:#071b2b;
  box-shadow:0 10px 24px rgba(7,27,43,.24);
}
.kia-card--night .kia-card-title,
.kia-card--night .kia-card-desc { color:#f3f7fb; }
.kia-card--night .kia-card-icon {
  color:#d5a01e;
  background:rgba(255,255,255,.06);
}
.kia-card--night .kia-card-arrow {
  background:#d5a01e;
  color:#081523;
}
.kia-card--mist { background:#f4f4f4; }
.kia-card--lavender { background:#eceef7; }
.kia-card--violet { background:#efedff; }
.kia-card--mint { background:#ebf7f3; }

.kia-cta {
  margin-top:14px;
  border-radius:14px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(17,24,39,.06);
  box-shadow:0 8px 24px rgba(17,24,39,.06);
  padding:2px;
}

.kia-cta-content {
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px;
}

.kia-cta-icon {
  width:34px;
  height:34px;
  color:#0f2233;
  flex-shrink:0;
}
.kia-cta-icon svg { width:100%; height:100%; }

.kia-cta-text {
  min-width:0;
  flex:1;
}
.kia-cta-text h3 {
  margin:0;
  font-size:clamp(16px, 2.7vw, 21px);
  color:#111827;
}
.kia-cta-text p {
  margin:3px 0 0;
  font-size:clamp(12px, 2vw, 15px);
  color:#374151;
}

.kia-cta-btn {
  border:none;
  background:#071b2b;
  color:#f7fafc;
  border-radius:12px;
  padding:clamp(9px, 1.4vw, 11px) clamp(10px, 1.6vw, 14px);
  font-size:clamp(11px, 1.6vw, 13px);
  font-weight:600;
  display:inline-flex;
  gap:6px;
  align-items:center;
  cursor:pointer;
  min-height:40px;
  white-space:nowrap;
}

@media (max-width: 899px) {
  .kia-hero-right {
    min-height:clamp(180px, 48vw, 280px);
  }

  .kia-trust {
    margin-top:-18px;
    border-radius:14px;
  }

  .kia-trust-item {
    padding:12px 10px;
    gap:8px;
  }

  .kia-trust-text strong {
    font-size:12px;
  }
  .kia-trust-text span {
    font-size:10px;
  }

  .kia-section-title {
    font-size:clamp(28px, 8.5vw, 40px);
    max-width:10ch;
  }

  .kia-dot-grid {
    width:64px;
    height:60px;
    background-size:10px 10px;
  }

  .kia-card {
    padding:14px 12px;
    gap:10px;
    border-radius:11px;
  }

  .kia-card-icon {
    width:36px;
    height:36px;
  }
  .kia-card-icon svg {
    width:18px;
    height:18px;
  }

  .kia-cta-content {
    flex-wrap:wrap;
    align-items:flex-start;
    gap:10px;
  }
  .kia-cta-btn {
    margin-left:auto;
  }
}

@media (max-width: 560px) {
  .kia-hero {
    padding:14px 10px 10px;
  }

  .kia-hero-left {
    padding:16px 14px 14px;
  }

  .kia-title {
    font-size:clamp(34px, 12vw, 48px);
  }

  .kia-sub {
    max-width:none;
    font-size:13px;
  }

  .kia-trust {
    grid-template-columns:1fr;
    margin-top:8px;
  }

  .kia-main {
    padding:18px 10px 26px;
  }

  .kia-section-label {
    font-size:10px;
    margin-bottom:7px;
  }

  .kia-section-title {
    font-size:clamp(25px, 9vw, 33px);
    max-width:9ch;
  }

  .kia-dot-grid {
    display:none;
  }

  .kia-card {
    min-height:76px;
  }

  .kia-cta-icon {
    width:28px;
    height:28px;
  }

  .kia-cta-btn {
    width:100%;
    justify-content:center;
    margin-left:0;
  }
}

@media (min-width: 900px) {
  .kia-hero-split {
    grid-template-columns:1.05fr 1fr;
    min-height:460px;
  }

  .kia-hero-left {
    padding:38px 34px 30px;
    clip-path:polygon(0 0, 82% 0, 100% 100%, 0% 100%);
  }

  .kia-hero-right {
    min-height:460px;
    background-position:center;
  }

  .kia-trust {
    margin-top:-52px;
    max-width:690px;
    grid-template-columns:repeat(4, 1fr);
  }

  .kia-main { padding-top:34px; }

  .kia-section-title {
    font-size:56px;
    max-width:12ch;
  }

  .kia-cards-grid {
    grid-template-columns:repeat(3, minmax(0,1fr));
    gap:14px;
  }

  .kia-card {
    min-height:150px;
    padding:20px 16px;
    align-items:flex-start;
    flex-direction:column;
  }

  .kia-card-arrow {
    margin-top:auto;
    align-self:flex-end;
  }

  .kia-card-title { font-size:24px; }
  .kia-card-desc { font-size:14px; }

  .kia-cta {
    padding:4px;
  }
}

/* ════════════════════════════════════════════
   SAMSUNG — Custom business page
════════════════════════════════════════════ */
#biz.samsung-biz {
  background: #000;
  color: #fff;
  font-family: "SamsungOne", "Samsung Sans", "Inter", sans-serif;
  overflow-x: hidden;
}

.sam-page {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.sam-hero {
  position: relative;
  padding: clamp(60px, 10vw, 100px) clamp(20px, 5vw, 60px) clamp(40px, 8vw, 60px);
  background: radial-gradient(circle at 75% 35%, #1428a0 0%, #000 65%);
  overflow: hidden;
}

.sam-back {
  position: absolute;
  top: 20px;
  left: 20px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: #fff;
  padding: 8px 16px;
  border-radius: 99px;
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  backdrop-filter: blur(12px);
  z-index: 10;
  font-size: 14px;
  font-weight: 600;
  transition: all 0.2s;
}
.sam-back:hover { background: rgba(255, 255, 255, 0.15); }

.sam-hero-content {
  display: flex;
  align-items: center;
  gap: clamp(30px, 5vw, 60px);
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.sam-hero-text {
  flex: 1.2;
  animation: sam-fade-up 0.8s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.sam-eyebrow {
  color: #3671e9;
  font-weight: 700;
  letter-spacing: 0.15em;
  font-size: clamp(12px, 2vw, 14px);
  margin-bottom: 12px;
  text-transform: uppercase;
}

.sam-title {
  font-size: clamp(36px, 6vw, 64px);
  font-weight: 800;
  margin-bottom: 20px;
  line-height: 1.05;
  letter-spacing: -0.02em;
}

.sam-title span {
  color: #3671e9;
  display: block;
}

.sam-desc {
  font-size: clamp(16px, 2.5vw, 19px);
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 36px;
  max-width: 520px;
  line-height: 1.5;
}

.sam-hero-btns {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.sam-btn {
  padding: 14px 28px;
  border-radius: 99px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  font-size: 15px;
  letter-spacing: 0.01em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.sam-btn-primary {
  background: #3671e9;
  color: #fff;
  border: none;
  box-shadow: 0 4px 20px rgba(54, 113, 233, 0.3);
}
.sam-btn-primary:hover {
  background: #4a82f0;
  transform: translateY(-2px);
  box-shadow: 0 6px 25px rgba(54, 113, 233, 0.4);
}

.sam-btn-outline {
  background: transparent;
  border: 1.5px solid rgba(255, 255, 255, 0.25);
  color: #fff;
}
.sam-btn-outline:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.5);
}

.sam-hero-visual {
  flex: 0.8;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

.sam-hero-img {
  width: 100%;
  max-width: clamp(280px, 40vw, 500px);
  max-height: clamp(280px, 40vw, 500px);
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 20px 40px rgba(0,0,0,0.6));
  position: relative;
  z-index: 1;
}

.sam-ai-sparkle-overlay {
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  width: 60px;
  height: 60px;
  z-index: 2;
  pointer-events: none;
  animation: sam-ai-pulse 2.5s infinite ease-in-out;
  filter: drop-shadow(0 0 15px rgba(54, 113, 233, 0.8));
}

@keyframes sam-ai-pulse {
  0%, 100% { transform: scale(1) rotate(0deg); opacity: 0.4; filter: blur(1px); }
  50% { transform: scale(1.3) rotate(15deg); opacity: 1; filter: blur(0); }
}

@keyframes sam-fade-up {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes sam-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

.sam-quick-nav {
  display: flex;
  justify-content: center;
  gap: clamp(20px, 4vw, 50px);
  margin-top: clamp(40px, 6vw, 80px);
  background: rgba(255, 255, 255, 0.03);
  padding: 18px clamp(15px, 3vw, 30px);
  border-radius: 24px;
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 10px 40px rgba(0,0,0,0.3);
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}

.sam-q-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  color: rgba(255, 255, 255, 0.5);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sam-q-item:hover {
  color: #3671e9;
  transform: translateY(-3px);
}

.sam-q-icon {
  width: 24px;
  height: 24px;
  transition: transform 0.3s;
}
.sam-q-item:hover .sam-q-icon { transform: scale(1.1); }

.sam-q-item span {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.sam-main {
  padding: clamp(40px, 8vw, 80px) clamp(20px, 5vw, 40px);
  max-width: 1200px;
  margin: 0 auto;
}

.sam-section-header {
  margin-bottom: clamp(30px, 6vw, 50px);
  text-align: center;
}

.sam-section-title {
  font-size: clamp(28px, 4vw, 36px);
  font-weight: 800;
  margin-bottom: 12px;
  letter-spacing: -0.01em;
}

.sam-section-sub {
  font-size: clamp(14px, 2vw, 16px);
  color: rgba(255, 255, 255, 0.5);
  max-width: 600px;
  margin: 0 auto;
}

.sam-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 340px), 1fr));
  gap: 20px;
}

.sam-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: 24px;
  border-radius: 28px;
  display: flex;
  align-items: center;
  gap: 24px;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.sam-card:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(54, 113, 233, 0.4);
  transform: translateY(-6px);
  box-shadow: 0 20px 40px rgba(0,0,0,0.4);
}

.sam-card-icon {
  width: 52px;
  height: 52px;
  background: linear-gradient(135deg, rgba(54, 113, 233, 0.15), rgba(54, 113, 233, 0.05));
  color: #3671e9;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.sam-card-content {
  flex: 1;
}

.sam-card-title {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 6px;
  color: #fff;
}

.sam-card-desc {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.4;
}

.sam-card-arrow {
  color: rgba(255, 255, 255, 0.2);
  transition: transform 0.3s;
}
.sam-card:hover .sam-card-arrow { transform: translateX(4px); color: #3671e9; }

.sam-banner {
  margin-top: clamp(40px, 10vw, 100px);
  background: linear-gradient(105deg, #1428a0 0%, #3671e9 100%);
  border-radius: 40px;
  padding: clamp(30px, 6vw, 60px);
  position: relative;
  overflow: hidden;
}

.sam-banner::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -20%;
  width: 100%;
  height: 200%;
  background: radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 60%);
  pointer-events: none;
}

.sam-banner-content {
  display: flex;
  align-items: center;
  gap: clamp(24px, 5vw, 40px);
  position: relative;
  z-index: 1;
}

.sam-banner-icon {
  width: clamp(56px, 8vw, 72px);
  height: clamp(56px, 8vw, 72px);
  background: rgba(255, 255, 255, 0.15);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  backdrop-filter: blur(10px);
  color: #fff;
}

.sam-banner-text {
  flex: 1;
}

.sam-banner-text h3 {
  font-size: clamp(22px, 3.5vw, 28px);
  font-weight: 800;
  margin-bottom: 10px;
  color: #fff;
}

.sam-banner-text p {
  color: rgba(255, 255, 255, 0.9);
  max-width: 600px;
  font-size: clamp(14px, 2vw, 16px);
  line-height: 1.5;
}

.sam-trust {
  margin-top: clamp(60px, 12vw, 100px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 50px;
  text-align: center;
}

.sam-trust-item strong {
  display: block;
  font-size: clamp(16px, 2.5vw, 20px);
  margin-bottom: 8px;
  font-weight: 800;
  color: #fff;
}

.sam-trust-item span {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.5);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

@media (max-width: 991px) {
  .sam-hero-content {
    flex-direction: column-reverse;
    text-align: center;
    gap: 40px;
  }
  .sam-hero-text {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .sam-desc {
    margin-left: auto;
    margin-right: auto;
  }
  .sam-hero-btns {
    justify-content: center;
  }
}

@media (max-width: 768px) {
  .sam-hero {
    padding-top: 80px;
  }
  .sam-quick-nav {
    width: 100%;
    overflow-x: auto;
    justify-content: flex-start;
    padding: 15px 20px;
    gap: 30px;
    scrollbar-width: none;
  }
  .sam-quick-nav::-webkit-scrollbar { display: none; }
  .sam-q-item { flex-shrink: 0; }
  
  .sam-banner-content {
    flex-direction: column;
    text-align: center;
  }
  .sam-trust {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .sam-btn {
    width: 100%;
  }
}

@media (max-width: 480px) {
  .sam-hero {
    background: radial-gradient(circle at 50% 20%, #1428a0 0%, #000 60%);
  }
  .sam-device-mock {
    width: 150px;
    height: 300px;
  }
  .sam-title {
    font-size: 34px;
  }
}

/* ════════════════════════════════════════════
   LULU — see public/css/lulu-instore.css
════════════════════════════════════════════ */

/* ── Mushrif Mall — home-style header + mall details + outlet grid ── */
#biz.mushrif-biz {
  background:#111;
}

/* Match theme.html #home .app — width, padding, column rhythm */
#biz.mushrif-biz .mm-app {
  width:100%;
  min-height:100%;
  padding-top: calc(var(--apt) + var(--safe-top));
  padding-left: max(var(--apx), var(--safe-left));
  padding-right: max(var(--apx), var(--safe-right));
  padding-bottom: max(clamp(40px,8vw,80px), calc(clamp(40px,8vw,80px) + var(--safe-bottom)));
}
@media(min-width:560px)  { #biz.mushrif-biz .mm-app { max-width:600px;  margin:0 auto; } }
@media(min-width:768px)  { #biz.mushrif-biz .mm-app { max-width:860px;  } }
@media(min-width:1024px) { #biz.mushrif-biz .mm-app { max-width:1060px; } }

#biz.mushrif-biz .mm-back-chip {
  display:flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  margin-right:2px;
  padding:0;
  border:none;
  border-radius:50%;
  background:transparent;
  color:#888;
  cursor:pointer;
  flex-shrink:0;
  font-family:inherit;
  transition:color .15s, background .15s;
}

#biz.mushrif-biz .mm-back-chip:hover {
  color:#f0ede6;
  background:rgba(255,255,255,.06);
}

#biz.mushrif-biz .mm-header {
  justify-content:flex-start;
}

#biz.mushrif-biz .mm-mall-head {
  margin-bottom:clamp(18px, 4vw, 30px);
}

#biz.mushrif-biz .mm-eyebrow {
  font-size:var(--f-xs);
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#888;
  margin:0 0 clamp(8px, 2vw, 12px);
}

#biz.mushrif-biz .mm-mall-title {
  font-family:'Playfair Display', Georgia, serif;
  font-size:clamp(28px, 8vw, 54px);
  font-weight:700;
  line-height:1.15;
  color:#f0ede6;
  margin:0 0 clamp(10px, 2.5vw, 14px);
}

#biz.mushrif-biz .mm-mall-title .name {
  font-style:italic;
  color:#c9a227;
}

#biz.mushrif-biz .mm-rating-row {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:6px;
  font-size:var(--f-sm);
  color:#aaa;
  margin-bottom:clamp(12px, 3vw, 16px);
}

#biz.mushrif-biz .mm-rating {
  font-weight:800;
  color:#f0ede6;
}

#biz.mushrif-biz .mm-dot { opacity:.45; }

#biz.mushrif-biz .mm-status {
  font-weight:600;
  color:#c9a227;
}

#biz.mushrif-biz .mm-link {
  color:#c9a227;
  text-decoration:none;
  font-weight:600;
}

#biz.mushrif-biz .mm-link:hover { text-decoration:underline; }

#biz.mushrif-biz .mm-section-head {
  text-align:center;
  margin-bottom:clamp(18px, 4vw, 28px);
}

#biz.mushrif-biz .mm-section-label {
  font-size:10px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#888;
  margin:0 0 8px;
}

#biz.mushrif-biz .mm-section-title {
  font-family:'Playfair Display', Georgia, serif;
  font-size:clamp(22px, 5.5vw, 30px);
  font-weight:700;
  color:#f0ede6;
  margin:0;
}

/* Outlet grid — same structure as theme.html .grid > .col > .card */
#biz.mushrif-biz .mm-outlet-grid {
  display:flex;
  gap:var(--gap);
  align-items:flex-start;
}

#biz.mushrif-biz .mm-outlet-grid .col {
  flex:1;
  display:flex;
  flex-direction:column;
  gap:var(--gap);
  min-width:0;
}

#biz.mushrif-biz .mm-outlet-grid .card {
  width:100%;
}

/* ════════════════════════════════════════════
   adidas UAE — Webpage-style outlet (no header/footer bars)
════════════════════════════════════════════ */
#biz.adidas-biz {
  background:#fff;
  color:#111;
  overflow-x:hidden;
}

.ad-web {
  min-height:100vh;
  background:#fff;
}

.ad-back-fab {
  position:fixed;
  top:max(12px, env(safe-area-inset-top, 12px));
  left:max(12px, env(safe-area-inset-left, 12px));
  z-index:30;
  width:42px;
  height:42px;
  border-radius:50%;
  border:none;
  background:rgba(255,255,255,.92);
  color:#111;
  box-shadow:0 2px 12px rgba(0,0,0,.15);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:inherit;
}

.ad-back-fab:hover { background:#fff; }

.ad-banner {
  position:relative;
  min-height:clamp(320px, 58vw, 480px);
  display:flex;
  align-items:flex-end;
  overflow:hidden;
}

.ad-banner-img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 30%;
}

.ad-banner-shade {
  position:absolute;
  inset:0;
  background:linear-gradient(105deg, rgba(0,0,0,.78) 0%, rgba(0,0,0,.45) 45%, rgba(0,0,0,.2) 100%);
  pointer-events:none;
}

.ad-banner-copy {
  position:relative;
  z-index:1;
  width:100%;
  max-width:1100px;
  margin:0 auto;
  padding:clamp(48px, 12vw, 80px) clamp(20px, 5vw, 48px) clamp(36px, 8vw, 56px);
  color:#fff;
}

.ad-kicker {
  font-size:11px;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin:0 0 12px;
  opacity:.75;
}

.ad-wordmark {
  font-family:'Inter', sans-serif;
  font-size:clamp(56px, 14vw, 96px);
  font-weight:800;
  font-style:italic;
  letter-spacing:-.05em;
  line-height:.85;
  margin:0 0 16px;
  text-transform:lowercase;
}

.ad-lead {
  font-size:clamp(15px, 2.8vw, 18px);
  line-height:1.5;
  max-width:36ch;
  margin:0 0 20px;
  opacity:.9;
}

.ad-shop-link {
  display:inline-block;
  font-size:13px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#fff;
  text-decoration:underline;
  text-underline-offset:4px;
  background:transparent;
  border:none;
  padding:0;
  cursor:pointer;
  font-family:inherit;
}

.ad-shop-link:hover { opacity:.85; }

.ad-wrap {
  max-width:1100px;
  margin:0 auto;
  padding:0 clamp(16px, 4vw, 40px) clamp(48px, 10vw, 72px);
}

.ad-block {
  padding:clamp(32px, 6vw, 48px) 0;
  border-bottom:1px solid #e8e8e8;
}

.ad-block:last-child { border-bottom:none; }

.ad-block--muted {
  background:#f5f5f5;
  margin-left:calc(-1 * clamp(16px, 4vw, 40px));
  margin-right:calc(-1 * clamp(16px, 4vw, 40px));
  padding-left:clamp(16px, 4vw, 40px);
  padding-right:clamp(16px, 4vw, 40px);
}

.ad-h2 {
  font-size:clamp(22px, 4.5vw, 28px);
  font-weight:800;
  letter-spacing:-.03em;
  margin:0 0 clamp(16px, 3vw, 24px);
  text-transform:uppercase;
}

.ad-sub {
  font-size:14px;
  color:#666;
  margin:-12px 0 20px;
}

.ad-collection-grid {
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:clamp(10px, 2vw, 16px);
}

@media(min-width:640px) {
  .ad-collection-grid { grid-template-columns:repeat(4, 1fr); }
}

.ad-collection-tile {
  aspect-ratio:4/5;
  border-radius:2px;
  padding:16px 14px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  position:relative;
  overflow:hidden;
  color:#fff;
  border:none;
  cursor:pointer;
  font-family:inherit;
  text-align:left;
  width:100%;
  transition:transform .15s;
}

.ad-collection-tile:hover { transform:translateY(-2px); }

.ad-collection-img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}

.ad-collection-shade {
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 25%, rgba(0,0,0,.75) 100%);
  pointer-events:none;
}

.ad-collection-tile--originals .ad-collection-shade {
  background:linear-gradient(180deg, transparent 20%, rgba(0,0,0,.55) 100%);
}

.ad-collection-tag {
  position:relative;
  z-index:1;
  font-size:9px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  opacity:.9;
  margin-bottom:auto;
  padding-top:4px;
}

.ad-collection-name {
  position:relative;
  z-index:1;
  font-size:clamp(18px, 3.5vw, 22px);
  font-weight:800;
  line-height:1.1;
  margin-bottom:4px;
}

.ad-collection-lines {
  position:relative;
  z-index:1;
  font-size:11px;
  opacity:.9;
  line-height:1.35;
}

.ad-block--visual {
  padding-top:0;
  border-bottom:none;
}

.ad-visual-split {
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}

@media(min-width:640px) {
  .ad-visual-split { grid-template-columns:1fr 1fr; }
}

.ad-visual-card {
  margin:0;
  position:relative;
  overflow:hidden;
  aspect-ratio:16/10;
  background:#111;
}

.ad-visual-card img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.ad-visual-card figcaption {
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:14px 16px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#fff;
  background:linear-gradient(transparent, rgba(0,0,0,.7));
}

.ad-visual-card--dark figcaption {
  background:linear-gradient(transparent, rgba(0,0,0,.85));
}

.ad-strip-title {
  font-size:12px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:#666;
  margin:0 0 14px;
}

.ad-chips {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.ad-chip {
  font-size:12px;
  font-weight:600;
  padding:10px 18px;
  border:1px solid #111;
  border-radius:0;
  background:#fff;
  color:#111;
}

.ad-promo {
  background:#000;
  color:#fff;
  border-radius:0;
}

.ad-promo--split {
  display:grid;
  grid-template-columns:1fr;
  overflow:hidden;
}

@media(min-width:720px) {
  .ad-promo--split { grid-template-columns:1fr 1fr; }
}

.ad-promo-media {
  min-height:220px;
  background:#111;
}

.ad-promo-media img {
  width:100%;
  height:100%;
  min-height:220px;
  object-fit:cover;
  display:block;
}

.ad-promo-body {
  padding:clamp(28px, 5vw, 40px);
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.ad-promo-label {
  display:inline-block;
  font-size:10px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  background:#fff;
  color:#000;
  padding:6px 12px;
  margin-bottom:16px;
}

.ad-promo-title {
  font-size:clamp(22px, 4.5vw, 32px);
  font-weight:800;
  letter-spacing:-.03em;
  line-height:1.15;
  margin:0 0 12px;
  max-width:20ch;
}

.ad-promo-text {
  font-size:14px;
  line-height:1.55;
  color:rgba(255,255,255,.75);
  margin:0 0 22px;
  max-width:48ch;
}

.ad-btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 28px;
  font-size:13px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  border:none;
  cursor:pointer;
  font-family:inherit;
}

.ad-btn--dark {
  background:#fff;
  color:#000;
}

.ad-btn--dark:hover { background:#e5e5e5; }

.ad-tile-grid {
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:10px;
}

@media(min-width:560px) {
  .ad-tile-grid { grid-template-columns:repeat(4, 1fr); }
}

.ad-tile {
  text-align:left;
  padding:16px 14px;
  background:#f5f5f5;
  border:1px solid #e8e8e8;
  border-radius:0;
  cursor:pointer;
  font-family:inherit;
  color:#111;
  transition:background .15s, border-color .15s;
  min-height:120px;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.ad-tile:hover {
  background:#ebebeb;
  border-color:#111;
}

.ad-tile-icon {
  width:22px;
  color:#111;
}

.ad-tile-icon svg { width:100%; height:auto; }

.ad-tile-label {
  font-size:13px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.02em;
}

.ad-tile-desc {
  font-size:11px;
  color:#666;
  line-height:1.35;
}

.ad-app-list {
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:0;
  border-top:1px solid #ddd;
}

.ad-app-row {
  display:flex;
  flex-direction:column;
  gap:2px;
  padding:16px 0;
  border-bottom:1px solid #ddd;
  font-size:14px;
}

.ad-app-row strong { font-weight:700; }
.ad-app-row span { color:#666; font-size:13px; }

/* ════════════════════════════════════════════
   India Palace UAE — Mughal royal outlet page
════════════════════════════════════════════ */
#biz.india-palace-biz {
  background:#1a0810;
  color:#f8f0e4;
  overflow-x:hidden;
  width:100%;
}

.ip-web {
  position:relative;
  width:100%;
  max-width:100%;
  min-height:100vh;
  min-height:100dvh;
  background:linear-gradient(180deg, #1a0810 0%, #2d0f1a 40%, #f8f0e4 40%, #f8f0e4 100%);
}

.ip-pattern {
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.04;
  background-image:
    radial-gradient(circle at 20% 30%, #c9a227 1px, transparent 1px),
    radial-gradient(circle at 80% 70%, #c9a227 1px, transparent 1px);
  background-size:24px 24px;
  z-index:0;
}

.ip-back-fab {
  position:fixed;
  top:max(12px, env(safe-area-inset-top, 12px));
  left:max(12px, env(safe-area-inset-left, 12px));
  z-index:30;
  width:42px;
  height:42px;
  border-radius:50%;
  border:1px solid rgba(201,162,39,.45);
  background:rgba(26,8,16,.75);
  color:#f8f0e4;
  backdrop-filter:blur(8px);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:inherit;
}

.ip-back-fab:hover {
  background:#4a0e1e;
  border-color:#c9a227;
}

.ip-royal-hero {
  position:relative;
  min-height:clamp(340px, 62vw, 520px);
  overflow:hidden;
  z-index:1;
}

.ip-arch {
  position:absolute;
  bottom:-2px;
  left:50%;
  transform:translateX(-50%);
  width:min(120%, 720px);
  height:clamp(80px, 18vw, 140px);
  background:#f8f0e4;
  border-radius:50% 50% 0 0 / 100% 100% 0 0;
  z-index:4;
  box-shadow:0 -4px 24px rgba(0,0,0,.12);
}

.ip-hero-img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 40%;
}

.ip-hero-veil {
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,
    rgba(26,8,16,.55) 0%,
    rgba(74,14,30,.75) 55%,
    rgba(26,8,16,.9) 100%);
  z-index:1;
}

.ip-hero-content {
  position:relative;
  z-index:3;
  padding:max(72px, 14vw) 24px clamp(100px, 22vw, 160px);
  text-align:center;
  max-width:640px;
  margin:0 auto;
}

.ip-since {
  font-size:11px;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:#c9a227;
  margin:0 0 10px;
}

.ip-logo {
  font-family:Georgia, 'Times New Roman', serif;
  font-size:clamp(36px, 9vw, 56px);
  font-weight:400;
  letter-spacing:.04em;
  margin:0 0 8px;
  color:#fff;
  text-shadow:0 2px 20px rgba(0,0,0,.4);
}

.ip-namaste {
  font-size:clamp(14px, 3.2vw, 17px);
  color:rgba(248,240,228,.9);
  margin:0 0 6px;
  line-height:1.45;
}

.ip-branch {
  font-size:13px;
  color:rgba(248,240,228,.65);
  margin:0 0 20px;
}

.ip-cta {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 28px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  text-decoration:none;
  color:#1a0810;
  background:linear-gradient(135deg, #e8c96a 0%, #c9a227 50%, #a67c1a 100%);
  border:1px solid rgba(255,255,255,.25);
  box-shadow:0 4px 16px rgba(0,0,0,.25);
  transition:transform .15s, box-shadow .15s;
  cursor:pointer;
  font-family:inherit;
}

.ip-cta:hover {
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(201,162,39,.35);
}

.ip-gold-rule {
  height:3px;
  max-width:200px;
  margin:-1px auto 0;
  background:linear-gradient(90deg, transparent, #c9a227, transparent);
  position:relative;
  z-index:5;
}

.ip-trust {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:8px 12px;
  padding:18px 16px;
  font-size:11px;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#4a0e1e;
  background:#f8f0e4;
  border-bottom:1px solid rgba(74,14,30,.12);
  position:relative;
  z-index:2;
}

.ip-trust-dot {
  color:#c9a227;
  font-size:8px;
}

.ip-body {
  position:relative;
  z-index:2;
  background:#f8f0e4;
  padding:8px clamp(16px, 4vw, 48px) 32px;
  max-width:min(1280px, 100%);
  margin:0 auto;
  width:100%;
}

.ip-block { margin-bottom:28px; }

.ip-h2 {
  font-family:Georgia, 'Times New Roman', serif;
  font-size:clamp(22px, 5vw, 28px);
  font-weight:400;
  color:#4a0e1e;
  margin:0 0 16px;
  text-align:center;
}

.ip-h2-deco {
  color:#c9a227;
  margin-right:8px;
  font-size:.85em;
}

.ip-sig-grid {
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:10px;
}

@media(min-width:520px) {
  .ip-sig-grid { grid-template-columns:repeat(4, 1fr); }
}

.ip-sig {
  position:relative;
  aspect-ratio:3/4;
  border-radius:4px;
  overflow:hidden;
  border:1px solid rgba(74,14,30,.15);
  box-shadow:0 4px 12px rgba(26,8,16,.12);
  padding:0;
  cursor:pointer;
  font-family:inherit;
  text-align:left;
  width:100%;
  transition:border-color .15s, box-shadow .15s, transform .15s;
}

.ip-sig:hover {
  border-color:#c9a227;
  box-shadow:0 6px 16px rgba(74,14,30,.2);
  transform:translateY(-2px);
}

.ip-sig img {
  width:100%;
  height:100%;
  object-fit:cover;
}

.ip-sig-veil {
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 35%, rgba(26,8,16,.88) 100%);
}

.ip-sig-tag {
  position:absolute;
  top:8px;
  left:8px;
  font-size:9px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:4px 8px;
  background:rgba(201,162,39,.92);
  color:#1a0810;
}

.ip-sig-name {
  position:absolute;
  left:10px;
  right:10px;
  bottom:28px;
  font-family:Georgia, serif;
  font-size:15px;
  color:#fff;
}

.ip-sig-lines {
  position:absolute;
  left:10px;
  right:10px;
  bottom:10px;
  font-size:10px;
  color:rgba(248,240,228,.75);
  line-height:1.3;
}

.ip-block--quote { padding:0 8px; }

.ip-quote {
  display:block;
  width:100%;
  margin:0;
  padding:20px 22px;
  background:#4a0e1e;
  color:#f8f0e4;
  border:1px solid rgba(74,14,30,.2);
  border-left:4px solid #c9a227;
  border-radius:0 8px 8px 0;
  cursor:pointer;
  font-family:inherit;
  text-align:left;
  transition:background .15s, border-color .15s;
}

.ip-quote:hover {
  background:#5a1228;
  border-color:#c9a227;
}

.ip-quote p {
  margin:0;
  font-family:Georgia, serif;
  font-size:15px;
  line-height:1.55;
  font-style:italic;
  color:inherit;
}

.ip-favs {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:center;
}

.ip-fav {
  font-size:12px;
  font-weight:600;
  padding:8px 14px;
  background:#fff;
  color:#4a0e1e;
  border:1px solid rgba(74,14,30,.2);
  border-radius:999px;
  cursor:pointer;
  font-family:inherit;
  transition:background .15s, border-color .15s;
}

.ip-fav:hover {
  background:#fff9f0;
  border-color:#c9a227;
}

.ip-feast {
  display:grid;
  gap:0;
  width:100%;
  border-radius:8px;
  overflow:hidden;
  border:1px solid rgba(74,14,30,.15);
  box-shadow:0 6px 20px rgba(26,8,16,.1);
  padding:0;
  cursor:pointer;
  font-family:inherit;
  text-align:left;
  background:transparent;
  transition:border-color .15s, box-shadow .15s;
}

.ip-feast:hover {
  border-color:#c9a227;
  box-shadow:0 8px 24px rgba(74,14,30,.18);
}

@media(min-width:480px) {
  .ip-feast { grid-template-columns:1fr 1fr; }
}

.ip-feast img {
  width:100%;
  height:100%;
  min-height:180px;
  object-fit:cover;
}

.ip-feast-copy {
  padding:22px 20px;
  background:linear-gradient(135deg, #4a0e1e, #2d0f1a);
  color:#f8f0e4;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.ip-feast-copy h2 {
  font-family:Georgia, serif;
  font-size:20px;
  font-weight:400;
  margin:0 0 8px;
  color:#c9a227;
}

.ip-feast-copy p {
  margin:0;
  font-size:13px;
  line-height:1.5;
  color:rgba(248,240,228,.85);
}

.ip-services {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:8px;
  margin-bottom:14px;
}

.ip-service {
  text-align:center;
  padding:14px 8px;
  background:#fff;
  border:1px solid rgba(74,14,30,.12);
  border-radius:4px;
  cursor:pointer;
  font-family:inherit;
  transition:background .15s, border-color .15s;
}

.ip-service:hover {
  background:#fff9f0;
  border-color:#c9a227;
}

.ip-service strong {
  display:block;
  font-size:12px;
  color:#4a0e1e;
  margin-bottom:4px;
}

.ip-service span {
  font-size:10px;
  color:#666;
  line-height:1.35;
}

.ip-link-out {
  display:block;
  width:100%;
  text-align:center;
  font-size:12px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#4a0e1e;
  text-decoration:none;
  padding:10px;
  background:transparent;
  border:none;
  cursor:pointer;
  font-family:inherit;
}

.ip-link-out:hover { color:#c9a227; }

.ip-sub {
  text-align:center;
  font-size:13px;
  color:#666;
  margin:-8px 0 16px;
}

.ip-tile-grid {
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:clamp(10px, 1.5vw, 14px);
  width:100%;
}

@media(min-width:600px) {
  .ip-tile-grid { grid-template-columns:repeat(3, 1fr); }
}

@media(min-width:900px) {
  .ip-tile-grid { grid-template-columns:repeat(4, 1fr); }
}

.ip-tile {
  text-align:left;
  padding:14px 12px;
  background:#fff;
  border:1px solid rgba(74,14,30,.18);
  border-radius:4px;
  cursor:pointer;
  font-family:inherit;
  color:#4a0e1e;
  transition:background .15s, border-color .15s, box-shadow .15s;
  min-height:108px;
  display:flex;
  flex-direction:column;
  gap:4px;
}

.ip-tile:hover {
  background:#fff9f0;
  border-color:#c9a227;
  box-shadow:0 4px 12px rgba(74,14,30,.12);
}

.ip-tile-icon {
  display:flex;
  align-items:center;
  justify-content:flex-start;
  width:32px;
  height:32px;
  color:#c9a227;
  flex-shrink:0;
}

.ip-tile-icon svg { width:100%; height:100%; }

.ip-tile-label {
  font-size:13px;
  font-weight:800;
  letter-spacing:.02em;
}

.ip-tile-desc {
  font-size:11px;
  color:#666;
  line-height:1.35;
}

/* ── IL Forno — wood-fired trattoria (Mushrif) ── */
#biz.il-forno-biz {
  background:#f6f0e6;
  overflow-x:hidden;
}

.if-web {
  max-width:1280px;
  margin:0 auto;
  min-height:100%;
  font-family:'Inter', sans-serif;
  color:#2a1810;
}

.if-back {
  position:fixed;
  top:max(12px, env(safe-area-inset-top));
  left:12px;
  z-index:30;
  display:flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border:none;
  border-radius:50%;
  background:rgba(42,24,16,.75);
  color:#fff8f0;
  cursor:pointer;
  backdrop-filter:blur(8px);
}

.if-hero {
  position:relative;
  padding:56px 20px 32px;
  background:
    radial-gradient(ellipse 70% 50% at 50% 100%, rgba(201, 90, 42, .35) 0%, transparent 70%),
    linear-gradient(165deg, #3d2218 0%, #2a1810 45%, #1f120c 100%);
  color:#fff8f0;
  overflow:hidden;
}

.if-brick {
  position:absolute;
  inset:0;
  opacity:.12;
  background:
    repeating-linear-gradient(0deg, transparent, transparent 18px, rgba(0,0,0,.4) 18px, rgba(0,0,0,.4) 20px),
    repeating-linear-gradient(90deg, transparent, transparent 42px, rgba(0,0,0,.25) 42px, rgba(0,0,0,.25) 44px);
  pointer-events:none;
}

.if-oven-glow {
  position:absolute;
  bottom:-20%;
  left:50%;
  transform:translateX(-50%);
  width:min(90%, 480px);
  height:55%;
  background:radial-gradient(ellipse at center, rgba(255, 140, 60, .45) 0%, transparent 70%);
  pointer-events:none;
}

.if-hero-grid {
  position:relative;
  z-index:1;
  display:grid;
  gap:24px;
  align-items:center;
}
@media (min-width:720px) {
  .if-hero-grid { grid-template-columns:1fr 1fr; gap:32px; padding:0 24px; }
}

.if-eyebrow {
  font-size:11px;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:#e8b88a;
  margin:0 0 8px;
}

.if-logo {
  font-family:'Playfair Display', Georgia, serif;
  font-size:clamp(2.4rem, 8vw, 3.6rem);
  font-weight:800;
  line-height:1.05;
  margin:0 0 10px;
  letter-spacing:-.02em;
}
.if-logo span { color:#7cb87c; font-style:italic; font-weight:700; }

.if-tagline {
  font-size:15px;
  line-height:1.5;
  opacity:.9;
  margin:0 0 16px;
  max-width:28em;
}

.if-badges {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:20px;
}
.if-badges span {
  font-size:11px;
  font-weight:600;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(255,248,240,.12);
  border:1px solid rgba(255,248,240,.2);
}

.if-cta {
  font-size:14px;
  font-weight:700;
  padding:12px 24px;
  border:none;
  border-radius:8px;
  background:#c45a2a;
  color:#fff;
  cursor:pointer;
  box-shadow:0 4px 16px rgba(196, 90, 42, .45);
  transition:transform .15s, background .15s;
}
.if-cta:hover { background:#d96a38; transform:translateY(-1px); }

.if-hero-plate {
  position:relative;
  margin:0;
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 16px 40px rgba(0,0,0,.35);
  aspect-ratio:4/3;
  max-width:420px;
  margin-inline:auto;
}
.if-hero-plate img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.if-steam {
  position:absolute;
  top:8%;
  left:20%;
  width:60%;
  height:30%;
  background:linear-gradient(180deg, rgba(255,255,255,.15) 0%, transparent 100%);
  border-radius:50%;
  filter:blur(12px);
  animation:if-steam 4s ease-in-out infinite;
}
@keyframes if-steam {
  0%, 100% { opacity:.4; transform:translateY(0); }
  50% { opacity:.7; transform:translateY(-8px); }
}

.if-ribbon {
  display:flex;
  height:6px;
}
.if-ribbon span:nth-child(1) { flex:1; background:#1a6b3c; }
.if-ribbon span:nth-child(2) { flex:1; background:#fff; }
.if-ribbon span:nth-child(3) { flex:1; background:#c41230; }

.if-main {
  padding:28px 16px 40px;
}
@media (min-width:720px) {
  .if-main { padding:36px 32px 48px; }
}

.if-block { margin-bottom:32px; }
.if-block-head { margin-bottom:20px; }

.if-h2 {
  font-family:'Playfair Display', Georgia, serif;
  font-size:clamp(1.5rem, 4vw, 2rem);
  font-weight:800;
  margin:0 0 8px;
  color:#2a1810;
}
.if-h2--small { font-size:1.15rem; }
.if-lead {
  margin:0;
  font-size:14px;
  color:#5c4030;
  line-height:1.55;
  max-width:36em;
}

.if-menu {
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:12px;
}
@media (min-width:640px) {
  .if-menu { grid-template-columns:repeat(4, 1fr); gap:14px; }
}

.if-menu-card {
  position:relative;
  min-height:clamp(160px, 28vw, 220px);
  border:none;
  border-radius:16px;
  overflow:hidden;
  cursor:pointer;
  text-align:left;
  padding:0;
  font-family:inherit;
  transition:transform .2s, box-shadow .2s;
}
.if-menu-card:hover {
  transform:translateY(-4px);
  box-shadow:0 12px 28px rgba(42,24,16,.2);
}
.if-menu-card img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}
.if-menu-shade {
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 25%, rgba(26,12,8,.9) 100%);
}
.if-menu-tag {
  position:absolute;
  top:10px;
  left:10px;
  z-index:2;
  font-size:9px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:4px 8px;
  background:#c45a2a;
  color:#fff;
  border-radius:4px;
}
.if-menu-name {
  position:absolute;
  left:12px;
  right:12px;
  bottom:32px;
  z-index:2;
  font-family:'Playfair Display', Georgia, serif;
  font-size:1.05rem;
  font-weight:700;
  color:#fff8f0;
}
.if-menu-lines {
  position:absolute;
  left:12px;
  right:12px;
  bottom:12px;
  z-index:2;
  font-size:10px;
  color:rgba(255,248,240,.85);
  line-height:1.3;
}

.if-dolci {
  display:grid;
  width:100%;
  border:none;
  border-radius:20px;
  overflow:hidden;
  cursor:pointer;
  padding:0;
  text-align:left;
  font-family:inherit;
  min-height:140px;
  box-shadow:0 8px 24px rgba(42,24,16,.12);
  transition:transform .2s;
}
@media (min-width:640px) {
  .if-dolci { grid-template-columns:1.2fr 1fr; min-height:180px; }
}
.if-dolci:hover { transform:scale(1.01); }
.if-dolci img {
  width:100%;
  height:100%;
  min-height:140px;
  object-fit:cover;
}
.if-dolci-copy {
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:20px 24px;
  background:linear-gradient(135deg, #fffef8 0%, #f0e6d8 100%);
}
.if-dolci-label {
  font-size:10px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#1a6b3c;
}
.if-dolci-copy h3 {
  font-family:'Playfair Display', Georgia, serif;
  font-size:1.35rem;
  margin:6px 0 8px;
  color:#2a1810;
}
.if-dolci-copy p {
  margin:0;
  font-size:13px;
  color:#5c4030;
  line-height:1.45;
}

.if-chips {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.if-chip {
  font-size:12px;
  font-weight:600;
  padding:8px 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid #e0d4c4;
  color:#3d2218;
}

.if-services {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:10px;
}
.if-service {
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:14px 12px;
  border:1px solid #e0d4c4;
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  font-family:inherit;
  text-align:left;
  transition:border-color .15s, box-shadow .15s;
}
.if-service:hover {
  border-color:#c45a2a;
  box-shadow:0 4px 12px rgba(196,90,42,.15);
}
.if-service strong { font-size:13px; color:#2a1810; }
.if-service span { font-size:11px; color:#6b5344; }

.if-actions {
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:10px;
}
@media (min-width:560px) {
  .if-actions { grid-template-columns:repeat(4, 1fr); }
}
.if-action {
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:6px;
  padding:14px;
  border:1px solid #e0d4c4;
  border-radius:14px;
  background:#fff;
  cursor:pointer;
  font-family:inherit;
  text-align:left;
  transition:border-color .15s, transform .15s;
}
.if-action:hover {
  border-color:#1a6b3c;
  transform:translateY(-2px);
}
.if-action-icon {
  display:flex;
  width:28px;
  height:28px;
  color:#c45a2a;
}
.if-action-icon svg { width:100%; height:100%; }
.if-action-l { font-size:13px; font-weight:700; color:#2a1810; }
.if-action-d { font-size:11px; color:#6b5344; line-height:1.35; }
