/*
 * PokerGPS.de, Stylesheet
 * Font: DM Sans (neutral, modern)
 * Colors: Weiss / Schwarz / Rot / Filzgruen
 */

/* VARIABLES */
:root {
  --white:      #ffffff;
  --off-white:  #f8f8f8;
  --light-grey: #f2f2f2;
  --mid-grey:   #e5e5e5;
  --near-black: #111111;
  --black:      #0d0d0d;

  --red:        #c41e3a;
  --red-hover:  #a8192f;
  --red-pale:   #fff0f2;
  --red-border: rgba(196,30,58,0.18);

  --felt:       #1b4d35;
  --gold:       #c8972e;

  --text-primary:   #0d0d0d;
  --text-secondary: #444444;
  --text-muted:     #888888;

  --border:       #e5e5e5;
  --border-light: #f0f0f0;
  --border-dark:  #1a1a1a;

  --font: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --container:  1280px;
  --nav-height: 64px;
  --radius:     10px;
  --radius-lg:  16px;
  --radius-sm:  6px;

  --shadow:      0 2px 12px rgba(0,0,0,0.07);
  --shadow-lg:   0 8px 40px rgba(0,0,0,0.13);
  --shadow-card: 0 1px 4px rgba(0,0,0,0.06);
  --ease: 0.2s ease;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;height:100%}
body{font-family:var(--font);background:var(--white);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100%;display:flex;flex-direction:column}
.footer{margin-top:auto}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit;transition:color var(--ease)}
ul{list-style:none}
input,select,textarea,button{font-family:inherit;font-size:inherit}
button{cursor:pointer}

/* TYPOGRAPHY, DM Sans everywhere */
h1,h2,h3,h4{font-family:var(--font);line-height:1.18;color:var(--text-primary);font-weight:700}
h1{font-size:clamp(2.4rem,5vw,4.2rem);letter-spacing:-0.03em}
h2{font-size:clamp(1.7rem,3vw,2.5rem);letter-spacing:-0.02em}
h3{font-size:1.15rem;font-weight:600}
p{color:var(--text-secondary)}

/* LAYOUT */
.container{max-width:var(--container);margin:0 auto;padding:0 1.5rem}
@media(max-width:600px){.container{padding:0 1rem}}
.section{padding:5rem 0}
.section-md{padding:3.5rem 0}

/* NAVIGATION */
.nav{
  position:fixed;top:0;left:0;right:0;height:var(--nav-height);
  background:transparent;
  border-bottom:1px solid transparent;
  z-index:2000;transition:background 0.3s ease,border-color 0.3s ease,box-shadow 0.3s ease
}
.nav.scrolled{
  background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);border-bottom-color:var(--border);
  box-shadow:0 2px 16px rgba(0,0,0,0.08)
}
/* Auf Seiten mit dunklem Hero: Logo/Links weiß solange transparent */
.nav.nav-hero-dark:not(.scrolled) .nav-logo{color:#fff}
.nav.nav-hero-dark:not(.scrolled) .nav-logo:hover{color:rgba(255,255,255,0.7)}
.nav.nav-hero-dark:not(.scrolled) .nav-logo span{color:var(--red)}
.nav.nav-hero-dark:not(.scrolled) .nav-link{color:rgba(255,255,255,0.85)}
.nav.nav-hero-dark:not(.scrolled) .nav-link:hover{color:#fff;background:rgba(255,255,255,0.12)}
.nav.nav-hero-dark:not(.scrolled) .nav-cta:hover{background:#fff !important;color:var(--black) !important;transform:translateY(-1px)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:100%}

.nav-logo{
  display:inline-flex;align-items:center;
  font-size:1.2rem;font-weight:700;letter-spacing:0.1em;
  color:var(--text-primary);white-space:nowrap;line-height:1
}
.nav-logo:hover{color:var(--red)}
.nav-logo-pin{height:1.6em;width:1.6em;flex-shrink:0;display:block;margin-right:0.4rem}
.nav-logo span{color:var(--red)}

.nav-links{display:flex;align-items:center;gap:0.25rem}
.nav-links .nav-cta{margin-left:0.5rem}
.nav-link{font-size:0.875rem;font-weight:500;color:var(--text-secondary);padding:0.45rem 0.85rem;border-radius:var(--radius-sm);transition:color var(--ease),background var(--ease)}
.nav-link:hover{color:var(--text-primary);background:var(--light-grey)}
.nav-link.active{color:var(--black);font-weight:600}
/* Kontakt-Button: gleiche Höhe wie Language-Button */
.nav-cta{
  display:inline-flex !important;align-items:center !important;
  height:36px !important;padding:0 1.2rem !important;box-sizing:border-box !important;
  background:var(--red) !important;color:var(--white) !important;
  font-weight:600 !important;border-radius:var(--radius-sm) !important;
  border:none !important;
  transition:background var(--ease),transform var(--ease) !important
}
/* Transparent nav auf hellem Hintergrund (Unterseiten): dunkelrot, immer lesbar */
.nav:not(.nav-hero-dark):not(.scrolled) .nav-cta:hover{background:var(--red-hover) !important;color:#fff !important;transform:translateY(-1px)}
/* Gescrollt: Standard schwarz, hover → rot */
.nav.scrolled .nav-cta{background:var(--black) !important}
.nav.scrolled .nav-cta:hover{background:var(--red) !important;color:#fff !important;transform:translateY(-1px)}

.lang-select{display:none}

.nav-right{display:flex;align-items:center;gap:0.5rem}
.lang-dropdown{position:relative}
/* Language-Button: minimal transparent */
.lang-dropdown-btn{
  display:flex;align-items:center;gap:0.3rem;
  height:36px;padding:0 0.5rem;box-sizing:border-box;
  background:rgba(255,255,255,0.2);border:1px solid rgba(0,0,0,0.12);border-radius:var(--radius-sm);
  font-size:0.8rem;font-weight:500;cursor:pointer;
  color:var(--text-secondary);transition:background var(--ease),border-color var(--ease)
}
.lang-dropdown-btn:hover{background:rgba(255,255,255,0.55);border-color:rgba(0,0,0,0.25)}
/* Scrolled nav: lang button clearly visible */
.nav.scrolled .lang-dropdown-btn{
  background:var(--light-grey);border-color:var(--border);color:var(--text-secondary)
}
.nav.scrolled .lang-dropdown-btn:hover{background:var(--off-white);border-color:var(--near-black)}
/* Auf dunklem Hero: weißlicher Hintergrund bleibt, Rahmen heller */
.nav.nav-hero-dark:not(.scrolled) .lang-dropdown-btn{
  background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.35);color:#fff
}
.nav.nav-hero-dark:not(.scrolled) .lang-dropdown-btn:hover{
  background:rgba(255,255,255,0.28);border-color:rgba(255,255,255,0.6)
}
.lang-btn-flag{border-radius:2px}
.lang-chevron{opacity:0.7;transition:transform var(--ease);flex-shrink:0;width:18px;height:18px}
.lang-dropdown.open .lang-chevron{transform:rotate(180deg)}
.lang-dropdown-list{
  display:none;position:absolute;right:0;top:calc(100% + 6px);
  background:var(--light-grey);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);min-width:110px;z-index:3000;padding:0.3rem 0;list-style:none
}
.lang-dropdown.open .lang-dropdown-list{display:block}
.lang-opt{
  display:flex;align-items:center;gap:0.5rem;
  padding:0.45rem 0.85rem;cursor:pointer;font-size:0.8rem;color:var(--text-secondary);
  transition:background var(--ease)
}
.lang-opt:hover{background:#e8e8e8;color:var(--text-primary)}
.lang-opt.active{color:var(--black);font-weight:600}
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:all var(--ease)}
.nav-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
@media(max-width:820px){
  .nav-hamburger{display:none}
  .nav-links{display:flex;position:static;flex-direction:row;background:transparent;border:none;box-shadow:none;padding:0;align-items:center}
  .nav-link{padding:0.4rem 0.6rem;border-bottom:none;border-radius:var(--radius-sm)}
  .nav-links .nav-cta{margin-left:0.25rem !important}
  .nav-cta{padding:0 0.9rem !important}
}
@media(max-width:420px){
  .lang-btn-code{display:none}
  .lang-dropdown-btn{padding:0 0.4rem}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  background:#0d0d0d;
  margin-top:0;
  min-height:100vh;
  padding:calc(var(--nav-height) + 4rem) 0 4.5rem;
  display:flex;align-items:center;
  position:relative;overflow:hidden
}
.hero-video{
  position:absolute;top:0;left:0;right:0;bottom:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center center;z-index:0;pointer-events:none;
  transition:opacity 0.6s ease
}
.hero-video.fading{opacity:0}
@media(max-width:768px){.hero-video{object-position:center center}}
.hero-overlay{
  position:absolute;top:0;left:0;right:0;bottom:0;
  background:linear-gradient(160deg, rgba(0,0,0,0.28) 0%, rgba(10,25,15,0.32) 100%);
  z-index:1;pointer-events:none
}

/* Top red glow */
.hero::before{
  content:'';position:absolute;
  top:-80px;left:50%;transform:translateX(-50%);
  width:700px;height:400px;
  background:radial-gradient(ellipse, rgba(196,30,58,0.28) 0%, transparent 65%);
  pointer-events:none;z-index:2
}

/* Floating suits */
.hero-suits{
  position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:2
}
.hero-suit{
  position:absolute;font-family:Georgia,serif;line-height:1;
  user-select:none;animation:heroSuitFloat linear infinite
}
@keyframes heroSuitFloat{
  0%  {transform:translateY(110vh) rotate(var(--r,0deg))}
  100%{transform:translateY(-20%) rotate(var(--r,0deg))}
}

.hero-inner{
  max-width:580px;margin:0 auto;text-align:center;position:relative;z-index:3
}

/* Eyebrow badge */
.hero-badge{
  display:inline-flex;align-items:center;gap:0.4rem;
  background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.18);
  border-radius:100px;padding:0.4rem 1rem;
  font-size:0.78rem;font-weight:600;color:rgba(255,255,255,0.7);
  letter-spacing:0.03em;margin-bottom:1.5rem
}

.hero-heading{
  font-size:clamp(2rem,4.5vw,3rem);font-weight:700;color:var(--white);
  line-height:1.1;letter-spacing:-0.02em;margin-bottom:0.75rem;white-space:nowrap
}
.hero-heading em{font-style:normal;color:var(--red)}
@media(max-width:500px){.hero-heading{white-space:normal;font-size:clamp(1.8rem,8vw,2.5rem)}}
.hero-sub{
  font-size:1rem;color:rgba(255,255,255,0.65);margin-bottom:2.5rem;font-weight:400
}

/* Big GPS button, runder Button */
.hero-gps-primary{display:flex;justify-content:center;margin-bottom:1.5rem}
.gps-big-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.5rem;
  width:160px;height:160px;border-radius:50%;border:3px solid rgba(255,255,255,0.15);
  cursor:pointer;
  background:linear-gradient(135deg,#c41e3a 0%,#a01530 100%);
  box-shadow:0 8px 32px rgba(196,30,58,0.6),0 2px 8px rgba(0,0,0,0.3);
  animation:gps-hero-pulse-idle 3.2s ease-out infinite;
  transition:transform 0.2s ease,box-shadow 0.2s ease
}
.gps-big-btn:hover{
  transform:scale(1.07);
  box-shadow:0 12px 40px rgba(196,30,58,0.7),0 4px 12px rgba(0,0,0,0.3);
  animation:none;border-color:rgba(255,255,255,0.35)
}
.gps-big-btn:active{transform:scale(0.96)}
.gps-big-btn.loading{cursor:wait;pointer-events:none;animation:gps-loading-pulse 0.85s ease-out infinite}
.gps-big-btn.success{background:linear-gradient(135deg,#1b4d35,#14382a);animation:none;
  box-shadow:0 8px 32px rgba(27,77,53,0.5);border-color:rgba(255,255,255,0.2)}
.gps-big-icon{
  position:relative;width:80px;height:80px;
  display:flex;align-items:center;justify-content:center
}
.gps-pin-icon{
  width:72px;height:72px;position:relative;z-index:2;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,0.35))
}
.gps-big-btn .gps-ring{
  position:absolute;width:60px;height:60px;top:10px;left:10px;
  border:2px solid rgba(255,255,255,0.4);border-radius:50%;opacity:0
}
.gps-big-btn.loading .gps-ring{animation:gps-ping 1.4s ease-out infinite}
.gps-big-btn.loading .gps-ring.r2{animation-delay:0.47s}
.gps-big-btn.loading .gps-ring.r3{animation-delay:0.94s}
/* GPS button tap cursor */
.gps-btn-wrap{position:relative;width:160px;height:160px;display:inline-block;overflow:visible}
.gps-tap-cursor{
  position:absolute;
  top:50%;left:50%;
  width:34px;height:34px;
  pointer-events:none;
  z-index:10;
  filter:drop-shadow(0 3px 10px rgba(0,0,0,0.6));
  animation:cursor-fly 3.2s ease-in-out infinite;
  transform-origin:top left
}
.gps-big-btn.loading ~ .gps-tap-cursor,
.gps-big-btn.success ~ .gps-tap-cursor{display:none}
@keyframes cursor-fly{
  0%   {transform:translate(120px,0) scale(1.1);opacity:0}
  18%  {transform:translate(120px,0) scale(1.1);opacity:1}
  52%  {transform:translate(0,0) scale(1.0);opacity:1}
  61%  {transform:translate(3px,4px) scale(0.85);opacity:1}
  70%  {transform:translate(0,0) scale(1.0);opacity:1}
  88%  {transform:translate(120px,0) scale(1.1);opacity:0.3}
  100% {transform:translate(120px,0) scale(1.1);opacity:0}
}
@keyframes gps-hero-pulse-idle{
  0%,58%  {box-shadow:0 8px 32px rgba(196,30,58,0.6),0 2px 8px rgba(0,0,0,0.3),0 0 0 0 rgba(196,30,58,0)}
  59%     {box-shadow:0 8px 32px rgba(196,30,58,0.6),0 2px 8px rgba(0,0,0,0.3),0 0 0 0 rgba(196,30,58,0.65)}
  93%,100%{box-shadow:0 8px 32px rgba(196,30,58,0.4),0 2px 8px rgba(0,0,0,0.3),0 0 0 40px rgba(196,30,58,0)}
}
@keyframes gps-loading-pulse{
  0%  {box-shadow:0 0 0 0 rgba(196,30,58,0.7)}
  70% {box-shadow:0 0 0 48px rgba(196,30,58,0)}
  100%{box-shadow:0 0 0 0 rgba(196,30,58,0)}
}

.hero-tap-hint{
  display:flex;flex-direction:column;align-items:center;gap:0;
  margin-bottom:0.6rem;animation:tap-bounce 1.2s ease-in-out infinite
}
.hero-tap-hint svg{width:22px;height:22px;color:rgba(255,255,255,0.55);display:block}
.hero-tap-hint svg:first-child{opacity:0.35}
@keyframes tap-bounce{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(5px)}
}

/* Search form */
.hero-search-form{margin-bottom:2.25rem}
.hero-search-secondary{
  margin-top:1.5rem;margin-bottom:0;max-width:360px;margin-left:auto;margin-right:auto
}
.hero-search-wrap-sm{height:46px}
.hero-search-wrap-sm .hero-search-btn{padding:0 1.25rem;font-size:0.82rem}
.hero-search-wrap{
  display:flex;height:58px;
  background:var(--white);
  border-radius:var(--radius-lg);
  box-shadow:0 8px 48px rgba(0,0,0,0.35),0 2px 8px rgba(0,0,0,0.15);
  overflow:hidden
}
.hero-search-input-group{
  flex:1;display:flex;align-items:center;gap:0.5rem;padding:0 1.1rem
}
.hero-search-icon{color:var(--text-muted);width:17px;height:17px;flex-shrink:0}
.hero-search-input{
  background:none;border:none;outline:none;
  color:var(--text-primary);width:100%;font-size:0.95rem;font-weight:400
}
.hero-search-input::placeholder{color:var(--text-muted)}

/* GPS inline button */
.gps-inline-btn{
  background:none;border:none;border-left:1px solid var(--mid-grey);
  padding:0 1.1rem;cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--ease)
}
.gps-inline-btn:hover{background:var(--light-grey)}

/* GPS dot + ring */
.gps-icon-wrap{
  position:relative;width:22px;height:22px;
  display:flex;align-items:center;justify-content:center
}
.gps-dot{
  width:9px;height:9px;background:var(--text-muted);border-radius:50%;
  position:relative;z-index:2;transition:background var(--ease)
}
.gps-inline-btn:hover .gps-dot,.gps-inline-btn.loading .gps-dot{background:var(--red)}
.gps-inline-btn.success .gps-dot{background:var(--felt)}
.gps-ring{
  position:absolute;width:9px;height:9px;
  border:2px solid var(--red);border-radius:50%;opacity:0;animation:none
}
.gps-inline-btn.loading .gps-ring{animation:gps-ping 1.4s ease-out infinite}
.gps-inline-btn.loading .gps-ring.r2{animation-delay:0.6s}
.gps-inline-btn.success .gps-ring{border-color:var(--felt)}
@keyframes gps-ping{
  0%  {transform:scale(1);opacity:0.7}
  80% {transform:scale(3.2);opacity:0}
  100%{transform:scale(3.2);opacity:0}
}

.hero-search-btn{
  background:var(--red);color:var(--white);border:none;
  padding:0 2rem;font-weight:700;font-size:0.9rem;white-space:nowrap;
  cursor:pointer;transition:background var(--ease);letter-spacing:0.01em
}
.hero-search-btn:hover{background:#a8192f}
.hero-or{display:flex;align-items:center;gap:0.75rem;margin:0.9rem auto 0;width:120px}
.hero-or::before,.hero-or::after{content:'';flex:1;height:1px;background:rgba(255,255,255,0.55)}
.hero-or span{font-size:0.72rem;color:rgba(255,255,255,0.8);white-space:nowrap;letter-spacing:0.06em;text-transform:uppercase}
.hero-search-toggle{background:none;border:1px solid rgba(255,255,255,0.28);color:rgba(255,255,255,0.65);font-size:0.82rem;font-family:var(--font-sans);cursor:pointer;padding:0.35rem 1rem;border-radius:2rem;margin-top:0.75rem;transition:all var(--ease)}
.hero-search-toggle:hover{color:#fff;border-color:rgba(255,255,255,0.6)}

/* Stats */
.hero-stats{
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;
  padding-top:2rem
}
.hero-stat{
  text-align:center;padding:0 2rem;
}
.hero-stat:last-child{border-right:none}
.hero-stat strong{
  display:block;font-size:1.55rem;font-weight:700;
  color:var(--white);letter-spacing:-0.02em;line-height:1
}
.hero-stat span{
  font-size:0.68rem;color:rgba(255,255,255,0.75);
  text-transform:uppercase;letter-spacing:0.08em;margin-top:0.3rem;display:block
}
@media(max-width:560px){
  .hero-stat{padding:0.75rem 1.25rem;border-right:none}
}

/* ============================================================
   CLUB CARDS
   ============================================================ */
.cards-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:1.25rem
}
@media(max-width:640px){.cards-grid{grid-template-columns:1fr}}

.club-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius-lg);display:flex;flex-direction:column;
  box-shadow:var(--shadow-card);
  transition:border-color var(--ease),box-shadow var(--ease),transform var(--ease);overflow:hidden
}
.club-card:hover{border-color:var(--near-black);box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.card-main{padding:1.35rem;flex:1}
.card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:0.5rem;margin-bottom:0.3rem}
.card-name{font-size:1.05rem;font-weight:700;color:var(--text-primary);line-height:1.25}
.card-location{display:flex;align-items:center;gap:0.3rem;font-size:0.78rem;color:var(--text-muted);margin-bottom:0.9rem}
.card-region{font-size:0.76rem}
.card-region-sep{opacity:0.35}
.days-row{display:flex;gap:0.3rem;flex-wrap:wrap;margin-bottom:0.8rem}
.day-pill{
  width:28px;height:25px;display:flex;align-items:center;justify-content:center;
  border-radius:5px;font-size:0.63rem;font-weight:700;
  background:var(--light-grey);color:var(--text-muted);
  border:1px solid var(--border);transition:all var(--ease)
}
.day-pill.active{background:var(--black);color:var(--white);border-color:var(--black)}
.card-info-line{display:flex;align-items:center;gap:0.5rem;margin-bottom:0.8rem;flex-wrap:wrap}
.card-buyin{font-weight:700;font-size:0.95rem;color:var(--red)}
.card-info-sep{color:var(--text-muted);font-size:0.8rem}
.card-time{font-size:0.8rem;color:var(--text-secondary)}
.card-desc{font-size:0.82rem;color:var(--text-muted);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-foot{
  padding:0.85rem 1.35rem;border-top:1px solid var(--border);background:var(--off-white);
  display:flex;align-items:center;justify-content:space-between;gap:0.75rem
}
.card-ext-link{
  font-size:0.76rem;color:var(--text-muted);
  display:flex;align-items:center;gap:0.25rem;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:155px;
  transition:color var(--ease)
}
.card-ext-link:hover{color:var(--red)}
.btn-card{
  background:transparent;border:1.5px solid var(--border-dark);
  color:var(--black);padding:0.4rem 0.9rem;
  border-radius:var(--radius-sm);font-size:0.78rem;font-weight:600;
  white-space:nowrap;transition:all var(--ease);flex-shrink:0
}
.btn-card:hover{background:var(--black);color:var(--white)}
.badge-new{
  background:var(--red-pale);color:var(--red);border:1px solid var(--red-border);
  padding:0.15rem 0.55rem;border-radius:4px;font-size:0.62rem;font-weight:700;
  letter-spacing:0.05em;text-transform:uppercase;white-space:nowrap
}
.card-dist{
  margin-left:auto;font-size:0.72rem;font-weight:600;
  color:var(--felt);background:rgba(27,77,53,0.08);
  border-radius:100px;padding:0.15rem 0.55rem;white-space:nowrap;flex-shrink:0
}
.no-results{grid-column:1/-1;text-align:center;padding:4rem 2rem}
.no-results-suit{font-size:2rem;opacity:0.12;display:block;margin-bottom:1rem}
.no-results h3{font-weight:600;font-size:1rem;color:var(--text-secondary);margin-bottom:0.5rem}

/* ============================================================
   SECTIONS
   ============================================================ */
.section-header{margin-bottom:2.5rem;display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.section-header h2{letter-spacing:-0.02em}
.section-header p{color:var(--text-muted);font-size:0.9rem;margin-top:0.3rem}

.nearby-section{background:var(--off-white);border-top:1px solid var(--border)}
.nearby-section.hidden{display:none}
.result-highlight{
  display:inline-flex;align-items:center;gap:0.5rem;
  font-size:0.8rem;color:var(--text-muted);margin-bottom:1.5rem;
  background:var(--light-grey);border-radius:100px;padding:0.3rem 0.9rem
}
.result-highlight strong{color:var(--text-primary)}

/* Owner strip */
.owner-strip{background:var(--felt);padding:2.5rem 0}
.owner-strip-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.owner-strip h2{color:var(--white);font-size:clamp(1.2rem,2.5vw,1.75rem)}
.owner-strip p{color:rgba(255,255,255,0.6);font-size:0.9rem;margin-top:0.3rem}

/* Buttons */
.btn-primary{
  background:var(--white);color:var(--black);border:none;border-radius:var(--radius);
  padding:0.875rem 2rem;font-weight:700;font-size:0.9rem;
  display:inline-flex;align-items:center;gap:0.5rem;
  transition:background var(--ease),color var(--ease),transform var(--ease);white-space:nowrap
}
.btn-primary:hover{background:var(--red-pale);color:var(--red);transform:translateY(-1px)}
.btn-secondary{
  background:transparent;color:rgba(255,255,255,0.75);
  border:1px solid rgba(255,255,255,0.3);border-radius:var(--radius);
  padding:0.875rem 2rem;font-weight:600;font-size:0.9rem;
  display:inline-flex;align-items:center;gap:0.5rem;transition:all var(--ease)
}
.btn-secondary:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.6)}
.btn-outline{
  background:transparent;color:var(--text-primary);
  border:1.5px solid var(--border-dark);border-radius:var(--radius);
  padding:0.75rem 1.75rem;font-weight:600;font-size:0.875rem;
  display:inline-flex;align-items:center;gap:0.5rem;transition:all var(--ease)
}
.btn-outline:hover{background:var(--black);color:var(--white)}

/* CTA Banner */
.cta-banner{background:var(--near-black);padding:3rem 0}
.cta-banner-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cta-banner-text h2{color:var(--white);font-size:clamp(1.3rem,2.5vw,1.8rem);margin-bottom:0.4rem}
.cta-banner-text p{color:rgba(255,255,255,0.6);font-size:0.9rem;margin:0}
.cta-banner-btns{display:flex;gap:0.75rem;flex-shrink:0;flex-wrap:wrap}
.cta-banner-btn-primary{
  background:var(--red);color:var(--white);border:none;border-radius:var(--radius-sm);
  padding:0.7rem 1.5rem;font-weight:700;font-size:0.9rem;
  display:inline-flex;align-items:center;transition:background var(--ease),transform var(--ease)
}
.cta-banner-btn-primary:hover{background:var(--red-hover);transform:translateY(-1px)}
.cta-banner-btn-outline{
  background:transparent;color:rgba(255,255,255,0.8);
  border:1.5px solid rgba(255,255,255,0.3);border-radius:var(--radius-sm);
  padding:0.7rem 1.5rem;font-weight:600;font-size:0.9rem;
  display:inline-flex;align-items:center;transition:all var(--ease)
}
.cta-banner-btn-outline:hover{border-color:#fff;color:#fff}
@media(max-width:600px){
  .cta-banner-inner{flex-direction:column;align-items:flex-start}
  .cta-banner-btns{width:100%}
  .cta-banner-btn-primary,.cta-banner-btn-outline{flex:1;justify-content:center}
}

/* ============================================================
   FILTER BAR (turniere.html)
   ============================================================ */
.turniere-wrap{padding:calc(var(--nav-height) + 2rem) 0 5rem}
.page-header{
  padding:calc(var(--nav-height) + 3rem) 0 2.5rem;
  background:var(--off-white);
  border-bottom:1px solid var(--border)
}
.page-header .container{max-width:calc(720px + 3rem)}
.page-header h1{font-size:clamp(1.8rem,4vw,2.8rem);letter-spacing:-0.02em;margin-bottom:0.4rem;color:var(--text-primary)}
.page-header p{color:var(--text-muted);font-size:0.9rem}
.breadcrumb{display:none}
.page-header p{display:none}
/* City subpages: slim bar, h1 lives in content */
.page-header-bar{padding:var(--nav-height) 0 0;min-height:0}
.city-h1{font-size:clamp(1.4rem,3.5vw,2rem);font-weight:700;letter-spacing:-0.02em;margin:0 0 1.25rem;color:var(--text-primary)}
.breadcrumb-sep{opacity:0.4}
.filter-bar{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:1rem 1.25rem;display:flex;align-items:center;gap:0.75rem;flex-wrap:wrap;
  margin-bottom:1.5rem;box-shadow:var(--shadow-card)
}
.filter-search-wrap{
  flex:1;min-width:180px;display:flex;align-items:center;gap:0.5rem;
  background:var(--off-white);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:0 0.85rem;transition:border-color var(--ease)
}
.filter-search-wrap:focus-within{border-color:var(--near-black)}
.filter-search-wrap .search-icon{color:var(--text-muted);width:14px;height:14px}
.filter-search{background:none;border:none;outline:none;color:var(--text-primary);padding:0.65rem 0;width:100%;font-size:0.875rem}
.filter-search::placeholder{color:var(--text-muted)}
.filter-select{
  background:var(--off-white);border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text-secondary);padding:0.65rem 0.85rem;font-size:0.85rem;cursor:pointer
}
.filter-select:focus{outline:none;border-color:var(--near-black);color:var(--text-primary)}
.filter-days{display:flex;gap:0.25rem}
.day-toggle{
  width:34px;height:34px;border:1px solid var(--border);background:var(--off-white);
  color:var(--text-muted);border-radius:var(--radius-sm);font-size:0.7rem;font-weight:700;transition:all var(--ease)
}
.day-toggle:hover{border-color:var(--near-black);color:var(--text-primary)}
.day-toggle.active{background:var(--black);border-color:var(--black);color:var(--white)}
.buyin-wrap{display:flex;align-items:center;gap:0.35rem}
.buyin-sep{color:var(--text-muted);font-size:0.85rem}
.buyin-input{
  background:var(--off-white);border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text-primary);padding:0.65rem 0.6rem;width:68px;font-size:0.85rem;text-align:center
}
.buyin-input:focus{outline:none;border-color:var(--near-black)}
.btn-reset{
  background:none;border:1px solid var(--border);color:var(--text-muted);
  border-radius:var(--radius-sm);padding:0.65rem 0.9rem;font-size:0.8rem;font-weight:500;
  transition:all var(--ease);white-space:nowrap
}
.btn-reset:hover{border-color:var(--red);color:var(--red)}
.umkreis-wrap{display:flex;align-items:center;gap:0.35rem}
.umkreis-input-group{
  display:flex;align-items:center;
  background:var(--off-white);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:0 0 0 0.75rem;transition:border-color var(--ease)
}
.umkreis-input-group:focus-within{border-color:var(--near-black)}
.umkreis-ort{
  background:none;border:none;outline:none;color:var(--text-primary);
  padding:0.65rem 0;width:100px;font-size:0.875rem
}
.umkreis-ort::placeholder{color:var(--text-muted)}
.umkreis-gps-btn{
  background:none;border:none;border-left:1px solid var(--mid-grey);
  padding:0.65rem 0.65rem;cursor:pointer;
  display:flex;align-items:center;transition:background var(--ease)
}
.umkreis-gps-btn:hover{background:var(--light-grey)}
.umkreis-gps-btn:hover .gps-dot,.umkreis-gps-btn.loading .gps-dot{background:var(--red)}
.umkreis-gps-btn.loading .gps-ring{animation:gps-ping 1.4s ease-out infinite}
.umkreis-gps-btn.loading .gps-ring.r2{animation-delay:0.6s}
.umkreis-gps-btn.success .gps-dot{background:var(--felt)}
.umkreis-gps-btn.success .gps-ring{border-color:var(--felt)}
.results-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:0.75rem}
.results-count{font-size:0.875rem;color:var(--text-muted)}
.results-count strong{color:var(--text-primary)}
.sort-select{background:var(--white);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);padding:0.5rem 0.85rem;font-size:0.8rem;cursor:pointer}
.sort-select:focus{outline:none;border-color:var(--near-black)}

/* ============================================================
   MAP FULL WIDTH
   ============================================================ */
/* Leaflet tile grid seam fix */
.leaflet-container{background:#f2efea}
.leaflet-tile{border-radius:0}
.leaflet-tile-container img{display:block}

/* ── Map section ── */
.maplist-section{
  background:var(--off-white);
  padding:2rem 1.5rem 2.5rem;
  border-bottom:1px solid var(--border)
}
/* Outer wrapper: border-radius + shadow on the box */
.map-wrap{
  max-width:var(--container);
  margin:0 auto;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:0 2px 24px rgba(0,0,0,0.11);
  border:1px solid var(--border)
}
/* Topbar: normal block element ABOVE the map, no z-index tricks */
.map-topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:0.7rem 1rem;
  background:var(--white);
  border-bottom:1px solid var(--border);
  gap:1rem
}
.map-topbar-count{
  font-size:0.82rem;font-weight:600;color:var(--text-secondary);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0
}
.map-topbar-gps{
  display:flex;align-items:center;justify-content:center;
  background:var(--red);color:var(--white);
  border:none;border-radius:50%;
  width:32px;height:32px;
  cursor:pointer;flex-shrink:0;
  transition:background var(--ease),transform var(--ease)
}
.map-topbar-gps:hover{background:var(--red-hover);transform:scale(1.08)}
.map-topbar-gps.loading{opacity:0.7;cursor:wait;pointer-events:none}
.map-topbar-gps.loading svg{animation:gps-icon-spin 0.9s linear infinite;transform-box:fill-box;transform-origin:center}
.map-locate-btn.loading svg{transform-box:fill-box;transform-origin:center}
/* Day filter bar */
.map-day-filter{
  display:flex;align-items:center;gap:0.3rem;flex-wrap:wrap;
  padding:0.5rem 1rem;
  background:var(--off-white);border-bottom:1px solid var(--border)
}
.map-day-label{font-size:0.72rem;font-weight:600;color:var(--text-muted);margin-right:0.2rem;white-space:nowrap}
.map-day-btn{
  min-width:34px;height:28px;padding:0 0.5rem;
  font-size:0.73rem;font-weight:600;letter-spacing:0.02em;
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-sm);
  cursor:pointer;color:var(--text-secondary);transition:all var(--ease)
}
.map-day-btn.active{background:var(--red);color:#fff;border-color:var(--red)}
.map-day-btn:hover:not(.active){background:var(--light-grey);border-color:var(--near-black)}
/* Map canvas: explicit height, no flex dependency */
#clubs-map{width:100%;height:calc(100vh - var(--nav-height) - 52px - 48px - 2rem);min-height:300px;max-height:500px;display:block}
.leaflet-grab{cursor:default!important}
.leaflet-grab:active{cursor:grabbing!important}

/* Mobile map info overlay (fixed, escapes overflow:hidden) */
#map-popup-overlay{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  z-index:9000;
  background:var(--white);border-top:1px solid var(--border);
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  box-shadow:0 -4px 24px rgba(0,0,0,0.14);
  padding:1rem 1.1rem 1.4rem;
  transform:translateY(100%);
  transition:transform 0.25s ease
}
#map-popup-overlay.active{display:block;transform:translateY(0)}
.map-overlay-close{
  position:absolute;top:0.6rem;right:0.9rem;
  background:none;border:none;font-size:1.3rem;line-height:1;
  cursor:pointer;color:var(--text-muted);padding:0.2rem 0.5rem
}
.map-overlay-close:hover{color:var(--text-primary)}
@media(min-width:641px){#map-popup-overlay{display:none!important}}

@keyframes user-ping{
  0%{transform:scale(0.6);opacity:0.7}
  100%{transform:scale(2.2);opacity:0}
}

@media(max-width:768px){
  .maplist-section{padding:0.75rem 0.75rem 1.25rem}
  .map-wrap{border-radius:var(--radius)}
  #clubs-map{height:calc(100vh - var(--nav-height) - 46px - 42px);min-height:300px;max-height:420px}
  .map-topbar{padding:0.6rem 0.75rem}
  .map-topbar-count{font-size:0.75rem}
}
@media(max-width:420px){
  #clubs-map{height:calc(100vh - var(--nav-height) - 46px - 42px);min-height:280px;max-height:360px}
  .map-topbar-count{font-size:0.7rem}
}


/* Floating club detail panel */
.map-detail-panel{
  position:absolute;top:0;right:0;
  width:320px;max-width:100%;height:100%;
  background:var(--white);border-left:1px solid var(--border);
  z-index:1002;
  overflow-y:auto;
  transform:translateX(100%);
  transition:transform 0.28s ease;
  box-shadow:-4px 0 24px rgba(0,0,0,0.14);
}
.map-detail-panel.open{transform:translateX(0)}

/* Keep existing list-detail styles for reuse inside detail panel */
.list-more-btn{
  width:100%;padding:0.6rem;font-size:0.78rem;font-weight:600;
  background:var(--black);color:var(--white);
  border:none;border-radius:var(--radius-sm);
  cursor:pointer;transition:background var(--ease)
}
.list-more-btn:hover{background:var(--red)}
.list-pane-header{
  position:sticky;top:0;z-index:1;
  background:var(--white);border-bottom:1px solid var(--border);
  padding:0.9rem 1.25rem;display:flex;align-items:center;justify-content:space-between
}
.list-pane-count{font-size:0.8rem;color:var(--text-muted);font-weight:500}
.list-detail-header{
  padding:0.85rem 1.25rem;border-bottom:1px solid var(--border);
  background:var(--white)
}
.list-back-btn{
  display:inline-flex;align-items:center;gap:0.35rem;
  background:var(--off-white);border:1px solid var(--border);border-radius:var(--radius-sm);
  cursor:pointer;font-size:0.75rem;font-weight:600;font-family:var(--font);
  color:var(--text-secondary);padding:0.4rem 0.85rem;margin-bottom:0.85rem;
  transition:background var(--ease),border-color var(--ease),color var(--ease)
}
.list-back-btn:hover{background:var(--near-black);border-color:var(--near-black);color:var(--white)}
.list-detail-name{
  font-size:1rem;font-weight:700;color:var(--text-primary);
  margin:0 0 0.25rem;line-height:1.3
}
.list-detail-location{
  display:flex;align-items:center;gap:0.3rem;
  font-size:0.75rem;color:var(--text-muted)
}
.list-detail-body{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:1rem}
.list-detail-pills{display:flex;gap:0.25rem;flex-wrap:wrap}
.list-detail-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:0.5rem
}
.list-detail-stat{
  background:var(--off-white);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:0.6rem 0.75rem
}
.list-detail-stat-label{
  font-size:0.65rem;font-weight:700;text-transform:uppercase;
  letter-spacing:0.07em;color:var(--text-muted);margin-bottom:0.2rem
}
.list-detail-stat-value{font-size:0.88rem;font-weight:600;color:var(--text-primary)}
.list-detail-stat-value.red{color:var(--red)}
.list-detail-schedule{display:flex;flex-direction:column;gap:0.35rem}
.list-detail-sched-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:0.5rem 0.75rem;background:var(--off-white);border:1px solid var(--border);
  border-radius:var(--radius-sm);font-size:0.8rem
}
.list-detail-sched-day{color:var(--text-secondary)}
.list-detail-sched-buyin{font-weight:700;color:var(--red);white-space:nowrap;margin-left:0.5rem}
.list-detail-website{
  display:inline-flex;align-items:center;gap:0.4rem;
  font-size:0.8rem;font-weight:500;color:var(--red);transition:opacity var(--ease)
}
.list-detail-website:hover{opacity:0.7}
.list-detail-desc{
  font-size:0.8rem;color:var(--text-secondary);line-height:1.7;
  padding-top:0.85rem;border-top:1px solid var(--border-light)
}
/* Club detail panel (inline in list pane) */
.cds-header-venue{font-size:0.8rem;font-weight:600;color:var(--text-primary);margin-top:0.25rem}
.cds-header-addr{font-size:0.72rem;color:var(--text-muted);margin-top:0.1rem}
.cds-schedule{display:flex;flex-direction:column;margin-bottom:0.85rem}
.cds-row{padding:0.3rem 0;border-bottom:1px solid var(--border-light)}
.cds-row:last-child{border-bottom:none}
.cds-venue{font-size:0.75rem;font-weight:600;color:var(--text-primary);margin-bottom:0.1rem}
.cds-addr{font-size:0.68rem;color:var(--text-muted);margin-bottom:0.2rem}
.cds-sched{display:flex;justify-content:space-between;align-items:center;gap:0.5rem}
.cds-day{font-size:0.82rem;color:var(--text-primary)}
.cds-buyin{font-size:0.82rem;font-weight:700;color:var(--red);white-space:nowrap;flex-shrink:0}
.cds-extra{font-size:0.7rem;color:var(--text-muted);margin-top:0.1rem}
#map-radius-expand{padding:0.6rem 1.25rem 0.9rem}
.btn-radius-expand{
  width:100%;background:var(--off-white);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:0.6rem 1rem;
  font-size:0.78rem;font-weight:600;color:var(--text-primary);
  cursor:pointer;text-align:center;transition:background var(--ease),border-color var(--ease)
}
.btn-radius-expand:hover{background:var(--mid-grey);border-color:var(--near-black)}
.list-detail-sachpreis{
  font-size:0.75rem;color:var(--text-secondary);line-height:1.5;
  background:rgba(200,151,46,0.08);border:1px solid rgba(200,151,46,0.25);
  border-radius:var(--radius-sm);padding:0.6rem 0.75rem;margin-top:0.75rem
}
.map-radius-select{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text-secondary);padding:0.3rem 0.5rem;font-size:0.75rem;cursor:pointer
}
.map-radius-select:focus{outline:none;border-color:var(--near-black)}
.list-filter-bar{
  border-bottom:1px solid var(--border);padding:0.6rem 1.25rem;
  display:flex;flex-direction:column;gap:0.5rem;background:var(--white);
  position:sticky;top:47px;z-index:1
}
.list-filter-label{
  font-size:0.63rem;font-weight:700;text-transform:uppercase;
  letter-spacing:0.07em;color:var(--text-muted)
}
.list-filter-days{display:flex;gap:0.25rem;align-items:center;flex-wrap:wrap}
.lf-day{
  background:none;border:1px solid var(--border);border-radius:0.3rem;
  font-size:0.68rem;font-weight:600;color:var(--text-muted);
  padding:0.2rem 0.45rem;cursor:pointer;transition:all var(--ease)
}
.lf-day:hover{border-color:var(--near-black);color:var(--text-primary)}
.lf-day.active{background:var(--near-black);border-color:var(--near-black);color:var(--white)}
.list-filter-selects{display:flex;gap:0.4rem}
.list-filter-selects .map-radius-select{flex:1}
/* Prevent FOUC: Leaflet zoom control uses <a> elements that render large + browser-colored before leaflet.css loads */
.leaflet-control-zoom a{
  background-color:white!important;color:#333!important;
  text-decoration:none!important;display:block!important;
  width:26px!important;height:26px!important;line-height:26px!important;
  text-align:center!important;font-size:18px!important;font-weight:bold!important
}
.leaflet-touch .leaflet-control-zoom a{
  width:34px!important;height:34px!important;line-height:34px!important
}
.map-locate-btn{
  background:white;border:2px solid rgba(0,0,0,0.15);border-radius:6px;
  width:34px;height:34px;min-width:34px;max-width:34px;min-height:34px;max-height:34px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:#444;box-shadow:0 1px 4px rgba(0,0,0,0.15);transition:background 0.15s;
  overflow:hidden;flex-shrink:0
}
.map-locate-btn:hover{background:#f0f0f0;color:#c41e3a}
.map-locate-btn.loading{cursor:wait;pointer-events:none;animation:map-btn-pulse 0.85s ease-out infinite}
.map-locate-btn.loading svg{animation:gps-icon-spin 0.9s linear infinite}
.map-locate-btn.success{background:#1b4d35;border-color:#1b4d35;color:white;animation:none;pointer-events:none}
@keyframes map-btn-pulse{0%{box-shadow:0 0 0 0 rgba(196,30,58,0.7)}70%{box-shadow:0 0 0 10px rgba(196,30,58,0)}100%{box-shadow:0 0 0 0 rgba(196,30,58,0)}}


/* Rich map popup */
.map-club-popup .leaflet-popup-content-wrapper{
  border-radius:10px;padding:0;
  box-shadow:0 4px 20px rgba(0,0,0,0.18);
  font-family:var(--font);
  border:1px solid var(--border)
}
.map-club-popup .leaflet-popup-content{
  margin:0;
  max-height:50vh;
  overflow-y:auto
}
.map-club-popup .leaflet-popup-tip-container{margin-top:-1px}
.mpop{padding:0.85rem 0.95rem}
.mpop-head{margin-bottom:0.5rem}
.mpop-name{display:block;font-size:0.88rem;font-weight:700;color:var(--text-primary);line-height:1.3;margin-bottom:0.1rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mpop-city{font-size:0.7rem;color:var(--text-muted)}
.mpop-addr{font-size:0.7rem;color:var(--text-muted);margin-bottom:0.5rem;padding-top:0.2rem;border-top:1px solid var(--border-light);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mpop-schedule{display:flex;flex-direction:column;gap:0.28rem;margin-bottom:0.55rem}
.mpop-row{display:flex;align-items:center;justify-content:space-between;gap:0.75rem;flex-wrap:nowrap;min-width:0}
.mpop-venue-label{font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;color:var(--text-muted);width:100%;margin-bottom:0.1rem}
.mpop-days{font-size:0.75rem;color:var(--text-primary);font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}
.mpop-buyin{font-size:0.72rem;font-weight:700;color:var(--red);white-space:nowrap;flex-shrink:0}
.mpop-website{
  display:flex;align-items:center;gap:0.35rem;
  font-size:0.72rem;color:var(--text-muted);
  border-top:1px solid var(--border-light);
  padding-top:0.55rem;margin-top:0.1rem;
  transition:color var(--ease)
}
.mpop-website:hover{color:var(--red)}
/* Club List Item */
.mci{
  padding:0.85rem 1.25rem;border-bottom:1px solid var(--border-light);
  cursor:pointer;display:flex;flex-direction:column;gap:0.4rem;
  transition:background var(--ease)
}
.mci:hover{background:var(--off-white)}
.mci.highlighted{background:var(--red-pale);border-left:3px solid var(--red);padding-left:calc(1.25rem - 3px)}
.mci.nearest{border-left:3px solid var(--felt);padding-left:calc(1.25rem - 3px)}
.mci-top{display:flex;align-items:baseline;justify-content:space-between;gap:0.5rem}
.mci-name{font-weight:700;font-size:0.875rem;color:var(--text-primary);line-height:1.3;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mci-buyin{font-size:0.75rem;font-weight:700;color:var(--red);white-space:nowrap;flex-shrink:0}
.mci-meta{display:flex;align-items:center;justify-content:space-between;gap:0.5rem}
.mci-city{font-size:0.71rem;color:var(--text-muted)}
.mci-tags{display:flex;gap:0.3rem;align-items:center;flex-shrink:0}
.mci-schedule{display:flex;gap:0.25rem;flex-wrap:wrap;max-width:100%}
.mci-day{
  display:flex;flex-direction:column;align-items:center;
  background:var(--off-white);border:1px solid var(--border-light);
  border-radius:0.3rem;padding:0.18rem 0.4rem;min-width:32px
}
.mci-day-label{font-size:0.59rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:0.03em}
.mci-day-time{font-size:0.59rem;color:var(--text-muted);white-space:nowrap}
.mci-footer{display:flex;align-items:center;justify-content:space-between;gap:0.5rem;padding-top:0.1rem}
.mci-more{
  background:none;border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:0.67rem;font-weight:600;color:var(--text-muted);font-family:var(--font-sans);
  padding:0.22rem 0.55rem;cursor:pointer;display:inline-flex;align-items:center;gap:0.25rem;
  transition:border-color var(--ease),color var(--ease);white-space:nowrap;flex-shrink:0
}
.mci-more:hover{border-color:var(--red);color:var(--red)}
.map-club-website{
  font-size:0.68rem;color:var(--text-muted);display:inline-flex;align-items:center;
  gap:0.3rem;text-decoration:none;transition:color var(--ease)
}
.map-club-website:hover{color:var(--red)}
.map-club-dist{
  font-size:0.68rem;font-weight:700;color:var(--felt);
  background:rgba(27,77,53,0.08);border:1px solid rgba(27,77,53,0.2);
  border-radius:100px;padding:0.1rem 0.45rem;white-space:nowrap;flex-shrink:0
}
.map-club-item.nearest{border-left:3px solid var(--felt);padding-left:calc(1.25rem - 3px)}
.map-club-item-tags{display:flex;gap:0.35rem;align-items:center;margin-left:auto;flex-shrink:0}
@media(max-width:560px){
  .map-club-item-bottom{flex-wrap:wrap}
  .map-club-item-tags{width:100%;margin-left:0;margin-top:0.3rem}
}
.map-club-nearest{
  font-size:0.65rem;font-weight:700;color:var(--felt);
  background:rgba(27,77,53,0.1);border:1px solid rgba(27,77,53,0.25);
  border-radius:100px;padding:0.15rem 0.55rem;white-space:nowrap
}
@media(max-width:768px){
  .map-detail-panel{
    top:auto;right:0;left:0;bottom:0;
    width:100%;height:70%;
    border-left:none;border-top:1px solid var(--border);
    border-radius:1rem 1rem 0 0;
    transform:translateY(100%);
    box-shadow:0 -4px 24px rgba(0,0,0,0.14);
  }
  .map-detail-panel.open{transform:translateY(0)}
}

/* ============================================================
   VERANSTALTER
   ============================================================ */
.veranstalter-hero{padding:calc(var(--nav-height) + 2.5rem) 0 2.5rem;border-bottom:1px solid var(--border)}
.veranstalter-header{display:flex;align-items:flex-start;gap:1.5rem}
.veranstalter-icon{width:80px;height:80px;background:var(--light-grey);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2.2rem;color:var(--red);flex-shrink:0}
.veranstalter-info h1{font-size:clamp(1.6rem,3vw,2.4rem);letter-spacing:-0.02em;margin-bottom:0.5rem}
.veranstalter-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:0.75rem}
.vmeta-item{display:flex;align-items:center;gap:0.35rem;font-size:0.85rem;color:var(--text-secondary)}
.vmeta-item a:hover{color:var(--red)}
.veranstalter-badges{display:flex;gap:0.4rem;flex-wrap:wrap;margin-top:0.5rem}
.veranstalter-body{padding:3rem 0 5rem}
.veranstalter-layout{display:grid;grid-template-columns:1fr 320px;gap:2rem;align-items:start}
@media(max-width:900px){.veranstalter-layout{grid-template-columns:1fr}}
.info-box{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.25rem;box-shadow:var(--shadow-card)}
.info-box-title{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-muted);margin-bottom:1rem;padding-bottom:0.6rem;border-bottom:1px solid var(--border)}
.info-box p{font-size:0.875rem;color:var(--text-secondary);line-height:1.7}
.info-row{display:flex;align-items:flex-start;gap:0.75rem;padding:0.65rem 0;border-bottom:1px solid var(--border-light)}
.info-row:last-child{border-bottom:none;padding-bottom:0}
.info-row-icon{color:var(--text-muted);font-size:0.9rem;margin-top:2px;flex-shrink:0}
.info-row-label{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.07em;color:var(--text-muted);margin-bottom:0.1rem}
.info-row-value{font-size:0.875rem;color:var(--text-primary)}
.info-row-value a:hover{color:var(--red);text-decoration:underline}
.schedule-list{display:flex;flex-direction:column;gap:0.75rem}
.schedule-item{background:var(--off-white);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;transition:border-color var(--ease)}
.schedule-item:hover{border-color:var(--near-black)}
.schedule-venue{font-size:0.95rem;font-weight:700;color:var(--text-primary);margin-bottom:0.2rem}
.schedule-address{font-size:0.78rem;color:var(--text-muted);margin-bottom:0.75rem}
.schedule-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:0.5rem}
.schedule-days{display:flex;gap:0.3rem}
.schedule-time{font-size:0.82rem;color:var(--text-secondary)}
.schedule-buyin{font-size:1.1rem;font-weight:700;color:var(--red)}
.sachpreis-box{background:var(--off-white);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;margin-top:1rem}
.sachpreis-box h3{display:flex;align-items:center;gap:0.4rem;font-size:0.78rem;font-weight:700;text-transform:uppercase;letter-spacing:0.07em;color:var(--gold);margin-bottom:0.6rem}
.sachpreis-box p{font-size:0.8rem;color:var(--text-muted);line-height:1.6;margin-bottom:0.4rem}
.sachpreis-box p:last-child{margin-bottom:0}
.sachpreis-box a:hover{color:var(--red)}

/* ============================================================
   FORMS
   ============================================================ */
.form-section{padding:calc(var(--nav-height) + 3rem) 0 5rem}
.form-container{max-width:680px;margin:0 auto}
.form-intro{margin-bottom:2.5rem}
.form-intro h1{font-size:clamp(1.8rem,3vw,2.4rem);letter-spacing:-0.02em;margin-bottom:0.6rem}
.form-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem;box-shadow:var(--shadow);position:relative}
.form-section-title{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-muted);margin-bottom:1.25rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.form-section-title:first-child{padding-top:0;border-top:none}
.form-group{margin-bottom:1.1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.form-label{display:block;font-size:0.78rem;font-weight:600;color:var(--text-secondary);margin-bottom:0.4rem}
.form-label .req{color:var(--red)}
.form-input,.form-select,.form-textarea{
  width:100%;background:var(--off-white);border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text-primary);padding:0.75rem 1rem;font-size:0.9rem;
  transition:border-color var(--ease),box-shadow var(--ease)
}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--near-black);box-shadow:0 0 0 3px rgba(13,13,13,0.06)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}
.form-textarea{min-height:120px;resize:vertical;line-height:1.6}
.form-hint{font-size:0.76rem;color:var(--text-muted);margin-top:0.3rem}
.form-checkbox-group{display:flex;flex-wrap:wrap;gap:0.4rem;margin-top:0.4rem}
.day-checkbox{display:none}
.day-checkbox-label{
  width:38px;height:34px;display:flex;align-items:center;justify-content:center;
  background:var(--off-white);border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:0.72rem;font-weight:700;color:var(--text-muted);cursor:pointer;transition:all var(--ease)
}
.day-checkbox:checked+.day-checkbox-label{background:var(--black);border-color:var(--black);color:var(--white)}
.form-submit{margin-top:2rem}
.form-submit-btn{
  width:100%;padding:1rem;font-size:1rem;background:var(--black);color:var(--white);
  border:none;border-radius:var(--radius);font-weight:700;cursor:pointer;
  font-family:var(--font);transition:background var(--ease);display:block;text-align:center
}
.form-submit-btn:hover{background:var(--red)}
.form-note{font-size:0.78rem;color:var(--text-muted);text-align:center;margin-top:0.75rem}
.form-success{text-align:center;padding:3rem;display:none}
.form-success h3{font-weight:700;margin-bottom:0.5rem}

/* ============================================================
   LEGAL
   ============================================================ */
.legal-wrap{padding:3rem 0 5rem;max-width:720px;margin:0 auto}
.legal-wrap h1{font-size:clamp(1.8rem,3vw,2.4rem);letter-spacing:-0.02em;margin-bottom:0.75rem}
.legal-wrap .lead{font-size:1rem;color:var(--text-secondary);margin-bottom:2.5rem;line-height:1.8}
.legal-wrap h2{font-size:1rem;font-weight:700;color:var(--text-primary);margin:2rem 0 0.6rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.legal-wrap h2:first-of-type{margin-top:0;padding-top:0;border-top:none}
.legal-wrap p{font-size:0.875rem;color:var(--text-secondary);margin-bottom:0.85rem;line-height:1.8}
.legal-wrap ul{list-style:disc;padding-left:1.5rem;margin-bottom:0.85rem}
.legal-wrap ul li{font-size:0.875rem;color:var(--text-secondary);margin-bottom:0.35rem;line-height:1.7}
.legal-wrap a{color:var(--red)}
.legal-wrap a:hover{text-decoration:underline}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--black);width:100%;display:flex;align-items:center;min-height:var(--nav-height)}
.footer>.container{width:100%;padding-top:0;padding-bottom:0}
.footer-slim{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;
  gap:0;width:100%
}
.footer-logo-link{
  flex:1;display:inline-flex;align-items:center;letter-spacing:0.08em;
  font-size:1.1rem;font-weight:700;color:var(--white);text-decoration:none;
  transition:opacity var(--ease)
}
.footer-logo-link:hover{opacity:0.8}
.footer-logo-link span{color:var(--red)}
.footer-logo-link .footer-pin{height:1.2em;width:auto;flex-shrink:0;display:block;margin-right:0.3rem}
.footer-copy{flex:1;font-size:0.73rem;color:#888;text-align:center}
.footer-nav-slim{flex:1;display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:0.25rem 1.25rem}
.footer-nav-slim a{font-size:0.78rem;color:#bbb;transition:color var(--ease)}
.footer-nav-slim a:hover{color:#fff}
.footer-cities{
  font-size:0.72rem;color:#bbb;line-height:1.7;
  text-align:center;padding:1rem 0 0;border-top:1px solid rgba(255,255,255,0.2)
}
.footer-bottom{display:none}

/* ============================================================
   KONTAKT PAGE
   ============================================================ */
.kontakt-topics{display:flex;flex-direction:column;gap:0.65rem}
.kontakt-topic-btn{
  display:flex;align-items:center;gap:1rem;
  background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-lg);
  padding:1.1rem 1.25rem;cursor:pointer;text-align:left;width:100%;
  transition:border-color var(--ease),box-shadow var(--ease),transform var(--ease)
}
.kontakt-topic-btn:hover{border-color:var(--red);box-shadow:0 4px 16px rgba(196,30,58,0.1);transform:translateY(-2px)}
.kontakt-topic-btn:hover .kontakt-topic-icon{color:var(--red)}
.kontakt-topic-btn:hover .kontakt-topic-arrow{color:var(--red);transform:translateX(3px)}
.kontakt-topic-icon{
  width:46px;height:46px;border-radius:0.6rem;flex-shrink:0;
  background:var(--light-grey);color:var(--text-secondary);
  display:flex;align-items:center;justify-content:center;
  transition:color var(--ease),background var(--ease)
}
.kontakt-topic-text{flex:1;min-width:0}
.kontakt-topic-title{font-weight:700;font-size:0.95rem;color:var(--text-primary);display:block;margin-bottom:0.2rem}
.kontakt-topic-desc{font-size:0.8rem;color:var(--text-muted);display:block;line-height:1.4}
.kontakt-topic-arrow{color:var(--mid-grey);flex-shrink:0;transition:color var(--ease),transform var(--ease)}
.kontakt-back-btn{
  background:none;border:none;cursor:pointer;font-size:0.82rem;
  color:var(--text-muted);padding:0 0 1.25rem;transition:color var(--ease)
}
.kontakt-back-btn:hover{color:var(--red)}
.form-card-header{
  position:relative;display:flex;align-items:center;justify-content:center;
  margin-bottom:1.5rem
}
.form-card-header .form-section-title{
  text-align:center;
  border-top:none;padding-top:0;margin-bottom:0
}
.kontakt-back-inline{
  position:absolute;left:0;
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
  background:none;color:var(--text-muted);border:1px solid var(--border);
  border-radius:50%;width:1.9rem;height:1.9rem;padding:0;
  cursor:pointer;
  transition:color var(--ease),border-color var(--ease)
}
.kontakt-back-inline:hover{color:var(--text-primary);border-color:var(--mid-grey)}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp 0.42s ease both}
.delay-1{animation-delay:0.08s}
.delay-2{animation-delay:0.16s}
.delay-3{animation-delay:0.24s}
.card-enter{animation:fadeUp 0.3s ease both}
.cards-grid .club-card:nth-child(1){animation-delay:0.00s}
.cards-grid .club-card:nth-child(2){animation-delay:0.05s}
.cards-grid .club-card:nth-child(3){animation-delay:0.10s}
.cards-grid .club-card:nth-child(4){animation-delay:0.15s}
.cards-grid .club-card:nth-child(5){animation-delay:0.20s}
.cards-grid .club-card:nth-child(6){animation-delay:0.00s}

/* UTILITY */
.sr-only{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
/* City landing pages */
.city-clubs-list{display:flex;flex-direction:column;gap:1.5rem}
.city-club-card{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:1.75rem 2rem;box-shadow:0 2px 16px rgba(0,0,0,0.06)
}
.city-club-name{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin-bottom:0.25rem;line-height:1.3}
.city-club-addr{
  font-size:0.78rem;color:var(--text-muted);margin-bottom:1.1rem
}
.city-club-schedule{
  display:flex;flex-direction:column;
  border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;margin-bottom:1.1rem
}
.city-club-row{
  display:flex;justify-content:space-between;align-items:center;gap:0.75rem;
  padding:0.6rem 1rem;border-bottom:1px solid var(--border-light)
}
.city-club-row:last-child{border-bottom:none}
.city-club-day{font-size:0.82rem;color:var(--text-primary);font-weight:500}
.city-club-buyin{font-size:0.78rem;font-weight:700;color:var(--red);white-space:nowrap}
.city-club-format{font-size:0.72rem;color:var(--text-muted);padding:0.15rem 1rem 0.5rem;background:var(--off-white);border-bottom:1px solid var(--border-light)}
.city-club-format:last-child{border-bottom:none}
.city-club-notes{font-size:0.72rem;color:var(--text-muted);padding:0.1rem 1rem 0.4rem;background:var(--off-white);border-bottom:1px solid var(--border-light)}
.city-club-notes:last-child{border-bottom:none}
.city-club-desc{font-size:0.82rem;color:var(--text-secondary);line-height:1.65;margin-bottom:1.1rem;padding-top:0.1rem}
.city-club-link{
  display:inline-flex;align-items:center;gap:0.35rem;
  font-size:0.82rem;font-weight:600;
  background:var(--near-black);color:var(--white);
  border-radius:var(--radius-sm);padding:0.55rem 1rem;
  text-decoration:none;transition:background var(--ease)
}
.city-club-link:hover{background:var(--red)}
.city-link-pill{font-size:0.78rem;font-weight:500;color:var(--text-secondary);background:var(--off-white);border:1px solid var(--border);border-radius:2rem;padding:0.25rem 0.75rem;text-decoration:none;transition:all var(--ease)}
.city-link-pill:hover{background:var(--near-black);color:var(--white);border-color:var(--near-black)}
.no-scroll{overflow:hidden}
.lucide{width:1em;height:1em;stroke-width:1.75;display:inline-block;vertical-align:middle;flex-shrink:0}

/* ============================================================
   MOBILE IMPROVEMENTS
   ============================================================ */

/* Horizontal overflow prevention, on specific containers, not body (body overflow breaks sticky) */
#map-club-list{overflow-x:hidden}
.mci-schedule{overflow:hidden}

/* ── Nav ── */
@media(max-width:820px){
  .lang-select{max-width:75px;font-size:0.78rem;padding:0.3rem 0.25rem}
}
/* ── Hero ── */
@media(max-width:768px){
  .hero{padding:2.5rem 0 2rem;min-height:calc(100vh - var(--nav-height))}
  .hero-heading{font-size:clamp(1.75rem,7vw,2.4rem);white-space:normal}
  .hero-gps-primary{margin-bottom:1.1rem}
  .gps-btn-wrap{width:132px;height:132px}
  .gps-big-btn{width:132px;height:132px}
  .gps-big-icon{width:72px;height:72px}
  .gps-pin-icon{width:72px;height:72px}
  .gps-tap-cursor{width:28px;height:28px}
  .hero-or{margin-top:0.6rem}
  .hero-stats{padding-top:1.25rem;gap:0}
  .hero-stat{padding:0.6rem 1.25rem}
  .hero-search-secondary{margin-top:1.1rem}
}
@media(max-width:420px){
  .hero{padding:2rem 0 1.75rem;min-height:calc(100vh - var(--nav-height))}
  .gps-btn-wrap{width:118px;height:118px}
  .gps-big-btn{width:118px;height:118px}
  .gps-big-icon{width:62px;height:62px}
  .gps-pin-icon{width:62px;height:62px}
  .gps-tap-cursor{width:24px;height:24px}
  .hero-stats{flex-wrap:wrap;justify-content:center}
  .hero-stat{padding:0.5rem 1rem;flex:0 0 auto}
}

/* ── Map (full width) ── */
@media(max-width:768px){
  /* Day filter: bigger touch targets */
  .lf-day{
    padding:0.45rem 0.5rem;font-size:0.7rem;
    min-height:34px;display:flex;align-items:center;justify-content:center
  }

  /* Detail panel (bottom sheet) */
  .list-detail-header{padding:0.75rem 1rem 0.5rem}
  .list-detail-body{padding:0 1rem 1.5rem}
  .list-detail-name{font-size:0.95rem}
  .list-detail-location{font-size:0.72rem}
  .cds-row{padding:0.3rem 0}
  .cds-day{font-size:0.8rem}
  .cds-buyin{font-size:0.8rem}

  .list-back-btn{padding:0.45rem 0.9rem;font-size:0.75rem;margin-bottom:0.75rem;min-height:36px}
}

/* ── Cards / Club grid ── */
@media(max-width:640px){
  .card-body{padding:1rem 1rem 0.65rem}
  .card-foot{padding:0.65rem 1rem}
  .card-name{font-size:0.92rem}
}

/* ── Form pages ── */
@media(max-width:600px){
  .form-card{padding:1.5rem 1.1rem}
  .form-section-title{font-size:0.78rem;padding-bottom:0.6rem;margin-bottom:1rem}
  .turnier-block{padding:1rem}
  .turnier-block-header{margin-bottom:0.65rem}
  .btn-add-turnier{font-size:0.8rem;padding:0.55rem 1rem}
}

/* ── Page header (city pages, static pages) ── */
@media(max-width:768px){
  .page-header{padding:calc(var(--nav-height) + 1.5rem) 0 1.5rem}
  .page-header h1{font-size:clamp(1.5rem,6vw,2rem)}
}

/* ── Cities section ── */
.cities-section{padding:2.5rem 0;border-bottom:1px solid var(--border)}
.cities-heading{font-size:1rem;font-weight:700;margin-bottom:1.25rem;color:var(--text-primary)}
.cities-grid{
  display:flex;flex-wrap:wrap;gap:0.4rem
}
.cities-grid a{
  font-size:0.82rem;font-weight:500;
  color:var(--text-secondary);
  background:var(--off-white);
  border:1px solid var(--border);
  border-radius:100px;
  padding:0.3rem 0.85rem;
  text-decoration:none;
  transition:all var(--ease)
}
.cities-grid a:hover{background:var(--near-black);color:var(--white);border-color:var(--near-black)}

/* ── City landing pages ── */
@media(max-width:600px){
  .city-club-card{padding:1.25rem 1.25rem}
  .city-club-row{padding:0.5rem 0.85rem}
  .city-club-format,.city-club-notes{padding-left:0.85rem;padding-right:0.85rem}
  .city-club-day{font-size:0.78rem}
  .city-club-buyin{font-size:0.75rem}
}

/* ── Filter page ── */
@media(max-width:768px){
  .filter-bar{flex-direction:column;gap:0.6rem;padding:0.75rem 1rem}
  .filter-row{flex-wrap:wrap;gap:0.5rem}
  .day-toggles{gap:0.25rem}
  .day-toggle{padding:0.4rem 0.5rem;font-size:0.72rem;min-height:34px}
  .section-header{flex-direction:column;align-items:flex-start;gap:0.5rem}
}

/* ── Footer ── */
/* ── Kontakt mobile ── */
@media(max-width:600px){
  .page-header-bar{padding:calc(var(--nav-height) - 4px) 0 0}
  .city-h1{font-size:1.35rem;margin-bottom:1rem}
  .kontakt-topic-btn{padding:0.85rem 1rem;gap:0.75rem}
  .kontakt-topic-icon{width:38px;height:38px}
  .kontakt-topic-title{font-size:0.9rem}
  .kontakt-topic-desc{font-size:0.75rem}
}
@media(max-width:600px){
  .footer{height:auto;padding:0.85rem 0}
  .footer-slim{flex-direction:column;align-items:center;gap:0.4rem;text-align:center}
  .footer-logo-link{flex:none;font-size:1rem}
  .footer-copy{flex:none;font-size:0.7rem;color:#777}
  .footer-nav-slim{flex:none;justify-content:center;gap:0.2rem 0.85rem}
  .footer-nav-slim a{font-size:0.72rem}
  .footer-cities{font-size:0.7rem;line-height:1.9}
}