:root {
  --bg: #ffffff;
  --surface: rgba(255,255,255,0.96);
  --surface-soft: #fbfbfb;
  --navy: #585858;
  --navy-dark: #3f3f3f;
  --text: #585858;
  --muted: #7a7a7a;
  --line: rgba(88, 88, 88, 0.14);
  --primary: #f2849e;
  --primary-dark: #e76c8d;
  --white: #ffffff;
  --shadow-xl: 0 28px 60px rgba(88, 88, 88, 0.18);
  --shadow-lg: 0 18px 40px rgba(88, 88, 88, 0.14);
  --radius-xl: 26px;
  --radius-lg: 20px;
  --header-h: 88px;
  --footer-h: 60px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%;font-family:"Source Sans Pro",Helvetica,sans-serif;background:var(--bg);color:var(--text);font-weight:300;line-height:1.75}
a{text-decoration:none;color:inherit}img{display:block;max-width:100%}
body.page-map{height:100dvh;display:flex;flex-direction:column;overflow:hidden}
.site-header{position:relative;z-index:1100;height:var(--header-h);background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:28px;padding:16px 34px}
.brand{display:inline-flex;align-items:center;gap:14px;font-size:2rem;font-weight:900;color:var(--navy);letter-spacing:-.03em;white-space:nowrap;border-bottom:0}.brand:hover{color:var(--primary)!important}.brand-logo{width:40px;height:40px;display:block;flex:0 0 auto}.brand-text{display:block;line-height:1}.main-nav{display:flex;justify-content:center;gap:42px}.main-nav a{font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:.88rem;color:var(--navy);border-bottom:0}.main-nav a:hover{color:var(--primary)!important}.main-nav a.accent{color:var(--primary)}.header-actions{display:flex;gap:12px}.mobile-menu-button{display:none;border:0;background:transparent;font-size:1.8rem;color:var(--navy);cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 24px;border-radius:16px;font-weight:700;transition:.2s ease;border:0;font-family:inherit}.btn-primary{background:var(--primary);color:var(--white);box-shadow:0 10px 20px rgba(242,132,158,.25)}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:#fff;color:var(--navy);border:1px solid rgba(88,88,88,.18)}
.map-page{position:relative;height:calc(100dvh - var(--header-h) - var(--footer-h));flex:1 1 auto;overflow:hidden;background:#f7f7f7}#map{position:absolute;inset:0}.leaflet-container{width:100%;height:100%;background:linear-gradient(180deg,#f6f6f6 0%,#ffffff 100%);font:inherit}.leaflet-control-zoom{border:0!important;box-shadow:var(--shadow-lg)!important;overflow:hidden;border-radius:18px!important}.leaflet-control-zoom a{width:46px!important;height:46px!important;line-height:46px!important;color:var(--navy)!important;font-weight:700}
.custom-marker{width:26px;height:26px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:var(--primary);border:4px solid var(--primary);box-shadow:0 8px 20px rgba(242,132,158,.35);position:relative;transition:transform .2s ease, box-shadow .2s ease, filter .2s ease}.custom-marker::after{content:'';position:absolute;inset:5px;background:#fff;border-radius:50%}.custom-marker.is-active{transform:rotate(-45deg) scale(1.16);box-shadow:0 0 0 8px rgba(242,132,158,.18),0 16px 34px rgba(242,132,158,.48);filter:saturate(1.08)}.custom-marker.is-active::before{content:'';position:absolute;inset:-10px;border-radius:50%;border:2px solid rgba(242,132,158,.34);transform:rotate(45deg)}.marker-wrap.is-active{z-index:1200!important}.leaflet-div-icon{background:transparent;border:0}
.destination-popup .leaflet-popup-content-wrapper{background:transparent;box-shadow:none;border-radius:0}.destination-popup .leaflet-popup-tip-container{display:none}.destination-popup .leaflet-popup-content{margin:0;width:280px!important}.destination-popup.leaflet-popup{margin-bottom:24px}.popup-card{background:rgba(255,255,255,.98);border-radius:22px;overflow:hidden;box-shadow:var(--shadow-xl);border:1px solid rgba(88,88,88,.08)}.popup-card-image{height:138px;overflow:hidden}.popup-card-image img{width:100%;height:100%;object-fit:cover}.popup-card-body{padding:14px 16px 16px}.popup-title-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:var(--muted);font-size:.95rem}.popup-dot{font-size:1.05rem}.popup-title{font-size:1.45rem;font-weight:800;color:var(--navy);line-height:1.05;margin:0 0 10px}.popup-teaser{font-size:.92rem;line-height:1.5;color:var(--muted);margin:0 0 14px}.popup-btn{display:inline-flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;min-height:42px;padding:0 18px;border-radius:12px;font-weight:700}
.tips-toggle{position:absolute;top:54px;right:34px;z-index:1050;display:flex;align-items:center;justify-content:space-between;gap:16px;width:min(360px,calc(100vw - 28px));min-height:74px;border:1px solid var(--line);cursor:pointer;background:rgba(255,255,255,.94);box-shadow:var(--shadow-lg);border-radius:24px;padding:18px 22px}.tips-toggle-title{font-size:1.1rem;font-weight:900;color:var(--navy);text-align:left}.tips-toggle-title .light{font-weight:400;color:var(--muted)}.tips-toggle-icon{width:34px;height:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(242,132,158,.12);color:var(--primary);font-size:1.4rem;font-weight:700}
.tips-overlay{position:absolute;top:140px;right:34px;z-index:1040;width:min(360px,calc(100vw - 28px));max-height:calc(100dvh - var(--header-h) - 140px - 72px);display:flex;flex-direction:column;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-radius:28px;box-shadow:var(--shadow-xl);padding:18px;border:1px solid var(--line);transition:opacity .25s ease,transform .25s ease,visibility .25s ease}.tips-overlay.is-collapsed{opacity:0;visibility:hidden;transform:translateY(-12px) scale(.98);pointer-events:none}.tips-overlay-header{display:flex;align-items:start;justify-content:space-between;gap:12px;margin-bottom:14px}.tips-overlay-header h2{margin:0;color:var(--navy);font-size:2rem;line-height:1.02}.tips-overlay-header h2 span{color:var(--muted);font-weight:500}.tips-close{border:0;background:rgba(37,73,140,.08);color:var(--navy);width:36px;height:36px;border-radius:50%;font-size:1.4rem;cursor:pointer}.tips-cards{display:grid;gap:12px;overflow-y:auto;padding-right:4px;min-height:0}.tips-destinations{flex:1 1 auto}.tip-card{position:relative;overflow:hidden;border-radius:18px;min-height:138px;box-shadow:0 8px 24px rgba(33,50,92,.12)}.tip-card::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,16,35,.08) 18%,rgba(8,16,35,.72) 100%)}.tip-card img{width:100%;height:138px;object-fit:cover}.tip-card-label{position:absolute;left:16px;right:16px;bottom:16px;z-index:1;color:#fff;font-size:1.7rem;font-weight:800;text-shadow:0 8px 20px rgba(0,0,0,.28)}.tip-card-button{margin-top:14px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;min-height:56px;border-radius:16px;background:var(--primary);color:#fff;font-weight:800;box-shadow:0 12px 24px rgba(228,95,112,.22)}.tips-cards::-webkit-scrollbar{width:10px}.tips-cards::-webkit-scrollbar-thumb{background:rgba(37,73,140,.18);border-radius:999px}.tips-cards::-webkit-scrollbar-track{background:transparent}.tips-overlay-headline{flex:1 1 auto;min-width:0}.tips-search{display:flex;align-items:center;gap:10px;margin-top:14px;background:#fafafa;border:1px solid rgba(88,88,88,.12);border-radius:16px;padding:0 12px;min-height:54px;box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}.tips-search:focus-within{border-color:rgba(242,132,158,.4);box-shadow:0 0 0 4px rgba(242,132,158,.12)}.tips-search-icon{flex:0 0 auto;color:#7b89a3;font-size:1.1rem}.tips-search input{flex:1 1 auto;min-width:0;border:0;background:transparent;color:var(--navy);font:inherit;font-size:.98rem;outline:none}.tips-search input::placeholder{color:#9b9b9b}.tips-search-clear{border:0;background:rgba(37,73,140,.08);color:var(--navy);width:30px;height:30px;border-radius:50%;font-size:1.1rem;cursor:pointer;flex:0 0 auto}.tips-search-status{min-height:20px;margin:-2px 2px 12px;color:#7383a1;font-size:.92rem;font-weight:600}.tip-card.is-hidden{display:none}.tips-empty{display:none;padding:18px 16px;border-radius:18px;background:#f6f8fc;border:1px dashed rgba(37,73,140,.14);color:#6e7e9c;line-height:1.5}.tips-empty.is-visible{display:block}
.site-footer{height:var(--footer-h);padding:12px 34px;background:rgba(255,255,255,.95);border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:24px;color:var(--muted);font-size:.95rem}.footer-links{display:flex;gap:18px}.site-footer a{border-bottom:0}.site-footer a:hover{color:var(--primary)!important}
.detail-page{min-height:calc(100dvh - var(--header-h) - var(--footer-h));padding-bottom:32px}.detail-hero{position:relative;min-height:420px;background-image:var(--hero-image);background-size:cover;background-position:center}.detail-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(9,18,38,.24),rgba(9,18,38,.64))}.detail-hero-content{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:44px 32px 54px;color:#fff}.back-link{display:inline-flex;margin-bottom:26px;padding:10px 14px;background:rgba(255,255,255,.14);backdrop-filter:blur(8px);border-radius:999px;font-weight:600}.eyebrow{letter-spacing:.18em;text-transform:uppercase;font-size:.82rem;font-weight:900;margin:0 0 10px}.detail-hero h1{font-size:clamp(2.2rem,5vw,4.6rem);line-height:.95;margin:0 0 16px;max-width:900px}.hero-teaser{max-width:720px;font-size:1.1rem;line-height:1.7;margin:0 0 24px}.detail-shell{max-width:1200px;margin:0 auto;padding:28px 32px 0}.detail-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;align-items:start}.detail-content-card,.detail-sidebar-card,.detail-card{background:#fff;border-radius:28px;box-shadow:var(--shadow-lg);padding:28px;border:1px solid rgba(88,88,88,.08)}.detail-sidebar-card{position:sticky;top:24px;display:grid;gap:22px}.detail-sidebar-card h2{margin:0;font-size:1.55rem;color:#523349}.meta-list{display:grid;gap:16px;margin:0}.meta-list dt{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:800;margin-bottom:4px}.meta-list dd{margin:0;font-weight:600;color:#33415c}.prose{font-size:1rem;line-height:1.8;color:var(--text)}.prose p:first-child{margin-top:0}.prose img{width:100%;border-radius:18px;margin:18px 0}.prose a{color:var(--primary);font-weight:700;border-bottom:1px dotted rgba(242,132,158,.55)}.prose figure{margin:0 0 18px}.not-found{text-align:center;padding:54px 28px}code{background:#f3f6fb;padding:.15rem .4rem;border-radius:.4rem}
@media (max-width:1100px){.site-header{grid-template-columns:auto 1fr auto;gap:18px}.main-nav{gap:22px}.header-actions .btn-secondary{display:none}.tips-toggle,.tips-overlay{right:18px}.detail-layout{grid-template-columns:1fr}}
@media (max-width:860px){
  :root{--header-h:78px;--footer-h:54px}
  .site-header{grid-template-columns:1fr auto;padding:14px 18px}
  .main-nav,.header-actions{display:none}
  .mobile-menu-button{display:block}
  .brand{font-size:1.7rem}
  .page-map{overflow:auto}
  .map-page{height:calc(100dvh - var(--header-h) - var(--footer-h))}
  .tips-toggle{left:12px;right:12px;top:auto;bottom:max(12px,calc(env(safe-area-inset-bottom) + 12px));width:auto;min-height:64px;border-radius:22px}
  .tips-overlay{left:12px;right:12px;width:auto;top:auto;bottom:calc(env(safe-area-inset-bottom) + 86px);max-height:calc(100dvh - 220px);border-radius:24px}
  .tips-overlay-header h2{font-size:1.55rem}
  .tip-card,.tip-card img{min-height:118px;height:118px}
  .tip-card-label{font-size:1.4rem}
  .site-footer{min-height:var(--footer-h);height:auto;padding:8px 18px 10px;flex-direction:column;align-items:flex-start;justify-content:center;gap:4px}
  .detail-hero{min-height:340px}
  .detail-hero-content,.detail-shell{padding-left:18px;padding-right:18px}
  .detail-content-card,.detail-sidebar-card,.detail-card{padding:20px}

  .site-header.mobile-menu-open{
    z-index:2100;
  }
  .site-header.mobile-menu-open .main-nav{
    display:flex;
    position:absolute;
    top:calc(100% + 10px);
    left:18px;
    right:18px;
    flex-direction:column;
    gap:0;
    padding:10px;
    background:rgba(255,255,255,.98);
    border:1px solid var(--line);
    border-radius:24px;
    box-shadow:var(--shadow-lg);
    backdrop-filter:blur(12px);
  }
  .site-header.mobile-menu-open .main-nav a{
    display:block;
    padding:14px 16px;
    border-radius:16px;
    font-size:.95rem;
  }
  .site-header.mobile-menu-open .main-nav a:hover{
    background:rgba(242,132,158,.08);
  }
  .site-header.mobile-menu-open .header-actions{
    display:flex;
    position:absolute;
    top:calc(100% + 292px);
    left:18px;
    right:18px;
    padding:10px;
    background:rgba(255,255,255,.98);
    border:1px solid var(--line);
    border-radius:24px;
    box-shadow:var(--shadow-lg);
    backdrop-filter:blur(12px);
  }
  .site-header.mobile-menu-open .header-actions .btn{
    width:100%;
  }
}
.fm-cluster{
  border-radius:50%;
  display:flex!important;
  align-items:center;
  justify-content:center;
  border:6px solid rgba(255,255,255,.82);
  box-shadow:0 14px 30px rgba(22,36,77,.20), inset 0 0 0 2px rgba(255,255,255,.16);
  color:#16325d;
  font-weight:800;
}
.fm-cluster__count{font-size:1rem;line-height:1}
.fm-cluster.is-1{background:radial-gradient(circle at 30% 30%, #d6f8a0 0%, #9adc55 58%, #79c23b 100%)}
.fm-cluster.is-2{background:radial-gradient(circle at 30% 30%, #fff3a8 0%, #f6d75a 58%, #e7b81c 100%)}
.fm-cluster.is-3{background:radial-gradient(circle at 30% 30%, #ffd3a8 0%, #ff9d52 56%, #ef6f22 100%); color:#5d2605}
.fm-cluster.is-4{background:radial-gradient(circle at 30% 30%, #ffb7b7 0%, #ff6b75 52%, #e73b46 100%); color:#ffffff}

body,input,select,textarea{font-family:"Source Sans Pro",Helvetica,sans-serif;color:var(--text)}
h1{font-weight:700;line-height:1.3;letter-spacing:-0.035em}
h2,h3,h4,h5,h6{font-weight:900;line-height:1.5;letter-spacing:0.18em;text-transform:uppercase}
a{transition:border-bottom-color .2s ease,color .2s ease}

.detail-gallery-block{
  margin-bottom:30px;
  padding-bottom:26px;
  border-bottom:1px solid rgba(88,88,88,.10);
}
.detail-gallery-head{
  margin-bottom:16px;
}
.detail-gallery-head .eyebrow{
  color:var(--primary);
  margin-bottom:6px;
}
.detail-gallery-head h2{
  margin:0;
  color:var(--navy);
  font-size:1.15rem;
}
.thumbnail-gallery{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(120px,1fr));
  gap:12px;
}
.thumbnail-gallery-item{
  appearance:none;
  border:1px solid rgba(88,88,88,.12);
  background:#fff;
  border-radius:18px;
  padding:0;
  overflow:hidden;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(88,88,88,.10);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.thumbnail-gallery-item:hover,
.thumbnail-gallery-item:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(242,132,158,.45);
  box-shadow:0 16px 30px rgba(242,132,158,.18);
  outline:none;
}
.thumbnail-gallery-item img{
  display:block;
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
}
.lightbox[hidden]{display:none!important}
.lightbox{
  position:fixed;
  inset:0;
  z-index:3000;
}
.lightbox-backdrop{
  position:absolute;
  inset:0;
  background:rgba(28,28,30,.78);
  backdrop-filter:blur(8px);
}
.lightbox-dialog{
  position:relative;
  z-index:1;
  width:min(1120px,calc(100vw - 24px));
  height:min(88vh,860px);
  margin:min(6vh,42px) auto;
  display:grid;
  grid-template-columns:72px minmax(0,1fr) 72px;
  grid-template-rows:minmax(0,1fr) auto;
  align-items:center;
  gap:14px;
}
.lightbox-figure{
  margin:0;
  grid-column:2;
  grid-row:1;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:0;
  height:100%;
}
.lightbox-image{
  max-width:100%;
  max-height:100%;
  border-radius:24px;
  box-shadow:0 24px 60px rgba(0,0,0,.32);
  background:#fff;
}
.lightbox-nav,
.lightbox-close{
  appearance:none;
  border:0;
  cursor:pointer;
  color:#fff;
  background:rgba(255,255,255,.14);
  backdrop-filter:blur(8px);
  box-shadow:0 12px 30px rgba(0,0,0,.18);
}
.lightbox-nav{
  width:56px;
  height:56px;
  border-radius:50%;
  font-size:2rem;
  line-height:1;
}
.lightbox-prev{grid-column:1;grid-row:1}
.lightbox-next{grid-column:3;grid-row:1}
.lightbox-close{
  position:absolute;
  top:0;
  right:0;
  width:48px;
  height:48px;
  border-radius:50%;
  font-size:2rem;
  line-height:1;
}
.lightbox-meta{
  grid-column:1 / -1;
  grid-row:2;
  justify-self:center;
  color:#fff;
  font-weight:700;
  background:rgba(255,255,255,.14);
  padding:10px 16px;
  border-radius:999px;
  backdrop-filter:blur(8px);
}
body.lightbox-open{
  overflow:hidden;
}
@media (max-width:860px){
  .thumbnail-gallery{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
  .lightbox-dialog{
    width:calc(100vw - 16px);
    height:min(86vh,760px);
    margin:8px auto;
    grid-template-columns:52px minmax(0,1fr) 52px;
    gap:8px;
  }
  .lightbox-nav{width:44px;height:44px;font-size:1.6rem}
  .lightbox-close{top:8px;right:4px;width:42px;height:42px;font-size:1.8rem}
  .lightbox-image{border-radius:18px}
}

.detail-location-map-block{
  margin-top:24px;
  padding-top:22px;
  border-top:1px solid rgba(125, 98, 118, .16);
}
.detail-location-map-block h3{
  margin:0 0 14px;
  font-size:1rem;
  color:#6d5565;
}
.detail-location-map{
  position:relative;
  width:100%;
  height:220px;
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(125, 98, 118, .16);
  box-shadow:0 18px 36px rgba(82, 51, 73, .12);
  background:#f4eef2;
}
.detail-location-map .leaflet-tile-pane{
  filter:saturate(.9) contrast(1.02);
}
.detail-map-marker-wrap{
  background:transparent;
  border:none;
}
.detail-map-marker{
  width:22px;
  height:22px;
  border-radius:50% 50% 50% 0;
  transform:rotate(-45deg);
  background:linear-gradient(180deg,#ec7daa 0%,#c74883 100%);
  border:3px solid rgba(255,255,255,.95);
  box-shadow:0 10px 26px rgba(199,72,131,.36);
  position:relative;
}
.detail-map-marker::after{
  content:'';
  position:absolute;
  width:8px;
  height:8px;
  border-radius:50%;
  background:#fff;
  top:4px;
  left:4px;
}
.back-to-top{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:#8c4e71;
  font-weight:700;
  padding:12px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
  border:1px solid rgba(236, 125, 170, .24);
  box-shadow:0 18px 38px rgba(82, 51, 73, .14);
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.back-to-top-floating{
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:1200;
}
.back-to-top:hover{
  transform:translateY(-1px);
  background:rgba(236, 125, 170, .18);
  box-shadow:0 16px 32px rgba(82, 51, 73, .12);
}
.back-to-top-icon{
  width:30px;
  height:30px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(180deg,#ec7daa 0%,#c74883 100%);
  color:#fff;
  box-shadow:0 8px 18px rgba(199,72,131,.28);
  font-size:1rem;
  line-height:1;
}
@media (max-width:860px){
  .detail-location-map{height:200px}
  .back-to-top-floating{right:14px;left:14px;bottom:max(14px,calc(env(safe-area-inset-bottom) + 14px));justify-content:center}
}

.popup-weather{
  display:flex;
  align-items:center;
  gap:10px;
  margin:0 0 14px;
  padding:10px 12px;
  border-radius:14px;
  background:linear-gradient(180deg,#fff7fb 0%,#f7f9fc 100%);
  border:1px solid rgba(242,132,158,.18);
  color:var(--navy);
  font-weight:700;
}
.popup-weather-icon{font-size:1.2rem;line-height:1}
.popup-weather-text{font-size:.92rem;line-height:1.35}

.detail-weather-block{
  display:grid;
  gap:14px;
  margin-bottom:2px;
}
.detail-weather-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.detail-weather-head h3{
  margin:0;
  font-size:1rem;
  color:#6d5565;
}
.detail-weather-link{
  color:var(--primary);
  font-weight:700;
  font-size:.95rem;
}
.detail-weather-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.detail-weather-day,
.detail-weather-loading{
  border-radius:18px;
  background:linear-gradient(180deg,#fff7fb 0%,#f5f8fc 100%);
  border:1px solid rgba(236,125,170,.18);
  box-shadow:0 12px 28px rgba(82,51,73,.08);
  padding:14px 12px;
  text-align:center;
}
.detail-weather-day-label{font-size:.86rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.detail-weather-day-icon{font-size:1.6rem;line-height:1;margin-bottom:6px}
.detail-weather-day-temp{font-weight:800;color:var(--navy);font-size:.98rem}

.meteo-page,.meteo-page *{box-sizing:border-box}
.meteo-page{min-height:calc(100dvh - var(--header-h) - var(--footer-h));padding:26px 0 40px;background:linear-gradient(180deg,#f8f4f7 0%,#fdfdfe 100%);overflow-x:hidden}
.meteo-shell{width:100%;max-width:1200px;margin:0 auto;padding:0 32px;display:grid;gap:24px}
.meteo-hero-card,
.meteo-content-card{width:100%;max-width:100%;min-width:0;background:rgba(255,255,255,.96);border:1px solid rgba(88,88,88,.08);border-radius:30px;box-shadow:var(--shadow-lg);overflow:hidden}
.meteo-hero-card{padding:30px 32px;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);gap:28px;align-items:end}
.meteo-hero-card > *,.meteo-content-card > *,.meteo-app > *{min-width:0}
.meteo-hero-card h1{margin:0 0 12px;color:var(--navy);font-size:clamp(2.2rem,5vw,4rem);line-height:.96;letter-spacing:-.04em;text-transform:none}
.meteo-hero-text{margin:0;color:var(--muted);font-size:1.03rem;max-width:50rem;line-height:1.65}
.meteo-search-wrap{display:grid;gap:10px;justify-self:end;width:min(100%,420px);min-width:0}
.meteo-search-label{font-size:.82rem;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:#6d5565}
.meteo-search-box{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}
.meteo-search-box input{width:100%;min-width:0;border:1px solid rgba(88,88,88,.12);border-radius:18px;background:#fafafa;padding:0 18px;min-height:56px;color:var(--navy);font:inherit;box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
.meteo-search-box input:focus{outline:none;border-color:rgba(242,132,158,.4);box-shadow:0 0 0 4px rgba(242,132,158,.12)}
.meteo-search-box .btn{min-height:56px;white-space:nowrap}
.meteo-suggestions{display:grid;gap:8px}
.meteo-suggestion-item{padding:13px 16px;border:1px solid rgba(88,88,88,.1);background:#fff;border-radius:16px;text-align:left;font:inherit;color:var(--navy);cursor:pointer;transition:border-color .2s ease, transform .2s ease, box-shadow .2s ease}
.meteo-suggestion-item:hover{border-color:rgba(242,132,158,.34);background:#fff7fb;transform:translateY(-1px);box-shadow:0 10px 22px rgba(242,132,158,.12)}
.meteo-content-card{padding:30px}
.meteo-loading,.meteo-error{padding:22px;border-radius:20px;background:#f7f9fc;border:1px solid rgba(88,88,88,.08);font-weight:700;color:var(--navy)}
.meteo-app{display:grid;gap:22px;min-width:0}
.meteo-current-card{display:grid;gap:18px;padding:28px;border-radius:28px;background:linear-gradient(135deg,#fff7fb 0%,#eef6ff 100%);border:1px solid rgba(242,132,158,.14)}
.meteo-current-main{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;min-width:0}
.meteo-current-copy{max-width:60%;min-width:0}
.meteo-location-kicker{margin:0 0 8px;color:#6d5565;font-size:.82rem;font-weight:900;letter-spacing:.16em;text-transform:uppercase}
.meteo-current-main h2{margin:0;color:var(--navy);font-size:clamp(1.9rem,3vw,3rem);letter-spacing:-.03em;text-transform:none;line-height:1.02}
.meteo-current-desc{margin-top:10px;font-size:1.12rem;color:#5e6b83;font-weight:700}
.meteo-current-temp-wrap{display:flex;align-items:center;gap:14px;padding:12px 16px 12px 18px;border-radius:22px;background:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.8);flex:0 0 auto;max-width:100%}
.meteo-current-icon{font-size:3.1rem;line-height:1}
.meteo-current-temp{font-size:3rem;font-weight:900;color:var(--navy);line-height:1}
.meteo-current-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.meteo-metric{padding:18px;border-radius:20px;background:rgba(255,255,255,.76);border:1px solid rgba(88,88,88,.08);min-width:0}
.meteo-metric span{display:block;font-size:.8rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:#6d5565;margin-bottom:8px}
.meteo-metric strong{display:block;font-size:1.02rem;color:var(--navy);overflow-wrap:anywhere}
.meteo-section-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-top:2px;min-width:0}
.meteo-section-head .eyebrow{margin-bottom:6px;color:var(--primary)}
.meteo-section-head h3{margin:0;color:var(--navy);font-size:1.2rem;letter-spacing:-.02em;text-transform:none;line-height:1.1}
.meteo-days-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;min-width:0}
.meteo-day-card{padding:18px 16px;border-radius:24px;background:#fff;border:1px solid rgba(88,88,88,.08);box-shadow:0 12px 30px rgba(88,88,88,.08);text-align:center;min-width:0}
.meteo-day-label{font-size:.82rem;font-weight:900;color:#6d5565;letter-spacing:.14em;text-transform:uppercase;margin-bottom:12px}
.meteo-day-icon{font-size:2rem;line-height:1;margin-bottom:10px}
.meteo-day-desc{font-weight:700;color:var(--navy);font-size:.98rem;min-height:2.7em;display:flex;align-items:center;justify-content:center}
.meteo-day-temp{margin-top:10px;font-weight:900;color:var(--primary);font-size:1.02rem}
.meteo-hours-card{padding:22px;border-radius:28px;background:#fff;border:1px solid rgba(88,88,88,.08);box-shadow:0 12px 30px rgba(88,88,88,.08);min-width:0}
.meteo-hours-scroll{display:flex;gap:12px;overflow-x:auto;overflow-y:hidden;padding:4px 2px 8px;scrollbar-width:thin;overscroll-behavior-x:contain}
.meteo-hour-item{flex:0 0 96px;padding:14px 10px;border-radius:18px;background:linear-gradient(180deg,#fff7fb 0%,#f6f9fd 100%);border:1px solid rgba(242,132,158,.12);text-align:center}
.meteo-hour-time{font-size:.82rem;font-weight:900;color:#6d5565;margin-bottom:8px}
.meteo-hour-icon{font-size:1.4rem;line-height:1;margin-bottom:8px}
.meteo-hour-temp{font-weight:900;color:var(--navy);margin-bottom:6px}
.meteo-hour-rain{font-size:.84rem;color:var(--muted);font-weight:700}
@media (max-width:1100px){.meteo-hero-card{grid-template-columns:1fr;align-items:start}.meteo-search-wrap{justify-self:stretch;width:100%}.meteo-days-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.meteo-current-copy{max-width:none}}
@media (max-width:860px){.meteo-page{padding:18px 0 30px}.meteo-shell{padding:0 18px}.meteo-content-card,.meteo-hero-card{padding:20px;border-radius:24px}.meteo-search-box{grid-template-columns:1fr}.meteo-current-main{align-items:flex-start;flex-direction:column}.meteo-current-temp-wrap{align-self:flex-start}.meteo-current-meta{grid-template-columns:1fr}.meteo-days-grid{grid-template-columns:1fr 1fr}.detail-weather-grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.meteo-days-grid{grid-template-columns:1fr}.detail-weather-grid{grid-template-columns:1fr}}

#map.fm-map-pink{
  position: absolute;
  inset: 0;
  overflow: hidden;
}

/* Nur Tiles einfärben */
#map.fm-map-pink .leaflet-tile-pane{
  filter:
    saturate(0.42)
    brightness(1.08)
    contrast(0.9)
    sepia(0.16)
    hue-rotate(-12deg);
}

/* Pink Overlay */
#map.fm-map-pink::before{
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 200; /* bewusst UNTER Controls */
  background:
    radial-gradient(
      circle at 50% 38%,
      rgba(242,132,158,0.16) 0%,
      rgba(242,132,158,0.09) 22%,
      rgba(255,255,255,0.00) 58%
    ),
    linear-gradient(
      180deg,
      rgba(255,245,248,0.24) 0%,
      rgba(242,132,158,0.08) 45%,
      rgba(255,255,255,0.02) 100%
    );
  mix-blend-mode: multiply;
}

#map.fm-map-pink::after{
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 201;
  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.10) 0%,
      rgba(255,255,255,0.00) 30%,
      rgba(242,132,158,0.06) 100%
    );
}

/* ⚠️ WICHTIG: KEINE Manipulation mehr an Leaflet-Panes oder Controls */