/*
Theme Name: Doma Najlepšie
Theme URI: https://domanajlepsie.sk
Author: OpenAI
Author URI: https://openai.com
Description: WordPress téma pre mestský návratový portál domanajlepsie.sk
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: domanajlepsie
*/

:root {
  --bg: #f7f5f0;
  --surface: #ffffff;
  --surface-alt: #f0ebe1;
  --text: #1f2933;
  --muted: #5f6c78;
  --line: #e1ddd4;
  --primary: #0f766e;
  --primary-dark: #115e59;
  --accent: #d97706;
  --accent-soft: #fff3e6;
  --success: #166534;
  --danger: #b91c1c;
  --radius-sm: 14px;
  --radius-md: 20px;
  --radius-lg: 28px;
  --shadow: 0 18px 50px rgba(31, 41, 51, .08);
  --container: 1200px;
}

*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a { color: var(--primary); text-decoration: none; }
a:hover { color: var(--primary-dark); }

.site-wrap {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.site-main { flex: 1; }

.container {
  width: min(100% - 2rem, var(--container));
  margin-inline: auto;
}

.section {
  padding: 4.5rem 0;
}

.section-tight {
  padding: 3rem 0;
}

.section h2,
.section h1,
.entry-title {
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.page-header,
.archive-header,
.single-header {
  padding: 3rem 0 1.5rem;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .45rem .9rem;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  font-weight: 700;
  font-size: .9rem;
  margin-bottom: 1rem;
}

.lead {
  font-size: clamp(1.05rem, 1rem + .6vw, 1.3rem);
  color: var(--muted);
  max-width: 62ch;
}

.button,
.wp-block-button__link,
button,
input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .6rem;
  padding: .95rem 1.3rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background: var(--primary);
  color: #fff;
  font-weight: 700;
  cursor: pointer;
  transition: .2s ease;
}

.button:hover,
.wp-block-button__link:hover,
button:hover,
input[type="submit"]:hover {
  transform: translateY(-1px);
  background: var(--primary-dark);
  color: #fff;
}

.button-outline {
  background: transparent;
  border-color: var(--line);
  color: var(--text);
}

.button-outline:hover {
  background: var(--surface);
  color: var(--text);
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 999;
  backdrop-filter: blur(14px);
  background: rgba(247, 245, 240, .86);
  border-bottom: 1px solid rgba(225, 221, 212, .7);
}

.header-inner {
  min-height: 78px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.branding {
  display: flex;
  flex-direction: column;
  gap: .15rem;
}

.site-title {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--text);
}

.site-tagline {
  font-size: .9rem;
  color: var(--muted);
}

.main-navigation ul {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.main-navigation a {
  display: inline-flex;
  padding: .7rem .9rem;
  border-radius: 999px;
  color: var(--text);
  font-weight: 600;
}

.main-navigation a:hover,
.main-navigation .current-menu-item > a {
  background: var(--surface);
  box-shadow: var(--shadow);
}

.hero {
  padding: 5rem 0 4rem;
  background:
    radial-gradient(circle at top right, rgba(217, 119, 6, .08), transparent 25%),
    linear-gradient(180deg, rgba(240, 235, 225, .6), rgba(247, 245, 240, .9));
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.25fr .95fr;
  gap: 2rem;
  align-items: center;
}

.hero-card {
  background: var(--surface);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  box-shadow: var(--shadow);
  border: 1px solid rgba(225,221,212,.65);
}

.hero h1 {
  font-size: clamp(2.3rem, 2rem + 2vw, 4.3rem);
  margin: 0 0 1rem;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  margin-top: 1.5rem;
}

.hero-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .9rem;
  margin-top: 1.5rem;
}

.stat-card {
  background: var(--surface-alt);
  border-radius: var(--radius-md);
  padding: 1rem;
}

.stat-card strong {
  display: block;
  font-size: 1.35rem;
  line-height: 1.1;
}

.hero-checklist,
.feature-list,
.simple-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.hero-checklist li,
.feature-list li,
.simple-list li {
  position: relative;
  padding-left: 1.4rem;
  margin-bottom: .7rem;
}

.hero-checklist li::before,
.feature-list li::before,
.simple-list li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: var(--accent);
  font-weight: 900;
}

.grid-2,
.grid-3,
.grid-4 {
  display: grid;
  gap: 1.2rem;
}

.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.card,
.info-card,
.cta-card,
.archive-card,
.path-step,
.map-layer,
.calc-card,
.story-quote,
.contact-card {
  background: var(--surface);
  border: 1px solid rgba(225,221,212,.8);
  border-radius: var(--radius-md);
  padding: 1.3rem;
  box-shadow: var(--shadow);
}

.info-card h3,
.archive-card h3,
.path-step h3,
.calc-card h3,
.cta-card h3,
.contact-card h3 {
  margin-top: 0;
  margin-bottom: .65rem;
}

.muted { color: var(--muted); }

.badge-row,
.filter-tags,
.meta-row {
  display: flex;
  gap: .55rem;
  flex-wrap: wrap;
  margin-top: 1rem;
}

.badge,
.filter-tag,
.meta-pill {
  display: inline-flex;
  align-items: center;
  padding: .42rem .72rem;
  border-radius: 999px;
  background: var(--surface-alt);
  color: var(--text);
  font-size: .88rem;
  font-weight: 600;
}

.quick-links a {
  display: block;
  height: 100%;
  color: inherit;
}

.quick-links .info-card:hover {
  transform: translateY(-2px);
  transition: .2s ease;
}

.highlight-section {
  background: linear-gradient(180deg, rgba(255,255,255,.5), rgba(240,235,225,.7));
}

.listing-card {
  display: flex;
  flex-direction: column;
  gap: .8rem;
  background: var(--surface);
  border: 1px solid rgba(225,221,212,.8);
  border-radius: var(--radius-md);
  padding: 1.2rem;
  box-shadow: var(--shadow);
}

.listing-card-top {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
}

.listing-card h3 {
  margin: 0;
}

.listing-meta {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: .95rem;
}

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.section-head p {
  margin: 0;
  max-width: 58ch;
  color: var(--muted);
}

.dual-layout {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 1.4rem;
}

.map-box {
  min-height: 420px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(15,118,110,.12), rgba(217,119,6,.08)),
    var(--surface-alt);
  border: 1px solid rgba(225,221,212,.9);
  position: relative;
  box-shadow: var(--shadow);
}

.map-box::before,
.map-box::after {
  content: "";
  position: absolute;
  inset: 12%;
  border: 1px dashed rgba(15,118,110,.25);
  border-radius: 24px;
}
.map-box::after {
  inset: 28%;
  border-color: rgba(217,119,6,.35);
}

.map-pin {
  position: absolute;
  width: 16px;
  height: 16px;
  background: var(--primary);
  border-radius: 999px;
  box-shadow: 0 0 0 6px rgba(15,118,110,.15);
}

.map-pin.pin-1 { top: 20%; left: 30%; }
.map-pin.pin-2 { top: 48%; left: 52%; }
.map-pin.pin-3 { top: 62%; left: 22%; }
.map-pin.pin-4 { top: 35%; left: 70%; }
.map-pin.pin-5 { top: 70%; left: 66%; }

.timeline {
  display: grid;
  gap: 1rem;
}

.path-step-number {
  display: inline-flex;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  align-items: center;
  justify-content: center;
  background: var(--accent-soft);
  color: var(--accent);
  font-weight: 800;
  margin-bottom: 1rem;
}

.story-quote blockquote {
  margin: 0;
  font-size: 1.08rem;
}

.story-quote cite {
  display: block;
  margin-top: 1rem;
  color: var(--muted);
  font-style: normal;
}

.calc-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 1.25rem;
}

.calc-result {
  margin-top: 1rem;
  padding: 1rem;
  border-radius: var(--radius-sm);
  background: var(--surface-alt);
  font-weight: 700;
}

label {
  display: block;
  font-weight: 700;
  margin-bottom: .35rem;
}

input,
select,
textarea {
  width: 100%;
  padding: .85rem 1rem;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: #fff;
  font: inherit;
  color: inherit;
}

textarea { min-height: 150px; resize: vertical; }

.form-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0,1fr));
}

.full-width { grid-column: 1 / -1; }

.site-footer {
  background: #17313a;
  color: rgba(255,255,255,.92);
  padding: 4rem 0 2rem;
  margin-top: 4rem;
}

.site-footer a { color: rgba(255,255,255,.92); }

.footer-grid {
  display: grid;
  grid-template-columns: 1.2fr .8fr .8fr .9fr;
  gap: 1.4rem;
}

.footer-grid h3 {
  margin-top: 0;
  font-size: 1rem;
}

.footer-note {
  margin-top: 2rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.7);
}

.archive-grid,
.post-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.2rem;
}

.archive-card .entry-title,
.post-grid .entry-title {
  font-size: 1.3rem;
  margin-top: 0;
}

.single-layout {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 1.6rem;
}

.single-content,
.single-sidebar {
  background: var(--surface);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(225,221,212,.8);
  box-shadow: var(--shadow);
  padding: 1.5rem;
}

.table-wrap {
  overflow-x: auto;
}

.content-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--surface);
}

.content-table th,
.content-table td {
  padding: .9rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--line);
}

.notice-box {
  padding: 1rem 1.1rem;
  border-radius: var(--radius-sm);
  background: var(--accent-soft);
  border: 1px solid rgba(217,119,6,.18);
}

@media (max-width: 1100px) {
  .hero-grid,
  .dual-layout,
  .single-layout,
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .grid-4,
  .archive-grid,
  .post-grid {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

@media (max-width: 780px) {
  .grid-2,
  .grid-3,
  .grid-4,
  .calc-grid,
  .archive-grid,
  .post-grid,
  .form-grid,
  .hero-stats {
    grid-template-columns: 1fr;
  }

  .header-inner,
  .section-head {
    align-items: start;
    flex-direction: column;
  }

  .main-navigation ul {
    gap: .2rem;
  }

  .hero {
    padding-top: 3.2rem;
  }

  .site-footer {
    margin-top: 3rem;
  }
}

.section-alt {
  background: rgba(240, 235, 225, .55);
}

.current-city-badge,
.current-archive-city,
.current-page-city {
  display: inline-flex;
  margin-top: .45rem;
  padding: .35rem .7rem;
  border-radius: 999px;
  background: rgba(15, 118, 110, .08);
  color: var(--primary);
  font-size: .86rem;
  font-weight: 700;
}

.selector-layout {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 1.4rem;
  margin-top: 2rem;
}

.slovakia-selector-card,
.selector-info-card,
.city-map-placeholder {
  background: var(--surface);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(225,221,212,.75);
  box-shadow: var(--shadow);
}

.slovakia-map-shell {
  position: relative;
  min-height: 520px;
  padding: 1rem;
}

.slovakia-outline {
  width: 100%;
  height: 100%;
}

.slovakia-outline path {
  fill: #efe9dc;
  stroke: #cbbda6;
  stroke-width: 12;
}

.city-marker {
  position: absolute;
  transform: translate(-50%, -50%);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: .3rem;
  color: var(--text);
  font-weight: 700;
}

.city-marker:hover .city-label,
.city-chip:hover,
.city-chip.is-active {
  background: var(--primary);
  color: #fff;
}

.city-dot {
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: var(--accent);
  border: 3px solid #fff;
  box-shadow: 0 8px 20px rgba(0,0,0,.18);
}

.city-label,
.city-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .45rem .8rem;
  border-radius: 999px;
  background: rgba(255,255,255,.95);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  font-size: .9rem;
  transition: .2s ease;
}

.city-list-section {
  padding-top: 0;
}

.city-chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
}

.city-chip-grid.compact {
  gap: .6rem;
}

.path-list {
  margin: 0;
  padding-left: 1.1rem;
}

.path-list li + li {
  margin-top: .65rem;
}

.city-hero {
  padding-top: 4.2rem;
}

.city-hero-grid {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 1.6rem;
  align-items: start;
}

.city-intro-card {
  padding: 1.5rem;
}

.city-anchor-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .7rem;
}

.city-anchor-grid a {
  display: flex;
  justify-content: center;
  padding: .8rem 1rem;
  border-radius: var(--radius-sm);
  background: var(--surface-alt);
  color: var(--text);
  font-weight: 700;
}

.city-anchor-grid a:hover {
  background: var(--primary);
  color: #fff;
}

.city-switcher-strip {
  padding-top: 0;
}

.city-stats-grid {
  margin-top: 1.2rem;
}

.section-heading-row {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.city-map-placeholder {
  padding: 1.5rem;
}

.map-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}

.map-pin-card {
  display: flex;
  flex-direction: column;
  gap: .2rem;
  padding: 1rem;
  border-radius: var(--radius-md);
  background: var(--surface-alt);
}

.cta-card.large {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}

@media (max-width: 1100px) {
  .selector-layout,
  .city-hero-grid,
  .cta-card.large {
    grid-template-columns: 1fr;
    display: grid;
  }

  .map-grid {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

@media (max-width: 780px) {
  .slovakia-map-shell {
    min-height: 430px;
  }

  .city-label {
    font-size: .78rem;
    padding: .35rem .55rem;
  }

  .city-anchor-grid,
  .map-grid {
    grid-template-columns: 1fr;
  }

  .section-heading-row {
    align-items: start;
    flex-direction: column;
  }
}


/* === Modern refresh === */
:root {
  --bg: #f5f7fb;
  --surface: #ffffff;
  --surface-alt: #eef3ff;
  --text: #0f172a;
  --muted: #5b6475;
  --line: #d9e2f1;
  --primary: #2954d1;
  --primary-dark: #1f3fa1;
  --accent: #f59e0b;
  --accent-soft: #fff5dd;
  --shadow: 0 20px 60px rgba(15, 23, 42, .08);
  --shadow-strong: 0 28px 80px rgba(41, 84, 209, .16);
}

body {
  background:
    radial-gradient(circle at top left, rgba(41, 84, 209, .06), transparent 22%),
    radial-gradient(circle at top right, rgba(245, 158, 11, .09), transparent 26%),
    var(--bg);
}

.site-header {
  background: rgba(245, 247, 251, .86);
  border-bottom: 1px solid rgba(217, 226, 241, .85);
}

.modern-header-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1rem;
}

.branding-modern {
  align-items: center;
  flex-direction: row;
  gap: 1rem;
}

.current-city-badge,
.muted-badge {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .5rem .8rem;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  font-size: .9rem;
}

.muted-badge { color: var(--muted); }
.header-cta-wrap { display: flex; justify-content: flex-end; }
.header-cta { white-space: nowrap; }
.hero-modern { padding: 5.5rem 0 4.25rem; }
.hero-grid-modern { gap: 2.4rem; align-items: stretch; }
.hero-modern h1,
.city-hero-modern h1 {
  font-size: clamp(2.8rem, 2rem + 2.4vw, 4.7rem);
  margin-bottom: 1.1rem;
}

.hero-modern .lead,
.city-hero-modern .lead { max-width: 62ch; }
.glass-card {
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.72));
  border: 1px solid rgba(255,255,255,.75);
  box-shadow: var(--shadow-strong);
}

.modern-selector-card,
.modern-card,
.soft-card,
.feature-panel,
.contact-band,
.archive-card,
.info-card,
.contact-card,
.calc-card,
.cta-card,
.map-layer,
.path-step {
  border: 1px solid rgba(217, 226, 241, .95);
  box-shadow: var(--shadow);
}

.modern-card,
.soft-card,
.feature-panel,
.contact-band { background: var(--surface); }
.hero-duo-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.4rem;
}
.audience-card {
  padding: 1.15rem 1.2rem;
  border-radius: 22px;
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(217, 226, 241, .8);
  box-shadow: var(--shadow);
}
.audience-card-alt { background: linear-gradient(180deg, #fffaf0, #ffffff); }
.search-label {
  display: block;
  font-weight: 700;
  margin-bottom: .45rem;
}
.city-search-input,
input[type="text"],
input[type="email"],
input[type="number"],
select,
textarea {
  width: 100%;
  padding: .95rem 1rem;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--text);
  font: inherit;
}

.city-search-input { margin-bottom: 1rem; }
.mini-flow-list {
  display: grid;
  gap: .8rem;
  margin-top: 1rem;
}
.mini-flow-list > div {
  padding: .85rem 1rem;
  border-radius: 18px;
  background: var(--surface-alt);
  color: var(--text);
}
.mini-flow-list.spaced { margin-top: 1.2rem; }
.feature-split-grid { align-items: stretch; gap: 1.4rem; }
.feature-panel {
  padding: 1.6rem;
  border-radius: 26px;
}
.feature-panel-primary { background: linear-gradient(180deg, rgba(41,84,209,.08), #fff); }
.feature-panel-secondary { background: linear-gradient(180deg, rgba(245,158,11,.11), #fff); }
.steps-grid .modern-card,
.summary-grid .summary-card,
.partner-grid .partner-card,
.contact-grid-modern .contact-card,
.calc-grid .modern-card,
.story-card,
.compact-card {
  border-radius: 24px;
}
.step-kicker {
  display: inline-flex;
  width: 2rem;
  height: 2rem;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  font-weight: 800;
  margin-bottom: .8rem;
}
.partner-badge {
  display: inline-flex;
  margin-bottom: .75rem;
  padding: .35rem .7rem;
  border-radius: 999px;
  background: var(--surface-alt);
  color: var(--primary);
  font-size: .84rem;
  font-weight: 700;
}
.text-link { font-weight: 700; color: var(--primary); }
.searchable-city-grid .city-chip {
  display: flex;
  flex-direction: column;
  gap: .2rem;
  min-height: 72px;
  justify-content: center;
}
.searchable-city-grid .city-chip small { color: var(--muted); font-size: .8rem; }
.city-chip.is-active {
  background: var(--primary);
  color: #fff;
  border-color: transparent;
}
.city-chip.is-active small { color: rgba(255,255,255,.85); }
.sticky-lite {
  position: sticky;
  top: 78px;
  z-index: 20;
  backdrop-filter: blur(10px);
  background: rgba(245,247,251,.92);
  border-top: 1px solid rgba(217, 226, 241, .65);
  border-bottom: 1px solid rgba(217, 226, 241, .65);
}
.gap-top-large { margin-top: 1.6rem; }
.grid-1 { display: grid; grid-template-columns: 1fr; gap: 1rem; }
.card-stack { gap: 1rem; }
.compact-card h4 { margin: 0 0 .6rem; }
.quote-bar {
  margin-top: 1rem;
  padding: .85rem 1rem;
  border-left: 4px solid var(--accent);
  background: #fffaf0;
  border-radius: 0 16px 16px 0;
  font-weight: 600;
}
.contact-band {
  padding: 1.6rem 1.8rem;
  border-radius: 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.4rem;
  background: linear-gradient(135deg, rgba(41,84,209,.08), rgba(245,158,11,.08));
}
.final-cta-band { background: linear-gradient(135deg, rgba(41,84,209,.12), rgba(255,255,255,.9)); }
.footer-badges { margin-top: 1rem; }
.small-note { font-size: .87rem; }
.modern-site-footer {
  background: #0f172a;
  color: rgba(255,255,255,.92);
  margin-top: 3rem;
}
.modern-site-footer .muted,
.modern-site-footer a,
.modern-site-footer .footer-note { color: rgba(255,255,255,.75); }
.modern-site-footer .badge {
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.88);
}
.modern-footer-grid { gap: 2rem; padding-top: 3rem; }
.footer-note {
  border-top: 1px solid rgba(255,255,255,.12);
  margin-top: 1.8rem;
  padding: 1.2rem 0 1.6rem;
}
.selector-hero .slovakia-selector-card {
  background: linear-gradient(180deg, rgba(41,84,209,.05), rgba(255,255,255,.95));
  border-radius: 24px;
  padding: 1rem;
}
.selector-hero .slovakia-map-shell { min-height: 410px; }
.slovakia-outline path { fill: #dce6f8; stroke: rgba(41,84,209,.22); stroke-width: 10; }
.city-marker .city-dot {
  width: 14px;
  height: 14px;
  background: var(--primary);
  border: 3px solid #fff;
  box-shadow: 0 0 0 6px rgba(41,84,209,.15);
}
.city-marker:hover .city-dot { transform: scale(1.12); }
.city-marker .city-label {
  background: #fff;
  border: 1px solid rgba(217, 226, 241, .95);
  box-shadow: var(--shadow);
}
.map-box-modern {
  position: relative;
  overflow: hidden;
  min-height: 420px;
  border-radius: 30px;
  background:
    linear-gradient(135deg, rgba(41,84,209,.1), rgba(255,255,255,.9)),
    linear-gradient(180deg, rgba(255,255,255,.65), rgba(238,243,255,.95));
}
.map-overlay-card {
  position: absolute;
  left: 1.25rem;
  bottom: 1.25rem;
  padding: .9rem 1rem;
  border-radius: 18px;
  background: rgba(255,255,255,.92);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  font-weight: 700;
}
.path-step-number {
  background: var(--primary);
  color: #fff;
}
.calc-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.2rem;
}
.calc-result {
  margin-top: 1rem;
  padding: 1rem;
  border-radius: 18px;
  background: var(--surface-alt);
  font-weight: 600;
}
.compact-list li { padding-left: 1.2rem; }
.compact-list li::before { width: .45rem; height: .45rem; top: .62rem; }
@media (max-width: 1100px) {
  .modern-header-inner,
  .hero-grid-modern,
  .modern-city-hero-grid,
  .calc-grid-3 {
    grid-template-columns: 1fr;
  }
  .header-cta-wrap { display: none; }
  .contact-band { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 800px) {
  .hero-duo-cards,
  .grid-2,
  .dual-layout,
  .hero-grid,
  .city-hero-grid,
  .grid-3,
  .grid-4,
  .calc-grid,
  .calc-grid-3 {
    grid-template-columns: 1fr;
  }
  .modern-header-inner { grid-template-columns: 1fr; }
  .branding-modern { flex-direction: column; align-items: flex-start; }
  .main-navigation ul { gap: .25rem; }
  .sticky-lite { position: static; }
}

/* Enhanced sections */
.narrow-container{max-width:980px}
.submission-form{padding:28px;border-radius:24px;background:#fff;box-shadow:0 18px 60px rgba(22,32,62,.08)}
.submission-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.submission-form label{display:block;font-weight:600;margin-bottom:8px}
.submission-form input,.submission-form select,.submission-form textarea{width:100%;padding:14px 16px;border:1px solid #d7dceb;border-radius:14px;background:#f9fbff}
.submission-actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:16px}
.success-box{border-color:#8fd19e;background:#edf9f0}
.generations-grid .info-card h3{margin-bottom:8px}
@media (max-width: 800px){.submission-grid{grid-template-columns:1fr}}


/* 2026 upgrade */
.service-card h3{font-size:1rem;line-height:1.5}
.service-card .partner-badge{margin-bottom:.8rem}
.searchable-city-grid .city-chip small{display:block;margin-top:.15rem;color:var(--muted)}
.current-page-city{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .8rem;border-radius:999px;background:rgba(41,84,209,.08);color:var(--primary);font-weight:700;margin-bottom:1rem}
.archive-card.compact-card{padding:1rem 1.1rem}
.card-stack{display:grid;gap:1rem}
.gap-top-large{margin-top:2rem}
.section-heading-row .muted{max-width:720px}
.feature-split-grid{align-items:start}
.calc-card input[type="text"],.calc-card input[type="number"],.calc-card select{width:100%;padding:12px 14px;border:1px solid #d7dceb;border-radius:14px;background:#f9fbff;margin:.35rem 0 .9rem}
.calc-card button{width:100%;margin-top:.3rem}
.section .page-header{margin-bottom:1.5rem}
.hero-modern .hero-card,.city-hero-modern .hero-card{backdrop-filter:blur(10px)}
.hero-modern .audience-card p,.city-hero-modern .hero-card p{margin-bottom:0}
.simple-list{margin:0;padding-left:0;list-style:none}
.simple-list li{position:relative;padding-left:1rem;margin-bottom:.6rem}
.simple-list li::before{content:"";position:absolute;left:0;top:.55rem;width:.38rem;height:.38rem;border-radius:50%;background:var(--primary)}
