/* ============================================================
   MERIDIAN — "The Concierge Almanac" (Redesign)
   A world-class, cutting-edge editorial aesthetic. 
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none!important}

:root{
  /* paper + ink */
  --paper:#f3eee3; --paper-2:#e6dfcd;
  --card:#fdfbf7; --card-2:#f6f3eb;
  --ink:#1a1612; --ink-2:#4d4337; --ink-3:#867a68;
  --muted:#867a68; --cream:#fdfbf7; --cream-dim:#c4b7a1; --surface:#fdfbf7;
  --hair:rgba(26,22,18,.1); --hair-soft:rgba(26,22,18,.06); --hair-fine:rgba(26,22,18,.03);
  --track:rgba(36,28,18,.12);
  --blur-bg:rgba(243,238,227,.85);
  --blur-bg-solid:rgba(253,251,247,.95);
  --shadow-color:rgba(60,44,20,.05);
  /* accents */
  --gold:#ad6d2f; --gold-soft:#d4a570;
  --jade:#376646; --jade-soft:#629973;
  --clay:#b24b2a;
  /* geometry */
  --r:16px; --r-sm:10px; --r-lg:28px;
  --shadow:0 18px 44px -14px rgba(60,44,20,.12), 0 1px 0 rgba(255,255,255,.7) inset;
  --shadow-sm:0 8px 24px -8px rgba(60,44,20,.1), 0 1px 0 rgba(255,255,255,.6) inset;
  --bg-grad: radial-gradient(120% 90% at 12% 0%, rgba(255,252,246,.8), transparent 60%),
             radial-gradient(120% 100% at 100% 100%, rgba(212,197,166,.4), transparent 60%),
             linear-gradient(var(--paper),var(--paper-2));
  --grain-op:0.4;
  --grain-blend:multiply;
  --ease:cubic-bezier(.19,1,.22,1);
  --safe-b:env(safe-area-inset-bottom,0px);
  --safe-t:env(safe-area-inset-top,0px);
  --display:"Fraunces",Georgia,serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"Spline Sans Mono",ui-monospace,"SF Mono",monospace;
}

html,body{margin:0;height:100%}
body{
  font-family:var(--body); color:var(--ink); background:var(--paper);
  background-image: var(--bg-grad);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overscroll-behavior:none;
}
::selection{background:rgba(173,109,47,.2)}

/* dark theme variables */
@media (prefers-color-scheme: dark) {
  html:not([data-theme="light"]) {
    --paper:#1e1a17; --paper-2:#161310;
    --card:#28231e; --card-2:#2e2823;
    --ink:#f3eee3; --ink-2:#cbbda4; --ink-3:#867a68;
    --muted:#867a68; --cream:#1e1a17; --cream-dim:#4d4337; --surface:#28231e;
    --hair:rgba(243,238,227,.12); --hair-soft:rgba(243,238,227,.08); --hair-fine:rgba(243,238,227,.04);
    --track:rgba(243,238,227,.12);
    --blur-bg:rgba(30,26,23,.85);
    --blur-bg-solid:rgba(38,33,29,.95);
    --shadow-color:rgba(0,0,0,.2);
    --gold:#d4a570; --gold-soft:#e6c39a;
    --jade:#629973; --jade-soft:#8bbda0;
    --clay:#d67053;
    --shadow:0 18px 44px -14px rgba(0,0,0,.5), 0 1px 0 rgba(255,255,255,.05) inset;
    --shadow-sm:0 8px 24px -8px rgba(0,0,0,.4), 0 1px 0 rgba(255,255,255,.05) inset;
    --bg-grad: radial-gradient(120% 90% at 12% 0%, rgba(255,255,255,.05), transparent 60%),
               radial-gradient(120% 100% at 100% 100%, rgba(0,0,0,.6), transparent 60%),
               linear-gradient(var(--paper),var(--paper-2));
    --grain-op: 0.15;
    --grain-blend: screen;
  }
}
html[data-theme="dark"] {
  --paper:#1e1a17; --paper-2:#161310;
  --card:#28231e; --card-2:#2e2823;
  --ink:#f3eee3; --ink-2:#cbbda4; --ink-3:#867a68;
  --muted:#867a68; --cream:#1e1a17; --cream-dim:#4d4337; --surface:#28231e;
  --hair:rgba(243,238,227,.12); --hair-soft:rgba(243,238,227,.08); --hair-fine:rgba(243,238,227,.04);
  --track:rgba(243,238,227,.12);
  --blur-bg:rgba(30,26,23,.85);
  --blur-bg-solid:rgba(38,33,29,.95);
  --shadow-color:rgba(0,0,0,.2);
  --gold:#d4a570; --gold-soft:#e6c39a;
  --jade:#629973; --jade-soft:#8bbda0;
  --clay:#d67053;
  --shadow:0 18px 44px -14px rgba(0,0,0,.5), 0 1px 0 rgba(255,255,255,.05) inset;
  --shadow-sm:0 8px 24px -8px rgba(0,0,0,.4), 0 1px 0 rgba(255,255,255,.05) inset;
  --bg-grad: radial-gradient(120% 90% at 12% 0%, rgba(255,255,255,.05), transparent 60%),
             radial-gradient(120% 100% at 100% 100%, rgba(0,0,0,.6), transparent 60%),
             linear-gradient(var(--paper),var(--paper-2));
  --grain-op: 0.15;
  --grain-blend: screen;
}

/* paper grain */
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:var(--grain-op);mix-blend-mode:var(--grain-blend);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");}

/* app shell */
#app{position:relative;z-index:2;height:100%;}
.screen{position:absolute;inset:0;overflow-y:auto;overflow-x:hidden;
  padding:calc(var(--safe-t) + 32px) 24px calc(120px + var(--safe-b));
  -webkit-overflow-scrolling:touch}
.screen[hidden]{display:none}
.screen:not([hidden])>*{animation:rise .6s var(--ease) backwards}
.screen:not([hidden])>*:nth-child(1){animation-delay:.02s}
.screen:not([hidden])>*:nth-child(2){animation-delay:.08s}
.screen:not([hidden])>*:nth-child(3){animation-delay:.14s}
.screen:not([hidden])>*:nth-child(4){animation-delay:.20s}
.stack>*{animation:rise .55s var(--ease) backwards}
.stack>*:nth-child(2){animation-delay:.06s}
.stack>*:nth-child(3){animation-delay:.12s}
.stack>*:nth-child(4){animation-delay:.18s}
.stack>*:nth-child(5){animation-delay:.24s}
.stack>*:nth-child(n+6){animation-delay:.3s}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0}to{opacity:1}}
.stack{display:flex;flex-direction:column;gap:20px}

/* headers */
.top{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;
  padding-bottom:18px;margin-bottom:24px;border-bottom:1px solid var(--hair);position:relative}
.top::after{content:"";position:absolute;left:0;bottom:-1px;width:54px;height:2px;background:var(--gold)}
.eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);margin:0 0 10px;font-weight:500}
.screen-title{font-family:var(--display);font-weight:300;font-size:clamp(38px,10vw,52px);line-height:1;
  letter-spacing:-.02em;margin:0;font-optical-sizing:auto}
.screen-title em{font-style:italic;color:var(--ink-2)}
.ghost-pill{font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;background:var(--card);
  color:var(--ink);border:1px solid var(--hair);border-radius:100px;padding:10px 16px;cursor:pointer;
  box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),background .2s;display:inline-flex;align-items:center;gap:6px}
.ghost-pill:active{transform:scale(.96)}
.header-actions { display: flex; gap: 8px; }

/* cards */
.card{position:relative;background:var(--card);border:1px solid var(--hair-soft);border-radius:var(--r);
  padding:26px;box-shadow:var(--shadow)}
.card::before,.card::after{content:"";position:absolute;width:6px;height:6px;opacity:.3;pointer-events:none}
.card::before{top:12px;left:12px;border-top:1px solid var(--ink-3);border-left:1px solid var(--ink-3)}
.card::after{bottom:12px;right:12px;border-bottom:1px solid var(--ink-3);border-right:1px solid var(--ink-3)}
.card-label{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:18px;display:flex;align-items:center;gap:12px}
.card-label::after{content:"";flex:1;height:1px;background:var(--hair-soft)}
.lead{font-family:var(--display);font-size:17.5px;line-height:1.55;color:var(--ink-2);margin:0;font-weight:300}
.brief{font-family:var(--display);font-size:18px;line-height:1.65;color:var(--ink);margin:0;white-space:pre-wrap;font-weight:300}
.brief strong,.verdict strong{font-weight:400;color:var(--gold)}
.section-label{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;color:var(--ink-3);
  margin:4px 2px 8px;text-transform:none}

/* readiness dial */
.ready{display:flex;flex-direction:column;align-items:center;text-align:center;padding:36px 24px 32px}
.ring{position:relative;width:240px;height:240px;display:grid;place-items:center}
.ring::before{content:"";position:absolute;inset:0;border-radius:50%;
  background:repeating-conic-gradient(var(--hair) 0deg .4deg, transparent .4deg 5deg);
  -webkit-mask:radial-gradient(circle, transparent 112px, #000 112px, #000 120px, transparent 120px);
          mask:radial-gradient(circle, transparent 112px, #000 112px, #000 120px, transparent 120px)}
.ring svg{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg)}
.ring .track{fill:none;stroke:var(--hair-soft);stroke-width:2}
.ring .val{fill:none;stroke:url(#g);stroke-width:4;stroke-linecap:round;
  transition:stroke-dasharray 1.1s var(--ease);filter:drop-shadow(0 4px 8px rgba(173,109,47,0.25))}
.ring-num{font-family:var(--display);font-weight:300;font-size:86px;line-height:1;letter-spacing:-.03em}
.ring-cap{font-family:var(--mono);font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-3);margin-top:8px}
.verdict{font-family:var(--display);font-size:20px;line-height:1.5;font-weight:300;margin:28px 4px 0;color:var(--ink);max-width:32ch}

/* metrics */
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--hair-soft);
  border:1px solid var(--hair-soft);border-radius:var(--r);overflow:hidden}
.metric{background:var(--card);padding:18px 16px}
.m-k{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.m-v{font-family:var(--display);font-size:30px;font-weight:300;line-height:1.1;margin-top:6px}
.m-d{font-family:var(--mono);font-size:10.5px;letter-spacing:.02em;margin-top:6px;display:block}
.m-d.up{color:var(--jade)} .m-d.down{color:var(--clay)} .m-d.flat{color:var(--ink-3)}

/* timeline */
.timeline{display:flex;flex-direction:column;gap:2px}
.tl{display:grid;grid-template-columns:68px 1fr;gap:16px;padding:16px 0;border-top:1px solid var(--hair-soft);align-items:start}
.tl:first-child{border-top:0;padding-top:4px}
.tl-time{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);padding-top:4px}
.tl-body strong{display:block;font-family:var(--display);font-size:17.5px;font-weight:400;margin-bottom:4px}
.tl-body span{font-size:14.5px;line-height:1.55;color:var(--ink-2)}

/* macros */
.macros{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.macro{display:flex;flex-direction:column;align-items:center;gap:10px}
.mini-ring{position:relative;width:66px;height:66px;display:grid;place-items:center}
.mini-ring svg{position:absolute;inset:0;transform:rotate(-90deg)}
.mr-num{font-family:var(--display);font-size:18px;font-weight:400}
.mk{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);text-align:center}

/* pills / tags */
.pill{display:inline-block;font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;padding:8px 14px;
  border-radius:100px;border:1px solid var(--hair);margin:5px 8px 0 0;color:var(--ink-2);background:var(--card-2);box-shadow:var(--shadow-sm)}
.pill.warn{color:var(--clay);border-color:rgba(178,75,42,.3);background:rgba(178,75,42,.05)}
.pill.ok{color:var(--jade);border-color:rgba(55,102,70,.3);background:rgba(55,102,70,.05)}
.tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);border:1px solid rgba(173,109,47,.3);border-radius:6px;padding:4px 8px}

/* sparkline */
.spark{display:flex;align-items:flex-end;gap:5px;height:44px}
.spark i{flex:1;background:linear-gradient(var(--jade),var(--jade-soft));border-radius:3px 3px 0 0;min-height:4px;opacity:.9}

/* buttons */
.btn-primary{font-family:var(--mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;
  background:var(--ink);color:var(--paper);border:none;border-radius:100px;padding:16px 26px;cursor:pointer;
  display:inline-flex;align-items:center;gap:10px;box-shadow:0 8px 24px -6px rgba(0,0,0,0.3);transition:transform .2s var(--ease),box-shadow .2s}
.btn-primary:active{transform:scale(.97);box-shadow:0 4px 12px -4px rgba(0,0,0,0.3)} 
.btn-primary .arr{transition:transform .25s}
.btn-primary:hover .arr{transform:translateX(4px)}
.btn-ghost{font-family:var(--mono);font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;
  background:transparent;color:var(--ink);border:1px solid var(--hair);border-radius:100px;padding:14px 22px;cursor:pointer;transition:background .2s,transform .2s var(--ease)}
.btn-ghost:active{transform:scale(.97)} .btn-ghost:hover{background:var(--card-2)}
.btn-row{display:flex;gap:12px;flex-wrap:wrap} .btn-row>*{flex:1;justify-content:center;text-align:center}

/* seg */
.seg{display:flex;background:var(--card);border:1px solid var(--hair);border-radius:100px;padding:5px;
  width:fit-content;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.seg button{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;border:none;
  background:none;color:var(--ink-3);padding:10px 24px;border-radius:100px;cursor:pointer;transition:all .25s var(--ease)}
.seg button.active{background:var(--ink);color:var(--paper);box-shadow:0 4px 12px rgba(0,0,0,0.15)}

/* search */
.search-wrap{display:flex;gap:10px;margin-bottom:18px}
.search{flex:1;font-family:var(--body);font-size:16px;color:var(--ink);background:var(--card);
  border:1px solid var(--hair);border-radius:100px;padding:16px 22px;box-shadow:var(--shadow-sm);transition:all .2s}
.search::placeholder{color:var(--ink-3)} .search:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(173,109,47,.1)}
.search-go{font-family:var(--mono);font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;
  background:var(--ink);color:var(--paper);border:none;border-radius:100px;padding:0 26px;cursor:pointer;transition:transform .2s}
.search-go:active{transform:scale(0.96)}
.chips{display:flex;gap:10px;overflow-x:auto;padding-bottom:16px;margin-bottom:8px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:none;font-family:var(--body);font-size:14.5px;background:var(--card);border:1px solid var(--hair);
  border-radius:100px;padding:10px 18px;cursor:pointer;color:var(--ink-2);white-space:nowrap;transition:all .2s;box-shadow:var(--shadow-sm)}
.chip:hover{border-color:var(--gold);color:var(--ink);transform:translateY(-1px)}

/* venues */
.venue{padding:0;overflow:hidden;cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s}
.venue::before,.venue::after{display:none}
.venue:active{transform:scale(.98)}
.v-photo{position:relative;height:180px;background:var(--paper-2) center/cover no-repeat;
  border-bottom:1px solid var(--hair-soft)}
.v-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(26,22,18,.6) 100%)}
.v-rank{position:absolute;top:14px;left:14px;z-index:2;font-family:var(--display);font-size:22px;font-weight:300;
  width:44px;height:44px;display:grid;place-items:center;background:var(--blur-bg-solid);color:var(--ink);
  border-radius:50%;box-shadow:var(--shadow-sm);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.v-rating{position:absolute;bottom:14px;right:14px;z-index:2;font-family:var(--mono);font-size:12.5px;
  color:#fff;letter-spacing:.04em;text-shadow:0 1px 4px rgba(0,0,0,0.6)}.v-rating b{font-size:16.5px;font-weight:500}
.v-save{position:absolute;top:14px;right:14px;z-index:3;width:44px;height:44px;border-radius:50%;
  border:1px solid var(--hair);background:var(--blur-bg-solid);color:var(--ink);font-size:19px;cursor:pointer;
  display:grid;place-items:center;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),color .2s;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.v-save:active{transform:scale(.82)} .v-save.on{color:var(--gold);border-color:var(--gold)}
.rec-label{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);
  align-self:center;margin-right:4px;flex:none}
.chip.rec{background:transparent;font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;text-transform:none;border-color:transparent;box-shadow:none;padding:8px 12px}
.chip.rec:hover{background:var(--hair-soft)}
.v-body{padding:22px}
.v-name{font-family:var(--display);font-size:24px;font-weight:300;line-height:1.2;letter-spacing:-.015em}
.v-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:12px;
  font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--ink-3)}
.v-evidence{margin-top:16px;padding-top:16px;border-top:1px solid var(--hair-soft);
  font-family:var(--display);font-size:16px;line-height:1.6;color:var(--ink-2);font-style:italic}
.v-evidence strong{font-style:normal;font-weight:400;color:var(--jade)}
.v-caution{margin-top:12px;font-family:var(--mono);font-size:12px;color:var(--clay);letter-spacing:.02em}
/* dish photo — SECONDARY captioned card (venue photo stays the hero) */
.v-dish{margin:16px 0 0;border:1px solid var(--hair-soft);border-radius:var(--r-sm);overflow:hidden;background:var(--paper-2)}
.v-dish img{display:block;width:100%;height:150px;object-fit:cover}
.v-dish figcaption{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink-2);padding:9px 12px}
/* detail-sheet dish gallery */
.dish-gallery{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none}.dish-gallery::-webkit-scrollbar{display:none}
.dg-item{flex:none;margin:0;width:140px}
.dg-item img{width:140px;height:105px;object-fit:cover;border-radius:var(--r-sm);border:1px solid var(--hair-soft);cursor:zoom-in}
.dg-item figcaption{font-family:var(--mono);font-size:10px;letter-spacing:.03em;color:var(--ink-2);margin-top:6px;text-align:center}
/* dish photo inside a chat reply */
.chat-dish{margin:10px 0 0}
.chat-dish img{width:100%;max-width:240px;height:150px;object-fit:cover;border-radius:var(--r-sm);border:1px solid var(--hair-soft);display:block}
.chat-dish figcaption{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink-2);margin-top:6px}
/* global voice button — speak to the system from any screen */
.global-mic{position:fixed;right:18px;bottom:calc(96px + var(--safe-b));z-index:55;width:56px;height:56px;border-radius:50%;
  background:var(--gold);color:#fff;border:none;box-shadow:var(--shadow);font-size:22px;cursor:pointer;display:grid;place-items:center;
  transition:transform .2s var(--ease)}
.global-mic:active{transform:scale(.92)}
.global-mic.rec{background:var(--clay);animation:pulse 1.1s infinite}
body[data-screen="concierge"] .global-mic, body[data-screen="onboarding"] .global-mic{display:none}

/* venue sheet */
.sheet{position:fixed;inset:0;z-index:70;background:rgba(26,22,18,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:flex-end;animation:fade .35s var(--ease)}
.sheet-card{background:var(--paper);width:100%;max-height:92vh;border-radius:var(--r-lg) var(--r-lg) 0 0;
  overflow-y:auto;box-shadow:0 -24px 80px -20px rgba(0,0,0,.6);animation:slideup .45s var(--ease)}
@keyframes slideup{from{transform:translateY(100%)}to{transform:none}}
.sheet-hero{position:relative;height:260px;background:var(--paper-2) center/cover no-repeat}
.sheet-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,22,18,.3),transparent 40%,var(--paper))}
.sheet-x{position:absolute;top:18px;right:18px;z-index:3;width:44px;height:44px;border-radius:50%;
  background:var(--blur-bg-solid);border:1px solid var(--hair);color:var(--ink);cursor:pointer;font-size:16px;box-shadow:var(--shadow-sm);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.sheet-body{position:relative;padding:12px 24px calc(40px + var(--safe-b));margin-top:-48px}
.sheet-body h2{font-family:var(--display);font-weight:300;font-size:34px;line-height:1.1;letter-spacing:-.02em;margin:0}
.photo-strip{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none}.photo-strip::-webkit-scrollbar{display:none}
.photo-strip img{height:110px;width:auto;border-radius:var(--r-sm);border:1px solid var(--hair-soft);cursor:zoom-in;transition:transform .2s var(--ease)}
.photo-strip img:active{transform:scale(.96)}

/* full-screen photo viewer */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(20,15,9,.95);display:grid;place-items:center;
  animation:fade .2s var(--ease);touch-action:pan-y}
.lb-full{max-width:94vw;max-height:84vh;object-fit:contain;border-radius:6px;box-shadow:0 24px 70px rgba(0,0,0,.6)}
.lb-x{position:absolute;top:max(var(--safe-t),18px);right:18px;width:44px;height:44px;border-radius:50%;
  background:rgba(245,239,224,.14);border:1px solid rgba(245,239,224,.3);color:#fff;font-size:17px;cursor:pointer}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;
  background:rgba(245,239,224,.14);border:1px solid rgba(245,239,224,.3);color:#fff;font-size:26px;line-height:1;
  cursor:pointer;display:grid;place-items:center}
.lb-prev{left:14px} .lb-next{right:14px}
.lb-count{position:absolute;bottom:calc(max(var(--safe-b),24px));left:50%;transform:translateX(-50%);
  font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:rgba(245,239,224,.85)}
.detail-grid{display:grid;gap:1px;background:var(--hair-soft);border:1px solid var(--hair-soft);
  border-radius:var(--r);overflow:hidden;margin:22px 0}
.dg{background:var(--card);padding:16px 18px}
.dg .k{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px}
.dg .v{font-size:15.5px;color:var(--ink)}
.review{padding:16px 0;border-top:1px solid var(--hair-soft);font-size:15px;line-height:1.6;color:var(--ink-2)}
.review:first-child{border-top:0}
.r-top{font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--gold);margin-bottom:6px}
.r-date{color:var(--ink-3)}.r-top .r-date{margin-left:8px}
.dg .v a{color:var(--gold);text-decoration:none;border-bottom:1px solid rgba(173,109,47,.3)}
.hr{display:flex;justify-content:space-between;font-size:14.5px;padding:6px 0;color:var(--ink-2)}
.hr span:first-child{text-transform:capitalize;font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;color:var(--ink-3)}

/* concierge */
.concierge{display:flex;flex-direction:column;padding-bottom:0}
.concierge-top{flex:none}
.thread{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:18px;padding:10px 4px 20px;-webkit-overflow-scrolling:touch}
.bubble{max-width:88%;padding:16px 20px;border-radius:var(--r-lg);font-size:16px;line-height:1.6;animation:rise .4s var(--ease) backwards;white-space:pre-wrap;word-wrap:break-word}
.bubble strong{font-weight:600}
.bubble.cc{align-self:flex-start;background:var(--card);border:1px solid var(--hair-soft);box-shadow:var(--shadow-sm);
  border-bottom-left-radius:6px;font-family:var(--display);font-weight:300;font-size:17.5px;color:var(--ink)}
.bubble.me{align-self:flex-end;background:var(--ink);color:var(--paper);border-bottom-right-radius:6px}
.bubble.me strong{color:var(--gold-soft)}
.vt{font-family:var(--mono);font-size:11.5px;letter-spacing:.03em;color:var(--ink-3);margin-bottom:8px;font-style:normal}
.chat-photos{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.chat-photos img{width:130px;height:130px;object-fit:cover;border-radius:var(--r-sm);border:1px solid var(--hair-soft)}
.chat-map{display:inline-block;margin-top:12px;font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;color:var(--gold);text-decoration:none;border-bottom:1px solid rgba(173,109,47,.3);padding-bottom:2px}
.suggest{align-self:flex-start;display:flex;flex-wrap:wrap;gap:10px;max-width:94%}
.suggest .chip{font-family:var(--body);font-size:14px}
.vcard-mini{display:flex;align-items:stretch;gap:0;width:100%;margin-top:14px;background:var(--paper);
  border:1px solid var(--hair);border-radius:var(--r-sm);overflow:hidden;cursor:pointer;text-align:left;padding:0;
  transition:transform .2s var(--ease),box-shadow .2s}
.vcard-mini:active{transform:scale(.98)}
.vm-photo{flex:none;width:76px;background:var(--paper-2) center/cover no-repeat}
.vm-body{display:flex;flex-direction:column;justify-content:center;gap:4px;padding:12px 16px;min-width:0}
.vm-name{font-family:var(--display);font-size:17.5px;font-weight:400;line-height:1.2;color:var(--ink)}
.vm-meta{font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--gold)}
.typing{align-self:flex-start;display:flex;gap:6px;padding:18px 22px;background:var(--card);border:1px solid var(--hair-soft);border-radius:var(--r-lg);border-bottom-left-radius:6px}
.typing span{width:8px;height:8px;border-radius:50%;background:var(--ink-3);animation:blink 1.4s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.25;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}

/* composer */
.composer{flex:none;display:flex;align-items:center;gap:10px;padding:14px 0 calc(16px + var(--safe-b));
  background:linear-gradient(transparent,var(--paper) 24%);position:sticky;bottom:0}
.comp-btn{flex:none;width:50px;height:50px;border-radius:50%;border:1px solid var(--hair);background:var(--card);
  color:var(--ink);font-size:20px;cursor:pointer;display:grid;place-items:center;transition:transform .2s var(--ease),background .2s;box-shadow:var(--shadow-sm)}
.comp-btn:active{transform:scale(.92)}
.comp-btn.send{background:var(--ink);color:var(--paper);border:none}
.comp-btn.rec{background:var(--clay);color:#fff;border:none;animation:pulse 1.1s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(178,75,42,.5)}50%{box-shadow:0 0 0 10px rgba(178,75,42,0)}}
.comp-input{flex:1;font-family:var(--body);font-size:16px;color:var(--ink);background:var(--card);
  border:1px solid var(--hair);border-radius:100px;padding:16px 20px;box-shadow:var(--shadow-sm)}
.comp-input::placeholder{color:var(--ink-3)}.comp-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(173,109,47,.1)}

/* flow */
.flow{position:fixed;inset:0;z-index:90;background:
  radial-gradient(circle at 50% 38%, var(--card-2), var(--paper-2) 75%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;animation:fade .45s var(--ease)}
.flow[hidden]{display:none}
.flow-close{position:absolute;top:max(var(--safe-t),24px);right:24px;width:46px;height:46px;border-radius:50%;
  background:var(--card);border:1px solid var(--hair);color:var(--ink);font-size:18px;cursor:pointer;box-shadow:var(--shadow-sm)}
.orb{position:relative;width:220px;height:220px;display:grid;place-items:center}
.orb::after{content:"";position:absolute;width:130px;height:130px;border-radius:50%;border:1px solid var(--hair);
  animation:ripple 2.8s var(--ease) infinite}
@keyframes ripple{0%{transform:scale(.7);opacity:.8}100%{transform:scale(1.7);opacity:0}}
.orb span{position:absolute;border-radius:50%;filter:blur(8px);mix-blend-mode:multiply;animation:float 6s ease-in-out infinite}
.orb span:nth-child(1){width:150px;height:150px;background:radial-gradient(circle,var(--gold),transparent 70%);animation-delay:0s}
.orb span:nth-child(2){width:130px;height:130px;background:radial-gradient(circle,var(--jade),transparent 70%);animation-delay:-2s;left:46px}
.orb span:nth-child(3){width:110px;height:110px;background:radial-gradient(circle,var(--clay),transparent 70%);animation-delay:-4s;top:46px}
.orb.speaking span{animation-duration:2.5s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(18px,-14px) scale(1.08)}66%{transform:translate(-14px,12px) scale(.94)}}
.flow-status{font-family:var(--mono);font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin:0}
.flow-caption{font-family:var(--display);font-size:22px;font-weight:300;line-height:1.45;text-align:center;color:var(--ink);max-width:26ch;min-height:1.45em;margin:0;font-style:italic}
.flow-stop{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;background:transparent;border:1px solid var(--hair);color:var(--ink-2);border-radius:100px;padding:12px 22px;cursor:pointer}

/* tab bar */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:grid;grid-template-columns:repeat(5,1fr);
  padding:12px 8px calc(12px + var(--safe-b));background:var(--blur-bg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-top:1px solid var(--hair-soft);box-shadow:0 -10px 30px var(--shadow-color)}
.tab{display:flex;flex-direction:column;align-items:center;gap:6px;background:none;border:none;cursor:pointer;
  padding:8px 2px;color:var(--ink-3);position:relative;transition:color .2s}
.tab i{font-style:normal;font-size:20px;line-height:1}
.tab span{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase}
.tab.active{color:var(--ink)}
.tab.active::before{content:"";position:absolute;top:-8px;width:24px;height:3px;background:var(--gold);border-radius:3px}
.tab .cc{color:var(--gold)}

/* onboarding */
.onboarding{display:flex;align-items:center;padding:calc(var(--safe-t) + 48px) 28px 70px}
.ob-inner{width:100%;max-width:480px;margin:0 auto}
.ob-title{font-family:var(--display);font-weight:300;font-size:clamp(48px,15vw,72px);line-height:.96;letter-spacing:-.03em;margin:16px 0 0}
.ob-title em{font-style:italic;color:var(--gold)}
.ob-sub{font-family:var(--display);font-size:18.5px;line-height:1.55;color:var(--ink-2);font-weight:300;margin:24px 0 38px;max-width:40ch}
.ob-form{display:flex;flex-direction:column;gap:20px}
.ob-form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ob-form label{display:flex;flex-direction:column;gap:8px;font-family:var(--mono);font-size:10.5px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.ob-form input{font-family:var(--body);font-size:17.5px;color:var(--ink);background:transparent;border:none;
  border-bottom:1px solid var(--hair);padding:10px 2px;transition:border-color .2s}
.ob-form input::placeholder{color:var(--ink-3);opacity:.6}
.ob-form input:focus{outline:none;border-bottom-color:var(--gold)}
.ob-form .btn-primary{margin-top:16px;align-self:flex-start}

/* misc */
.empty{text-align:center;padding:60px 24px;color:var(--ink-3);font-family:var(--display);font-size:17.5px;font-style:italic;font-weight:300}
.e-ico{display:block;font-size:34px;margin-bottom:14px;color:var(--hair);font-style:normal}
.skeleton{height:130px;border-radius:var(--r);background:linear-gradient(100deg,var(--card) 30%,var(--card-2) 50%,var(--card) 70%);
  background-size:200% 100%;animation:shimmer 1.5s infinite;border:1px solid var(--hair-soft)}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
.toast{position:fixed;left:50%;bottom:calc(110px + var(--safe-b));transform:translateX(-50%);z-index:100;
  background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:12.5px;letter-spacing:.05em;
  padding:14px 24px;border-radius:100px;box-shadow:var(--shadow);animation:rise .35s var(--ease)}
.toast[hidden]{display:none}
.toast.tappable{cursor:pointer;background:var(--gold);color:#fff;border:none}
h3{font-family:var(--display);font-weight:300;font-size:26px;letter-spacing:-.015em;margin:0 0 6px}

@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
