/*
Theme Name: Radlrouten Planer
Theme URI: https://example.com/
Author: OpenAI
Description: WordPress-Theme für Kartenansicht, Routenplanung, Touren, POIs und Unterkünfte – inspiriert vom hochgeladenen Radl-Route-Finder-Projekt.
Version: 2.0.0
Requires at least: 6.4
Tested up to: 6.6
Requires PHP: 8.0
Text Domain: radlrouten-planer
*/

:root {
  --rrp-primary: #16a34a;
  --rrp-primary-dark: #15803d;
  --rrp-primary-soft: #dcfce7;
  --rrp-accent: #0f172a;
  --rrp-bg: #f5f7fb;
  --rrp-surface: #ffffff;
  --rrp-surface-soft: #f8fafc;
  --rrp-border: #e2e8f0;
  --rrp-text: #0f172a;
  --rrp-muted: #64748b;
  --rrp-red: #ef4444;
  --rrp-orange: #f59e0b;
  --rrp-blue: #2563eb;
  --rrp-purple: #7c3aed;
  --rrp-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
  --rrp-shadow-soft: 0 8px 24px rgba(15, 23, 42, 0.06);
  --rrp-radius: 24px;
  --rrp-radius-sm: 16px;
  --rrp-container: 1280px;
  --rrp-surface-2: #f8fafc;
  --rrp-success: #16a34a;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--rrp-text);
  background:
    radial-gradient(circle at top left, rgba(22,163,74,.08), transparent 30%),
    linear-gradient(180deg, #f8fbff 0%, #f5f7fb 100%);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.55;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; }
button, input, textarea, select { font: inherit; }
.site-main, .site-footer-inner, .site-header-inner, .rrp-container { max-width: var(--rrp-container); margin: 0 auto; }
.site-header {
  position: sticky; top: 0; z-index: 99; backdrop-filter: blur(14px);
  background: rgba(245,247,251,.8); border-bottom: 1px solid rgba(226,232,240,.75);
}
.site-header-inner { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:16px 20px; }
.brand-box, .main-nav-box, .menu-toggle {
  background:#fff; border-radius:20px; box-shadow: var(--rrp-shadow-soft); border:1px solid rgba(226,232,240,.95);
}
.brand-box { padding:12px 18px; min-width: 180px; display:flex; align-items:center; }
.site-title { font-size: 1.1rem; font-weight: 800; }
.site-tagline { color: var(--rrp-muted); font-size: .84rem; }
.main-nav-box { padding: 7px 12px; flex: 1; }
.main-nav ul, .footer-nav ul, .mobile-nav ul { list-style:none; display:flex; gap:8px; margin:0; padding:0; flex-wrap:wrap; }
.main-nav a, .footer-nav a, .mobile-nav a { display:inline-flex; padding:10px 14px; border-radius:14px; color:var(--rrp-muted); font-weight:600; }
.main-nav a:hover, .footer-nav a:hover, .mobile-nav a:hover, .main-nav .current-menu-item > a, .mobile-nav .current-menu-item > a { background: #f1f5f9; color: var(--rrp-text); }
.menu-toggle { padding: 12px 16px; cursor:pointer; border:none; font-weight:800; }
.mobile-panel {
  position: fixed; inset: 86px 14px auto 14px; background: rgba(255,255,255,.98); border:1px solid var(--rrp-border);
  border-radius: 24px; box-shadow: var(--rrp-shadow); padding: 18px; display:none; z-index: 98;
}
.rrp-mobile-open .mobile-panel { display:block; }
.site-content { padding: 28px 20px 64px; }
.hero-grid { display:grid; grid-template-columns: 1.12fr .88fr; gap:24px; align-items:stretch; }
.hero-card, .panel, .archive-card, .single-card, .planner-card, .glass-card {
  background: var(--rrp-surface); border:1px solid var(--rrp-border); border-radius: var(--rrp-radius); box-shadow: var(--rrp-shadow);
}
.hero-card { padding: 30px; }
.hero-card h1 { font-size: clamp(2.2rem, 4vw, 3.6rem); line-height:1.02; margin:0 0 16px; letter-spacing:-0.04em; }
.muted { color: var(--rrp-muted); }
.button, button, input[type="submit"] {
  background: var(--rrp-primary); color:#fff; border:none; border-radius:16px; padding:12px 18px; font-weight:700; cursor:pointer;
  transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
}
.button:hover, button:hover, input[type="submit"]:hover { background: var(--rrp-primary-dark); transform: translateY(-1px); }
.button.secondary { background:#fff; color:var(--rrp-text); border:1px solid var(--rrp-border); }
.button.ghost { background:#f1f5f9; color: var(--rrp-text); }
.button-row { display:flex; flex-wrap:wrap; gap:12px; margin-top:18px; }
.stats-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:14px; margin-top:22px; }
.stat-box { padding:18px; border-radius:20px; background:#f8fafc; border:1px solid var(--rrp-border); }
.stat-box strong { display:block; font-size:1.5rem; }
.map-shell { display:grid; grid-template-columns: 360px 1fr; gap:20px; min-height: 74vh; }
.map-sidebar { padding:20px; background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,252,.96)); }
.map-stage { position:relative; overflow:hidden; min-height: 74vh; }
#rrp-map, .rrp-mini-map { width:100%; height:100%; min-height:74vh; border-radius: var(--rrp-radius); }
.map-floating-search {
  position:absolute; top:20px; left:20px; right:20px; z-index:500; display:flex; gap:12px; flex-wrap:wrap;
}
.map-floating-search input {
  flex: 1; min-width: 220px; border:1px solid var(--rrp-border); border-radius:16px; padding:14px 16px; box-shadow: var(--rrp-shadow-soft);
}
.filter-chips, .tag-list, .legend-list { display:flex; gap:10px; flex-wrap:wrap; }
.filter-chip { padding:9px 13px; background:#f1f5f9; border:1px solid var(--rrp-border); color:var(--rrp-text); border-radius:999px; font-weight:700; cursor:pointer; }
.filter-chip.active { background:var(--rrp-primary); color:#fff; border-color:var(--rrp-primary); }
.poi-list, .archive-grid, .feature-stack, .detail-grid { display:grid; gap:14px; }
.poi-item, .archive-card, .detail-card { padding:18px; }
.poi-item, .detail-card { border:1px solid var(--rrp-border); border-radius:18px; background:#fff; cursor:pointer; }
.poi-item:hover, .archive-card:hover { transform: translateY(-2px); }
.poi-meta { font-size:.92rem; color:var(--rrp-muted); }
.section-title { font-size:1.65rem; margin:0 0 14px; letter-spacing:-0.03em; }
.cards-3 { display:grid; grid-template-columns: repeat(3,1fr); gap:18px; }
.feature-card { padding:24px; }
.badge { display:inline-flex; padding:6px 10px; border-radius:999px; background:#dcfce7; color:#166534; font-size:.82rem; font-weight:800; }
.type-badge { display:inline-flex; padding:6px 10px; border-radius:999px; font-size:.75rem; font-weight:800; }
.type-ebike-ladestation,.type-ebike_ladestation { background:#fee2e2; color:#991b1b; }
.type-service-station,.type-service_station { background:#dbeafe; color:#1d4ed8; }
.type-parkplatz { background:#fef3c7; color:#92400e; }
.type-accommodation { background:#ede9fe; color:#6d28d9; }
.type-tour { background:#dcfce7; color:#166534; }
.grid-2 { display:grid; grid-template-columns: 1fr 1fr; gap:20px; }
.archive-grid { grid-template-columns: repeat(3, 1fr); }
.archive-card h3 { margin: 10px 0 6px; }
.single-card { padding: 28px; }
.meta-line { display:flex; flex-wrap:wrap; gap:14px; color:var(--rrp-muted); font-size:.95rem; margin-bottom:18px; }
.form-grid { display:grid; grid-template-columns: 1fr 1fr; gap:14px; }
.form-grid .full { grid-column: 1 / -1; }
label { display:block; font-weight:700; margin-bottom:6px; }
input[type="text"], input[type="email"], input[type="number"], input[type="file"], textarea, select {
  width:100%; border:1px solid var(--rrp-border); border-radius:16px; padding:12px 14px; background:#fff; color:var(--rrp-text);
}
textarea { min-height: 120px; resize: vertical; }
.notice { padding:14px 16px; border-radius:14px; margin-bottom:16px; }
.notice.success { background:#dcfce7; color:#166534; }
.notice.error { background:#fee2e2; color:#991b1b; }
.footer-cta { margin-top: 40px; padding: 26px; }
.site-footer { padding: 0 20px 30px; }
.site-footer-inner { padding: 26px; }
.footer-bottom { margin-top:16px; padding-top:14px; border-top:1px solid var(--rrp-border); display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap; color:var(--rrp-muted); }
.planner-layout { display:grid; grid-template-columns: 430px 1fr; gap:20px; min-height: 76vh; }
.planner-card { padding:22px; }
.route-summary { display:grid; grid-template-columns: repeat(3,1fr); gap:12px; margin-top:16px; }
.route-summary div { background:#f8fafc; border:1px solid var(--rrp-border); border-radius:16px; padding:14px; }
.waypoint-item { padding:14px; border:1px solid var(--rrp-border); border-radius:18px; margin-bottom:12px; background:#fff; }
.leaflet-popup-content-wrapper { border-radius: 16px; }
.leaflet-popup-content { margin: 14px 16px; }
.rrp-icon { display:flex; align-items:center; justify-content:center; width:18px; height:18px; border-radius:999px; border:2px solid #fff; box-shadow:0 3px 10px rgba(0,0,0,.15); }
.rrp-icon.rrp-poi-ebike,.legend-ebike { background: var(--rrp-red); }
.rrp-icon.rrp-poi-service,.legend-service { background: var(--rrp-blue); }
.rrp-icon.rrp-poi-parkplatz,.legend-parkplatz { background: var(--rrp-orange); }
.rrp-icon.rrp-accommodation,.legend-accommodation { background: var(--rrp-purple); }
.rrp-icon.rrp-tour,.legend-tour { background: var(--rrp-primary); }
.legend-dot { width: 12px; height: 12px; border-radius:999px; display:inline-block; }
@media (max-width: 1100px) {
  .hero-grid, .map-shell, .planner-layout, .grid-2, .archive-grid, .cards-3 { grid-template-columns: 1fr; }
  .main-nav-box { display:none; }
}
@media (max-width: 640px) {
  .site-header-inner, .site-content, .site-footer { padding-left:14px; padding-right:14px; }
  .stats-grid, .route-summary, .form-grid { grid-template-columns: 1fr; }
  .brand-box { min-width: auto; }
  .hero-card, .panel, .archive-card, .single-card, .planner-card { border-radius: 20px; }
  .mobile-panel { inset: 82px 12px auto 12px; }
}


.page-shell { display:grid; gap:24px; }
.page-hero { padding:28px; display:grid; gap:18px; }
.page-hero.compact { grid-template-columns: 1.15fr .85fr; align-items:start; }
.page-kicker { display:inline-flex; padding:6px 12px; border-radius:999px; background:var(--rrp-primary-soft); color:var(--rrp-primary-dark); font-weight:800; font-size:.8rem; }
.page-title { font-size: clamp(2rem, 4vw, 3rem); line-height:1.02; margin:0; letter-spacing:-0.04em; }
.page-subtitle { color: var(--rrp-muted); max-width: 70ch; }
.metric-grid { display:grid; grid-template-columns: repeat(4,1fr); gap:14px; }
.metric-card { background:linear-gradient(180deg,#fff,var(--rrp-surface-2)); border:1px solid var(--rrp-border); border-radius:20px; padding:18px; }
.metric-card strong { display:block; font-size:1.4rem; }
.content-grid { display:grid; grid-template-columns: minmax(0,1fr) 320px; gap:24px; }
.stacked-cards { display:grid; gap:14px; }
.list-card { padding:20px; border:1px solid var(--rrp-border); border-radius:22px; background:#fff; box-shadow: var(--rrp-shadow-soft); }
.list-card:hover { transform:translateY(-2px); }
.list-card-media { aspect-ratio: 16/8; overflow:hidden; border-radius:18px; margin:-4px -4px 14px; background:#e2e8f0; }
.list-card-media img { width:100%; height:100%; object-fit:cover; display:block; }
.list-card-head { display:flex; align-items:flex-start; justify-content:space-between; gap:14px; }
.meta-pills { display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; }
.meta-pill { display:inline-flex; padding:7px 10px; border-radius:999px; background:#f8fafc; border:1px solid var(--rrp-border); color:var(--rrp-muted); font-size:.82rem; font-weight:700; }
.side-panel { padding:22px; }
.side-panel ul { margin:0; padding-left:18px; color:var(--rrp-muted); }
.side-panel li + li { margin-top:8px; }
.empty-state { text-align:center; padding:32px 20px; color:var(--rrp-muted); border:1px dashed var(--rrp-border); border-radius:20px; }
.template-map { min-height: 60vh; border-radius:24px; overflow:hidden; }
.info-grid-2 { display:grid; grid-template-columns: repeat(2,1fr); gap:18px; }
.profile-grid { display:grid; grid-template-columns: 320px minmax(0,1fr); gap:24px; }
.profile-card { padding:24px; }
.avatar-circle { width:86px; height:86px; border-radius:999px; display:grid; place-items:center; background:var(--rrp-primary-soft); color:var(--rrp-primary-dark); font-size:2rem; font-weight:800; }
.login-prompt { padding:28px; text-align:center; }
.admin-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:16px; }
.admin-box { background:#fff; border:1px solid var(--rrp-border); border-radius:20px; padding:18px; box-shadow: var(--rrp-shadow-soft); }
.rrp-admin-wrap { max-width: 1220px; margin-top: 20px; }
.rrp-admin-hero { background: linear-gradient(135deg, rgba(22,163,74,.12), rgba(37,99,235,.06)); border:1px solid var(--rrp-border); border-radius:24px; padding:24px; margin-bottom:20px; }
.rrp-admin-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:16px; }
.rrp-admin-card { background:#fff; border:1px solid var(--rrp-border); border-radius:20px; padding:18px; box-shadow: var(--rrp-shadow-soft); }
.rrp-admin-card h3 { margin-top:0; }
.rrp-admin-form { background:#fff; border:1px solid var(--rrp-border); border-radius:24px; padding:24px; box-shadow: var(--rrp-shadow-soft); }
.rrp-admin-form .form-table th { width:240px; }
.rrp-admin-swatch { width:36px; height:36px; border-radius:12px; border:1px solid var(--rrp-border); display:inline-block; vertical-align:middle; margin-right:10px; }
@media (max-width: 1100px) {
  .content-grid, .profile-grid, .page-hero.compact, .info-grid-2, .metric-grid, .admin-grid, .rrp-admin-grid { grid-template-columns:1fr; }
}

/* --- v1.3 app-like refresh --- */
:root {
  --rrp-primary-soft: #e7f8ee;
  --rrp-accent-soft: #fff4e7;
  --rrp-frost: rgba(255,255,255,.78);
  --rrp-frost-border: rgba(255,255,255,.58);
  --rrp-shadow-app: 0 20px 60px rgba(15, 23, 42, .14);
}
body {
  background:
    radial-gradient(circle at 0% 0%, rgba(22,163,74,.10), transparent 24%),
    radial-gradient(circle at 100% 0%, rgba(245,158,11,.10), transparent 24%),
    linear-gradient(180deg, #f7fbf8 0%, #f2f7f5 100%);
}
.site-header {
  background: rgba(247,251,248,.72);
  border-bottom: 1px solid rgba(226,232,240,.55);
  box-shadow: 0 8px 28px rgba(15,23,42,.04);
}
.site-header-inner { padding: 14px 20px; }
.brand-box, .main-nav-box, .menu-toggle {
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(255,255,255,.65);
  box-shadow: 0 10px 32px rgba(15,23,42,.08);
  backdrop-filter: blur(18px);
}
.main-nav a, .footer-nav a, .mobile-nav a {
  padding: 11px 15px;
  border-radius: 999px;
}
.main-nav a:hover, .footer-nav a:hover, .mobile-nav a:hover, .main-nav .current-menu-item > a, .mobile-nav .current-menu-item > a {
  background: var(--rrp-primary-soft);
  color: var(--rrp-primary-dark);
}
.hero-card, .panel, .archive-card, .single-card, .planner-card, .glass-card {
  border-color: rgba(226,232,240,.7);
  box-shadow: var(--rrp-shadow-app);
}
.glass-card {
  background: var(--rrp-frost);
  border: 1px solid var(--rrp-frost-border);
  backdrop-filter: blur(18px);
}
.button, button, input[type="submit"] {
  border-radius: 999px;
  box-shadow: 0 8px 20px rgba(22,163,74,.18);
}
.button.secondary {
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(14px);
}
.badge, .page-kicker {
  background: var(--rrp-primary-soft);
  color: var(--rrp-primary-dark);
}
.filter-chip, .app-filter-chip {
  border-radius: 999px;
  box-shadow: 0 8px 22px rgba(15,23,42,.08);
}
.list-card, .poi-item, .quick-link-card {
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.list-card:hover, .poi-item:hover, .quick-link-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 34px rgba(15,23,42,.10);
  border-color: rgba(22,163,74,.18);
}
.app-map-page { margin-top: -8px; }
.app-map-shell {
  position: relative;
  min-height: calc(100vh - 170px);
  display: grid;
  grid-template-columns: minmax(320px, 390px) 1fr;
  gap: 18px;
}
.app-map-sidepanel {
  position: relative;
  z-index: 4;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 78vh;
}
.app-panel-head h1 {
  margin: 10px 0 10px;
  font-size: clamp(1.8rem, 2.2vw, 2.5rem);
  line-height: 1.02;
  letter-spacing: -.04em;
}
.metric-stack {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 14px;
}
.metric-pill {
  padding: 12px 10px;
  border-radius: 18px;
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(255,255,255,.7);
  text-align: center;
}
.metric-pill strong { display: block; font-size: 1.2rem; }
.metric-pill span { color: var(--rrp-muted); font-size: .8rem; }
.app-map-stage {
  position: relative;
  min-height: 78vh;
  overflow: hidden;
  border-radius: 32px;
  background: linear-gradient(180deg, rgba(255,255,255,.78), rgba(248,250,252,.72));
}
.rrp-map-fullscreen, .app-map-stage #rrp-map {
  min-height: 78vh;
  height: 100%;
  border-radius: 32px;
}
.app-map-topbar {
  position: absolute;
  top: 18px;
  left: 408px;
  right: 18px;
  z-index: 5;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px;
}
.app-map-search {
  position: relative;
  flex: 1;
}
.app-map-search input {
  width: 100%;
  height: 54px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.72);
  background: rgba(255,255,255,.9);
  padding: 0 18px 0 46px;
  box-shadow: 0 12px 30px rgba(15,23,42,.08);
}
.app-map-search-icon {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--rrp-muted);
  font-size: 1.1rem;
}
.app-map-actions { display:flex; gap:10px; flex-wrap: wrap; }
.app-filter-rail {
  position: absolute;
  top: 92px;
  left: 408px;
  right: 18px;
  z-index: 5;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.app-filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border: 1px solid rgba(255,255,255,.66);
  background: rgba(255,255,255,.84);
  backdrop-filter: blur(14px);
  font-weight: 700;
}
.app-filter-chip strong {
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(22,163,74,.10);
  color: var(--rrp-primary-dark);
  font-size: .82rem;
}
.app-filter-chip.active {
  background: rgba(22,163,74,.92);
  color: #fff;
  border-color: rgba(22,163,74,.92);
}
.app-filter-chip.active strong {
  background: rgba(255,255,255,.2);
  color: #fff;
}
.chip-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  display: inline-block;
}
.app-map-results {
  display: grid;
  gap: 12px;
  overflow: auto;
  max-height: 52vh;
  padding-right: 4px;
}
.app-map-results .poi-item {
  padding: 16px;
  border-radius: 22px;
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(10px);
}
.app-quick-links {
  display: grid;
  gap: 10px;
}
.quick-link-card {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border-radius: 22px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(255,255,255,.78);
}
.quick-link-card strong { display:block; margin-bottom:2px; }
.quick-link-card span:last-child, .quick-link-card div span { color: var(--rrp-muted); font-size: .92rem; }
.quick-link-icon {
  display:flex; align-items:center; justify-content:center;
  width:44px; height:44px; border-radius:16px;
  background: linear-gradient(180deg, var(--rrp-primary-soft), #fff);
}
.compact-legend { font-size: .87rem; }
.app-map-bottom-dock {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 18px;
  z-index: 5;
  display: flex;
  gap: 10px;
  padding: 10px;
  border-radius: 999px;
}
.app-map-bottom-dock a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 92px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.82);
  font-weight: 700;
}
.app-map-bottom-dock a:hover { background: var(--rrp-primary-soft); color: var(--rrp-primary-dark); }
.rrp-map-controls {
  position: absolute;
  right: 16px;
  bottom: 90px;
  z-index: 450;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.rrp-map-control-btn {
  width: 42px;
  height: 42px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.8);
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(12px);
  box-shadow: 0 8px 22px rgba(15,23,42,.12);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  font-weight: 800;
}
.rrp-layer-picker {
  position: absolute;
  left: 16px;
  bottom: 90px;
  z-index: 450;
}
.rrp-layer-menu {
  display: none;
  margin-bottom: 8px;
  padding: 10px;
  border-radius: 24px;
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(16px);
  box-shadow: 0 14px 34px rgba(15,23,42,.14);
}
.rrp-layer-menu.open { display: grid; gap: 6px; }
.rrp-layer-menu button,
.rrp-layer-toggle {
  min-width: 148px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.82);
  color: var(--rrp-text);
  border: 1px solid rgba(226,232,240,.8);
  box-shadow: none;
}
.rrp-layer-menu button.active { background: var(--rrp-primary); color:#fff; }
.rrp-mobile-dock {
  display:none;
}
@media (max-width: 1100px) {
  .app-map-shell { grid-template-columns: 1fr; }
  .app-map-topbar, .app-filter-rail { left: 18px; }
  .app-map-sidepanel { min-height: auto; order: 2; }
  .app-map-stage { order: 1; min-height: 72vh; }
}
@media (max-width: 780px) {
  .site-content { padding-top: 18px; }
  .app-map-topbar {
    position: relative;
    top: 0; left: 0; right: 0;
    padding: 0;
    background: transparent;
    box-shadow: none;
    border: 0;
    backdrop-filter: none;
    flex-direction: column;
    align-items: stretch;
  }
  .app-filter-rail {
    position: relative;
    top: 0; left: 0; right: 0;
    overflow: auto;
    flex-wrap: nowrap;
    padding-bottom: 4px;
  }
  .app-map-sidepanel {
    padding: 14px;
    border-radius: 24px;
  }
  .app-map-stage, .rrp-map-fullscreen, .app-map-stage #rrp-map {
    min-height: 62vh;
    border-radius: 24px;
  }
  .metric-stack { grid-template-columns: 1fr 1fr 1fr; }
  .app-map-bottom-dock { display:none; }
  .rrp-mobile-dock {
    display:flex;
    position: fixed;
    left: 12px;
    right: 12px;
    bottom: 12px;
    z-index: 80;
    padding: 8px;
    gap: 8px;
    justify-content: space-between;
    border-radius: 24px;
    background: rgba(255,255,255,.88);
    backdrop-filter: blur(16px);
    box-shadow: 0 16px 34px rgba(15,23,42,.12);
  }
  .rrp-mobile-dock a {
    flex: 1;
    text-align: center;
    padding: 10px 8px;
    border-radius: 18px;
    font-size: .86rem;
    font-weight: 700;
  }
}


/* === 1.4 app-style refinements and fullscreen map fix === */
body {
  background:
    radial-gradient(circle at top left, rgba(22,163,74,.08), transparent 28%),
    radial-gradient(circle at top right, rgba(37,99,235,.06), transparent 24%),
    linear-gradient(180deg, #f4f7fb 0%, #eef3f9 100%);
}
.site-header {
  background: rgba(255,255,255,.7);
  border-color: rgba(226,232,240,.72);
  box-shadow: 0 14px 40px rgba(15,23,42,.06);
}
.site-header-inner {
  max-width: min(var(--rrp-container), calc(100vw - 24px));
}
.brand-box,
.main-nav-box,
.menu-toggle,
.mobile-panel {
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(255,255,255,.82);
  box-shadow: 0 16px 34px rgba(15,23,42,.08);
  backdrop-filter: blur(18px);
}
.main-nav a,
.mobile-nav a,
.rrp-mobile-dock a,
.app-map-bottom-dock a {
  letter-spacing: -.01em;
}
.footer-cta.panel {
  background: linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.68));
  backdrop-filter: blur(18px);
}
.quick-link-card,
.app-map-results .poi-item,
.metric-pill {
  box-shadow: 0 10px 26px rgba(15,23,42,.08);
}
.page-template-page-map-home .site-content {
  max-width: none;
  padding-top: 20px;
}
.page-template-page-map-home .site-footer {
  padding-top: 6px;
}
.page-template-page-map-home .site-footer-inner {
  max-width: min(1440px, calc(100vw - 40px));
}
.page-template-page-map-home .site-footer .panel {
  border-radius: 28px;
}
.app-map-page {
  margin-top: 0;
}
.app-map-shell {
  display: block;
  min-height: calc(100vh - 180px);
}
.app-map-stage {
  position: relative;
  min-height: calc(100vh - 220px);
  border-radius: 34px;
  border: 1px solid rgba(255,255,255,.7);
  box-shadow: 0 24px 54px rgba(15,23,42,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.34), rgba(255,255,255,.12));
  isolation: isolate;
}
.rrp-map-fullscreen,
.app-map-stage #rrp-map {
  position: relative;
  min-height: calc(100vh - 220px);
  z-index: 1;
}
.app-map-stage .leaflet-pane,
.app-map-stage .leaflet-control-container,
.app-map-stage .leaflet-top,
.app-map-stage .leaflet-bottom {
  z-index: 200;
}
.app-map-topbar,
.app-filter-rail,
.app-map-sidepanel,
.app-map-bottom-dock,
.rrp-map-controls,
.rrp-layer-picker,
.app-floating-meta,
.app-floating-actions {
  position: absolute;
  z-index: 1200;
}
.app-map-topbar {
  top: 18px;
  left: 18px;
  right: 18px;
  padding: 12px;
  border-radius: 26px;
}
.app-map-search input {
  height: 56px;
  border: 1px solid rgba(255,255,255,.8);
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(14px);
}
.app-map-actions .button {
  min-height: 48px;
}
.app-filter-rail {
  top: 92px;
  left: 18px;
  right: 18px;
  gap: 12px;
}
.app-filter-chip {
  padding: 12px 17px;
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(255,255,255,.84);
  box-shadow: 0 10px 30px rgba(15,23,42,.08);
}
.app-map-sidepanel {
  top: 152px;
  left: 18px;
  bottom: 18px;
  width: min(390px, calc(100% - 36px));
  min-height: 0;
  padding: 18px;
  z-index: 1250;
  background: linear-gradient(180deg, rgba(255,255,255,.76), rgba(255,255,255,.62));
  border: 1px solid rgba(255,255,255,.82);
}
.app-panel-head h1 {
  font-size: clamp(2rem, 2.8vw, 3rem);
}
.app-map-results {
  max-height: none;
  flex: 1;
  min-height: 180px;
}
.app-map-results .poi-item {
  border: 1px solid rgba(255,255,255,.74);
  background: rgba(255,255,255,.72);
}
.app-floating-meta {
  right: 18px;
  top: 152px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.app-floating-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(15,23,42,.78);
  color: #fff;
  backdrop-filter: blur(14px);
  box-shadow: 0 16px 34px rgba(15,23,42,.18);
}
.app-floating-pill strong {
  font-size: .95rem;
}
.app-floating-pill span {
  opacity: .75;
  font-size: .82rem;
}
.app-floating-actions {
  right: 18px;
  bottom: 92px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.app-floating-action {
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(255,255,255,.82);
  box-shadow: 0 12px 28px rgba(15,23,42,.12);
  backdrop-filter: blur(14px);
  color: var(--rrp-text);
  font-size: 1.05rem;
}
.app-map-bottom-dock {
  left: 50%;
  right: auto;
  bottom: 18px;
  transform: translateX(-50%);
  border: 1px solid rgba(255,255,255,.82);
  padding: 10px;
  z-index: 1260;
}
.app-map-bottom-dock a {
  min-width: 102px;
  min-height: 46px;
  background: rgba(255,255,255,.74);
}
.app-map-stage .rrp-map-controls {
  right: 18px;
  bottom: 154px;
  z-index: 1260;
}
.app-map-stage .rrp-layer-picker {
  left: auto;
  right: 76px;
  bottom: 154px;
  z-index: 1260;
}
.app-map-stage .rrp-layer-menu {
  margin-bottom: 10px;
}
.app-map-stage .leaflet-control-zoom,
.app-map-stage .leaflet-control-attribution {
  display: none;
}
.page-template-page-map-home .site-content > .app-map-page {
  max-width: min(1440px, calc(100vw - 40px));
  margin: 0 auto;
}
@media (max-width: 1180px) {
  .app-map-sidepanel {
    width: min(360px, calc(100% - 36px));
  }
}
@media (max-width: 960px) {
  .page-template-page-map-home .site-content > .app-map-page {
    max-width: none;
  }
  .app-map-stage,
  .rrp-map-fullscreen,
  .app-map-stage #rrp-map {
    min-height: calc(100vh - 170px);
  }
  .app-map-topbar {
    flex-direction: column;
    align-items: stretch;
  }
  .app-map-actions {
    width: 100%;
  }
  .app-map-actions .button {
    flex: 1 1 auto;
    justify-content: center;
  }
  .app-filter-rail {
    top: 148px;
  }
  .app-map-sidepanel {
    top: 208px;
    width: min(420px, calc(100% - 36px));
    bottom: 86px;
  }
  .app-floating-meta {
    top: auto;
    left: 18px;
    right: 18px;
    bottom: 146px;
    justify-content: flex-start;
  }
  .app-map-stage .rrp-layer-picker,
  .app-map-stage .rrp-map-controls,
  .app-floating-actions {
    bottom: 94px;
  }
}
@media (max-width: 780px) {
  .page-template-page-map-home .site-content {
    padding-left: 0;
    padding-right: 0;
    padding-top: 12px;
  }
  .app-map-stage {
    border-radius: 0;
    border-left: 0;
    border-right: 0;
    min-height: calc(100vh - 122px);
  }
  .rrp-map-fullscreen,
  .app-map-stage #rrp-map {
    min-height: calc(100vh - 122px);
    border-radius: 0;
  }
  .app-map-topbar,
  .app-filter-rail,
  .app-map-sidepanel,
  .app-floating-meta,
  .app-floating-actions,
  .app-map-bottom-dock,
  .app-map-stage .rrp-map-controls,
  .app-map-stage .rrp-layer-picker {
    left: 12px;
    right: 12px;
  }
  .app-map-topbar {
    top: 12px;
    padding: 10px;
    border-radius: 22px;
  }
  .app-map-search input {
    height: 50px;
  }
  .app-filter-rail {
    top: 132px;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 2px;
  }
  .app-filter-chip {
    white-space: nowrap;
  }
  .app-map-sidepanel {
    top: auto;
    bottom: 70px;
    width: auto;
    max-height: 38vh;
    border-radius: 24px;
    padding: 14px;
  }
  .app-panel-head h1 {
    font-size: 1.45rem;
  }
  .metric-stack,
  .app-quick-links,
  .compact-legend {
    display: none;
  }
  .app-map-results {
    min-height: 120px;
  }
  .app-floating-meta {
    display: none;
  }
  .app-floating-actions {
    left: auto;
    right: 12px;
    bottom: 134px;
  }
  .app-floating-action {
    width: 44px;
    height: 44px;
    border-radius: 16px;
  }
  .app-map-stage .rrp-map-controls {
    right: 12px;
    bottom: 188px;
  }
  .app-map-stage .rrp-layer-picker {
    left: 12px;
    right: auto;
    bottom: 188px;
  }
  .app-map-stage .rrp-layer-toggle,
  .app-map-stage .rrp-layer-menu button {
    min-width: 132px;
  }
  .app-map-bottom-dock {
    bottom: 12px;
    left: 12px;
    right: 12px;
    transform: none;
    justify-content: space-between;
    gap: 8px;
    border-radius: 22px;
  }
  .app-map-bottom-dock a {
    min-width: 0;
    flex: 1 1 0;
    font-size: .88rem;
    padding: 10px 8px;
  }
}


/* === 1.5 true fullscreen map-home layout === */
.page-template-page-map-home .site-main {
  max-width: none;
}
.page-template-page-map-home .site-content {
  max-width: none;
  padding: 0;
}
.page-template-page-map-home .site-content > .app-map-page {
  width: 100vw;
  max-width: none;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
.page-template-page-map-home .app-map-shell {
  min-height: calc(100vh - 84px - 96px);
}
.page-template-page-map-home .app-map-stage,
.page-template-page-map-home .rrp-map-fullscreen,
.page-template-page-map-home .app-map-stage #rrp-map {
  min-height: calc(100vh - 84px - 96px);
}
.page-template-page-map-home .app-map-stage {
  border-radius: 0;
  border-left: 0;
  border-right: 0;
}
.page-template-page-map-home .site-footer {
  padding: 0;
}
.page-template-page-map-home .site-footer-inner {
  max-width: none;
  padding: 14px 20px 20px;
}
.page-template-page-map-home .site-footer .panel {
  max-width: none;
  border-radius: 0;
  border-left: 0;
  border-right: 0;
  box-shadow: none;
}
@media (max-width: 960px) {
  .page-template-page-map-home .app-map-shell,
  .page-template-page-map-home .app-map-stage,
  .page-template-page-map-home .rrp-map-fullscreen,
  .page-template-page-map-home .app-map-stage #rrp-map {
    min-height: calc(100vh - 74px - 84px);
  }
}
@media (max-width: 780px) {
  .page-template-page-map-home .site-footer-inner {
    padding: 10px 0 0;
  }
  .page-template-page-map-home .site-footer .panel {
    border-top: 1px solid rgba(226,232,240,.72);
  }
}


/* === 1.6 screenshot-style map home refinement === */
.page-template-page-map-home body {
  background: #eef2f6;
}
.page-template-page-map-home .site-header {
  background: rgba(255,255,255,.96);
  border-bottom: 1px solid rgba(226,232,240,.9);
  backdrop-filter: blur(10px);
  box-shadow: 0 1px 0 rgba(15,23,42,.03);
}
.page-template-page-map-home .site-header-inner {
  max-width: none;
  padding: 10px 18px;
  gap: 18px;
}
.page-template-page-map-home .brand-box,
.page-template-page-map-home .main-nav-box,
.page-template-page-map-home .menu-toggle {
  background: transparent;
  border: 0;
  box-shadow: none;
}
.page-template-page-map-home .brand-box {
  min-width: 180px;
  padding: 0;
}
.page-template-page-map-home .brand-box a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 800;
}
.page-template-page-map-home .brand-box a::before {
  content: "✪";
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: linear-gradient(180deg, #2cbf6d, #16a34a);
  box-shadow: 0 8px 18px rgba(22,163,74,.28);
  font-size: 16px;
}
.page-template-page-map-home .site-title { font-size: 1.02rem; }
.page-template-page-map-home .site-tagline { display:none; }
.page-template-page-map-home .main-nav-box { flex: 1 1 auto; padding: 0; }
.page-template-page-map-home .main-nav ul {
  justify-content: center;
  gap: 14px;
  flex-wrap: nowrap;
}
.page-template-page-map-home .main-nav a {
  padding: 8px 2px;
  border-radius: 0;
  color: #5f6f63;
  font-weight: 700;
  font-size: .98rem;
}
.page-template-page-map-home .main-nav .current-menu-item > a,
.page-template-page-map-home .main-nav a:hover {
  background: transparent;
  color: #16a34a;
}
.page-template-page-map-home .menu-toggle {
  padding: 9px 12px;
  border-radius: 14px;
  background: #f8fafc;
  border: 1px solid rgba(226,232,240,.95);
}
.page-template-page-map-home .site-content,
.page-template-page-map-home .site-main,
.page-template-page-map-home .site-content > .app-map-page {
  max-width: none;
}
.page-template-page-map-home .app-map-shell {
  min-height: calc(100vh - 64px);
}
.page-template-page-map-home .app-map-stage,
.page-template-page-map-home .rrp-map-fullscreen,
.page-template-page-map-home .app-map-stage #rrp-map {
  min-height: calc(100vh - 64px);
}
.page-template-page-map-home .app-map-stage {
  border-radius: 0;
  border: 0;
  box-shadow: none;
  background: #dbeafe;
}
.page-template-page-map-home .app-map-topbar {
  top: 12px;
  left: 50%;
  right: auto;
  transform: translateX(-50%);
  width: min(1180px, calc(100vw - 34px));
  padding: 8px 12px;
  border-radius: 18px;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(226,232,240,.96);
  box-shadow: 0 12px 30px rgba(15,23,42,.08);
  backdrop-filter: blur(12px);
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto;
  align-items: center;
  gap: 10px;
}
.page-template-page-map-home .app-map-search {
  min-width: 0;
}
.page-template-page-map-home .app-map-search input {
  height: 44px;
  border-radius: 14px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
  color: #475569;
}
.page-template-page-map-home .app-map-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.page-template-page-map-home .app-map-actions .button,
.page-template-page-map-home .app-map-actions .button.secondary {
  min-height: 44px;
  border-radius: 14px;
  padding: 10px 16px;
  box-shadow: none;
}
.page-template-page-map-home .app-map-actions .button.secondary {
  background: #fff;
}
.page-template-page-map-home .app-filter-rail {
  top: 76px;
  left: 14px;
  right: auto;
  gap: 10px;
  width: auto;
  max-width: calc(100vw - 140px);
}
.page-template-page-map-home .app-filter-chip {
  min-height: 42px;
  padding: 8px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(226,232,240,.96);
  color: #334155;
  box-shadow: 0 8px 24px rgba(15,23,42,.08);
  font-size: .92rem;
}
.page-template-page-map-home .app-filter-chip.active {
  background: linear-gradient(180deg, #2cbf6d, #16a34a);
  border-color: #16a34a;
  color: #fff;
}
.page-template-page-map-home .app-filter-chip strong {
  display: inline-flex;
  min-width: 20px;
  height: 20px;
  border-radius: 999px;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.18);
  padding: 0 6px;
  font-size: .78rem;
}
.page-template-page-map-home .app-floating-meta {
  top: 76px;
  right: 14px;
  gap: 10px;
}
.page-template-page-map-home .app-floating-pill {
  min-height: 42px;
  padding: 8px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.96);
  color: #334155;
  border: 1px solid rgba(226,232,240,.96);
  box-shadow: 0 8px 24px rgba(15,23,42,.08);
}
.page-template-page-map-home .app-floating-pill span { opacity: 1; color:#64748b; }
.page-template-page-map-home .app-map-sidepanel {
  left: 14px;
  top: auto;
  bottom: 20px;
  width: 360px;
  max-height: min(42vh, 420px);
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(226,232,240,.94);
  box-shadow: 0 20px 46px rgba(15,23,42,.10);
  backdrop-filter: blur(14px);
  border-radius: 20px;
  padding: 16px;
}
.page-template-page-map-home .app-panel-head h1 {
  font-size: 1.42rem;
  margin: 0 0 6px;
}
.page-template-page-map-home .app-panel-head .muted {
  font-size: .92rem;
}
.page-template-page-map-home .metric-stack,
.page-template-page-map-home .compact-legend {
  display: none;
}
.page-template-page-map-home .app-quick-links {
  display: grid;
  gap: 10px;
}
.page-template-page-map-home .quick-link-card {
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(248,250,252,.95);
}
.page-template-page-map-home .app-map-results { min-height: 80px; }
.page-template-page-map-home .app-map-results .poi-item {
  background: rgba(255,255,255,.96);
  border-color: rgba(226,232,240,.96);
  box-shadow: none;
}
.page-template-page-map-home .app-floating-actions {
  top: 76px;
  right: 14px;
  bottom: auto;
  transform: translateY(152px);
}
.page-template-page-map-home .app-floating-action,
.page-template-page-map-home .app-map-stage .rrp-map-controls button,
.page-template-page-map-home .app-map-stage .rrp-layer-toggle {
  width: 40px;
  height: 40px;
  border-radius: 14px;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(226,232,240,.96);
  box-shadow: 0 8px 24px rgba(15,23,42,.08);
}
.page-template-page-map-home .app-map-stage .rrp-map-controls {
  top: 76px;
  right: 14px;
  bottom: auto;
  z-index: 1260;
}
.page-template-page-map-home .app-map-stage .rrp-layer-picker {
  left: 14px;
  bottom: 18px;
  right: auto;
}
.page-template-page-map-home .app-map-stage .rrp-layer-menu button {
  min-width: 120px;
  border-radius: 14px;
}
.page-template-page-map-home .app-map-bottom-dock {
  left: 50%;
  transform: translateX(-50%);
  bottom: 18px;
  padding: 8px;
  border-radius: 18px;
  background: rgba(255,255,255,.95);
  border: 1px solid rgba(226,232,240,.95);
  box-shadow: 0 10px 30px rgba(15,23,42,.08);
}
.page-template-page-map-home .app-map-bottom-dock a {
  min-width: 96px;
  min-height: 42px;
  border-radius: 14px;
  background: transparent;
  color: #334155;
}
.page-template-page-map-home .app-map-bottom-dock a:hover {
  background: #f1f5f9;
}
.page-template-page-map-home .site-footer {
  display: none;
}
.page-template-page-map-home .rrp-mobile-dock {
  display: none;
}
@media (max-width: 960px) {
  .page-template-page-map-home .site-header-inner { gap: 10px; }
  .page-template-page-map-home .main-nav-box { display:none; }
  .page-template-page-map-home .app-map-topbar {
    width: calc(100vw - 18px);
    top: 8px;
    grid-template-columns: 1fr;
  }
  .page-template-page-map-home .app-filter-rail {
    top: 66px;
    left: 8px;
    max-width: calc(100vw - 16px);
    overflow-x: auto;
    flex-wrap: nowrap;
  }
  .page-template-page-map-home .app-floating-meta {
    display:none;
  }
  .page-template-page-map-home .app-map-sidepanel {
    left: 8px;
    right: 8px;
    width: auto;
    bottom: 66px;
    max-height: 34vh;
  }
  .page-template-page-map-home .app-map-stage .rrp-map-controls {
    top: 132px;
    right: 8px;
  }
  .page-template-page-map-home .app-floating-actions {
    top: 132px;
    right: 8px;
    transform: none;
  }
  .page-template-page-map-home .app-map-stage .rrp-layer-picker {
    left: 8px;
    bottom: 8px;
  }
  .page-template-page-map-home .app-map-bottom-dock {
    left: 8px;
    right: 8px;
    bottom: 8px;
    transform: none;
  }
}


/* === 1.7 frontend submissions === */
.rrp-context-menu{position:absolute;z-index:1400;min-width:220px;background:rgba(255,255,255,.98);border:1px solid rgba(226,232,240,.96);box-shadow:0 18px 42px rgba(15,23,42,.18);border-radius:18px;padding:8px;display:none;backdrop-filter:blur(16px)}
.rrp-context-menu.open{display:block}
.rrp-context-menu button{display:flex;width:100%;align-items:center;justify-content:space-between;gap:8px;border:0;background:transparent;border-radius:14px;padding:12px 14px;font-weight:700;color:#1e293b;cursor:pointer}
.rrp-context-menu button:hover{background:#f1f5f9}
.rrp-context-menu small{display:block;font-size:.8rem;color:#64748b;font-weight:600}
.rrp-map-toast{position:absolute;left:50%;top:88px;transform:translateX(-50%);z-index:1370;background:rgba(15,23,42,.88);color:#fff;padding:10px 14px;border-radius:999px;box-shadow:0 12px 28px rgba(15,23,42,.16);display:none}
.rrp-map-toast.is-visible{display:block}
.rrp-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.46);backdrop-filter:blur(4px);z-index:1800;display:none;padding:24px;align-items:center;justify-content:center}
.rrp-modal-backdrop.open{display:flex}
.rrp-modal{width:min(560px,100%);max-height:min(88vh,900px);overflow:auto;background:#fff;border-radius:24px;padding:22px;border:1px solid rgba(226,232,240,.95);box-shadow:0 24px 54px rgba(15,23,42,.22)}
.rrp-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}
.rrp-modal-head h3{margin:0;font-size:1.3rem}
.rrp-close-btn{border:0;background:#f1f5f9;border-radius:14px;width:40px;height:40px;font-size:20px;cursor:pointer}
.rrp-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.rrp-form-grid .full{grid-column:1/-1}
.rrp-modal label{display:block;font-size:.9rem;font-weight:700;color:#334155;margin:0 0 6px}
.rrp-modal input,.rrp-modal textarea,.rrp-modal select{width:100%;border:1px solid #dbe3ee;border-radius:14px;padding:12px 14px;background:#fff;color:#0f172a}
.rrp-modal textarea{min-height:110px;resize:vertical}
.rrp-modal .muted-help{font-size:.82rem;color:#64748b;margin-top:4px}
.rrp-modal .button-row{justify-content:flex-end;margin-top:16px}
.rrp-hidden-hp{position:absolute;left:-9999px;opacity:0;pointer-events:none;height:0;width:0}
.rrp-tour-points{margin:10px 0 0;padding:0;list-style:none;display:grid;gap:8px}
.rrp-tour-points li{display:flex;justify-content:space-between;gap:10px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:10px 12px;color:#334155;font-size:.88rem}
.rrp-inline-notice{margin:12px 0 0;padding:12px 14px;border-radius:14px;background:#ecfdf5;color:#166534;border:1px solid #bbf7d0;font-weight:700}
.rrp-inline-notice.is-error{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.rrp-host-hint{margin-top:10px;font-size:.88rem;color:#64748b}
@media (max-width:780px){.rrp-modal-backdrop{padding:12px}.rrp-modal{padding:16px;border-radius:20px}.rrp-form-grid{grid-template-columns:1fr}.rrp-map-toast{top:70px;left:12px;right:12px;transform:none;border-radius:16px;text-align:center}}


/* Planner App 1.8 */
.rrp-planner-app{display:grid;grid-template-columns:400px minmax(0,1fr);gap:20px;align-items:stretch;min-height:calc(100vh - 160px);margin:18px 0 28px;}
.rrp-planner-sidebar{padding:22px;border-radius:28px;display:flex;flex-direction:column;gap:14px;background:rgba(255,255,255,.94);backdrop-filter:blur(16px);}
.rrp-planner-kicker{font-size:.8rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--rrp-primary-dark);}
.glass-inline{background:rgba(248,250,252,.92);border:1px solid rgba(148,163,184,.2);backdrop-filter:blur(10px);border-radius:18px;padding:14px 16px;display:flex;flex-direction:column;gap:4px;}
.rrp-planner-toolbar,.rrp-inline-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
.rrp-planner-topline label{display:block;font-weight:700;margin-bottom:8px;}
.rrp-planner-topline input,.rrp-planner-topline select{width:100%;}
.rrp-planner-section-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:4px;}
.rrp-planner-submit-row{margin-top:auto;}
.rrp-waypoints-app{display:grid;gap:12px;max-height:42vh;overflow:auto;padding-right:4px;}
.rrp-waypoint-meta{font-size:.84rem;color:var(--rrp-muted);margin-top:8px;}
.rrp-planner-map-shell{position:relative;overflow:hidden;border-radius:32px;min-height:78vh;padding:0;background:#eaf2ea;}
.rrp-planner-map-app{height:100%;min-height:78vh;border-radius:32px;}
.rrp-planner-map-top{position:absolute;z-index:1000;left:20px;right:20px;top:20px;display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 18px;background:rgba(255,255,255,.94);backdrop-filter:blur(14px);border-radius:22px;}
.rrp-planner-map-mode{position:absolute;z-index:1000;left:20px;bottom:20px;padding:11px 16px;background:rgba(15,23,42,.92);color:#fff;border-radius:999px;font-weight:700;box-shadow:0 20px 40px rgba(15,23,42,.18);}
.rrp-route-marker-icon{background:transparent;border:none;}
.rrp-route-marker-icon span{display:grid;place-items:center;width:28px;height:28px;border-radius:999px;background:linear-gradient(135deg,var(--rrp-primary),#22c55e);color:#fff;font-weight:800;box-shadow:0 10px 24px rgba(34,197,94,.35);border:2px solid #fff;}
.waypoint-item-app{border-radius:20px;padding:16px;background:#fff;border:1px solid rgba(148,163,184,.18);box-shadow:0 10px 26px rgba(15,23,42,.05);}
.waypoint-item-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;}
.rrp-route-summary-app{margin-top:4px;}
.rrp-route-summary-app div{background:linear-gradient(180deg,#fff,#f8fafc);}
.page-template-page-route-planner .leaflet-bottom.leaflet-right{bottom:18px;right:18px;}
.page-template-page-route-planner .leaflet-control-zoom a{width:42px;height:42px;line-height:42px;border-radius:14px;border:none;box-shadow:0 16px 32px rgba(15,23,42,.12);}
@media (max-width: 980px){.rrp-planner-app{grid-template-columns:1fr;}.rrp-waypoints-app{max-height:none;}.rrp-planner-map-shell,.rrp-planner-map-app{min-height:66vh;}.rrp-planner-map-top{left:14px;right:14px;top:14px;flex-direction:column;align-items:flex-start;}.rrp-planner-map-mode{left:14px;bottom:14px;}}


/* === 1.9 global header/footer alignment to map-home styling === */
body {
  background: #eef2f6;
}
.site-header {
  background: rgba(255,255,255,.96);
  border-bottom: 1px solid rgba(226,232,240,.9);
  backdrop-filter: blur(10px);
  box-shadow: 0 1px 0 rgba(15,23,42,.03);
}
.site-header-inner {
  max-width: none;
  padding: 10px 18px;
  gap: 18px;
}
.brand-box,
.main-nav-box,
.menu-toggle {
  background: transparent;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
}
.brand-box {
  min-width: 180px;
  padding: 0;
}
.brand-box a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 800;
}
.brand-box a::before {
  content: "✪";
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: linear-gradient(180deg, #2cbf6d, #16a34a);
  box-shadow: 0 8px 18px rgba(22,163,74,.28);
  font-size: 16px;
  flex: 0 0 auto;
}
.site-title { font-size: 1.02rem; }
.site-tagline { display: none; }
.main-nav-box { flex: 1 1 auto; padding: 0; }
.main-nav ul {
  justify-content: center;
  gap: 14px;
  flex-wrap: nowrap;
}
.main-nav a {
  padding: 8px 2px;
  border-radius: 0;
  color: #5f6f63;
  font-weight: 700;
  font-size: .98rem;
}
.main-nav .current-menu-item > a,
.main-nav a:hover,
.footer-nav .current-menu-item > a,
.footer-nav a:hover,
.mobile-nav .current-menu-item > a,
.mobile-nav a:hover {
  background: transparent;
  color: #16a34a;
}
.menu-toggle {
  padding: 9px 12px;
  border-radius: 14px;
  background: #f8fafc;
  border: 1px solid rgba(226,232,240,.95);
}
.mobile-panel {
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(226,232,240,.95);
  box-shadow: 0 20px 46px rgba(15,23,42,.10);
  backdrop-filter: blur(14px);
}
.mobile-nav ul {
  display: grid;
  gap: 8px;
}
.mobile-nav a {
  padding: 12px 14px;
  border-radius: 14px;
  color: #334155;
}
.site-content {
  padding-top: 22px;
}
.site-footer {
  padding: 22px 20px 30px;
  background: transparent;
}
.site-footer-inner {
  max-width: min(1280px, calc(100vw - 40px));
  padding: 0;
}
.site-footer .footer-cta.panel {
  border-radius: 24px;
  border: 1px solid rgba(226,232,240,.96);
  background: rgba(255,255,255,.96);
  box-shadow: 0 12px 30px rgba(15,23,42,.08);
  backdrop-filter: blur(12px);
}
.footer-nav ul {
  gap: 12px;
}
.footer-nav a {
  padding: 8px 2px;
  border-radius: 0;
  color: #5f6f63;
  font-weight: 700;
}
.footer-bottom {
  color: #64748b;
  border-top-color: rgba(226,232,240,.95);
}
.rrp-mobile-dock {
  background: rgba(255,255,255,.95);
  border-top: 1px solid rgba(226,232,240,.95);
  box-shadow: 0 -8px 24px rgba(15,23,42,.06);
}
.rrp-mobile-dock a,
.app-map-bottom-dock a {
  color: #334155;
}
.rrp-mobile-dock a:hover,
.app-map-bottom-dock a:hover {
  color: #16a34a;
}
@media (max-width: 1100px) {
  .main-nav-box { display:none; }
}
@media (max-width: 960px) {
  .site-header-inner { gap: 10px; }
}
@media (max-width: 780px) {
  .site-header-inner { padding: 10px 12px; }
  .brand-box { min-width: 0; }
  .brand-box a::before {
    width: 32px;
    height: 32px;
    border-radius: 11px;
  }
  .site-content {
    padding-left: 14px;
    padding-right: 14px;
    padding-top: 18px;
  }
  .site-footer {
    padding: 18px 14px 88px;
  }
  .site-footer-inner {
    max-width: none;
  }
  .site-footer .footer-cta.panel {
    border-radius: 20px;
  }
}


/* === 2.0 unified app surfaces + full-height planner === */
.page-shell {
  gap: 20px;
}
.page-hero,
.list-card,
.side-panel,
.metric-card,
.admin-box,
.rrp-admin-card,
.rrp-admin-form,
.template-map,
.empty-state {
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(226,232,240,.95);
  box-shadow: 0 16px 36px rgba(15,23,42,.08);
  backdrop-filter: blur(12px);
}
.page-hero {
  border-radius: 28px;
  padding: 26px;
}
.page-hero.compact {
  grid-template-columns: minmax(0,1.08fr) minmax(280px,.92fr);
}
.page-title {
  letter-spacing: -.045em;
}
.page-subtitle {
  font-size: 1.02rem;
}
.metric-grid {
  gap: 12px;
}
.metric-card {
  border-radius: 22px;
  padding: 16px 18px;
}
.metric-card strong {
  font-size: 1.25rem;
}
.content-grid {
  gap: 20px;
  align-items: start;
}
.list-card,
.side-panel,
.template-map,
.empty-state {
  border-radius: 26px;
}
.list-card {
  padding: 22px;
}
.list-card-head {
  align-items: center;
}
.meta-pill {
  background: #fff;
  border-color: rgba(226,232,240,.96);
  box-shadow: 0 6px 18px rgba(15,23,42,.04);
}
.side-panel {
  position: sticky;
  top: 92px;
}
.template-map {
  min-height: 68vh;
  background: linear-gradient(180deg,#eef5ef,#e7eef3);
}
.empty-state {
  border-style: solid;
}
.footer-cta.panel {
  overflow: hidden;
}

.rrp-planner-app {
  min-height: calc(100vh - 96px);
  grid-template-columns: minmax(320px, 420px) minmax(0,1fr);
  gap: 18px;
  margin: 0 0 24px;
  align-items: stretch;
}
.page-template-page-route-planner .site-content,
.page-template-page-route-planner .site-main {
  max-width: none;
}
.rrp-planner-sidebar {
  height: calc(100vh - 118px);
  max-height: calc(100vh - 118px);
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: rgba(148,163,184,.55) transparent;
}
.rrp-planner-sidebar::-webkit-scrollbar {
  width: 10px;
}
.rrp-planner-sidebar::-webkit-scrollbar-thumb {
  background: rgba(148,163,184,.5);
  border-radius: 999px;
  border: 2px solid transparent;
  background-clip: padding-box;
}
.rrp-planner-map-shell {
  min-height: calc(100vh - 118px);
  height: calc(100vh - 118px);
}
.rrp-planner-map-app,
#rrp-planner-map {
  min-height: calc(100vh - 118px);
  height: calc(100vh - 118px) !important;
}
.rrp-waypoints-app {
  max-height: none;
}
@media (max-width: 1100px) {
  .page-hero.compact,
  .content-grid {
    grid-template-columns: 1fr;
  }
  .side-panel {
    position: static;
    top: auto;
  }
}
@media (max-width: 980px) {
  .rrp-planner-app {
    min-height: auto;
    grid-template-columns: 1fr;
  }
  .rrp-planner-sidebar,
  .rrp-planner-map-shell,
  .rrp-planner-map-app,
  #rrp-planner-map {
    height: auto !important;
    max-height: none;
    min-height: 70vh;
  }
  .rrp-planner-sidebar {
    overflow: visible;
  }
}


/* --- v2.1 global app consistency --- */
.site-content { max-width: 1380px; }
.page-shell, .profile-grid, .content-grid, .info-grid-2 { align-items:start; }
.page-hero.compact.hero-card {
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.82));
  border: 1px solid rgba(226,232,240,.82);
  box-shadow: 0 20px 55px rgba(15,23,42,.08);
}
.page-hero.compact .feature-stack .detail-card,
.side-panel, .admin-box, .list-card, .metric-card {
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(226,232,240,.8);
  box-shadow: 0 14px 34px rgba(15,23,42,.06);
}
.page-title { letter-spacing: -.045em; }
.page-subtitle { font-size: 1.02rem; }
.side-panel { position: sticky; top: 106px; }
.list-card { border-radius: 24px; }
.list-card-head h3 { font-size: 1.2rem; letter-spacing: -.02em; }
.metric-card, .admin-box { border-radius: 24px; }
.footer-cta.panel {
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.84));
  box-shadow: 0 20px 50px rgba(15,23,42,.08);
}
.rrp-planner-app { min-height: calc(100vh - 132px); align-items: stretch; }
.rrp-planner-sidebar { max-height: calc(100vh - 132px); overflow-y: auto; overscroll-behavior: contain; }
.rrp-planner-map-shell { min-height: calc(100vh - 132px); }
.rrp-planner-map-top, .rrp-planner-map-mode { z-index: 5; }
body:not(.page-template-page-map-home) .site-content > section:first-child.page-shell,
body:not(.page-template-page-map-home) .site-content > section:first-child.profile-grid,
body:not(.page-template-page-map-home) .site-content > section:first-child.hero-card { margin-top: 6px; }
@media (max-width: 1100px) {
  .side-panel { position: static; }
  .rrp-planner-app, .rrp-planner-sidebar, .rrp-planner-map-shell { min-height: auto; max-height: none; }
}
