:root {
  --brand-orange:#ff5533; --brand-orange-deep:#d9411d; --brand-navy:#070b18;
  --pitch-green:#19b86a; --action-blue:#2f9dff;
  --bg:var(--brand-navy); --card:#111b33; --card2:#17233f; --border:rgba(255,255,255,.10); --border2:rgba(255,255,255,.18);
  --text:#f8fbff; --sub:#c3cee4; --muted:#8f9cb7; --A:var(--brand-orange);
  --font-display:'Barlow Condensed',sans-serif; --font-body:'Barlow',sans-serif;
}
* { box-sizing:border-box; margin:0; padding:0; }
body {
  min-height:100dvh; background:var(--bg); color:var(--text); font-family:var(--font-body);
  display:flex; justify-content:center;
}
body::after {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 70% 40% at 15% 0%, rgba(255,85,51,.10) 0%, transparent 65%),
    radial-gradient(ellipse 60% 35% at 85% 100%, rgba(25,184,106,.10) 0%, transparent 65%),
    linear-gradient(90deg, rgba(25,184,106,.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(25,184,106,.035) 1px, transparent 1px);
  background-size:auto, auto, 28px 28px, 28px 28px;
}
.wrap { width:100%; max-width:560px; padding:24px 14px 152px; position:relative; z-index:1; }
.brand { font-family:var(--font-display); font-size:24px; font-weight:900; display:flex; align-items:center; gap:8px; margin-bottom:24px; }
.brand img { width:32px; height:32px; border-radius:8px; background:var(--A); box-shadow:0 8px 18px rgba(255,85,51,.22); }
.brand em { color:var(--A); font-style:normal; }
.title { font-family:var(--font-display); font-size:32px; font-weight:900; line-height:1; margin-bottom:8px; }
.sub { font-size:13px; color:var(--sub); margin-bottom:20px; }
.public-ad-slot {
  width:100%; margin:0 0 16px; cursor:pointer; color:var(--text);
  background:linear-gradient(135deg,rgba(255,85,51,.12),rgba(25,184,106,.08));
  border:1.5px solid rgba(255,255,255,.14); border-radius:16px;
  overflow:hidden; box-shadow:0 10px 28px rgba(0,0,0,.22);
}
.public-ad-slot:active { opacity:.86; }
.public-ad-slot:focus { outline:2px solid rgba(255,204,0,.65); outline-offset:3px; }
.public-ad-inner {
  min-height:72px; display:flex; align-items:center; gap:12px;
  padding:12px 14px;
}
.public-ad-badge {
  width:42px; height:42px; border-radius:12px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
  font-family:var(--font-display); font-size:18px; font-weight:900;
  overflow:hidden;
}
.public-ad-badge img { width:100%; height:100%; object-fit:contain; }
.public-ad-copy { flex:1; min-width:0; }
.public-ad-name {
  font-family:var(--font-display); font-size:20px; font-weight:900;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.public-ad-tag {
  font-size:12px; color:var(--sub); white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.public-ad-label {
  font-size:9px; color:var(--muted); letter-spacing:1.2px; font-weight:800;
  white-space:nowrap;
}
.public-ad-banner { padding:0; position:relative; min-height:76px; }
.public-ad-banner img { display:block; width:100%; height:100%; min-height:76px; object-fit:cover; }
.public-ad-banner .public-ad-label {
  position:absolute; right:10px; bottom:8px; padding:3px 7px; border-radius:999px;
  background:rgba(0,0,0,.5); color:#fff;
}
.search {
  width:100%; padding:14px 16px; border-radius:14px; border:1.5px solid var(--border2);
  background:var(--card); color:var(--text); font-size:16px; outline:none; margin-bottom:14px;
}
.search:focus { border-color:var(--A); }
.meta { font-size:11px; color:var(--muted); letter-spacing:1px; margin-bottom:10px; }
.list { display:flex; flex-direction:column; gap:10px; }
.item {
  display:grid; grid-template-columns:1fr auto; align-items:center; gap:8px 12px; padding:14px 16px; color:var(--text);
  background:var(--card); border:1.5px solid var(--border); border-radius:16px;
  box-shadow:0 10px 24px rgba(0,0,0,.14);
}
.item:active { opacity:.85; }
.item-main {
  min-width:0; display:flex; align-items:center; gap:12px; color:var(--text); text-decoration:none;
}
.logo {
  width:46px; height:46px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center;
  background:var(--card2); border:1.5px solid var(--border2); overflow:hidden;
  font-family:var(--font-display); font-size:14px; font-weight:900;
}
.logo.light-logo { color:#111827; border-color:rgba(0,0,0,.18); }
.logo img { width:100%; height:100%; object-fit:cover; }
.info { flex:1; min-width:0; }
.name { font-family:var(--font-display); font-size:18px; font-weight:800; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.slug { font-size:11px; color:var(--sub); margin-top:2px; }
.org-place { font-size:11px; color:var(--sub); margin-top:3px; }
.map-link {
  grid-column:1 / -1; margin-left:58px; color:var(--A); font-size:12px; line-height:1.35;
  text-decoration:none; overflow-wrap:anywhere;
}
.map-link:hover { text-decoration:underline; }
.item-action {
  align-self:center; color:#fff; background:linear-gradient(135deg,var(--A),var(--brand-orange-deep)); text-decoration:none;
  border-radius:12px; padding:10px 12px;
  font-family:var(--font-display); font-size:13px; font-weight:900; letter-spacing:.8px;
  white-space:nowrap;
}
.item-action:active { opacity:.85; }
.empty {
  text-align:center; color:var(--muted); padding:24px 18px; font-size:13px;
  background:var(--card); border:1px dashed var(--border); border-radius:16px;
}
.cta {
  position:fixed; left:0; right:0; bottom:0; z-index:5; display:flex; justify-content:center;
  background:linear-gradient(to top, var(--bg) 70%, transparent); padding:16px 14px 20px;
}
.cta-inner {
  max-width:560px; width:100%;
  display:flex; flex-direction:column; gap:10px;
}
.cta-back-btn {
  width:100%; text-align:center; text-decoration:none;
  color:var(--text); background:var(--card);
  border:1.5px solid var(--border2);
  border-radius:14px; padding:14px 18px;
  font-family:var(--font-display); font-size:16px; font-weight:800; letter-spacing:.9px;
}
.cta a {
  width:100%; text-align:center; text-decoration:none; color:#fff; background:var(--A);
  border-radius:14px; padding:14px; font-family:var(--font-display); font-size:17px; font-weight:900; letter-spacing:1px;
}

@media (max-width: 380px) {
  .item { grid-template-columns:1fr; }
  .item-action { width:100%; text-align:center; }
  .map-link { margin-left:0; }
}

