/* AI Virtual Guide — prototype.css (vanilla PWA, v2)
   Дизайн-токени зі spec §5.1; день = дефолт, ніч = body.night.
   Правило двох акцентів: teal = факти/функції, sun = емоції/головні дії. */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root{
  --page:#f4ece0; --card:#fffdf8; --card-2:#f7efe3; --ink:#26323a; --ink-2:#7a6a5c;
  --line:#e8ddcd; --teal:#0e7c8b; --teal-2:#0a6675; --teal-soft:#e0f1f3;
  --sun:#e07a3e; --sun-2:#c9612b; --gold:#9a6a12; --lime:#1a7d4f; --danger:#c0392b;
  --fact-bg:#e2f0f4; --fact-ink:#0d6b7d; --legend-bg:#fbeccb; --legend-ink:#9a6a12;
  --new-bg:#fbeccb; --new-ink:#9a6a12;
  --shadow:0 8px 28px rgba(70,45,20,.13); --shadow-sm:0 2px 10px rgba(70,45,20,.08);
  /* Типографіка за функцією: narrative = наратив (назви/історії), ui = керування/цифри.
     Пряме ім'я гарнітури поза цими токенами не вживати (grep-перевірка). */
  --font-narrative:var(--font-ui);   /* апп повністю sans; токен лишено для сумісності селекторів */
  --font-ui:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
body.night{
  --page:#141824; --card:#1d2433; --card-2:#232b3c; --ink:#f1e9dd; --ink-2:#b0a293;
  --line:#33394d; --teal:#3fb6c6; --teal-2:#5fc6d4; --teal-soft:rgba(63,182,198,.13);
  --sun:#f0905a; --sun-2:#f5a877; --gold:#e9b65a; --lime:#57d98c; --danger:#ff6b81;
  --fact-bg:rgba(63,182,198,.16); --fact-ink:#8fd6e2; --legend-bg:rgba(233,182,90,.18); --legend-ink:#f0cd84;
  --new-bg:rgba(233,182,90,.18); --new-ink:#f0cd84;
  --shadow:0 10px 30px rgba(0,0,0,.5); --shadow-sm:0 3px 12px rgba(0,0,0,.4);
}

*{box-sizing:border-box}
[hidden]{display:none!important} /* hidden має перемагати класові display:flex/grid */
.sr-only{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:0;clip-path:inset(50%);overflow:hidden;white-space:nowrap}
html,body{height:100%}
body{margin:0;display:flex;flex-direction:column;overflow:hidden;color:var(--ink);
  font-family:var(--font-ui);
  background:radial-gradient(120% 80% at 82% -6%,#f7d9b0 0%,transparent 46%),
             radial-gradient(120% 80% at 0% 108%,#cfe7e6 0%,transparent 46%), var(--page)}
body.night{background:radial-gradient(120% 80% at 82% -6%,#3a2a3f 0%,transparent 46%),
             radial-gradient(120% 80% at 0% 108%,#16323a 0%,transparent 46%), var(--page)}

/* ── header ───────────────────────────────────────────────────── */
.vg-head{padding:calc(12px + env(safe-area-inset-top)) 16px 11px;display:flex;align-items:center;gap:11px;
  border-bottom:1px solid var(--line);position:relative;z-index:5;
  background:linear-gradient(135deg,color-mix(in srgb, black 10%, #fbe7cf),color-mix(in srgb, black 10%, #f7efe3) 60%)}
body.night .vg-head{background:linear-gradient(135deg,color-mix(in srgb, black 10%, #2a2336),color-mix(in srgb, black 10%, #232b3c) 60%)}
.vg-head .ico{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;font-size:18px;color:#fff;
  background:linear-gradient(135deg,var(--sun),var(--sun-2));box-shadow:0 6px 16px rgba(224,122,62,.32);
  flex:0 0 auto;border:0;cursor:pointer}
.vg-head .ttl{min-width:0;cursor:pointer}
.vg-head h1{font-family:var(--font-narrative);font-size:17.5px;margin:0;font-weight:600;line-height:1.15;text-wrap:balance}
.vg-head .kicker{font-size:11.5px;color:var(--ink-2);margin-top:2px;line-height:1.3}
.vg-head .hbtns{margin-left:auto;display:flex;gap:7px;flex:0 0 auto}
.hbtn{width:36px;height:36px;border-radius:11px;border:1px solid var(--line);background:var(--card);
  color:var(--ink);font-size:14px;font-weight:700;cursor:pointer;display:grid;place-items:center;transition:.15s}
.hbtn:active{transform:scale(.93)}
.hbtn.lang{font-family:var(--font-ui);font-size:12px;letter-spacing:.02em}
.vg-head .langwrap{position:relative;display:flex}
.vg-head .langpick{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;display:flex;flex-direction:column;gap:2px;
  background:var(--card);border:1px solid var(--line);border-radius:10px;padding:3px;box-shadow:var(--shadow)}
.vg-head .langpick .lp{min-width:0;min-height:28px;border:0;border-radius:7px;background:transparent;cursor:pointer;
  font:700 10px var(--font-ui);letter-spacing:.02em;color:var(--ink);padding:0;text-align:center;transition:.12s}
.vg-head .langpick .lp.sel{background:var(--teal-soft);color:var(--teal-2)}
.vg-head .langpick .lp:active{transform:scale(.95)}

/* ── body / screens ───────────────────────────────────────────── */
.vg-body{flex:1;overflow-y:auto;padding:14px 16px 10px;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column}
.vg-body::-webkit-scrollbar{width:0}
.screen{display:none;flex:1 0 auto}
.screen.active{display:flex;flex-direction:column;animation:vgScreenIn .34s cubic-bezier(.22,1,.36,1) both}
@keyframes vgScreenIn{from{transform:translateY(10px)}to{transform:none}}
@keyframes vgRise{from{transform:translateY(12px)}to{transform:none}}
.vg-rise{animation:vgRise .5s cubic-bezier(.22,1,.36,1) both}
@media (prefers-reduced-motion:reduce){.screen.active,.vg-rise,.found-card{animation:none!important}}

/* ── tabbar ───────────────────────────────────────────────────── */
.tabbar{display:flex;border-top:1px solid var(--line);background:color-mix(in srgb, black 10%, var(--card-2));
  padding-bottom:calc(6px + env(safe-area-inset-bottom));position:relative;z-index:5}
.tabbar button{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 2px 5px;
  background:none;border:0;color:var(--ink-2);font-size:12.5px;font-weight:700;cursor:pointer;transition:.15s;font-family:var(--font-ui)}
.tabbar button.on{font-weight:800}
.tabbar button .gl{font-size:21px;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;transition:.15s}
.tabbar button.on{color:var(--sun-2)}
.tabbar button.on .gl{background:linear-gradient(135deg,var(--sun),var(--sun-2));box-shadow:0 5px 12px rgba(224,122,62,.4);
  color:#fff}  /* текстові гліфи (⚙︎) інакше зливаються з помаранчевим кругом; емодзі color не чіпає */

/* ── typography helpers ───────────────────────────────────────── */
.eyebrow{font:600 11px var(--font-ui);letter-spacing:.1em;text-transform:uppercase;color:var(--sun-2)}
.num{font-family:var(--font-ui);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
h2{font-family:var(--font-narrative);font-size:21px;margin:2px 0;font-weight:600;line-height:1.12;letter-spacing:-.01em}
.group{padding:12px 0;border-bottom:1px solid var(--line)}.group:last-child{border-bottom:0}
.ghead{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:4px}
.group h3{font-family:var(--font-ui);font-size:16.5px;margin:0;font-weight:700;line-height:1.25;letter-spacing:.01em}
.new{font-size:10.5px;font-weight:700;color:var(--new-ink);background:var(--new-bg);padding:1px 7px;border-radius:8px}
.hint{font-size:12.5px;color:var(--ink-2);margin:6px 0 11px;line-height:1.45}
.vg-grp-title{font-family:var(--font-ui);font-weight:600;font-size:13.5px}

/* ── badges / fact-legend ─────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;padding:4px 11px;border-radius:13px;white-space:nowrap}
.badge.sm{font-size:11px;padding:1px 8px}
.badge-fact{background:var(--fact-bg);color:var(--fact-ink)}
.badge-legend{background:var(--legend-bg);color:var(--legend-ink)}
/* тип об'єкта компактним значком у кінці мета-рядка (✓ факт / ◆ вікі / ✦ переказ) */
.type-ico{flex:0 0 auto;font-weight:700;font-size:13px;line-height:1}
.type-ico.fact,.type-ico.wiki{color:var(--fact-ink)}
.type-ico.legend{color:var(--legend-ink)}
/* сигнал довіри до розповіді — ненав'язливий чіп у мета-рядку (.hd) */
.conf-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:1px 8px;border-radius:13px;cursor:pointer;border:1px solid rgba(0,0,0,.08);background:rgba(0,0,0,.04);color:var(--ink-2);white-space:nowrap}
.conf-chip:focus-visible{outline:2px solid var(--fact-ink);outline-offset:1px}
.conf-note{font-size:11.5px;color:var(--ink-2);line-height:1.4;margin:2px 0 6px}
.fl-ico{width:20px;height:20px;flex:0 0 auto;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700}
.fl-ico.fact{background:var(--fact-bg);color:var(--fact-ink)}
.fl-ico.legend{background:var(--legend-bg);color:var(--legend-ink)}

/* ── chips / segmented / switches ─────────────────────────────── */
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{display:inline-flex;align-items:center;gap:8px;min-height:48px;padding:0 16px;border-radius:26px;cursor:pointer;font-family:var(--font-ui);
  border:1.5px solid var(--line);background:var(--card);color:var(--ink);font-size:15px;font-weight:500;user-select:none;transition:.15s;box-shadow:var(--shadow-sm)}
.chip .ic{font-size:18px}
.chip.sel{border-color:var(--teal);background:var(--teal-soft);color:var(--teal-2)}
.seg{display:flex;border:1px solid var(--line);border-radius:13px;overflow:hidden;margin-top:6px;padding:3px;background:var(--card)}
.seg button{flex:1;min-height:46px;border:0;border-radius:10px;background:transparent;color:var(--ink-2);font:600 14px var(--font-ui);cursor:pointer;transition:.15s}
.seg button.sel{color:#fff;background:linear-gradient(135deg,var(--teal),var(--teal-2))}
.seg.mag button.sel{background:linear-gradient(135deg,var(--sun),var(--sun-2))}
.switch{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0}
.switch .lbl{font-size:15px}
.tog{width:52px;height:30px;border-radius:16px;border:1px solid var(--line);background:var(--card-2);position:relative;cursor:pointer;flex:0 0 auto;transition:.15s;padding:0}
.tog::after{content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:var(--teal);opacity:.55;transition:.15s}
.tog.on{background:var(--teal-soft);border-color:var(--teal)}
.tog.on::after{left:26px;opacity:1}

/* ── buttons ──────────────────────────────────────────────────── */
.cta{width:100%;min-height:54px;border:0;border-radius:15px;cursor:pointer;color:#fff;
  background:linear-gradient(135deg,var(--sun),var(--sun-2));font:700 16px var(--font-ui);box-shadow:0 8px 20px rgba(224,122,62,.32)}
.ghost{width:100%;min-height:50px;border:1px solid var(--line);border-radius:13px;background:var(--card-2);color:var(--ink);font:600 14px var(--font-ui);cursor:pointer}
.ghost.teal,.qbtn{border:0;background:linear-gradient(135deg,var(--teal),var(--teal-2));color:#fff}
.danger{width:100%;min-height:48px;border:1px solid var(--danger);border-radius:12px;background:transparent;color:var(--danger);font:600 14px var(--font-ui);cursor:pointer}
.tap{cursor:pointer;transition:transform .12s,box-shadow .2s}
.tap:active{transform:scale(.97)}

/* ── hero (golden hour) ───────────────────────────────────────── */
.hero{position:relative;border-radius:18px;overflow:hidden;height:196px;border:1px solid var(--line);box-shadow:var(--shadow-sm);
  background:linear-gradient(180deg,#f7b76a 0%,#e98a4e 38%,#a85a6e 72%,#5b4a6e 100%)}
.hero::before{content:"";position:absolute;right:34px;top:30px;width:54px;height:54px;border-radius:50%;
  background:radial-gradient(circle,#fff6e0,#ffd591 60%,transparent 72%)}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:62px;
  background:linear-gradient(90deg,#2b2440 0 8%,transparent 8% 12%,#2b2440 12% 17%,transparent 17% 22%,#332a4a 22% 34%,transparent 34% 40%,#2b2440 40% 52%,transparent 52% 58%,#3a2f54 58% 74%,transparent 74% 80%,#2b2440 80% 100%);
  -webkit-mask:linear-gradient(180deg,transparent,#000 40%);mask:linear-gradient(180deg,transparent,#000 40%);opacity:.9}
.hero .pin{position:absolute;left:13px;top:13px;z-index:3;display:inline-flex;align-items:center;gap:5px;
  background:rgba(0,0,0,.32);backdrop-filter:blur(4px);color:#fff;font:600 12px var(--font-ui);padding:6px 11px;border-radius:20px}
.hero .cap{position:absolute;left:15px;bottom:13px;right:15px;z-index:3}
.hero .cap .nm{font-family:var(--font-narrative);font-size:21px;font-weight:600;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.5);line-height:1.05}
.hero .cap .src{font:500 12px var(--font-ui);color:#ffe8cf;display:flex;gap:8px;align-items:center;margin-top:4px}

/* ── home tiles ───────────────────────────────────────────────── */
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-top:10px}
.tile{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px;box-shadow:var(--shadow-sm);text-align:left;cursor:pointer;font-family:var(--font-ui)}
.tile .tic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:22px;color:#fff;margin-bottom:9px;
  background:linear-gradient(135deg,var(--teal),var(--teal-2))}
.tile.warm .tic{background:linear-gradient(135deg,var(--sun),var(--sun-2))}
.tile .tnm{font-family:var(--font-ui);font-size:16px;font-weight:700;color:var(--ink)}
.tile .tds{font-size:12px;color:var(--ink-2);margin-top:3px;line-height:1.35}

/* ── camera: панель-дзеркало голосової ──────────────────────── */
.cam-panel{margin-top:2px;margin-bottom:12px;gap:14px}
/* у панелі камери всі акценти бірюзові (фото = холодний функціональний сценарій) */
.cam-panel .eyebrow{color:var(--teal-2)}
.cam-panel .cta{background:linear-gradient(135deg,var(--teal),var(--teal-2));box-shadow:0 8px 20px rgba(14,124,139,.32)}
#camCircle{background:linear-gradient(135deg,var(--teal),var(--teal-2));
  box-shadow:0 0 0 12px rgba(14,124,139,.14),0 0 0 26px rgba(14,124,139,.07)}
.cam-panel .vf{width:100%;margin:0;height:200px}
.cam-panel .vt{width:100%}

/* ── camera: viewfinder / scan / found / type ─────────────────── */
.vf{position:relative;border-radius:18px;overflow:hidden;height:278px;margin:2px 0 14px;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);background:linear-gradient(180deg,#f4c98a 0%,#e89a5a 40%,#9d6a78 75%,#4f4668 100%);
  transition:height .3s cubic-bezier(.22,1,.36,1)}
.vf img.shot{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:inherit;z-index:2}
.vf.compact{height:108px}
.vf .skyline{position:absolute;left:0;right:0;bottom:0;height:46%;
  background:linear-gradient(90deg,transparent 0 12%,#3a3052 12% 22%,transparent 22% 30%,#473a63 30% 40%,transparent 40% 47%,#2f2746 47% 53%,transparent 53% 60%,#473a63 60% 78%,transparent 78% 84%,#352c4c 84% 96%,transparent 96%);
  -webkit-mask:linear-gradient(180deg,transparent,#000 55%);mask:linear-gradient(180deg,transparent,#000 55%)}
.vf .castle{position:absolute;right:14%;bottom:40%;width:70px;height:56px;background:#2f2746;opacity:.8;transition:.4s;
  clip-path:polygon(0 40%,12% 40%,12% 10%,24% 10%,24% 40%,40% 40%,40% 0,60% 0,60% 40%,76% 40%,76% 10%,88% 10%,88% 40%,100% 40%,100% 100%,0 100%)}
.vf .corners i{position:absolute;width:22px;height:22px}
.vf .corners i:first-child{left:22px;top:22px;border-top:2px solid rgba(255,255,255,.85);border-left:2px solid rgba(255,255,255,.85);border-radius:4px 0 0 0}
.vf .corners i:last-child{right:22px;bottom:22px;border-bottom:2px solid rgba(255,255,255,.85);border-right:2px solid rgba(255,255,255,.85);border-radius:0 0 4px 0}
.vf .photochip{position:absolute;left:13px;top:13px;z-index:3;display:inline-flex;align-items:center;gap:5px;
  background:rgba(0,0,0,.32);backdrop-filter:blur(4px);color:#fff;font:600 12px var(--font-ui);padding:6px 11px;border-radius:20px}
.vf .aimchip{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);color:#fff;font:600 13px var(--font-ui);
  background:rgba(0,0,0,.32);backdrop-filter:blur(4px);padding:7px 14px;border-radius:20px;
  max-width:82%;width:max-content;text-align:center;line-height:1.35}
.vf .scanchip{position:absolute;left:50%;bottom:40px;transform:translateX(-50%);color:#fff;font:600 13px var(--font-ui);
  background:rgba(0,0,0,.4);backdrop-filter:blur(4px);padding:7px 14px;border-radius:20px;white-space:nowrap;z-index:3}
.scan-line{position:absolute;left:0;right:0;height:34%;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,transparent,rgba(255,233,196,0) 40%,rgba(255,224,170,.55) 92%,rgba(255,255,255,.85));
  border-bottom:2px solid rgba(255,255,255,.9);box-shadow:0 0 26px rgba(255,210,140,.55);
  animation:scanMove 1.7s cubic-bezier(.5,0,.5,1) infinite}
@keyframes scanMove{0%{top:-34%}100%{top:100%}}
.scan-grid{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background:linear-gradient(rgba(255,255,255,.16) 1px,transparent 1px) 0 0/100% 26px,
             linear-gradient(90deg,rgba(255,255,255,.16) 1px,transparent 1px) 0 0/26px 100%}
.scan-reticle{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);z-index:3;
  width:120px;height:120px;border-radius:18px;border:2px solid rgba(255,255,255,.92);
  box-shadow:0 0 0 9999px rgba(20,16,28,.18);animation:reticlePulse 1.3s ease-in-out infinite}
@keyframes reticlePulse{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.06)}}
.scan-dots{position:absolute;left:0;right:0;bottom:14px;z-index:3;display:flex;justify-content:center;gap:7px}
.scan-dots i{width:7px;height:7px;border-radius:50%;background:#fff;opacity:.4;animation:scanDot 1s infinite}
.scan-dots i:nth-child(2){animation-delay:.15s}.scan-dots i:nth-child(3){animation-delay:.3s}
@keyframes scanDot{0%,100%{opacity:.35;transform:translateY(0)}50%{opacity:1;transform:translateY(-4px)}}
@keyframes foundPop{0%{transform:translateY(14px) scale(.96)}100%{transform:none}}
.found-card{animation:foundPop .42s cubic-bezier(.22,1.4,.4,1) both}
.vf .fcard{position:absolute;left:12px;right:12px;bottom:12px;z-index:4;background:var(--card);border-radius:16px;
  padding:12px;display:flex;gap:12px;align-items:center;box-shadow:var(--shadow)}
.vf .fcard .fthumb{width:52px;height:52px;border-radius:12px;flex:0 0 auto;display:grid;place-items:center;font-size:26px;
  background:linear-gradient(135deg,#e98a4e,#5b4a6e)}
.vf .fcard .fnm{font-family:var(--font-narrative);font-weight:600;font-size:16px;line-height:1.15}
.vf .fcard .fmeta{font-size:12px;color:var(--ink-2);margin-top:3px}
.shutter{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;min-height:64px;border:0;border-radius:18px;
  cursor:pointer;color:#fff;background:linear-gradient(135deg,var(--sun),var(--sun-2));
  font-family:var(--font-narrative);font-weight:600;font-size:19px;box-shadow:0 10px 24px rgba(224,122,62,.4)}
.shutter:disabled{opacity:.7;cursor:default}
.qrow{display:flex;gap:9px;margin-top:14px}
.qrow .qbtn{flex:1;min-height:46px;border-radius:13px;font:600 14px var(--font-ui);cursor:pointer}
.typerow{display:flex;gap:9px}
.typerow input{flex:1;min-width:0;height:48px;border-radius:13px;border:1.5px solid var(--teal);background:var(--card);
  color:var(--ink);font:500 15px var(--font-ui);padding:0 14px;box-shadow:var(--shadow-sm)}
.typerow .xbtn{width:48px;min-width:48px;height:48px;padding:0;font-size:16px;border-radius:13px;flex:0 0 auto}

/* ── region stories accordion ─────────────────────────────────── */
.acc{border:1.5px solid var(--line);border-radius:14px;background:var(--card);margin-bottom:8px;overflow:hidden;box-shadow:var(--shadow-sm)}
.acc.open{border-color:var(--teal)}
.acc-h{display:flex;align-items:center;gap:9px;width:100%;min-height:48px;border:0;background:transparent;color:var(--ink);font:600 14px var(--font-ui);padding:0 13px;cursor:pointer;text-align:left}
.acc-h .ic{font-size:17px}
.acc-h .caret{margin-left:auto;color:var(--teal-2);font-size:28px;line-height:1}
.acc-b{padding:2px 10px 10px}
.teaser{border:1px solid var(--line);border-radius:11px;background:var(--card-2);margin-bottom:7px;overflow:hidden}
.teaser.open{border-color:var(--teal)}
.teaser-h{display:flex;align-items:center;gap:8px;width:100%;min-height:42px;border:0;background:transparent;color:var(--ink);font:600 13px var(--font-ui);padding:6px 11px;cursor:pointer;text-align:left}
.teaser-h .t-emoji{flex:0 0 auto;font-size:22px;line-height:1;width:28px;text-align:center}
.teaser-h .tt{flex:1;min-width:0}
.teaser-h .fl-ico{width:18px;height:18px;font-size:10px}
.teaser-h .caret{color:var(--teal-2);font-size:25px;flex:0 0 auto;line-height:1}
.teaser-b{padding:0 12px 11px}
.teaser-b .hd{display:flex;align-items:center;gap:8px;font:500 11.5px var(--font-ui);color:var(--ink-2);margin-bottom:6px}
.teaser-b .hd .src{margin-left:auto}
.t-play{margin-left:8px;width:28px;height:28px;flex:0 0 auto;border-radius:50%;border:0;cursor:pointer;
  background:linear-gradient(135deg,var(--teal),var(--teal-2));color:var(--sun);font-size:11px;
  display:grid;place-items:center;padding:0 0 0 1px;line-height:1;box-shadow:var(--shadow-sm)}
.t-play:active{transform:scale(.93)}
.teaser-b p{margin:0;font-family:var(--font-narrative);font-weight:500;font-size:14.5px;line-height:1.55}
.gen-row{display:flex;align-items:center;gap:10px;color:var(--ink-2);font:500 12.5px var(--font-ui);padding:8px 4px}
.region-offline{color:var(--ink-2);font:500 11.5px var(--font-ui);opacity:.7;padding:4px 4px 2px}
.map-offline{color:var(--ink-2);font:500 12.5px var(--font-ui);opacity:.8;padding:10px 6px;text-align:center}
.region-err{display:flex;flex-direction:column;gap:6px;padding:6px 4px}
.region-err .msg{color:var(--ink-2);font:500 12px var(--font-ui)}
.think-dots{display:inline-flex;gap:5px}
.think-dots i{width:8px;height:8px;border-radius:50%;background:var(--teal);animation:scanDot 1.1s infinite}
.think-dots i:nth-child(2){animation-delay:.18s}.think-dots i:nth-child(3){animation-delay:.36s}
.about-area{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:12px 14px;margin:0 0 10px;box-shadow:var(--shadow-sm)}
.about-area .aa-nm{font-family:var(--font-narrative);font-weight:600;font-size:15.5px;margin:0 0 4px}
.about-area .aa-sum{font-size:12.5px;color:var(--ink-2);line-height:1.5;margin:0}
.about-area .aa-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;font-size:11.5px;color:var(--ink-2)}
.about-area .aa-meta a{color:var(--teal-2);text-decoration:none}

/* ── POI cards (full + compact map style) ─────────────────────── */
.card{display:flex;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:12px;margin-bottom:11px;box-shadow:var(--shadow-sm);align-items:center}
.card .thumb{width:60px;height:60px;border-radius:12px;flex:0 0 auto;background:linear-gradient(135deg,#e98a4e,#5b4a6e);display:grid;place-items:center;font-size:24px}
.card .info{flex:1;min-width:0}
.card .info .nm{font-family:var(--font-narrative);font-size:16px;font-weight:600;line-height:1.15}
.card .info .meta{font-size:12px;color:var(--ink-2);margin-top:3px;display:flex;gap:8px;flex-wrap:wrap;align-items:center;font-variant-numeric:tabular-nums}
.card .info .meta .star{color:var(--gold)}
.card .go{width:40px;height:40px;border-radius:50%;border:0;background:linear-gradient(135deg,var(--sun),var(--sun-2));
  color:#fff;font-size:16px;cursor:pointer;flex:0 0 auto;box-shadow:0 4px 10px rgba(224,122,62,.32);
  display:grid;place-items:center;padding:0;line-height:1}
.card .go .gly{display:block;line-height:1;transform:translateX(1px)}
.map-list .card{padding:9px;margin-bottom:3px;border-radius:14px;background:color-mix(in srgb, var(--card) 15%, var(--card-2));box-shadow:none}
.map-list .card .thumb{width:44px;height:44px;font-size:20px;border-radius:10px}
.map-list .card .info .nm{font-size:15px}
.map-list .card .info .meta{font-size:11.5px}
.map-list .card .go{width:34px;height:34px;font-size:14px}

/* ── history: expandable story text ───────────────────────────── */
.hist-caret{margin-left:auto;color:var(--teal-2);font-size:11px}
.map-list .card.open{border-color:var(--teal);border-bottom-left-radius:0;border-bottom-right-radius:0;margin-bottom:0}
.hist-text{margin:0 0 8px;border:1px solid var(--teal);border-top:0;border-radius:0 0 14px 14px;padding:13px}
.hist-text .hist-chap{margin-bottom:14px}
.hist-text .hist-chap:last-child{margin-bottom:0}
.hist-text .hist-chap .hd{display:flex;gap:8px;align-items:center;margin-bottom:6px;font-size:12px;color:var(--ink-2)}
.hist-text .hist-chap p{margin:0;font-family:var(--font-narrative);font-weight:500;font-size:15px;line-height:1.55}

/* ── map (Leaflet) ────────────────────────────────────────────── */
#map{--mapctl-bg:rgba(247,239,227,.94)}
body.night #map{--mapctl-bg:rgba(29,36,51,.92)}
.vg-map{position:relative;height:368px;border-radius:18px 18px 0 0;overflow:hidden;
  border:1px solid var(--line);border-bottom:0;box-shadow:var(--shadow-sm);background:#dfeee7}
body.night .vg-map{background:#1a2230}
.vg-map .leaflet-tile-pane{filter:brightness(.85)}
body.night .vg-map .leaflet-tile-pane{filter:none}
.vg-map-canvas{position:absolute;inset:0}
.vg-map .leaflet-container{width:100%;height:100%;font-family:var(--font-ui);background:transparent}
/* контролі — суцільна панель ПІД картою: спільна рамка, без лінії між ними */
.mapctl{display:flex;gap:7px;align-items:center;padding:7px;margin-bottom:3px;
  border:1px solid var(--line);border-top:0;border-radius:0 0 18px 18px;
  background:var(--card);box-shadow:var(--shadow-sm)}
.mapctl input{flex:1;min-width:0;min-height:40px;border-radius:12px;border:1px solid var(--line);
  background:var(--mapctl-bg);backdrop-filter:blur(6px);padding:0 12px;font:500 13.5px var(--font-ui);color:var(--ink)}
.mapctl input::placeholder{color:var(--ink-2)}
.mapctl input.err{border-color:#d9534f;box-shadow:0 0 0 2px rgba(217,83,79,.25)}
.mapctl .mbtn{flex:0 0 auto;min-width:40px;height:40px;border-radius:12px;border:1px solid var(--line);
  background:var(--mapctl-bg);backdrop-filter:blur(6px);font:700 13px var(--font-ui);font-variant-numeric:tabular-nums;color:var(--ink);
  cursor:pointer;display:flex;align-items:center;justify-content:center;white-space:nowrap;padding:0 10px;transition:.15s}
.mapctl .mbtn:active{transform:scale(.93)}
.mapctl .mbtn.gold{color:var(--ink-2)}
.mapctl .mbtn.gold.on{color:var(--gold);border-color:var(--gold)}
.mapctl .ratewrap{position:relative;flex:0 0 auto;display:flex}
.mapctl .ratepick{position:absolute;bottom:46px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:2px;
  background:var(--mapctl-bg);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:14px;padding:6px 5px;z-index:900;box-shadow:var(--shadow)}
.mapctl .ratepick .rp{display:flex;flex-direction:column;align-items:center;justify-content:center;width:46px;min-height:42px;
  border:0;border-radius:10px;background:transparent;color:var(--gold);font-size:17px;line-height:1.05;cursor:pointer;padding:3px 0}
.mapctl .ratepick .rp small{font:600 9.5px var(--font-ui);color:var(--ink-2)}
.mapctl .ratepick .rp.off{color:var(--ink-2)}
.mapctl .ratepick .rp.sel{background:var(--teal-soft)}
.vg-pin-wrap{background:none;border:0}
/* Google-стиль («Золоті Тераси»): біле тіло-крапля (білий носик) + кольоровий круг-фон + білий гліф */
.vg-pin{position:relative;width:34px;height:44px;filter:drop-shadow(0 3px 5px rgba(0,0,0,.35));cursor:pointer}
.vg-pin-bg{position:absolute;inset:0;width:34px;height:44px;display:block}
.vg-pin-body{fill:#fff;stroke:rgba(0,0,0,.12);stroke-width:.5}
.vg-pin-disc{fill:var(--pin,#EA4335)}
.vg-pin .vg-glyph{position:absolute;left:17px;top:16px;transform:translate(-50%,-50%);width:18px;height:18px;fill:#fff;display:block}
.vg-pin .bd{position:absolute;top:-1px;right:0;width:18px;height:18px;border-radius:50%;z-index:2;
  background:#26323a;color:#fff;border:2px solid #fff;display:grid;place-items:center;font:700 10px var(--font-ui);font-style:normal}
.vg-you{position:relative;width:18px;height:18px;border-radius:50%;background:var(--gold);border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.35)}
.vg-you i{position:absolute;inset:-7px;border-radius:50%;border:2px solid var(--gold);opacity:0;animation:micPulse 2s ease-out infinite}
/* Кружок-кластер POI з лічильником (розгортається при зумі; еталон — стара мапа) */
.poi-cluster{background:none!important;border:none!important}
.poi-cluster span{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;
  background:radial-gradient(circle at 50% 34%,var(--teal),var(--teal-2));color:#fff;
  font-weight:700;font-size:15px;border:2px solid var(--line);box-shadow:0 2px 8px rgba(14,124,139,.35)}
body.night .poi-cluster span{border-color:var(--line);box-shadow:0 2px 10px rgba(0,0,0,.5)}
/* підписи об'єктів — як у Google: чистий sans-текст без підкладки, з білим ореолом */
.leaflet-tooltip.vg-tt{background:none;border:0;box-shadow:none;padding:0;
  max-width:140px;white-space:normal;text-align:center;line-height:1.2;
  font:500 10.5px var(--font-ui);color:#26323a;
  text-shadow:0 0 2px #fff,0 1px 2px #fff,1px 0 2px #fff,-1px 0 2px #fff}
.leaflet-tooltip.vg-tt::before{display:none}
body.night .leaflet-tooltip.vg-tt{color:#f1e9dd;
  text-shadow:0 0 2px #000,0 1px 2px #000,1px 0 2px #000,-1px 0 2px #000}
.leaflet-tooltip.vg-tt.you{font:500 10.5px var(--font-ui);color:var(--sun-2);padding:0;background:none;box-shadow:none}
.vg-map .leaflet-control-attribution{font-size:6.3px;background:rgba(255,255,255,.65);border-radius:6px 0 0 0;margin:0 3px 3px 0}
body.night .vg-map .leaflet-control-attribution{background:rgba(20,24,36,.65);color:#b0a293}

/* ── voice ────────────────────────────────────────────────────── */
.voice-panel{display:flex;flex-direction:column;align-items:center;gap:18px;padding:24px 16px;margin-top:2px;
  background:var(--card);border:1.5px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm)}
/* стабільна контент-зона: рядок кнопок не стрибає між idle/listening/thinking */
.vp-zone{display:flex;flex-direction:column;align-items:center;gap:18px;width:100%;min-height:280px;justify-content:center}
#voicePanel{margin-bottom:12px} /* гарантований зазор: панелі не склеюються, навіть коли auto-margin = 0 */
/* Голосове управління поки не реалізоване: панель без обводки, приглушений
   нейтральний фон, іконка й кнопка — у неробочому (disabled) вигляді. */
.voice-cmd{margin-top:auto;margin-bottom:4px;gap:12px;padding:20px 16px;
  background:var(--card-2);border:0;box-shadow:none}
.voice-cmd .vc-ico{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-size:25px;
  background:var(--line);color:var(--ink-2);box-shadow:none}
.voice-cmd h3{margin:0;font-family:var(--font-ui);font-weight:700;font-size:16.5px;color:var(--ink);text-align:center}
.voice-cmd .vc-btn{width:100%;min-height:48px;border:0;border-radius:13px;cursor:default;
  background:var(--line);color:var(--ink-2);font:600 14px var(--font-ui)}
.vbtns{display:flex;gap:10px;margin-top:12px}
.vbtns .ghost,.vbtns .cta{flex:1}
.mic{width:116px;height:116px;border-radius:50%;display:grid;place-items:center;font-size:46px;color:#fff;cursor:pointer;border:0;
  background:linear-gradient(135deg,var(--sun),var(--sun-2));
  box-shadow:0 0 0 12px rgba(224,122,62,.14),0 0 0 26px rgba(224,122,62,.07)}
.vt{font-family:var(--font-narrative);font-size:20px;text-align:center;margin:0}
.mic-ring{position:relative}
.mic-ring::before,.mic-ring::after{content:"";position:absolute;inset:0;border-radius:50%;
  border:2px solid var(--sun);opacity:0;animation:micPulse 2s ease-out infinite}
.mic-ring::after{animation-delay:1s}
@keyframes micPulse{0%{transform:scale(1);opacity:.55}100%{transform:scale(1.7);opacity:0}}
.mic-eq{display:flex;align-items:flex-end;gap:4px;height:30px}
.mic-eq i{width:5px;background:#fff;border-radius:3px;animation:eq .9s ease-in-out infinite}
.mic-eq i:nth-child(odd){animation-delay:.25s}.mic-eq i:nth-child(3n){animation-delay:.45s}
@keyframes eq{0%,100%{height:7px}50%{height:28px}}

/* ── story player ─────────────────────────────────────────────── */
.pgal-wrap{position:relative}
.pgal{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;border-radius:18px;scrollbar-width:none}
.pgal::-webkit-scrollbar{display:none}
.pgal > div{flex:0 0 100%;scroll-snap-align:start;min-width:0}
.pgal .pslot{height:196px;border-radius:18px;border:1.5px dashed var(--line);background:var(--card-2);
  display:grid;place-items:center;color:var(--ink-2);font:500 13px var(--font-ui);text-align:center;padding:10px;overflow:hidden}
.pgal .pslot.filled{border-style:solid;padding:0}
/* Фото іншого формату кадруємо зі зсувом угору: 1/3 обрізки зверху, 2/3 знизу
   (object-position y=33%) — об'єкт/будівля частіше у верхній частині кадру. */
.pgal .pslot img{width:100%;height:100%;object-fit:cover;object-position:50% 33%;display:block}
.pgal-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:30px;height:30px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(0,0,0,.32);color:#fff;font-size:15px;backdrop-filter:blur(4px);display:grid;place-items:center;padding:0;line-height:1}
.pgal-nav:active{transform:translateY(-50%) scale(.93)}
/* пагінація галереї — смужка прев'ю слайдів (замість крапок) */
.pgal-dots{position:absolute;top:10px;right:12px;z-index:3;display:flex;gap:5px}
.pgal-dots .gthumb{flex:0 0 auto;width:34px;height:34px;padding:0;border:0;border-radius:8px;overflow:hidden;cursor:pointer;
  background:rgba(0,0,0,.28);box-shadow:0 1px 4px rgba(0,0,0,.35);opacity:.62;outline:1.5px solid transparent;outline-offset:0;transition:opacity .15s,outline-color .15s}
.pgal-dots .gthumb.on{opacity:1;outline-color:#fff}
.pgal-dots .gthumb:active{transform:scale(.93)}
.pgal-dots .gthumb img{width:100%;height:100%;object-fit:cover;object-position:50% 33%;display:block}
.pgal-dots .gthumb.hero{background:linear-gradient(180deg,#f7b76a,#e98a4e 38%,#a85a6e 72%,#5b4a6e)}
.pgal-dots .gthumb.empty{display:flex;align-items:center;justify-content:center}
.pgal-dots .gthumb.empty::after{content:"📷";font-size:15px;opacity:.75}
.wave{display:flex;align-items:center;gap:3px;height:40px;margin:14px 0 4px}
.wave i{flex:1;background:var(--teal);opacity:.4;border-radius:3px}
.wave i.on{opacity:1}
.wave.live i{animation:waveBob 1.1s ease-in-out infinite}
@keyframes waveBob{0%,100%{transform:scaleY(.5)}50%{transform:scaleY(1)}}
.tlabel{display:flex;justify-content:space-between;font-size:12px;color:var(--ink-2);font-variant-numeric:tabular-nums}
.controls{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:14px 0}
.modetoggle{display:flex;flex:1 1 auto;min-width:0;border:1px solid var(--line);border-radius:27px;overflow:hidden;background:var(--card);padding:3px}
.modetoggle button{flex:1;min-width:0;min-height:46px;border:0;border-radius:23px;background:transparent;color:var(--ink-2);font:600 12px var(--font-ui);font-variant-numeric:tabular-nums;padding:6px 10px;cursor:pointer;line-height:1.15}
.modetoggle button small{display:block;font-size:9.5px;opacity:.8;margin-top:1px}
.modetoggle button.sel{color:#fff;background:linear-gradient(135deg,var(--teal),var(--teal-2))}
.playbtn{flex:0 0 auto;width:60px;height:60px;border-radius:50%;border:0;color:#fff;font-size:23px;cursor:pointer;
  background:linear-gradient(135deg,var(--sun),var(--sun-2));box-shadow:0 8px 20px rgba(224,122,62,.4)}
.more{flex:0 0 auto;min-height:54px;min-width:68px;border:0;background:linear-gradient(135deg,var(--teal),var(--teal-2));
  color:#fff;border-radius:27px;padding:6px 16px;font:600 13px var(--font-ui);cursor:pointer;line-height:1.15;text-align:center}
.more small{display:block;font-size:9.5px;color:rgba(255,255,255,.8);margin-top:1px}
.seg-text{margin-top:6px;background:var(--card-2);border:1px solid var(--line);border-radius:16px;padding:15px}
.seg-text .hd{display:flex;gap:10px;align-items:center;margin-bottom:8px;font-size:12.5px;color:var(--ink-2)}
/* hd-titled: бейдж типу — у кінці назви (перший рядок), джерело — рядком нижче праворуч */
.seg-text .hd.hd-titled{flex-wrap:wrap;align-items:baseline;gap:4px 10px}
.seg-text .hd.hd-titled .hd-ttl{flex:1 1 100%}
.seg-text .hd.hd-titled .hd-ttl .badge{margin-left:6px;vertical-align:middle}
.seg-text .hd.hd-titled .src{margin-left:auto}
.seg-text p{margin:0;font-family:var(--font-narrative);font-weight:500;font-size:16px;line-height:1.6}
.tw-caret{display:inline-block;width:2px;height:1em;background:var(--teal);margin-left:1px;
  vertical-align:-2px;animation:caretBlink .9s step-end infinite}
@keyframes caretBlink{0%,100%{opacity:1}50%{opacity:0}}

/* ── narrow tier (≤370dp) ─────────────────────────────────────── */
@media (max-width:370px){
  .vg-body{padding:12px 12px 8px}
  .vg-head{padding:10px 12px 9px}
  .vg-head h1{font-size:16px}
  h2{font-size:19px}
  .seg button{font-size:12.5px;min-height:42px;padding:0 4px}
  .chip{min-height:44px;padding:0 13px;font-size:14px}
  .tabbar button{font-size:11px}
  .tabbar button .gl{font-size:18.5px;width:36px;height:36px}
  .modetoggle button{padding:5px 8px;font-size:11px;min-height:42px}
  .playbtn{width:56px;height:56px;font-size:21px}
  .more{min-height:50px;padding:5px 12px;font-size:12px}
  .hero,.pgal .pslot{height:172px}
  .vg-map{height:284px}
}

/* ── нічна тема: тонкі засічки оптично «худнуть» на темному → +вага наративу ── */
body.night .card .info .nm,
body.night .hero .cap .nm,
body.night h2,
body.night .teaser-b p,
body.night .hist-text .hist-chap p,
body.night .vt{font-weight:600}

/* ── a11y: видимий фокус лише для клавіатурної навігації (NFR-A-02) ──
   Ринг показуємо тільки при keyboard-focus (:focus-visible), щоб тач/миша
   не лишали обведення; outline сам слідує за border-radius елемента. */
:focus-visible{outline:3px solid var(--teal);outline-offset:2px}
:focus:not(:focus-visible){outline:none}
