/* Светлая тема: мятный пастель под маскота-геккона (оранжевый — шлёпанцы) */
:root{
  --bg:#eef8f2; --surface:#fff; --surface-2:#f7fcf8; --surface-3:#eef6f0;
  --accent:#2aa876; --accent-2:#239466; --accent-deep:#14613f; --accent-soft:#dff3e7;
  --text:#1b2a22; --text-2:#3a4d42; --muted:#6b7f73; --border:#d7e8dc;
  --on-accent:#fff; --success:#12b886; --warn:#ffb454; --card-bg:var(--surface);
  --hero-bg:linear-gradient(160deg,#e4f4ea,#d4eede); --hero-text:var(--text); --hero-muted:#5c6f64; --hero-chip:rgba(20,97,63,.08); --hero-chip-border:rgba(20,97,63,.18);
}
/* Тёмная тема: включается адаптером по Telegram colorScheme (или вручную) */
body.theme-dark{
  --bg:#0e1621; --surface:#17212b; --surface-2:#1c2733; --surface-3:#202b36;
  --accent:#5eb5f7; --accent-2:#4da3e0; --accent-deep:#8fc8f5; --accent-soft:#1d3144;
  --text:#e9eef4; --text-2:#c4d0dc; --muted:#8696a8; --border:#2b3a4a;
  --on-accent:#fff; --success:#27c08f; --warn:#e8b84d; --card-bg:var(--surface);
  --hero-bg:linear-gradient(160deg,#15212c,#1a2a36); --hero-text:var(--text); --hero-muted:var(--muted); --hero-chip:rgba(255,255,255,.08); --hero-chip-border:rgba(255,255,255,.16);
}
body.theme-dark img{opacity:.92}
:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--text);background:var(--bg)}
*{box-sizing:border-box}
[hidden]{display:none!important}
html,body{height:100%;overflow:hidden}
body{margin:0;display:flex;flex-direction:column}
main{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
a{color:var(--accent);text-decoration:none}

/* ── View toggles ── */
.category-only,.cabinet-only,.search-only,.map-only{display:none}
body[data-view="home"] .ai-panel,body[data-view="ai"] .ai-panel{display:block}
body:not([data-view="home"]):not([data-view="ai"]) .ai-panel{display:none!important}
body[data-view="search"] .search-only{display:block}
body[data-view="search"] .browse-panel{display:block}
body:not([data-view="search"]) .browse-panel{display:none}
body[data-view="category"] .category-only{display:block}
body[data-view="cabinet"] .cabinet-only{display:block}
body[data-view="cabinet"] .home-only,body[data-view="cabinet"] .results-section,body[data-view="cabinet"] .category-only,body[data-view="cabinet"] .search-only,body[data-view="cabinet"] .browse-panel,body[data-view="cabinet"] .map-only{display:none}
body[data-view="map"] .map-only{display:block}
body[data-view="map"] .home-only,body[data-view="map"] .results-section,body[data-view="map"] .category-only,body[data-view="map"] .search-only,body[data-view="map"] .cabinet-only,body[data-view="map"] .browse-panel,body[data-view="map"] .ai-panel{display:none!important}
body.detail-open .map-only{display:none!important}
body.detail-open .map-panel{display:none!important}
body[data-view="home"] .results-section{display:none}
body[data-view="ai"] .home-only,body[data-view="ai"] .search-only,body[data-view="ai"] .cabinet-only,body[data-view="ai"] .category-only,body[data-view="ai"] .browse-panel{display:none!important}
body[data-view="category"] .browse-panel,body[data-view="category"] .search-only{display:none}
body[data-auth="in"] .guest-only{display:none!important}
body:not([data-auth="in"]) .auth-only{display:none!important}

/* ── Heights and widths per view ── */
body[data-view="home"] main,body[data-view="ai"] main{max-width:860px;margin:0 auto 12px;padding:0 16px 16px}
body[data-view="category"] main,body[data-view="cabinet"] main,body[data-view="search"] main,body[data-view="map"] main{margin:0 auto;padding:0 16px 16px;max-width:1120px}
body[data-view="category"] .hero,body[data-view="search"] .hero,body[data-view="cabinet"] .hero{min-height:auto;padding:14px 18px}
body[data-view="category"] .hero-controls,body[data-view="search"] .hero-controls,body[data-view="cabinet"] .hero-controls{margin-top:8px}
/* Compact header on AI results — hide title, keep controls bar */
body[data-view="ai"] .hero{padding:10px 16px;min-height:auto;border-radius:0 0 16px 16px}
body[data-view="ai"] .hero-body{display:none}
body[data-view="ai"] .hero-controls{margin:0;flex-wrap:nowrap}
body[data-view="ai"] .ai-panel{margin-top:0}
/* Compact search bar on AI results */
body[data-view="ai"] .ai-search-form{border-radius:14px;box-shadow:0 2px 12px rgba(20,45,70,.1)}
body[data-view="ai"] .ai-search-form textarea{min-height:44px;padding:10px 12px;font-size:15px}
body[data-view="ai"] .ai-submit{min-height:44px;padding:0 18px;font-size:14px}
body[data-view="ai"] .search-icon{font-size:18px;padding:0 0 0 12px}
body[data-view="ai"] .ai-samples{display:none}
body[data-view="ai"] .manual-row{display:none}

/* ── Hero ── */
.hero{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:14px 18px 12px;color:var(--hero-text);background:var(--hero-bg);border-radius:0 0 22px 22px;transition:box-shadow .25s ease}
.hero-body{flex:1;min-width:0}
.hero-controls{display:flex;gap:8px;align-items:center;flex-shrink:0;flex-wrap:wrap}
/* Collapsed header on scroll — shrink to back-button-only bar */
.hero.header-scrolled{padding:6px 16px!important;min-height:auto!important;border-radius:0 0 16px 16px!important;box-shadow:0 4px 18px rgba(0,0,0,.14)!important}
.hero.header-scrolled .hero-body{display:none!important}
.hero.header-scrolled .hero-controls{display:none!important}
.hero.header-scrolled .back-button{width:30px!important;height:30px!important;font-size:16px!important;margin-right:4px!important}
/* Back button — top left corner */
.back-button{flex-shrink:0;width:36px;height:36px;border:none;border-radius:50%;background:var(--hero-chip);color:var(--hero-text);font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-right:8px;transition:background .15s}
.back-button:hover{background:var(--accent-soft)}
.back-button[hidden]{display:none!important}
/* On AI view — compact header, smaller back button */
body[data-view="ai"] .back-button{width:32px;height:32px;font-size:18px}
.ai-hero{background:var(--hero-bg)}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-weight:800;margin:0 0 8px;opacity:.85}
h1{font-size:22px;line-height:1.15;margin:0}
.subtitle{font-size:13px;max-width:700px;margin:2px 0 0;color:var(--hero-muted);line-height:1.35}
.subtle-select{font:inherit;border-radius:11px;border:1px solid var(--hero-chip-border);padding:6px 10px;background:var(--hero-chip);color:var(--hero-text);font-size:12px;font-weight:700;cursor:pointer}
.subtle-select option{color:var(--text);background:var(--surface)}
.account-cta{background:var(--surface);color:var(--accent-deep);border:2px solid rgba(255,255,255,.96);box-shadow:0 12px 26px rgba(0,51,90,.22);font-weight:900;font-size:14px;padding:12px 18px;border-radius:14px;cursor:pointer}
.account-cta:focus,.account-cta:hover{background:var(--accent-soft);color:var(--accent-deep);transform:translateY(-1px)}

/* ── Main & panes ── */
main{max-width:1120px;margin:0 auto 40px;padding:0 16px 100px}
.ai-panel{max-width:860px;margin:18px auto;padding:0}

/* ── AI search form ── */
.ai-search-form{display:flex;gap:0;background:white;border-radius:22px;box-shadow:0 14px 40px rgba(20,45,70,.18),0 0 0 2px rgba(42,168,118,.18);align-items:stretch;overflow:hidden}
.search-icon{display:flex;align-items:center;padding:0 0 0 18px;font-size:22px;flex-shrink:0;user-select:none}
.ai-search-form textarea{flex:1;min-height:66px;border:none;border-radius:0;resize:none;padding:14px 10px;font-size:17px;background:var(--surface-2);outline:none;font:inherit;color:var(--text)}
.ai-search-form textarea::placeholder{color:#8a99aa;font-size:16px}
.ai-search-form textarea:focus{background:var(--surface)}
.ai-search-form:focus-within{box-shadow:0 14px 40px rgba(20,45,70,.18),0 0 0 3px rgba(42,168,118,.3)}
.ai-submit{white-space:nowrap;padding:12px 28px;font-size:15px;border-radius:0 20px 20px 0;align-self:stretch;min-height:66px;margin:0;border:none}
.ai-samples{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.ai-samples button{background:rgba(255,255,255,.92);border:1px solid var(--border);border-radius:999px;padding:8px 14px;font-size:13px;cursor:pointer;color:var(--text-2);font-weight:600}
.ai-samples button:hover{background:var(--accent-soft);border-color:var(--accent-2);color:var(--accent-deep)}
.manual-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:10px;color:var(--muted);font-size:13px}

/* ── Browse panel ── */
.browse-panel{max-width:1120px;margin:0 auto}

/* ── Shared cards/filters ── */
.search-card,.portal-filters,.search-panel,.form-card,.card,.section-card{background:white;border-radius:22px;box-shadow:0 14px 40px rgba(20,45,70,.12);padding:18px}
.portal-filters{margin-bottom:18px}
.portal-filters form{display:grid;grid-template-columns:1.4fr 1fr 1fr auto;gap:10px}
.filter-intro{margin:0 0 12px;color:var(--muted)}
.filter-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.filter-chip{border:1px solid var(--border);background:var(--surface-2)}
.filter-chip.active{background:var(--accent-soft);border-color:var(--accent-2);color:var(--accent-deep)}
.filter-check{display:flex;align-items:center;gap:8px;font-weight:800}

/* ── Sections ── */
.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:26px 0 12px}
.section-title p{margin:4px 0 0;color:var(--muted)}
.compact{align-items:flex-end}
.section-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.section-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ── Category grid ── */
.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.category{border:0;border-radius:18px;background:white;text-align:left;padding:16px;box-shadow:0 8px 24px rgba(20,45,70,.08);cursor:pointer;color:inherit;text-decoration:none}
.category strong{display:block;font-size:18px;margin-bottom:6px}
.category span{color:var(--muted);font-size:14px}
.category.active{outline:3px solid rgba(42,168,118,.28);border:1px solid var(--accent-2);background:var(--accent-soft)}
.category em{display:block;margin-top:8px;color:var(--accent);font-style:normal;font-size:12px;font-weight:800}

/* ── Cards ── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.card h3{font-size:18px}
.card p{color:var(--text-2);line-height:1.45}
.card ol{margin:10px 0 0;padding-left:20px;color:#4d5b6b}
.topline,.meta{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0}
.pill{font-size:12px;background:#e9f7ef;color:#087f5b;padding:5px 8px;border-radius:99px}
.kind-label{font-size:12px;color:var(--muted);padding:5px 0}
.verified{background:var(--accent-soft);color:#1864ab}
.warn{background:#fff3bf;color:#9a6700}
.muted-card{border:1px dashed #b6c7d5;background:var(--surface-2)}
.price{font-weight:800;color:#0b7285}
.empty{padding:20px;background:rgba(255,255,255,.65);border-radius:18px;color:var(--muted)}
input,select,textarea,button,.button{font:inherit;border-radius:14px;border:1px solid var(--border);padding:12px 14px;background:white}
textarea{min-height:120px;resize:vertical}
button,.button{cursor:pointer;font-weight:700}
button.primary,.primary{background:var(--accent-2);color:white;border-color:var(--accent-2)}
.ghost{background:transparent}
.button{display:inline-block;margin-top:8px}
.danger{color:#c92a2a}

/* ── Forms ── */
.form-card{margin-top:28px}
.form-card form{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.auth-panel{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.auth-card{background:var(--surface-2);border:1px solid var(--accent-soft);border-radius:20px;padding:16px}
.auth-card p{margin:0 0 12px;color:var(--muted)}
.account-status{margin-bottom:14px}
.auth-only{margin-top:14px}
.form-card label,.report-card label{display:grid;gap:6px;font-weight:700}
.form-card label:nth-child(3){grid-column:auto}
.form-card label:nth-child(5),.form-card label:last-of-type{grid-column:1/-1}
.form-rule{grid-column:1/-1}
.trust-meta{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0;color:var(--muted);font-size:12px}
.trust-meta span{background:#f4f8fb;border:1px solid #dce8ef;border-radius:99px;padding:5px 8px}
.report-card{margin-top:14px;background:#fffdf7;border:1px solid #f2d98d;border-radius:20px;padding:16px;box-shadow:0 8px 24px rgba(20,45,70,.08);display:grid;gap:10px}
.report-card[hidden]{display:none!important}
.report-card textarea{min-height:90px}
.credit-card{background:var(--surface-2);border:1px solid var(--accent-soft);border-radius:20px;padding:16px;margin:14px 0}
.credit-card p{color:var(--muted)}
.credit-chips{display:flex;flex-wrap:wrap;gap:8px}
.credit-chip{background:#edf7ff;color:var(--accent-deep);border:1px solid #cae7ff}
.credit-ledger{display:grid;gap:8px;margin-bottom:12px}
.ledger-row{display:flex;justify-content:space-between;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:10px 12px}
.credit-hint{margin-top:8px;background:#f6fbff;border:1px solid var(--accent-soft);border-radius:14px;padding:10px;color:var(--accent-deep)}
.photo-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin:-4px -4px 12px}
.photo-strip img{width:100%;height:138px;object-fit:cover;border-radius:16px;background:#dce8ef}
.rules-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.rule-card,.rule-box{background:white;border:1px solid var(--border);border-radius:18px;padding:14px;display:grid;gap:6px}
.rule-tags{display:flex;gap:6px;flex-wrap:wrap}
.rule-tags em{background:var(--bg);border-radius:99px;padding:4px 8px;font-size:12px;color:#4d5b6b}

/* ── AI results ── */
.ai-result{display:grid;gap:14px}
.search-cockpit{position:relative;overflow:hidden;border:1px solid var(--border);border-radius:28px;padding:18px;background:linear-gradient(180deg,#ffffff,#f7fbff);box-shadow:0 18px 50px rgba(9,33,59,.12);margin-top:14px}
.search-cockpit:before{content:"";position:absolute;inset:0 0 auto;height:5px;background:linear-gradient(90deg,var(--accent-2),var(--success),var(--warn))}
.search-cockpit.answer:before{background:linear-gradient(90deg,#7048e8,var(--accent))}
.search-cockpit.blocked:before{background:linear-gradient(90deg,#e03131,#f08c00)}
.cockpit-top{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;color:#526579;font-size:12px;font-weight:800}
.cockpit-top span{border:1px solid var(--border);background:var(--surface-2);border-radius:999px;padding:6px 9px}
.cockpit-top .mode-badge{background:var(--text);color:var(--on-accent);border-color:var(--text)}
.search-cockpit h2{font-size:24px;margin:0 0 8px;color:var(--text)}
.answer-text{margin:0;color:var(--text-2);line-height:1.5}
.interpretation{margin-top:12px;border:1px solid var(--border);background:var(--surface-2);border-radius:16px;padding:10px 12px;color:var(--text-2)}
/* ── Compact summary bar (replaces search-cockpit when results exist) ── */
.search-summary-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:12px 16px;border-radius:18px;background:var(--text);color:var(--on-accent);margin-top:14px;box-shadow:0 8px 28px rgba(9,33,59,.14)}
.search-summary-bar .summary-left{display:flex;align-items:center;gap:8px;font-size:14px}
.search-summary-bar .summary-left strong{font-size:20px;font-weight:700}
.search-summary-bar .summary-left span{opacity:.82}
.search-summary-bar .provider-dot{width:8px;height:8px;border-radius:50%;background:var(--success);display:inline-block}
.search-summary-bar .summary-right{display:flex;gap:8px}
.search-summary-bar .summary-right button{border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.08);color:var(--on-accent);border-radius:999px;padding:6px 14px;font-size:13px;cursor:pointer;white-space:nowrap}
.search-summary-bar .summary-right button:hover{background:rgba(255,255,255,.18)}
.search-summary-bar + .filter-chips.compact{border:none;background:0;padding:8px 0 0;margin:0}
.intent-chips button{background:var(--surface);border-color:#cfe0ec;color:var(--accent-deep)}
.result-section{display:grid;gap:10px}
.result-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:4px 2px}
.result-section-head h3{font-size:16px;margin:0;color:var(--text)}
.section-more{font-size:12px;color:var(--muted)}
.search-hit{display:grid;background:var(--surface);border:1px solid var(--border);border-radius:22px;overflow:hidden;box-shadow:0 10px 26px rgba(9,33,59,.08);max-width:600px}
.search-hit .photo-strip{margin:0;display:flex;gap:2px}
.search-hit .photo-strip img{flex:1;min-width:0;height:100px;object-fit:contain;background:var(--surface-3)}
.search-hit .photo-strip:has(img:only-child) img{height:120px}
.search-hit .photo-strip:has(img:nth-child(2)):not(:has(img:nth-child(3))) img{height:120px}
.hit-thumb{overflow:hidden;background:var(--surface-3)}
.hit-thumb img{border-radius:22px 22px 0 0;width:100%;height:120px;object-fit:contain}
.hit-body{padding:14px}
.search-hit h3{font-size:17px;margin:6px 0;color:var(--text)}
.search-hit p{font-size:14px;margin:0;color:var(--text-2)}
.search-hit .hit-footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:10px}
.ai-results-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:14px}
.ai-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.catalog-dashboard{display:grid;gap:10px;border:1px solid var(--border);border-radius:22px;background:linear-gradient(135deg,var(--text),#0b4773);color:var(--on-accent);padding:18px;box-shadow:0 18px 42px rgba(2,42,74,.18);margin-top:18px}
.catalog-dashboard div:first-child{display:flex;align-items:baseline;gap:8px}
.catalog-dashboard strong{font-size:30px;line-height:1}
.catalog-dashboard span,.catalog-dashboard small{color:rgba(255,255,255,.78)}
.density-bar{height:9px;border-radius:999px;background:rgba(255,255,255,.18);overflow:hidden}
.density-bar i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--success),var(--warn))}
.search-hit.compact-density{grid-template-columns:minmax(0,.3fr) minmax(0,.7fr)}
.search-hit.compact-density .photo-strip img{height:100%;min-height:100px;object-fit:contain;background:var(--surface-3)}
.search-hit.compact-density .hit-body{padding:10px 14px}
.search-hit.compact-density p{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
/* ── Thin / OSM-shell cards (no real data) ── */
.thin-card{border:1px dashed #d0d8e0;background:#fafbfc;box-shadow:none}
.thin-body{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:10px 14px}
.thin-body h3{font-size:15px;margin:0;color:var(--text);white-space:nowrap}
.thin-body .thin-desc{font-size:13px;color:#8899aa}
.thin-body .pill{margin:0}
.thin-body .pill.outline{background:0;border:1px dashed #c0c8d0;color:#8899aa;font-size:11px}
.thin-body .compact-map-btn{font-size:12px;padding:4px 10px;border:1px solid var(--border);border-radius:999px;color:var(--accent-deep);cursor:pointer}
.thin-body .open-detail-hint{font-size:12px;color:var(--accent-deep);margin-left:auto}
/* Thin detail CTA */
.thin-detail-cta{margin-top:14px;padding:14px 18px;border:1px dashed #d0d8e0;border-radius:16px;background:#fafcfd;text-align:center}
.thin-detail-cta p{font-size:14px;color:var(--muted);margin:0 0 10px}
.thin-detail-cta button:disabled{opacity:.5;cursor:not-allowed}
.search-hit[role="button"]:focus{outline:3px solid rgba(14,165,233,.25);outline-offset:3px}
/* No-results CTA */
.no-results-cta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:18px;padding:14px 18px;border:1px solid var(--border);border-radius:18px;background:#fafcfd}
.no-results-cta p{margin:0;color:var(--muted);font-size:14px}
.no-results-cta button{font-size:14px;color:var(--accent);border-color:#cae7ff;background:var(--surface);white-space:nowrap}
.no-results-cta button:hover{background:var(--accent-soft)}
/* Detail modal */
.detail-open{overflow:hidden}
.detail-modal[hidden]{display:none!important}
.detail-modal{position:fixed;inset:0;z-index:60;display:grid;align-items:end;background:rgba(8,24,40,.36)}
.detail-backdrop{position:absolute;inset:0}
.detail-sheet{position:relative;max-height:86vh;overflow:auto;background:var(--surface);border-radius:28px 28px 0 0;padding:22px 18px 96px;box-shadow:0 -24px 60px rgba(2,22,37,.24)}
.detail-close{position:sticky;top:0;float:right;width:42px;height:42px;border-radius:999px;border:0;background:var(--accent-soft);color:var(--accent-deep);font-size:28px;font-weight:900;z-index:2}
.detail-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:8px 0 14px}
.detail-photos img{width:100%;height:104px;object-fit:cover;border-radius:18px}
.detail-head h2{font-size:26px;line-height:1.06;margin:8px 0}
.detail-head p{color:var(--text-2);font-size:16px;line-height:1.42}
.detail-price{font-size:18px;color:var(--accent-deep)}
.detail-section{border:1px solid var(--border);border-radius:20px;padding:14px;margin:12px 0;background:var(--surface-2)}
.detail-section h4{margin:0 0 8px;font-size:16px}
.detail-section ul{margin:0;padding-left:20px;color:var(--text-2)}
.detail-section li{margin:6px 0}

/* ── Offering cards (establishment menus) ── */
.offering-grid{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.offering-card{display:flex;gap:12px;padding:12px;border:1px solid #e7edf3;border-radius:16px;background:var(--surface);transition:box-shadow .15s}
.offering-card:hover{box-shadow:0 2px 8px rgba(0,0,0,.06)}
.offering-thumb{flex-shrink:0;width:72px;height:72px;border-radius:12px;overflow:hidden}
.offering-thumb img{width:100%;height:100%;object-fit:cover}
.offering-body{flex:1;min-width:0}
.offering-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.offering-top strong{font-size:15px;font-weight:600;color:#0f172a}
.offering-price{font-size:15px;font-weight:700;color:var(--accent-deep);white-space:nowrap;margin-left:auto}
.offering-desc{font-size:13px;color:#64748b;margin:4px 0 0;line-height:1.4}
.offering-meta{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}
.count-badge{font-size:12px;font-weight:400;color:var(--muted);margin-left:4px}
.pill.accent.mini{font-size:11px;padding:2px 6px}
.detail-contact{margin-top:12px;display:flex;gap:8px}
.detail-contact .button.primary{background:var(--accent);color:var(--on-accent);border:0;padding:10px 18px;border-radius:14px;text-decoration:none;font-size:14px;font-weight:600}

/* ── Bottom nav ── */
.bottom-nav{flex-shrink:0;display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:6px;margin:0 8px 6px;border:1px solid rgba(0,0,0,.08);border-radius:24px;background:rgba(255,255,255,.94);box-shadow:0 14px 40px rgba(20,45,70,.22);backdrop-filter:blur(12px)}
.bottom-nav button{display:grid;gap:2px;justify-items:center;padding:9px 8px;border:0;background:transparent;color:var(--muted)}
.bottom-nav span{font-size:18px;line-height:1}
.bottom-nav strong{font-size:12px}
.bottom-nav button.active{background:var(--accent-soft);color:var(--accent-deep);border-radius:18px}

/* ── Responsive ── */
@media(max-width:860px){
  .hero{align-items:flex-start;flex-direction:column;gap:8px}.hero-controls{width:100%;justify-content:flex-start}
  .hero-body{width:100%}
  .ai-search-form{flex-direction:column}.ai-submit{width:100%;min-height:48px}
  .portal-filters form{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}h1{font-size:20px}
}
@media(max-width:640px){
  .search-cockpit{border-radius:22px;padding:15px}
  .search-cockpit h2{font-size:21px}
  .ai-results-grid{grid-template-columns:1fr}
  .cockpit-top span{font-size:11px}
  .search-hit.compact-density{grid-template-columns:1fr}
  .search-hit.compact-density .photo-strip img{height:100px;min-height:100px;object-fit:contain}
}
/* ── Reviews ── */
.review-stats{font-size:16px;margin-bottom:8px}
.review-avg{font-weight:700;color:#e67e22}
.review-form{margin:12px 0;padding:12px;background:#f8fafc;border-radius:10px;border:1px solid var(--border)}
.star-rating{display:flex;gap:4px;margin-bottom:8px}
.star-btn{background:none;border:none;font-size:24px;cursor:pointer;color:var(--border);padding:0 2px;transition:color 0.15s}
.star-btn.active,.star-btn:hover{color:#f1c40f}
.review-item{padding:10px 0;border-bottom:1px solid var(--border)}
.review-item:last-child{border-bottom:none}
.review-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.review-stars{color:#f1c40f;font-size:14px}
.review-author{font-weight:600;font-size:13px}
.review-date{font-size:11px;color:var(--muted);margin-left:auto}
.review-text{font-size:13px;color:var(--text-2);margin:4px 0 0}
#reviewText{width:100%;min-height:48px;margin-top:4px;padding:8px;border:1px solid var(--border);border-radius:8px;font-size:13px;resize:vertical}
/* ── Map actions in detail ── */
.detail-map-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.detail-map-btn{font-size:13px;padding:6px 12px}
.detail-route-btn{font-size:13px;padding:6px 14px;text-decoration:none;display:inline-block}
/* ── Map ── */
/* Map container — Google Maps */
#mapContainer{height:60vh;border-radius:12px;margin-bottom:12px;touch-action:pan-y pinch-zoom}
#mapContainer .gm-style{font-family:inherit}
.legend-item{display:inline-block;background:var(--surface-3);padding:2px 8px;border-radius:8px;font-size:0.8rem}
.map-legend{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;padding:8px 0}
.legend-item{display:inline-flex;align-items:center;gap:4px}
.map-filters{display:block;padding:4px 0 10px}
/* Searchable filter bar */
.map-filter-bar{display:flex;flex-direction:column;gap:8px}
.map-filter-search-wrap{position:relative}
.map-filter-input{width:100%;padding:8px 12px;font-size:14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:#0f172a;outline:none;box-sizing:border-box}
.map-filter-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(11,132,255,.15)}
.map-filter-input::placeholder{color:var(--muted)}
/* Dropdown */
.map-filter-dropdown{display:none;position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.1);max-height:200px;overflow-y:auto;z-index:100}
.map-filter-dropdown.open{display:block}
.map-filter-option{display:flex;justify-content:space-between;align-items:center;width:100%;padding:8px 12px;font-size:13px;border:none;background:none;color:var(--text-2);cursor:pointer;text-align:left}
.map-filter-option:hover{background:var(--surface-3)}
.map-filter-count{font-size:11px;color:var(--muted);background:var(--surface-3);padding:1px 6px;border-radius:10px}
.map-filter-empty{padding:10px 12px;font-size:13px;color:var(--muted);text-align:center}
/* Selected pills */
.map-filter-pills{display:flex;flex-wrap:wrap;gap:6px;min-height:0}
.map-filter-all-label{font-size:13px;color:var(--muted);padding:4px 0}
.map-filter-pill{font-size:12px;padding:4px 10px;border:1px solid var(--accent);border-radius:16px;background:#eff6ff;color:var(--accent);cursor:pointer;white-space:nowrap;transition:all .15s}
.map-filter-pill:hover{background:#dbeafe;border-color:#e74c3c;color:#e74c3c}

/* Fullscreen photo overlay */
.fullscreen-photo-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:9999;align-items:center;justify-content:center;user-select:none}
.fullscreen-photo-overlay.open{display:flex}
.fullscreen-photo-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:40px}
.fullscreen-photo-overlay img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}
.fullscreen-photo-close{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;border:none;background:rgba(255,255,255,.15);color:var(--on-accent);font-size:28px;cursor:pointer;z-index:10002;display:flex;align-items:center;justify-content:center;transition:background 0.2s}
.fullscreen-photo-close:hover{background:rgba(255,255,255,.3)}
.fullscreen-photo-nav{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border-radius:50%;border:none;background:rgba(255,255,255,.12);color:var(--on-accent);font-size:36px;cursor:pointer;z-index:10001;display:flex;align-items:center;justify-content:center;transition:background 0.2s}
.fullscreen-photo-nav:hover{background:rgba(255,255,255,.25)}
.fullscreen-photo-nav.prev{left:20px}
.fullscreen-photo-nav.next{right:20px}
.fullscreen-photo-counter{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.6);color:var(--on-accent);padding:6px 16px;border-radius:99px;font-size:14px;font-weight:600;z-index:10001;letter-spacing:1px}

/* ── Геккон в шапке ── */
.hero-title-row{display:flex;align-items:center;gap:10px}
.hero-gecko{width:42px;height:42px;flex-shrink:0;filter:drop-shadow(0 3px 6px rgba(0,0,0,.12))}

/* ── Обратная связь (идея/связаться) ── */
.feedback-link{font-size:13px;font-weight:700;color:var(--accent-deep);border:1px solid var(--border);border-radius:999px;padding:6px 12px;background:var(--surface);white-space:nowrap;margin-left:auto}
.feedback-link:hover{background:var(--accent-soft)}
.feedback-sheet{max-width:480px;margin:0 auto;padding-bottom:22px}
.feedback-head{display:flex;align-items:center;gap:10px;margin:2px 0 6px}
.feedback-head img{width:44px;height:44px}
.feedback-head h3{margin:0;font-size:20px}
.feedback-hint{margin:0 0 12px;color:var(--muted);font-size:14px}
#feedbackText{width:100%;min-height:110px;box-sizing:border-box;background:var(--surface-2);color:var(--text)}
.feedback-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}

/* Contact button in detail */
.detail-contact-btn{display:inline-flex;align-items:center;gap:6px;margin:8px 0 4px;font-size:15px}

/* Source link in detail */
.detail-source{margin:4px 0 8px;font-size:13px}
.detail-source a{color:var(--accent-deep)}
