
.lost-carousel-card { position: relative; background: rgba(255,255,255,.82); border: 1px solid var(--line); border-radius: 32px; padding: 18px; box-shadow: var(--shadow); overflow: hidden; }
.site-nav a.nav-stack { display: inline-flex; flex-direction: column; align-items: center; justify-content: center; gap: 1px; line-height: 1.08; min-height: 48px; text-align: center; text-decoration: none; }
.site-nav a.nav-stack span { display: block; }
.lost-carousel-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,255,255,.72), rgba(232,246,255,.58)); pointer-events: none; }
.carousel-head { position: relative; z-index: 2; display: flex; align-items: end; justify-content: space-between; gap: 18px; margin-bottom: 14px; }
.carousel-head h2 { font-size: clamp(22px,2.6vw,31px); }
.carousel-controls { display: flex; gap: 8px; }
.carousel-btn { width: 42px; height: 42px; border-radius: 50%; border: 1px solid var(--line); background: #fff; color: var(--text); font-size: 26px; line-height: 1; cursor: pointer; box-shadow: var(--shadow-soft); }
.lost-carousel { position: relative; z-index: 1; display: grid; grid-auto-flow: column; grid-auto-columns: minmax(260px, 1fr); gap: 14px; overflow-x: auto; scroll-snap-type: x mandatory; padding: 2px 2px 12px; scrollbar-width: thin; }
.empty-state { position: relative; z-index: 1; display: grid; align-content: center; gap: 12px; min-height: 340px; padding: 28px; border: 1px solid var(--line); border-radius: 24px; background: #f6fbff; color: var(--text); }
.empty-state p { margin: 0; color: var(--muted); }
.lost-slide { position: relative; min-height: 420px; border-radius: 28px; overflow: hidden; background: #eaf6ff; border: 1px solid rgba(216,232,245,.95); scroll-snap-align: start; box-shadow: var(--shadow-soft); }
.lost-slide img { width: 100%; height: 100%; min-height: 420px; object-fit: cover; display: block; transition: transform .35s ease; }
.lost-slide:hover img { transform: scale(1.04); }
.lost-slide::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 35%, rgba(30,52,76,.72) 100%); pointer-events: none; }
.lost-slide-content { position: absolute; z-index: 2; left: 18px; right: 18px; bottom: 18px; color: #fff; }
.lost-slide-content .pill { background: rgba(255,255,255,.9); color: #2279b6; }
.lost-slide-content h3 { font-size: 21px; margin: 10px 0 3px; color: #fff; }
.lost-slide-content .muted { color: rgba(255,255,255,.88); }
.lost-hover-card { position: absolute; z-index: 3; left: 14px; right: 14px; top: 14px; padding: 16px; border-radius: 22px; background: rgba(255,255,255,.96); color: var(--text); box-shadow: var(--shadow); opacity: 0; transform: translateY(-8px); transition: .22s ease; }
.lost-slide:hover .lost-hover-card, .lost-slide:focus-within .lost-hover-card { opacity: 1; transform: translateY(0); }
.lost-hover-card p { margin: 8px 0; color: var(--muted); }
.hover-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.carousel-dots { display: flex; justify-content: center; gap: 8px; position: relative; z-index: 2; padding-top: 4px; }
.carousel-dots button { width: 9px; height: 9px; border-radius: 50%; border: 0; background: #b9d6ea; cursor: pointer; }
.carousel-dots button.is-active { width: 24px; border-radius: 999px; background: var(--accent); }
.quick-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.quick-card { padding: 20px; border-radius: 26px; background: rgba(255,255,255,.9); border: 1px solid var(--line); box-shadow: var(--shadow-soft); }
.quick-card-icon { width: 52px; height: 52px; display: grid; place-items: center; border-radius: 18px; margin-bottom: 14px; background: linear-gradient(135deg, #cfefff, #fff2a8); font-size: 24px; }
.quick-card h3 { font-size: 20px; margin-bottom: 8px; }
.quick-card p { color: var(--muted); margin: 0 0 14px; }
.feature-list { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.feature { background: rgba(255,255,255,.9); border: 1px solid var(--line); border-radius: 24px; padding: 20px; box-shadow: var(--shadow-soft); }
.feature b { display: block; font-size: 18px; margin-bottom: 6px; }
.pet-card img, .recipe-card img { aspect-ratio: 1.35 / 1; object-fit: cover; }
.recipe-meta { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.recipe-detail { display: grid; gap: 22px; }
.recipe-detail-photo { width: 100%; max-height: 520px; object-fit: cover; border-radius: 28px; border: 1px solid var(--line); box-shadow: var(--shadow-soft); }
.recipe-detail-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 18px; align-items: start; }
.recipe-list { margin: 14px 0 0; padding-left: 22px; }
.recipe-list li { margin: 9px 0; }
.recipe-safety { margin-top: 4px; }
.business-card { position: relative; isolation: isolate; overflow: hidden; }
.business-card.has-photo::before { content: ""; position: absolute; inset: 0; z-index: -2; background-image: var(--card-bg); background-size: cover; background-position: center; opacity: .9; transform: scale(1.02); }
.business-card.has-photo::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(255,255,255,.22), rgba(255,255,255,.48)); }
.business-card .card-body { position: relative; }
.business-card .card-topline { display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.business-title-chip, .business-meta-chip, .business-summary-chip { width: fit-content; max-width: 100%; border-radius: 999px; box-shadow: 0 10px 22px rgba(33, 65, 96, .10); }
.business-title-chip { margin-top: 16px; padding: 9px 14px; background: rgba(232,246,255,.92); color: #114b76; }
.business-meta-chip { padding: 8px 13px; background: rgba(232,246,255,.9); color: #335c82; font-weight: 800; }
.business-summary-chip { border-radius: 20px; padding: 12px 15px; background: rgba(255,245,184,.92); color: #4f430c; font-weight: 800; line-height: 1.45; }
.directory-head { display: flex; align-items: end; justify-content: space-between; gap: 18px; margin-bottom: 18px; }
.directory-head h1 { margin-bottom: 8px; }
.business-directory-layout { display: grid; grid-template-columns: 280px minmax(0, 1fr); gap: 18px; align-items: start; }
.business-filter-sidebar { position: sticky; top: 92px; }
.business-filter-bar { display: grid; gap: 12px; padding: 16px; border: 1px solid var(--line); border-radius: 24px; background: rgba(255,255,255,.96); box-shadow: var(--shadow-soft); }
.filter-sidebar-head h2 { margin: 4px 0 0; font-size: 22px; }
.filter-field { display: grid; gap: 7px; font-weight: 900; color: var(--text); }
.filter-field span { font-size: 13px; color: var(--muted); }
.filter-checks { display: grid; gap: 8px; }
.filter-checks label { display: inline-flex; align-items: center; gap: 8px; min-height: 42px; padding: 9px 11px; border: 1px solid var(--line); border-radius: 999px; background: #f6fbff; font-weight: 850; color: var(--text); }
.business-filter-bar input[type="checkbox"] { width: 17px; height: 17px; accent-color: #39a96b; }
.filter-reset-link { justify-self: center; }
.business-results-column { min-width: 0; }
.business-card-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; align-items: stretch; }
.business-listing-card { position: relative; isolation: isolate; display: grid; grid-template-rows: 155px 1fr; min-height: 360px; border: 1px solid var(--line); border-radius: 24px; background: rgba(255,255,255,.98); box-shadow: var(--shadow-soft); overflow: hidden; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.business-listing-card:hover { transform: translateY(-3px); border-color: #9ed8f8; box-shadow: var(--shadow); }
.business-listing-card.is-partner { border: 3px solid #f1c84f; box-shadow: 0 20px 44px rgba(94,70,8,.16); }
.business-listing-card.is-partner::before { content: ""; position: absolute; inset: 0; z-index: -1; border-radius: 21px; background: radial-gradient(circle at 20% 0%, rgba(255,244,168,.42), transparent 32%), linear-gradient(135deg, rgba(255,250,218,.96), rgba(232,246,255,.96)); }
.business-cover { position: relative; display: grid; place-items: center; min-height: 155px; background: linear-gradient(135deg, rgba(232,246,255,.92), rgba(255,245,184,.84)), #eaf6ff; overflow: hidden; }
.business-listing-card.has-cover .business-cover::before { content: ""; position: absolute; inset: 0; background-image: var(--business-cover); background-size: cover; background-position: center; transform: scale(1.02); transition: transform .24s ease; }
.business-listing-card.has-cover:hover .business-cover::before { transform: scale(1.08); }
.business-listing-card.has-cover .business-cover::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(16,36,58,.05), rgba(16,36,58,.36)); }
.business-cover span { position: relative; z-index: 1; width: 72px; height: 72px; display: grid; place-items: center; border-radius: 24px; background: #fff; color: #2279b6; font-size: 36px; font-weight: 950; box-shadow: var(--shadow-soft); }
.partner-ribbon-diagonal { position: absolute; top: 22px; right: -42px; z-index: 6; width: 178px; padding: 8px 10px; transform: rotate(38deg); text-align: center; background: linear-gradient(135deg, #ffe36e, #fff4a8); color: #6f4d00; border: 1px solid rgba(128,91,0,.22); box-shadow: 0 10px 22px rgba(94,70,8,.22); font-size: 11px; font-weight: 950; text-transform: uppercase; letter-spacing: .6px; }
.business-listing-body { display: grid; align-content: start; gap: 9px; padding: 14px; min-width: 0; }
.business-title-row { display: grid; grid-template-columns: auto 1fr; gap: 10px; align-items: center; min-width: 0; }
.business-mini-logo { width: 48px; height: 48px; border-radius: 16px; object-fit: cover; background: #fff; border: 2px solid rgba(255,255,255,.9); box-shadow: 0 10px 22px rgba(33,65,96,.14); }
.business-listing-body h2 { margin: 0; font-size: 19px; line-height: 1.08; }
.business-meta { margin: 4px 0 0; color: #335c82; font-weight: 900; font-size: 13px; }
.business-summary { margin: 0; color: var(--text); line-height: 1.35; font-size: 14px; }
.business-facts { display: grid; gap: 4px; margin: 0; font-size: 12px; }
.business-facts div { display: grid; grid-template-columns: 72px 1fr; gap: 7px; }
.business-facts dt { color: var(--muted); font-weight: 850; }
.business-facts dd { margin: 0; font-weight: 800; overflow-wrap: anywhere; }
.business-tags { display: flex; flex-wrap: wrap; gap: 5px; min-height: 20px; }
.business-tags span { padding: 4px 7px; border-radius: 999px; background: #e8f6ff; color: #2279b6; font-size: 10px; font-weight: 950; }
.business-listing-card.is-partner .business-tags span { background: #fff4a8; color: #6f5b0f; }
.business-actions { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 2px; }
.business-actions .btn { padding: 7px 10px; font-size: 12px; }
.business-partner-overlay { position: absolute; inset: 0; z-index: 5; display: grid; place-items: center; align-content: center; gap: 8px; padding: 24px; text-align: center; text-decoration: none; background: rgba(20,38,56,.74); opacity: 0; pointer-events: none; transition: opacity .18s ease; }
.business-listing-card.is-partner:hover .business-partner-overlay { opacity: 1; pointer-events: auto; }
.business-partner-overlay span { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 13px 22px; border-radius: 999px; background: #5ab2e8; color: #fff; font-size: 18px; font-weight: 950; box-shadow: 0 16px 32px rgba(0,0,0,.22); }
.business-partner-overlay small { color: #fff; font-weight: 850; }
.business-mobile-store-btn { display: none; }
.partner-landing { background: var(--partner-bg, #f6fbff); color: var(--partner-text, var(--text)); }
.partner-landing .btn-primary { background: var(--partner-primary, #4aa3df); color: #fff; }
.partner-landing .pill, .partner-landing .business-tags span { background: color-mix(in srgb, var(--partner-primary, #4aa3df) 15%, #fff); color: var(--partner-primary, #2279b6); }
.partner-landing .partner-module-card, .partner-landing .card { border-color: color-mix(in srgb, var(--partner-primary, #4aa3df) 20%, #d8e8f5); }
.partner-storefront { display: grid; grid-template-columns: 280px minmax(0,1fr); min-height: calc(100vh - 96px); }
.partner-store-sidebar { position: sticky; top: 96px; align-self: start; height: calc(100vh - 96px); overflow: auto; padding: 20px; border-right: 1px solid color-mix(in srgb, var(--partner-primary, #4aa3df) 20%, #d8e8f5); background: color-mix(in srgb, var(--partner-bg, #f6fbff) 82%, #fff); }
.partner-store-brand { display: grid; gap: 10px; color: var(--partner-text, var(--text)); text-decoration: none; margin-bottom: 18px; }
.partner-store-brand img { width: 72px; height: 72px; border-radius: 20px; object-fit: cover; box-shadow: var(--shadow-soft); }
.partner-store-brand strong { display: block; font-size: 21px; line-height: 1.05; }
.partner-store-brand small { display: block; color: var(--muted); margin-top: 4px; font-weight: 800; }
.partner-store-nav { display: grid; gap: 7px; margin: 16px 0; }
.partner-store-nav a { display: flex; align-items: center; min-height: 40px; padding: 9px 11px; border-radius: 13px; color: var(--partner-text, var(--text)); text-decoration: none; font-weight: 950; background: rgba(255,255,255,.68); border: 1px solid transparent; }
.partner-store-nav a:hover { border-color: color-mix(in srgb, var(--partner-primary, #4aa3df) 30%, #fff); background: #fff; color: var(--partner-primary, #2279b6); }
.partner-store-actions { display: grid; gap: 8px; margin-top: 18px; }
.partner-store-main { min-width: 0; }
.partner-store-hero { position: relative; min-height: 430px; display: grid; align-items: end; overflow: hidden; padding: 42px; color: #fff; background: #d9eef8; }
.partner-store-hero::before { content: ""; position: absolute; inset: 0; background-image: var(--banner); background-size: cover; background-position: var(--banner-position, center); transform: scale(1.01); }
.partner-store-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(23,38,56,.08), rgba(23,38,56,.78)); }
.partner-store-hero > div { position: relative; z-index: 1; max-width: 820px; }
.partner-store-hero h1 { color: #fff; font-size: clamp(38px,6vw,76px); margin-bottom: 10px; }
.partner-store-hero p { color: rgba(255,255,255,.9); font-size: 19px; max-width: 680px; }
.partner-store-section { padding: 28px; scroll-margin-top: 96px; }
.partner-store-section > h2 { margin-bottom: 14px; }
.partner-category { border: 1px solid color-mix(in srgb, var(--partner-primary, #4aa3df) 22%, #d8e8f5); border-radius: 18px; background: #fff; box-shadow: var(--shadow-soft); margin-bottom: 10px; overflow: hidden; }
.partner-category summary { display: flex; justify-content: space-between; gap: 12px; padding: 14px 16px; cursor: pointer; font-weight: 950; }
.partner-category summary span { color: var(--partner-primary, #2279b6); }
.partner-category-items { display: flex; flex-wrap: wrap; gap: 8px; padding: 0 16px 16px; }
.partner-category-items a { padding: 7px 10px; border-radius: 999px; background: color-mix(in srgb, var(--partner-primary, #4aa3df) 12%, #fff); color: var(--partner-text, var(--text)); text-decoration: none; font-weight: 850; }
.partner-landing-hero { position: relative; min-height: 420px; display: grid; align-items: end; overflow: hidden; background: #d9eef8; color: #fff; }
.partner-landing-hero::before { content: ""; position: absolute; inset: 0; background-image: var(--banner); background-size: cover; background-position: var(--banner-position, center); filter: saturate(1.05); }
.partner-landing-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(23,38,56,.08), rgba(23,38,56,.78)); }
.partner-hero-inner { position: relative; z-index: 1; display: grid; grid-template-columns: 96px 1fr auto; gap: 18px; align-items: end; padding: 110px 0 34px; }
.partner-hero-logo { width: 96px; height: 96px; border-radius: 24px; object-fit: cover; border: 4px solid rgba(255,255,255,.9); background: #fff; }
.partner-hero-inner h1 { color: #fff; margin-bottom: 6px; }
.partner-hero-inner p { margin: 0; color: rgba(255,255,255,.9); }
.partner-module-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 14px; }
.partner-module-card { padding: 16px; border: 1px solid var(--line); border-radius: 20px; background: #fff; box-shadow: var(--shadow-soft); }
.partner-module-card img { width: 100%; aspect-ratio: 1.35 / 1; object-fit: cover; border-radius: 14px; margin-bottom: 10px; background: #eaf6ff; }
.partner-info-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: 18px; align-items: start; }
.partner-social-band { background: linear-gradient(135deg, var(--partner-primary, #4aa3df), var(--partner-accent, #fff4a8)); }
.business-admin-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.business-admin-tabs a { padding: 9px 12px; border-radius: 999px; border: 1px solid var(--line); text-decoration: none; color: var(--text); font-weight: 900; background: #fff; }
.business-admin-tabs a.active { background: #e8f6ff; color: #2279b6; border-color: #bfe5fb; }
.business-module-placeholder { padding: 18px; border: 1px dashed #b9d6ea; border-radius: 18px; background: #f6fbff; color: var(--muted); }
.lost-card { border-left: 6px solid var(--primary); }
.lost-card.found { border-left-color: var(--sage); }
.lost-card img { width: 100%; aspect-ratio: 1.35 / 1; object-fit: cover; display: block; }
.lost-report-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 14px; }
.lost-card-mini { position: relative; border: 1px solid var(--line); border-left: 5px solid var(--primary); border-radius: 18px; background: rgba(255,255,255,.96); box-shadow: var(--shadow-soft); outline: none; }
.lost-card-mini.found { border-left-color: var(--sage); }
.lost-mini-main { display: grid; grid-template-columns: 82px 1fr; gap: 12px; align-items: center; padding: 12px; min-height: 112px; }
.lost-mini-main img, .lost-mini-photo { width: 82px; height: 82px; border-radius: 14px; object-fit: cover; background: #eaf6ff; }
.lost-mini-photo { display: grid; place-items: center; color: #2279b6; font-size: 28px; font-weight: 950; }
.lost-mini-main h3 { margin: 7px 0 0; font-size: 17px; line-height: 1.15; }
.lost-preview-modal { position: fixed; inset: 0; z-index: 3500; display: grid; place-items: center; padding: 24px; background: rgba(23,38,56,.42); opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .16s ease, visibility .16s ease; }
.lost-card-mini:hover .lost-preview-modal, .lost-card-mini:focus-within .lost-preview-modal { opacity: 1; visibility: visible; }
.lost-preview-card { width: min(920px, 96vw); max-height: 86vh; display: grid; grid-template-columns: minmax(280px,.92fr) 1fr; overflow: auto; border: 1px solid var(--line); border-radius: 24px; background: #fff; box-shadow: var(--shadow); }
.lost-preview-media { min-height: 420px; background: #eaf6ff; }
.lost-preview-media img { width: 100%; height: 100%; min-height: 420px; object-fit: cover; display: block; }
.lost-preview-empty { height: 100%; min-height: 420px; display: grid; place-items: center; color: #2279b6; font-size: 86px; font-weight: 950; }
.lost-preview-info { display: grid; align-content: start; gap: 14px; padding: 24px; }
.lost-preview-info h2 { margin: 0; }
.lost-preview-info p { margin: 0; }
.lost-tech-list { display: grid; gap: 9px; margin: 0; }
.lost-tech-list div { display: grid; grid-template-columns: 112px 1fr; gap: 10px; padding: 9px 0; border-bottom: 1px solid var(--line); }
.lost-tech-list dt { color: var(--muted); font-weight: 850; }
.lost-tech-list dd { margin: 0; font-weight: 850; }
.cta-band { border-radius: 32px; background: linear-gradient(135deg, var(--primary), var(--accent)); color: #213348; padding: 32px; display: flex; align-items: center; justify-content: space-between; gap: 20px; box-shadow: 0 24px 42px rgba(74,163,223,.18); }
.cta-band p { color: rgba(33,51,72,.84); max-width: 720px; }
.cta-band .btn { background: rgba(255,255,255,.94); color: #2279b6; }
.timeline { display: grid; gap: 14px; }
.timeline-item { display: grid; grid-template-columns: 120px 1fr; gap: 18px; background: rgba(255,255,255,.92); border: 1px solid var(--line); border-radius: 24px; padding: 18px; }
.timeline-date { font-weight: 900; color: #2279b6; }
.map-placeholder { min-height: 360px; border-radius: 32px; background: radial-gradient(circle at 20% 20%, #fff4b9, transparent 24%), radial-gradient(circle at 75% 70%, #d7efff, transparent 22%), linear-gradient(135deg, #ffffff, #eaf6ff); border: 1px solid var(--line); position: relative; overflow: hidden; }
.map-pin { position: absolute; display: grid; place-items: center; width: 42px; height: 42px; border-radius: 50%; background: #fff; box-shadow: var(--shadow-soft); color: #2279b6; font-weight: 900; }
.map-pin:nth-child(1){top:22%;left:23%}.map-pin:nth-child(2){top:48%;left:58%}.map-pin:nth-child(3){top:62%;left:36%}
.leaflet-container { position: relative; overflow: hidden; font-family: inherit; touch-action: pan-x pan-y; background: #d9eef8; }
.leaflet-pane, .leaflet-tile, .leaflet-marker-icon, .leaflet-marker-shadow, .leaflet-tile-container, .leaflet-pane > svg, .leaflet-pane > canvas, .leaflet-zoom-box, .leaflet-image-layer, .leaflet-layer { position: absolute; left: 0; top: 0; }
.leaflet-tile, .leaflet-marker-icon, .leaflet-marker-shadow { user-select: none; -webkit-user-drag: none; }
.leaflet-tile { max-width: none !important; max-height: none !important; }
.leaflet-tile-container { pointer-events: none; }
.leaflet-pane { z-index: 400; }
.leaflet-tile-pane { z-index: 200; }
.leaflet-overlay-pane { z-index: 400; }
.leaflet-shadow-pane { z-index: 500; }
.leaflet-marker-pane { z-index: 600; }
.leaflet-tooltip-pane { z-index: 650; }
.leaflet-popup-pane { z-index: 700; }
.leaflet-control { position: relative; z-index: 800; pointer-events: auto; }
.leaflet-top, .leaflet-bottom { position: absolute; z-index: 1000; pointer-events: none; }
.leaflet-top { top: 0; }
.leaflet-right { right: 0; }
.leaflet-bottom { bottom: 0; }
.leaflet-left { left: 0; }
.leaflet-control-zoom a { display: block; width: 34px; height: 34px; line-height: 34px; text-align: center; background: #fff; color: var(--text); text-decoration: none; border-bottom: 1px solid #d8e8f5; font-weight: 900; }
.leaflet-control-zoom { margin: 14px; border-radius: 12px; overflow: hidden; box-shadow: var(--shadow-soft); border: 1px solid var(--line); }
.leaflet-popup { position: absolute; text-align: center; margin-bottom: 20px; }
.leaflet-popup-content-wrapper { background: #fff; border-radius: 16px; box-shadow: var(--shadow); padding: 8px; text-align: left; }
.leaflet-popup-tip-container { width: 40px; height: 20px; position: absolute; left: 50%; margin-left: -20px; overflow: hidden; pointer-events: none; }
.leaflet-popup-tip { width: 17px; height: 17px; padding: 1px; margin: -10px auto 0; transform: rotate(45deg); background: #fff; box-shadow: var(--shadow-soft); }
.leaflet-control-attribution { margin: 0; padding: 4px 8px; background: rgba(255,255,255,.86); font-size: 11px; }
.publish-map-panel[hidden] { display: none; }
.publish-map { min-height: 340px; border-radius: 24px; border: 1px solid var(--line); overflow: hidden; box-shadow: var(--shadow-soft); margin-top: 12px; }
.map-page { padding: 22px 0 0; min-height: calc(100vh - 96px); background: linear-gradient(180deg, #f6fbff, #ffffff); }
.map-toolbar { display: flex; align-items: end; justify-content: space-between; gap: 18px; padding-bottom: 16px; }
.map-toolbar h1 { font-size: clamp(30px,4vw,52px); margin: 0; }
.map-filters { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.map-filters label { display: inline-flex; align-items: center; gap: 8px; min-height: 44px; padding: 10px 14px; border-radius: 999px; background: #fff; border: 1px solid var(--line); font-weight: 900; box-shadow: var(--shadow-soft); cursor: pointer; }
.map-filters input { width: 18px; height: 18px; accent-color: #39a96b; }
.map-shell { padding-bottom: 24px; }
.pet-map { width: 100%; height: min(74vh, 760px); min-height: 540px; border-radius: 28px; border: 1px solid var(--line); overflow: hidden; box-shadow: var(--shadow); background: #eaf6ff; }
.pet-map-pin { position: relative; background: transparent; border: 0; }
.pet-map-pin span { position: absolute; left: 14px; bottom: 0; width: 30px; height: 30px; border-radius: 50% 50% 50% 0; transform: rotate(-45deg); box-shadow: 0 10px 18px rgba(33,51,72,.24); }
.pet-map-pin.perdido span { background: #e84d4f; }
.pet-map-pin.encontrado span { background: #39a96b; }
.pet-map-pin img { position: absolute; left: 4px; top: 0; width: 50px; height: 50px; object-fit: cover; border-radius: 12px; border: 3px solid #fff; box-shadow: 0 12px 22px rgba(33,51,72,.22); }
.map-popup-card { width: 240px; display: grid; gap: 8px; color: var(--text); }
.map-popup-card img { width: 100%; aspect-ratio: 1.45 / 1; object-fit: cover; border-radius: 12px; }
.map-popup-card b { font-size: 16px; }
.map-popup-card span { color: var(--muted); font-weight: 800; }
.map-popup-card p { margin: 0; line-height: 1.35; }
.map-popup-card a { width: fit-content; padding: 9px 12px; border-radius: 999px; background: #fff8c9; color: #6f5b0f; border: 1px solid #f8e58b; text-decoration: none; font-weight: 900; }
.directory-map-page { display: grid; grid-template-columns: minmax(340px, 420px) 1fr; min-height: calc(100vh - 96px); background: #f6fbff; border-top: 1px solid var(--line); }
.directory-panel { overflow: auto; max-height: calc(100vh - 96px); padding: 22px; background: #fff; border-right: 1px solid var(--line); }
.directory-panel h1 { margin: 0 0 14px; font-size: clamp(30px,3.5vw,46px); }
.directory-filters { display: grid; gap: 10px; margin: 14px 0 16px; }
.directory-results { display: grid; gap: 10px; }
.directory-item { display: grid; grid-template-columns: 82px 1fr; gap: 12px; width: 100%; padding: 10px; border-radius: 16px; border: 1px solid var(--line); background: #fff; box-shadow: var(--shadow-soft); text-align: left; cursor: pointer; color: var(--text); }
.directory-item:hover { border-color: #9ed8f8; background: #f6fbff; }
.directory-item img { width: 82px; height: 74px; object-fit: cover; border-radius: 12px; }
.directory-item b { display: block; margin-bottom: 5px; }
.directory-item small { color: var(--muted); font-weight: 800; line-height: 1.35; }
.directory-map-wrap { min-width: 0; padding: 16px; }
.directory-map { width: 100%; height: calc(100vh - 128px); min-height: 620px; border-radius: 24px; overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow); background: #eaf6ff; }
.places-rotate-message { display: none; }
.places-rotate-message div { width: min(100% - 36px, 420px); margin: 36px auto; padding: 24px; border-radius: 24px; border: 1px solid var(--line); background: #fff; box-shadow: var(--shadow-soft); text-align: center; }
.places-rotate-message strong { display: block; font-size: 24px; margin-bottom: 8px; }
.places-rotate-message p { margin: 0; color: var(--muted); }
.business-map-pin span { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 50% 50% 50% 0; transform: rotate(-45deg); background: #4aa3df; color: #fff; border: 3px solid #fff; box-shadow: 0 12px 24px rgba(33,51,72,.26); font-weight: 950; }
.business-map-pin b { transform: rotate(45deg); }
.place-map-pin span { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 50% 50% 50% 0; transform: rotate(-45deg); background: #39a96b; color: #fff; border: 3px solid #fff; box-shadow: 0 12px 24px rgba(33,51,72,.26); font-weight: 950; }
.place-map-pin b { transform: rotate(45deg); }
.place-directory-item { grid-template-columns: 46px 1fr; align-items: center; }
.place-directory-item img { display: none; }
.place-type-dot { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 16px; background: #e8f6ff; color: #2279b6; font-weight: 950; }
.place-popup img { display: none; }
.review-mini-form { display: grid; gap: 7px; margin-top: 8px; }
.review-mini-form input, .review-mini-form select, .review-mini-form textarea { width: 100%; border: 1px solid var(--line); border-radius: 10px; padding: 8px; font: inherit; }
.review-mini-form textarea { min-height: 68px; resize: vertical; }
.review-mini-form button { border: 0; border-radius: 999px; padding: 9px 12px; background: #4aa3df; color: #fff; font-weight: 900; cursor: pointer; }
.event-layout { display: grid; grid-template-columns: minmax(300px, .42fr) minmax(0, .88fr); gap: 18px; align-items: start; }
.event-list-panel { position: sticky; top: 96px; max-height: calc(100vh - 120px); overflow: auto; border: 1px solid var(--line); border-radius: 24px; background: #fff; padding: 18px; box-shadow: var(--shadow-soft); }
.event-list { display: grid; gap: 12px; }
.event-list-item { padding: 14px; border-radius: 18px; border: 1px solid var(--line); background: #f6fbff; }
.event-list-item h3 { font-size: 18px; margin: 9px 0 6px; }
.full-calendar { border: 1px solid var(--line); border-radius: 28px; background: #fff; padding: 18px; box-shadow: var(--shadow); }
.calendar-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 14px; }
.calendar-head h2 { margin: 0; font-size: clamp(24px,3vw,36px); }
.calendar-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 8px; }
.calendar-weekdays { margin-bottom: 8px; }
.calendar-weekdays span { text-align: center; font-weight: 950; color: var(--muted); font-size: 13px; }
.calendar-day { min-height: 112px; min-width: 0; border: 1px solid var(--line); border-radius: 16px; background: #fbfdff; padding: 10px; display: flex; flex-direction: column; align-content: start; gap: 7px; overflow: hidden; }
.calendar-day strong { color: #114b76; }
.calendar-day span { display: -webkit-box; max-width: 100%; padding: 6px 8px; border-radius: 10px; background: #fff8c9; color: #6f5b0f; font-weight: 850; font-size: 11px; line-height: 1.18; overflow: hidden; overflow-wrap: anywhere; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.calendar-day.has-event { border-color: #9ed8f8; background: #eef8ff; }
.calendar-day.is-empty { background: #f3f7fb; border-style: dashed; }
.event-calendar { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.event-card { display: grid; grid-template-columns: 94px 1fr; gap: 16px; align-items: start; padding: 18px; border-radius: 24px; background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-soft); }
.event-date { display: grid; place-items: center; min-height: 92px; border-radius: 20px; background: #e8f6ff; color: #114b76; }
.event-date strong { font-size: 34px; line-height: 1; }
.event-date span { font-weight: 950; }
.event-card h3 { margin: 10px 0 6px; }
.auth-card { max-width: 520px; }
.auth-form { display: grid; gap: 14px; }
.auth-social { display: grid; gap: 10px; margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--line); }
.auth-switch { margin: 18px 0 0; text-align: center; color: var(--muted); }
.auth-switch button { border: 0; background: transparent; color: #2279b6; font-weight: 900; cursor: pointer; text-decoration: underline; }
.modal-backdrop { position: fixed; inset: 0; z-index: 2000; display: grid; place-items: center; padding: 18px; background: rgba(23,38,56,.44); backdrop-filter: blur(4px); }
.modal-backdrop[hidden] { display: none; }
.modal-panel { position: relative; width: min(100%, 620px); max-height: min(760px, 92vh); overflow: auto; border-radius: 28px; background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow); padding: 26px; }
.modal-panel h2 { margin: 0 0 16px; }
.modal-close { position: absolute; top: 14px; right: 14px; width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--line); background: #fff; color: var(--text); font-size: 24px; line-height: 1; cursor: pointer; }
.soft-split { display: grid; grid-template-columns: 1fr .72fr; gap: 18px; align-items: center; padding: 28px; border-radius: 32px; background: rgba(255,255,255,.82); border: 1px solid var(--line); box-shadow: var(--shadow-soft); }
.soft-split p { color: var(--muted); max-width: 680px; }
.mini-list { display: grid; gap: 10px; }
.mini-list a { display: block; padding: 14px 16px; border-radius: 18px; background: #ffffff; border: 1px solid var(--line); text-decoration: none; color: var(--text); font-weight: 900; }
.section-recipes-home { background: linear-gradient(180deg, rgba(255,249,217,.38), rgba(246,251,255,.2)); }
.sponsor-strip { padding: 18px 0 0; background: transparent; }
.sponsor-card { display: grid; grid-template-columns: auto 1fr auto; gap: 18px; align-items: center; padding: 20px; border-radius: 28px; background: linear-gradient(135deg, rgba(255,249,217,.95), rgba(232,246,255,.95)); border: 1px solid var(--line); box-shadow: var(--shadow-soft); }
.sponsor-kicker { align-self: stretch; display: grid; place-items: center; min-width: 118px; padding: 12px 14px; border-radius: 20px; background: #fff; color: #2279b6; font-weight: 950; text-align: center; }
.sponsor-card h2 { font-size: clamp(20px,2vw,28px); margin-bottom: 6px; }
.sponsor-card p { margin: 0; color: var(--muted); }
.admin-shell { display: grid; grid-template-columns: 240px 1fr; min-height: 100vh; }
.admin-nav { background: linear-gradient(180deg, #213348, #172638); color: #fff; padding: 24px; }
.admin-nav a { display: block; color: #d9f0ff; text-decoration: none; padding: 11px 0; }
.admin-main { padding: 28px; }
.admin-title-row { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-bottom: 10px; }
.admin-title-row p { margin: 6px 0 0; color: var(--muted); }
.admin-form { display: grid; gap: 16px; max-width: 900px; }
.admin-form label { display: grid; gap: 8px; color: var(--muted); font-weight: 800; }
.code-sample { overflow: auto; padding: 16px; border: 1px solid var(--line); border-radius: 16px; background: #f6fbff; color: var(--text); }
.table{width:100%;border-collapse:separate;border-spacing:0 10px}.table th{text-align:left;color:var(--muted);font-size:12px;text-transform:uppercase}.table td{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px}.table td:first-child{border-left:1px solid var(--line);border-radius:14px 0 0 14px}.table td:last-child{border-right:1px solid var(--line);border-radius:0 14px 14px 0}
.research-dashboard { display: grid; gap: 12px; margin-top: 18px; }
.research-region, .research-district { border: 1px solid var(--line); border-radius: 18px; background: #fff; box-shadow: var(--shadow-soft); overflow: hidden; }
.research-region > summary, .research-district > summary { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 16px 18px; cursor: pointer; font-weight: 900; }
.research-region summary small { display: block; color: var(--muted); font-weight: 700; margin-top: 2px; }
.research-region[open] > summary, .research-district[open] > summary { background: #f6fbff; }
.research-percent { min-width: 68px; text-align: center; border-radius: 999px; background: #e8f6ff; color: #2279b6; padding: 8px 10px; font-weight: 950; }
.research-progress { height: 10px; background: #eef4fa; overflow: hidden; }
.research-progress span { display: block; height: 100%; background: linear-gradient(90deg, #4aa3df, #83cbb5); }
.research-progress.small { height: 8px; margin: 0 16px 10px; border-radius: 999px; }
.research-districts { display: grid; gap: 10px; padding: 14px; }
.research-district { box-shadow: none; }
.research-district p, .research-region > p { margin: 10px 18px; color: var(--muted); }
.research-actions { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; padding: 0 16px 16px; }
.research-actions form, .research-inline-form { display: grid; grid-template-columns: 1fr auto; gap: 8px; align-items: end; }
.research-actions label { color: var(--muted); font-weight: 800; font-size: 13px; }
.research-actions .select, .research-inline-form .select { min-height: 42px; padding: 8px 10px; border-radius: 12px; }
.research-inline-form { margin: 12px 18px 18px; max-width: 420px; }
.account-section { padding-top: 28px; }
.account-shell { display: grid; grid-template-columns: 260px 1fr; gap: 22px; align-items: start; }
.account-sidebar { position: sticky; top: 92px; display: grid; gap: 8px; padding: 16px; border: 1px solid var(--line); border-radius: 22px; background: rgba(255,255,255,.92); box-shadow: var(--shadow-soft); }
.account-user { display: grid; gap: 2px; padding: 10px 10px 14px; border-bottom: 1px solid var(--line); margin-bottom: 6px; }
.account-user strong { font-size: 18px; line-height: 1.1; }
.account-user span { color: var(--muted); font-size: 13px; overflow-wrap: anywhere; }
.account-sidebar a { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 11px 12px; border-radius: 14px; color: var(--text); text-decoration: none; font-weight: 900; }
.account-sidebar a:hover, .account-sidebar a.active { background: #e8f6ff; color: #2279b6; }
.account-sidebar b { min-width: 28px; text-align: center; padding: 3px 8px; border-radius: 999px; background: #fff5b8; color: #78600c; font-size: 12px; }
.account-main { display: grid; gap: 16px; min-width: 0; }
.account-head { display: flex; align-items: end; justify-content: space-between; gap: 16px; }
.account-head h1 { margin-bottom: 0; }
.account-card-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 14px; }
.account-post-card { display: grid; grid-template-columns: 110px 1fr; min-height: 180px; border: 1px solid var(--line); border-radius: 20px; background: rgba(255,255,255,.95); box-shadow: var(--shadow-soft); overflow: hidden; }
.account-post-card > img { width: 100%; height: 100%; object-fit: cover; background: #eaf6ff; }
.account-post-card:not(:has(> img)) { grid-template-columns: 1fr; }
.account-post-body { display: grid; gap: 8px; padding: 14px; min-width: 0; }
.account-post-body h3 { margin: 0; font-size: 18px; }
.account-post-body p { margin: 0; }
.account-post-top, .account-post-actions { display: flex; flex-wrap: wrap; gap: 7px; align-items: center; }
.account-post-actions { margin-top: 4px; }
.account-post-actions form { margin: 0; }
.account-post-actions .btn { padding: 8px 11px; font-size: 13px; }
.account-edit { margin-top: 4px; border-top: 1px solid var(--line); padding-top: 8px; }
.account-edit summary { cursor: pointer; font-weight: 950; color: #2279b6; }
.compact-form { gap: 10px; margin-top: 10px; }
.compact-form .input, .compact-form textarea { border-radius: 12px; padding: 10px 11px; }
.account-empty { min-height: 220px; }
.account-profile h2 { margin-top: 0; }
@media (min-width: 981px) { .lost-carousel { grid-auto-columns: minmax(220px, 1fr); } }
@media (max-width: 900px) { .site-nav a.nav-stack { flex-direction: row; gap: 4px; line-height: 1.2; min-height: 42px; text-align: left; } .site-nav a.nav-stack span + span::before { content: "/ "; } .feature-list, .quick-grid { grid-template-columns: repeat(2,1fr); } .timeline-item { grid-template-columns: 1fr; } .admin-shell { grid-template-columns: 1fr; } .soft-split, .recipe-detail-grid { grid-template-columns: 1fr; } .sponsor-card { grid-template-columns: 1fr; } .sponsor-kicker { place-items: start; justify-content: start; } .map-toolbar { align-items: flex-start; flex-direction: column; } .pet-map { min-height: 500px; height: 70vh; } .directory-map-page { grid-template-columns: 1fr; } .directory-panel { max-height: none; border-right: 0; border-bottom: 1px solid var(--line); padding: 16px; } .directory-panel h1 { font-size: 32px; margin-bottom: 10px; } .directory-results { gap: 8px; } .directory-map-wrap { padding: 10px; } .directory-map { height: 56vh; min-height: 380px; border-radius: 18px; } .directory-head { align-items: flex-start; flex-direction: column; } .business-directory-layout { grid-template-columns: 1fr; } .business-filter-sidebar { position: static; } .business-filter-bar { grid-template-columns: 1fr 1fr; } .filter-sidebar-head { grid-column: 1 / -1; } .filter-checks { grid-column: 1 / -1; grid-template-columns: 1fr 1fr; } .business-card-grid, .partner-module-grid, .partner-info-grid { grid-template-columns: 1fr; } .business-listing-card { grid-template-rows: 180px 1fr; } .business-mobile-store-btn { display: inline-flex; } .business-partner-overlay { display: none; } .partner-hero-inner { grid-template-columns: 72px 1fr; } .partner-hero-actions { grid-column: 1 / -1; } .partner-hero-logo { width: 72px; height: 72px; border-radius: 18px; } .event-calendar, .event-layout { grid-template-columns: 1fr; } .event-list-panel { position: static; max-height: none; padding: 14px; } .event-list-item { padding: 12px; } .full-calendar { padding: 14px; border-radius: 22px; } .lost-report-grid { grid-template-columns: repeat(2,minmax(0,1fr)); } .lost-preview-card { grid-template-columns: 1fr; } .lost-preview-media, .lost-preview-media img, .lost-preview-empty { min-height: 280px; max-height: 42vh; } }
@media (max-width: 900px) { .partner-storefront { grid-template-columns: 1fr; } .partner-store-sidebar { position: sticky; top: 66px; z-index: 20; height: auto; max-height: 46vh; border-right: 0; border-bottom: 1px solid var(--line); padding: 12px; } .partner-store-brand { grid-template-columns: 48px 1fr; align-items: center; margin-bottom: 10px; } .partner-store-brand img { width: 48px; height: 48px; border-radius: 14px; } .partner-store-brand strong { font-size: 17px; } .partner-store-nav { display: flex; gap: 7px; overflow-x: auto; margin: 10px 0; padding-bottom: 4px; } .partner-store-nav a { white-space: nowrap; min-height: 34px; padding: 7px 10px; font-size: 13px; } .partner-store-actions { grid-template-columns: repeat(2,1fr); margin-top: 10px; } .partner-store-hero { min-height: 340px; padding: 24px; } .partner-store-section { padding: 18px; scroll-margin-top: 210px; } }
@media (max-width: 560px) { .feature-list, .quick-grid { grid-template-columns: 1fr; } .lost-slide { min-height: 330px; } .lost-slide img { min-height: 330px; } .lost-hover-card { display: none; } .carousel-head { align-items: flex-start; } .carousel-controls { display: none; } .soft-split { padding: 16px; } .sponsor-card { padding: 16px; } .publish-map { min-height: 280px; } .pet-map { min-height: 360px; height: 58vh; border-radius: 18px; } .map-popup-card { width: 220px; } .directory-panel { padding: 12px; } .directory-filters { gap: 8px; margin: 10px 0 12px; } .directory-item { grid-template-columns: 58px 1fr; gap: 9px; padding: 8px; border-radius: 14px; } .place-directory-item { grid-template-columns: 42px 1fr; } .place-type-dot { width: 38px; height: 38px; border-radius: 14px; } .directory-item img { width: 58px; height: 54px; border-radius: 10px; } .directory-item b { font-size: 14px; margin-bottom: 2px; } .directory-item small { font-size: 12px; line-height: 1.25; } .directory-map { min-height: 330px; height: 54vh; } .business-filter-bar { grid-template-columns: 1fr; } .filter-checks { grid-template-columns: 1fr; } .business-listing-card { grid-template-rows: 165px 1fr; min-height: 0; } .business-actions .btn { width: 100%; justify-content: center; } .partner-ribbon-diagonal { top: 18px; right: -46px; } .event-card { grid-template-columns: 1fr; } .event-list-panel { padding: 12px; border-radius: 18px; } .event-list { gap: 8px; } .event-list-item { padding: 10px; border-radius: 14px; } .event-list-item h3 { font-size: 16px; margin: 6px 0 4px; } .event-list-item p { margin: 6px 0; font-size: 14px; } .calendar-grid { gap: 4px; } .calendar-weekdays span { font-size: 11px; } .calendar-day { min-height: 66px; padding: 6px; border-radius: 10px; gap: 4px; } .calendar-day strong { font-size: 13px; } .calendar-day span { font-size: 9px; padding: 4px 5px; border-radius: 7px; -webkit-line-clamp: 2; } .calendar-head { align-items: flex-start; flex-direction: column; } .calendar-head .btn { width: 100%; } .lost-report-grid { grid-template-columns: 1fr; } .lost-preview-modal { padding: 12px; } .lost-tech-list div { grid-template-columns: 1fr; gap: 2px; } }
@media (max-width: 900px) and (orientation: portrait) {
  .places-rotate-message { display: block; min-height: calc(100vh - 96px); padding-top: 24px; }
  .places-map-page { display: none; }
}
@media (max-width: 900px) and (orientation: landscape) {
  body:has(.places-map-page) { overflow: hidden; }
  body:has(.places-map-page) .site-header,
  body:has(.places-map-page) .site-footer { display: none; }
  body:has(.places-map-page) main { height: 100dvh; overflow: hidden; }
  .places-rotate-message { display: none; }
  .places-map-page { display: grid; grid-template-columns: 220px 1fr; height: 100dvh; min-height: 0; border-top: 0; }
  .places-map-page .directory-panel { max-height: none; height: 100dvh; overflow: auto; border-right: 1px solid var(--line); border-bottom: 0; padding: 8px; }
  .places-map-page .directory-panel .eyebrow { margin-bottom: 5px; font-size: 10px; letter-spacing: 1.8px; }
  .places-map-page .directory-panel h1 { font-size: 19px; line-height: 1.05; margin-bottom: 6px; }
  .places-map-page .directory-filters { gap: 5px; margin: 6px 0; }
  .places-map-page .directory-filters .input,
  .places-map-page .directory-filters .select { min-height: 34px; padding: 6px 9px; border-radius: 10px; font-size: 14px; line-height: 1.15; }
  .places-map-page .directory-results { max-height: calc(100dvh - 158px); overflow: auto; gap: 5px; }
  .places-map-page .directory-item { grid-template-columns: 34px 1fr; gap: 7px; padding: 6px; border-radius: 11px; }
  .places-map-page .place-type-dot { width: 32px; height: 32px; border-radius: 11px; font-size: 13px; }
  .places-map-page .directory-item b { font-size: 13px; line-height: 1.05; margin-bottom: 1px; }
  .places-map-page .directory-item small { font-size: 11px; line-height: 1.18; }
  .places-map-page .directory-map-wrap { padding: 5px; min-width: 0; }
  .places-map-page .directory-map { height: calc(100dvh - 10px); min-height: 0; border-radius: 12px; }
  .places-map-page .leaflet-control-zoom { margin: 9px; border-radius: 10px; }
  .places-map-page .leaflet-control-zoom a { width: 30px; height: 30px; line-height: 30px; }
}

/* Master admin utilities */
.admin-nav a.active { color: #fff; font-weight: 950; }
.admin-kpi-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin-top: 14px; }
.admin-kpi-grid .kpi { text-decoration: none; color: var(--text); }
.admin-filter-bar { grid-template-columns: minmax(220px, 1fr) repeat(3, minmax(150px, .55fr)) auto auto; margin-bottom: 18px; }
.admin-wide-table { min-width: 980px; }
.admin-main { overflow-x: auto; }
.admin-inline-actions { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; margin: 4px 0; }
.admin-inline-actions .select,
.admin-inline-actions .input { min-height: 38px; padding: 7px 10px; border-radius: 12px; }
.admin-inline-actions .btn { padding: 7px 10px; font-size: 12px; }
.admin-check { display: inline-flex; align-items: center; gap: 6px; padding: 7px 10px; border-radius: 999px; border: 1px solid var(--line); background: #f6fbff; font-weight: 850; }
@media (max-width: 900px) {
  .admin-kpi-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin-filter-bar { grid-template-columns: 1fr; }
  .admin-wide-table { min-width: 840px; }
}
@media (max-width: 560px) {
  .admin-kpi-grid { grid-template-columns: 1fr; }
}
