/* ==========================================================================
   Booking Nordzypern.live — Inhalts-Paket Stylesheet
   --------------------------------------------------------------------------
   WICHTIG: Das WpRentals-Theme setzt html{font-size:62.5%} (10px-Root).
   Deshalb sind Schriften/Abstände hier in PX (nicht rem) — unabhängig vom
   Theme-Root, alle Schriften >= 16px. Alles auf .sp-scope gescoped.
   ========================================================================== */

:root{
  --brand:#1b5163; --brand-deep:#0e3a47; --brand-light:#bfe0e9;
  --gold:#d2a86d; --gold-soft:#f3e9da;
  --ink:#0c2a33; --text:#2b2f33; --muted:#46515c;
  --bg:#ffffff; --bg-soft:#f5f7f8; --bg-tint:#eef3f4; --line:#dbe4e7; --warn:#b91c1c;
  --radius-sm:10px; --radius:10px; --radius-lg:10px;
  --shadow-sm:0 2px 12px rgba(12,42,51,.07);
  --shadow:0 20px 55px rgba(12,42,51,.14);
  --container:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}

.sp-scope,.sp-scope *{box-sizing:border-box}
.sp-mega-open{overflow:hidden}
.sp-scope{font-family:var(--font);color:var(--text);font-size:17px;line-height:1.75;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.sp-scope h1,.sp-scope h2,.sp-scope h3,.sp-scope h4{line-height:1.18;letter-spacing:-.01em;margin:0;color:var(--ink);font-weight:800}
.sp-scope h1{font-size:clamp(40px,5vw,60px);letter-spacing:-.02em;line-height:1.12}
.sp-scope h2{font-size:clamp(30px,3.6vw,44px)}
.sp-scope h3{font-size:19px}
.sp-scope p{margin:0;font-size:17px}
.sp-scope a{color:var(--brand-deep);text-decoration:none}
.sp-scope a:hover{color:var(--ink)}
.sp-scope main p a:not(.btn),.sp-scope .reviews-hint a{text-decoration:underline;text-underline-offset:3px}
.sp-scope main p a:not(.btn):hover{text-decoration:none}
.sp-scope img{max-width:100%;height:auto;display:block}
.sp-scope [id]{scroll-margin-top:90px}

.sp-scope .container{width:min(100% - 40px,var(--container));margin-inline:auto}
/* Theme-Kollision (WpRentals): im mobilen Sticky-Header-Modus setzt das Theme
   `.mobile_header_wrap_sticky_yes .container{margin-top:70px}` — das trifft auch
   unsere wiederverwendete `.container`-Klasse und blählt auf Mobil die Abstände
   vor Breadcrumb, Subhero und jeder Sektion auf. Hier neutralisiert. */
body .sp-scope .container{margin-top:0}
.sp-scope .container.narrow{max-width:780px}
.sp-scope .eyebrow{display:inline-block;font-size:16px;font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:var(--brand-deep);background:var(--bg-tint);padding:8px 16px;border-radius:10px;margin-bottom:18px}
.sp-scope .eyebrow-gold{color:var(--ink);background:var(--gold)}
.sp-scope .lead{font-size:21px;color:var(--muted)}

/* A11y */
.sp-scope .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.sp-skip{position:absolute;left:-9999px;top:0;z-index:300;background:var(--ink);color:#fff;padding:14px 20px;border-radius:0 0 10px 0}
.sp-skip:focus{left:0}
.sp-scope a:focus-visible,.sp-scope button:focus-visible,.sp-scope input:focus-visible,.sp-scope select:focus-visible,.sp-scope textarea:focus-visible,.sp-scope summary:focus-visible{outline:3px solid var(--brand);outline-offset:3px;border-radius:6px}

/* Buttons — kein Theme-Roter-Strich (box-shadow override) */
.sp-scope .btn,.sp-scope a.btn{display:inline-flex;align-items:center;gap:9px;padding:16px 30px;border-radius:10px;font-weight:700;font-size:17px;cursor:pointer;border:1px solid transparent;transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s;min-height:56px;line-height:1.2;text-decoration:none;box-shadow:none}
.sp-scope .btn:hover{transform:translateY(-2px)}
.sp-scope .btn-primary{background:var(--brand);color:#fff}
.sp-scope .btn-primary:hover{background:var(--brand-deep);color:#fff}
.sp-scope .btn-ghost{background:#fff;color:var(--brand-deep);border-color:var(--line)}
.sp-scope .btn-ghost:hover{background:var(--bg-tint);color:var(--brand-deep);border-color:var(--brand)}
.sp-scope .btn-light{background:#fff;color:var(--brand-deep)}
.sp-scope .btn-light:hover{background:var(--bg-soft);color:var(--ink)}
.sp-scope .btn-outline-light{background:rgba(255,255,255,.10);color:#fff;border-color:rgba(255,255,255,.8)}
.sp-scope .btn-outline-light:hover{background:rgba(255,255,255,.22);color:#fff}
.sp-scope .btn-sm{min-height:46px;padding:10px 18px;font-size:16px}

/* Header (nur falls eigenes Chrome aktiv — derzeit Theme-Chrome) */
.sp-scope header#site-header{position:fixed;top:0;left:0;right:0;z-index:100;border-bottom:1px solid transparent;transition:background .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.sp-scope header#site-header.over-hero{background:transparent}
.sp-scope header#site-header.over-hero::before{content:"";position:absolute;left:0;right:0;top:0;height:175px;background:linear-gradient(180deg,rgba(8,28,34,.7),rgba(8,28,34,0));pointer-events:none;z-index:-1}
.sp-scope header#site-header.scrolled{background:rgba(255,255,255,.97);backdrop-filter:saturate(150%) blur(8px);border-bottom-color:var(--line);box-shadow:var(--shadow-sm)}
.sp-scope #site-header .nav{display:flex;align-items:center;gap:16px;padding:10px 0;min-height:72px}

/* Hero */
.sp-scope .hero{position:relative;color:#fff;background:var(--ink);min-height:90vh;display:flex;align-items:center}
.sp-scope .hero-media{position:absolute;inset:0;overflow:hidden;background:#0c2a33}
.sp-scope .hero-media video,.sp-scope .hero-media img{width:100%;height:100%;object-fit:cover;display:block}
.sp-scope .hero-media video{opacity:0;transition:opacity .8s var(--ease)}
.sp-scope .hero-media video.ready{opacity:1}
.sp-scope .hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,42,51,.45) 0%,rgba(12,42,51,.5) 45%,rgba(12,42,51,.72) 100%)}
.sp-scope .hero-inner{position:relative;padding:clamp(56px,8vw,96px) 0 clamp(48px,6vw,72px);display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center}
@media (max-width:980px){.sp-scope .hero-inner{grid-template-columns:1fr;gap:36px}}
@media (min-width:981px){.sp-scope .hero-inner>.hero-text{grid-column:1}.sp-scope .hero-inner>.advsearch{grid-column:2}}
.sp-scope .hero h1{color:#fff;max-width:16ch}
.sp-scope .hero .eyebrow{color:var(--ink);background:var(--gold)}
.sp-scope .hero-sub{font-size:21px;color:#eaf2f4;max-width:54ch;margin-top:18px}
.sp-scope .hero-cta{margin-top:28px;display:flex;gap:14px;flex-wrap:wrap}

/* Such-Karte */
.sp-scope .advsearch{background:rgba(238,243,244,.97);backdrop-filter:blur(4px);border-radius:10px;box-shadow:var(--shadow);padding:clamp(24px,2.5vw,32px)}
.sp-scope .advsearch-title{font-size:19px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);margin-bottom:18px}
.sp-scope .advsearch .field{margin-bottom:14px}
.sp-scope .advsearch .field label{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
.sp-scope .advsearch .control{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:0 16px;min-height:62px}
.sp-scope .advsearch .control:focus-within{outline:3px solid var(--brand);outline-offset:2px}
.sp-scope .advsearch .control svg{flex:none;color:var(--brand)}
.sp-scope .advsearch .control input,.sp-scope .advsearch .control select{flex:1;border:0;background:none;font:inherit;color:var(--ink);min-height:60px;text-transform:uppercase;letter-spacing:.04em;font-size:16px}
.sp-scope .advsearch .control input:focus,.sp-scope .advsearch .control select:focus{outline:none}
.sp-scope .advsearch .control input::placeholder{color:#6b7480;text-transform:uppercase;letter-spacing:.04em;font-size:16px}
.sp-scope .advsearch .btn{width:100%;justify-content:center;text-transform:uppercase;letter-spacing:.09em;margin-top:6px}

/* Sektionen */
.sp-scope .block{padding:clamp(64px,8vw,112px) 0}
.sp-scope .block.soft{background:var(--bg-soft)}
.sp-scope .block.ink{background:var(--ink);color:#e6eff1}
.sp-scope .block.ink h2,.sp-scope .block.ink h3{color:#fff}
.sp-scope .section-head{max-width:64ch;margin-bottom:48px}
.sp-scope .section-head.center{margin-inline:auto;text-align:center}
.sp-scope .section-head p{color:var(--muted);margin-top:14px;font-size:18px}
.sp-scope .block.ink .section-head p{color:#e6eff1}

/* Raster + Karten */
.sp-scope .grid{display:grid;gap:30px}
.sp-scope .cols-2{grid-template-columns:repeat(2,1fr)}
.sp-scope .cols-3{grid-template-columns:repeat(3,1fr)}
.sp-scope .cols-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:880px){.sp-scope .cols-3,.sp-scope .cols-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.sp-scope .cols-2,.sp-scope .cols-3,.sp-scope .cols-4{grid-template-columns:1fr}}
/* Wetter-Widget: oben rechts im Subhero-Bild eingebettet (Feed-Seite). */
.sp-scope .nz-subhero-weather{
    position:absolute;top:16px;right:16px;z-index:2;
    width:260px;
    transform:scale(.72);transform-origin:top right;
    pointer-events:auto;
}
@media(max-width:640px){.sp-scope .nz-subhero-weather{display:none}}
/* Wetter/Wechselkurs-Widgets direkt unter dem Subhero in 2-Spalten-Layout. */
.sp-scope .nz-hero-widgets{margin-top:22px}
/* Live-Widget-Zellen füllen ihre Grid-Spalte voll aus. */
.sp-scope .grid > .reveal > .nz-wetter,.sp-scope .grid > .reveal > .nz-wechselkurs{height:100%}

.sp-scope .card{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;text-decoration:none;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.sp-scope .card-body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.sp-scope .card h3{margin-bottom:6px;transition:color .2s var(--ease)}
.sp-scope .card p{color:var(--muted);font-size:16px}
.sp-scope a.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--brand-light)}
.sp-scope a.card:hover h3{color:var(--brand-deep)}
.sp-scope .block.ink .card{background:transparent;border-color:rgba(191,224,233,.22);color:#e6eff1}
.sp-scope .block.ink .card p{color:#e6eff1}

.sp-scope .media{position:relative;display:block;overflow:hidden;aspect-ratio:4/3;background:var(--bg-tint)}
.sp-scope .media img{aspect-ratio:4/3;width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.sp-scope a.card:hover .media img{transform:scale(1.06)}
.sp-scope .region-badge{position:absolute;left:12px;bottom:12px;background:rgba(12,42,51,.9);color:#fff;padding:6px 12px;border-radius:10px;font-size:14px;font-weight:700;backdrop-filter:blur(2px)}
.sp-scope .card .price{font-weight:800;color:var(--brand-deep);font-size:21px;margin-top:auto;padding-top:6px}
.sp-scope .card .price span{font-weight:600;color:var(--muted);font-size:16px}
.sp-scope .meta{color:var(--muted);font-size:16px;margin-bottom:8px}

.sp-scope .icon-card{text-align:left}
.sp-scope .icon{width:54px;height:54px;border-radius:10px;background:var(--bg-tint);color:var(--brand-deep);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.sp-scope .block.ink .icon{background:rgba(191,224,233,.16);color:var(--brand-light)}

/* USP-Split */
.sp-scope .split{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:start}
.sp-scope .split img{border-radius:10px;box-shadow:var(--shadow)}
@media (max-width:880px){.sp-scope .split{grid-template-columns:1fr;gap:36px}}
@media (min-width:881px){.sp-scope .split>div:first-child{grid-column:1}.sp-scope .split>div:last-child{grid-column:2}}
.sp-scope .usp-list{list-style:none;margin:22px 0 0;padding:0;display:grid;gap:20px}
.sp-scope .usp-list li{display:flex;gap:14px;font-size:17px}
.sp-scope .usp-list strong{color:var(--ink)}
.sp-scope .tick{flex:none;width:30px;height:30px;border-radius:50%;background:var(--gold-soft);color:var(--brand-deep);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px}

/* Gästestimmen 3D-Karussell */
.sp-scope .reviews-hint{text-align:center;color:var(--muted);font-size:16px;margin-bottom:22px}
.sp-scope .stars{color:var(--gold);letter-spacing:.12em}
.sp-scope .reviews-3d{position:relative;margin-top:20px}
.sp-scope .r3d-stage{position:relative;height:400px;perspective:1500px;overflow:hidden}
.sp-scope .r3d-track{position:absolute;inset:0;list-style:none;margin:0;padding:0;transform-style:preserve-3d}
.sp-scope .r3d-card{position:absolute;top:50%;left:50%;width:min(500px,88vw);background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 10px 30px rgba(12,42,51,.10);padding:32px 34px;transform:translate(-50%,-50%);transition:transform .55s var(--ease),opacity .55s var(--ease);will-change:transform,opacity;backface-visibility:hidden}
.sp-scope .r3d-card .stars{font-size:20px}
.sp-scope .r3d-quote{color:var(--ink);font-size:19px;line-height:1.6;margin:14px 0 22px}
.sp-scope .r3d-person{display:flex;align-items:center;gap:14px}
.sp-scope .r3d-avatar{flex:none;width:52px;height:52px;border-radius:50%;background:var(--bg-tint);color:var(--brand-deep);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px}
.sp-scope .r3d-name{font-weight:700;color:var(--ink);font-size:18px}
.sp-scope .r3d-meta{display:block;color:var(--muted);font-size:16px}
.sp-scope .r3d-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:20;width:54px;height:54px;border-radius:50%;background:#fff;border:1px solid var(--line);color:var(--brand-deep);box-shadow:var(--shadow-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}
.sp-scope .r3d-nav:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.sp-scope .r3d-prev{left:0}.sp-scope .r3d-next{right:0}
.sp-scope .r3d-dots{display:flex;justify-content:center;gap:10px;margin-top:26px}
.sp-scope .r3d-dot{width:12px;height:12px;border-radius:50%;background:var(--line);border:0;cursor:pointer;padding:0;transition:background .2s,transform .2s}
.sp-scope .r3d-dot[aria-selected="true"]{background:var(--brand);transform:scale(1.25)}
@media (prefers-reduced-motion: reduce){.sp-scope .r3d-card{transition:none}}

/* CTA-Band */
.sp-scope .cta-band{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);color:#fff;border-radius:10px;padding:clamp(36px,5vw,56px);text-align:center}
.sp-scope .cta-band h2{color:#fff}
.sp-scope .cta-band p{color:#dceaee;margin:12px auto 0;max-width:54ch;font-size:18px}
/* Button-Reihe im CTA-Band: gleichmäßiger kleiner Abstand (10px), zentriert,
   bricht sauber um. Nur die Absätze mit Buttons (nicht der Beschreibungstext). */
.sp-scope .cta-band p:has(> .btn){display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:none}

/* Formular */
.sp-scope .lead-form{display:grid;gap:20px;margin-top:30px}
.sp-scope .form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:560px){.sp-scope .form-row{grid-template-columns:1fr}}
.sp-scope .field label{display:block;font-weight:700;color:var(--ink);margin-bottom:7px;font-size:17px}
.sp-scope .field input,.sp-scope .field textarea{width:100%;font:inherit;font-size:16px;color:var(--text);padding:14px 16px;border:1px solid var(--line);border-radius:10px;min-height:54px;background:#fff}
.sp-scope .field textarea{min-height:auto}
.sp-scope .field .req{color:var(--warn)}
.sp-scope .field-checkbox label{display:flex;gap:10px;align-items:flex-start;font-weight:400;font-size:16px;line-height:1.45}
.sp-scope .field-checkbox input[type="checkbox"]{-webkit-appearance:checkbox!important;appearance:checkbox!important;width:18px!important;height:18px!important;min-width:18px!important;min-height:18px!important;flex:0 0 auto;margin:3px 0 0!important;border-radius:3px}

/* Veröffentlichungs-Wahl: „Mit Namen" (Konto) ODER „Anonym" */
.sp-scope .nz-authmode{margin:6px 0 4px}
.sp-scope .nz-authmode-q{font-weight:700;margin:0 0 10px}
.sp-scope .nz-authmode-r{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;clip:rect(0 0 0 0)}
.sp-scope .nz-authmode-tabs{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:560px){.sp-scope .nz-authmode-tabs{grid-template-columns:1fr}}
.sp-scope .nz-authmode-tabs label{display:block;cursor:pointer;border:2px solid var(--line);border-radius:12px;padding:14px 16px;background:#fff;transition:border-color .15s,box-shadow .15s,background .15s}
.sp-scope .nz-authmode-tabs label strong{display:block;color:var(--ink);font-size:16px;margin-bottom:3px}
.sp-scope .nz-authmode-tabs label span{display:block;color:var(--muted);font-size:14px;line-height:1.4}
.sp-scope .nz-authmode-tabs label:hover{border-color:var(--brand-light)}
.sp-scope #nz-mode-named:checked ~ .nz-authmode-tabs label[for="nz-mode-named"],
.sp-scope #ev-mode-named:checked ~ .nz-authmode-tabs label[for="ev-mode-named"],
.sp-scope #bp-mode-named:checked ~ .nz-authmode-tabs label[for="bp-mode-named"],
.sp-scope #nz-mode-anon:checked ~ .nz-authmode-tabs label[for="nz-mode-anon"],
.sp-scope #ev-mode-anon:checked ~ .nz-authmode-tabs label[for="ev-mode-anon"],
.sp-scope #bp-mode-anon:checked ~ .nz-authmode-tabs label[for="bp-mode-anon"]{border-color:var(--brand);box-shadow:0 0 0 3px rgba(27,81,99,.12);background:var(--bg-tint)}
.sp-scope .nz-authmode-fields{margin-top:14px}
.sp-scope #nz-mode-anon:checked ~ .nz-authmode-fields,
.sp-scope #ev-mode-anon:checked ~ .nz-authmode-fields,
.sp-scope #bp-mode-anon:checked ~ .nz-authmode-fields{display:none}
.sp-scope .field-error{display:block;color:var(--warn);font-size:15px;margin-top:5px;min-height:1em}
.sp-scope .form-note{color:var(--muted);font-size:16px}
.sp-scope .sp-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.sp-scope .form-alert{padding:16px 20px;border-radius:10px;margin-top:24px;font-size:17px}
.sp-scope .form-alert-success{background:#e8f5ee;color:#155d3a;border:1px solid #b6dcc6}
.sp-scope .form-alert-error{background:#fef2f2;color:#8e1b1b;border:1px solid #f3c0c0}

/* Footer (rein weiß) */
.sp-scope footer{background:var(--ink);color:#fff;padding:64px 0 32px}
.sp-scope footer a{color:#fff;text-decoration:none}
.sp-scope footer a:hover{color:#fff;text-decoration:underline}
.sp-scope .footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
@media (max-width:880px){.sp-scope .footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.sp-scope .footer-grid{grid-template-columns:1fr}}
.sp-scope .footer-brand p{color:#fff;font-size:17px}
.sp-scope .footer-col h3{color:#fff;font-size:18px;margin-bottom:14px}
.sp-scope .footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.sp-scope .footer-col a{font-size:16px}
.sp-scope .footer-bottom{border-top:1px solid rgba(255,255,255,.22);margin-top:40px;padding-top:24px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:16px;color:#fff}
.sp-scope .langs{display:flex;gap:16px}
.sp-scope .langs a{font-size:16px}

/* Scroll-Reveal — Inhalte sind STANDARDMÄSSIG SICHTBAR. Nur per JS (.reveal-pending)
   werden Off-Screen-Elemente kurz versteckt und beim Scrollen eingeblendet. So bleibt
   die Seite auch bei langsamem/blockiertem JS (Mobil) sofort sichtbar. */
.sp-scope .reveal{transition:opacity .6s var(--ease),transform .6s var(--ease)}
.sp-scope .reveal.reveal-pending{opacity:0;transform:translateY(22px)}
.sp-scope .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.sp-scope .reveal,.sp-scope .reveal.reveal-pending{opacity:1!important;transform:none!important;transition:none!important}}

/* ==========================================================================
   Fullwidth-Layout für alle Paket-Seiten (body.nz-fullbleed) — gilt auch für
   Anlagen/Single-Templates mit Theme-Sidebar.
   `html`-Präfix erhöht die Spezifität um eine Stufe, damit später geladene
   Theme-Grid-Stylesheets (gleiche Spezifität, !important) die Regel NICHT mehr
   per Lade-Reihenfolge überschreiben (sonst bleibt die Sidebar sichtbar und
   der Inhalt in col-md-8 eingeengt).
   ========================================================================== */
html body.nz-fullbleed .widget-area-sidebar,
html body.nz-fullbleed aside.sidebar,
html body.nz-fullbleed #sidebar{display:none!important}
html body.nz-fullbleed .col-md-8{width:100%!important;max-width:100%!important;flex:0 0 100%!important;float:none!important;padding-top:0!important}
html body.nz-fullbleed .sp-scope{width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);position:relative;overflow-x:hidden}
html body.nz-fullbleed .single-title,
html body.nz-fullbleed h1.entry-title{display:none!important}
html body.nz-fullbleed .single-content{padding-top:0!important;margin-top:0!important}

/* ==========================================================================
   Rechtstext-/Prosa-Seiten (.sp-legal .sp-prose) — eigener Lesefluss, da die
   Basis-Typo auf .sp-scope margin:0 setzt. WCAG-AAA-Lesbarkeit.
   ========================================================================== */
.sp-legal .container.narrow{max-width:840px}
.sp-prose{padding:10px 0 16px;color:var(--text)}
.sp-prose h1{font-size:clamp(30px,4vw,42px);margin:0 0 22px}
.sp-prose h2{font-size:clamp(22px,2.4vw,28px);margin:40px 0 12px}
.sp-prose h3{font-size:19px;margin:26px 0 8px}
.sp-prose h4{font-size:17px;margin:20px 0 6px}
.sp-prose p{margin:0 0 14px;font-size:17px;line-height:1.75}
.sp-prose ul,.sp-prose ol{margin:0 0 16px;padding-left:1.45em}
.sp-prose li{margin:5px 0;font-size:17px;line-height:1.65}
.sp-prose a{color:var(--brand-deep,#143f4d);text-decoration:underline}
.sp-prose a:hover,.sp-prose a:focus{text-decoration:none}
.sp-prose strong{font-weight:700}
.sp-prose hr{border:0;border-top:1px solid #e1e8ea;margin:30px 0}
.sp-prose table{width:100%;border-collapse:collapse;margin:0 0 20px;font-size:15px}
.sp-prose th,.sp-prose td{border:1px solid #d8e0e2;padding:8px 11px;text-align:left;vertical-align:top;line-height:1.5}
.sp-prose th{background:#f4f8f9;font-weight:700}

/* ==========================================================================
   ANLAGEN-SEITEN + ANLAGEN-BANNER (Startseite)
   ========================================================================== */
.sp-scope .breadcrumb{font-size:15px;color:var(--muted);padding:18px 0 0}
.sp-scope .breadcrumb ol{list-style:none;margin:0;padding:0}
.sp-scope .breadcrumb a{color:var(--brand-deep)}

/* Subhero (Anlagen-Kopf, großes Bild + Hover-Reveal) */
.sp-scope .subhero{position:relative;color:#fff;background:var(--ink);overflow:hidden;margin-top:18px;border-radius:10px;min-height:clamp(460px,68vh,680px);display:flex;align-items:flex-end}
.sp-scope .subhero-media{position:absolute;inset:0;overflow:hidden}
.sp-scope .subhero-media img,.sp-scope .subhero-media video{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.sp-scope .info-list{list-style:none;margin:12px 0 0;padding:0;display:grid;gap:7px}
.sp-scope .info-list li{color:var(--muted);font-size:16px}
.sp-scope .info-list b{color:var(--ink);font-weight:700}
.sp-scope .subhero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,42,51,.4) 0%,rgba(12,42,51,.45) 45%,rgba(12,42,51,.82) 100%);transition:opacity .5s var(--ease)}
.sp-scope .subhero:hover .subhero-media img,.sp-scope .subhero:focus-within .subhero-media img{transform:scale(1.05)}
.sp-scope .subhero:hover .subhero-media::after,.sp-scope .subhero:focus-within .subhero-media::after{opacity:.55}
.sp-scope .subhero-inner{position:relative;width:100%;padding:clamp(36px,5vw,56px) clamp(24px,4vw,56px)}
.sp-scope .subhero h1{color:#fff;max-width:18ch;text-shadow:0 2px 14px rgba(0,0,0,.4)}
.sp-scope .subhero .eyebrow{color:var(--ink);background:var(--gold)}
.sp-scope .subhero-sub{font-size:20px;color:#eef5f6;max-width:60ch;margin-top:16px;text-shadow:0 1px 10px rgba(0,0,0,.4)}
.sp-scope .subhero-cta{margin-top:26px;display:flex;gap:14px;flex-wrap:wrap}
/* Mobile: Buttons dürfen umbrechen (nie über den Rand) + Button-Reihen gestapelt
   mit klarem Abstand. Behebt Überlauf langer Labels (z. B. „Veranstaltung vorschlagen"). */
@media (max-width:560px){
  .sp-scope .btn,.sp-scope a.btn{white-space:normal;max-width:100%;text-align:center}
  .sp-scope .subhero-cta{flex-direction:column;align-items:stretch;gap:16px}
  .sp-scope .subhero-cta .btn{width:100%;justify-content:center}
  .sp-scope .cta-band p .btn{width:100%;justify-content:center}
}
.sp-scope .facts{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:30px}
@media (max-width:760px){.sp-scope .facts{grid-template-columns:repeat(2,1fr)}}
.sp-scope .fact{background:rgba(8,28,34,.45);border:1px solid rgba(255,255,255,.22);border-radius:10px;padding:18px 20px;backdrop-filter:blur(3px)}
.sp-scope .fact b{display:block;font-size:24px;color:#fff;line-height:1.1}.sp-scope .fact span{display:block;font-size:16px;color:#dceaee;margin-top:4px}

/* Galerie */
.sp-scope .gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
@media (max-width:880px){.sp-scope .gallery{grid-template-columns:repeat(3,1fr);grid-auto-rows:180px}}
@media (max-width:560px){.sp-scope .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}}
.sp-scope .gallery a{display:block;overflow:hidden;border-radius:10px}
.sp-scope .gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.sp-scope .gallery a:hover img{transform:scale(1.07)}
.sp-scope .gallery .big{grid-column:span 2;grid-row:span 2}.sp-scope .gallery .wide{grid-column:span 2}
@media (max-width:560px){.sp-scope .gallery .big,.sp-scope .gallery .wide{grid-column:span 2;grid-row:span 1}}

/* Ausstattungs-Grid */
.sp-scope .amen-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media (max-width:880px){.sp-scope .amen-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.sp-scope .amen-grid{grid-template-columns:1fr}}
.sp-scope .amen{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:18px}
.sp-scope .amen .ic{flex:none;width:46px;height:46px;border-radius:10px;background:var(--bg-tint);color:var(--brand-deep);display:flex;align-items:center;justify-content:center}
.sp-scope .amen b{font-size:17px;color:var(--ink);font-weight:700}.sp-scope .amen span{display:block;font-size:15px;color:var(--muted)}

/* Restaurants */
.sp-scope .rest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}@media (max-width:880px){.sp-scope .rest-grid{grid-template-columns:1fr}}
.sp-scope .rest{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;display:flex;flex-direction:column}
.sp-scope .rest img{width:100%;aspect-ratio:16/10;object-fit:cover}
.sp-scope .rest-body{padding:20px 22px 24px}.sp-scope .rest-body p{color:var(--muted);font-size:16px;margin-top:6px}
.sp-scope .rest-body .tag{display:inline-block;font-size:14px;font-weight:700;color:var(--brand-deep);background:var(--bg-tint);padding:4px 10px;border-radius:8px;margin-bottom:8px}

/* Unterkünfte */
.sp-scope .units{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}@media (max-width:880px){.sp-scope .units{grid-template-columns:1fr}}
.sp-scope .unit{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.sp-scope .unit:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--brand-light)}
.sp-scope .unit img{width:100%;aspect-ratio:4/3;object-fit:cover}
.sp-scope .unit-body{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1}
.sp-scope .unit .meta{color:var(--muted);font-size:16px;margin-bottom:8px}
.sp-scope .unit .price{margin-top:auto;font-size:21px;font-weight:800;color:var(--brand-deep);padding-top:6px}

/* FAQ-Akkordeon */
.sp-scope .faq{display:grid;gap:14px}
.sp-scope .faq details{background:#fff;border:1px solid var(--line);border-radius:10px;padding:0 22px}
.sp-scope .faq summary{list-style:none;cursor:pointer;font-weight:700;color:var(--ink);font-size:18px;padding:20px 0;display:flex;justify-content:space-between;align-items:center;gap:16px}
.sp-scope .faq summary::-webkit-details-marker{display:none}
.sp-scope .faq summary::after{content:"+";font-size:24px;color:var(--brand);font-weight:700}
.sp-scope .faq details[open] summary::after{content:"–"}
.sp-scope .faq .a{padding:0 0 20px;color:var(--muted);font-size:17px}

/* Anlagen-Banner (Laufband) auf der Startseite */
.sp-scope .anlagen-marquee{overflow:hidden;position:relative;padding:8px 0}
.sp-scope .anlagen-track{display:flex;list-style:none;margin:0 auto;width:max-content;padding:0 12px;max-width:100%}
.sp-scope .anlagen-marquee.is-running .anlagen-track{margin:0;padding:0;max-width:none;animation:nz-marquee 44s linear infinite}
.sp-scope .anlagen-marquee.is-running:hover .anlagen-track,.sp-scope .anlagen-marquee.is-running:focus-within .anlagen-track{animation-play-state:paused}
/* Community-Feed-Slider ruhiger laufen lassen (war 44s = zu schnell). */
.sp-scope .anlagen-marquee.nz-feed-slider.is-running .anlagen-track{animation-duration:90s}
@keyframes nz-marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.sp-scope .anlagen-marquee.is-running .anlagen-track{animation:none}}
.sp-scope .anlage-card{flex:0 0 320px;max-width:320px;margin-right:24px}
.sp-scope .anlage-card a{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm);text-decoration:none;height:100%;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.sp-scope .anlage-card a:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--brand-light)}
.sp-scope .anlage-card .media{aspect-ratio:16/10}
.sp-scope .anlage-card a:hover .media img{transform:scale(1.06)}
.sp-scope .anlage-card-body{padding:16px 18px 20px}
.sp-scope .anlage-card-body strong{display:block;color:var(--ink);font-size:18px;font-weight:800}
.sp-scope .anlage-card-body span{display:block;color:var(--muted);font-size:15px;margin-top:4px}

/* ===================== ENTDECKEN-KARTE (Leaflet/OSM) ===================== */
.sp-scope .nz-karte{height:clamp(420px,60vh,640px);border-radius:10px;overflow:hidden;border:1px solid var(--line);z-index:0}
.sp-scope .nz-filterbar{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 18px}
.sp-scope .nz-filter{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 15px;font-size:15px;font-weight:600;color:var(--ink);cursor:pointer;transition:opacity .2s var(--ease),box-shadow .2s var(--ease)}
.sp-scope .nz-filter:hover{box-shadow:var(--shadow)}
.sp-scope .nz-filter[aria-pressed="false"]{opacity:.4}
.sp-scope .nz-filter .dot{width:12px;height:12px;border-radius:50%;flex:0 0 auto}
.sp-scope .nz-pin-wrap{background:none;border:0}
.sp-scope .nz-pin{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 2px 6px rgba(0,0,0,.35);border:2px solid #fff}
.sp-scope .nz-pin svg{transform:rotate(45deg);width:17px;height:17px;color:#fff;stroke:#fff}
.sp-scope .nz-pop{max-width:230px}
.sp-scope .nz-pop img{width:100%;height:120px;object-fit:cover;border-radius:6px;margin-bottom:8px}
.sp-scope .nz-pop h4{margin:0 0 4px;font-size:16px;color:var(--ink)}
.sp-scope .nz-pop p{margin:0 0 8px;font-size:14px;color:#3a4a4f}
.sp-scope .nz-pop a{font-weight:700;color:var(--brand-deep)}
.sp-scope .nz-orte-liste{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:34px}
@media (max-width:880px){.sp-scope .nz-orte-liste{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.sp-scope .nz-orte-liste{grid-template-columns:1fr}}
.sp-scope .nz-ort-card{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;display:flex;flex-direction:column}
.sp-scope .nz-ort-card img{width:100%;aspect-ratio:4/3;object-fit:cover}
.sp-scope .nz-ort-body{padding:16px 18px 18px}
.sp-scope .nz-ort-body .tag{display:inline-block;font-size:13px;font-weight:700;border:1px solid;border-radius:999px;padding:2px 10px;margin-bottom:8px}
.sp-scope .nz-ort-body h3{font-size:18px;margin:0 0 6px}
.sp-scope .nz-ort-body h3 a{color:var(--ink);text-decoration:none}
.sp-scope .nz-ort-body h3 a:hover{color:var(--brand-deep)}
.sp-scope .nz-ort-body p{margin:0;font-size:15px;color:var(--muted)}

/* Leaflet-Bedienelemente sichtbar machen — das WpRentals-Theme blendet
   `.leaflet-control-container` global aus (style.css). Wir re-aktivieren sie
   gezielt in unserer Karte, damit die Zoom-Buttons (+/-) und die OSM-Attribution
   erscheinen. Höhere Spezifität als die Theme-Regel. */
.sp-scope .leaflet-control-container,
.sp-scope .leaflet-top,
.sp-scope .leaflet-bottom{display:block}
.sp-scope .leaflet-control-zoom{display:inline-block;border:0;border-radius:8px;overflow:hidden;box-shadow:0 2px 10px rgba(12,42,51,.18)}
.sp-scope .leaflet-control-zoom a{width:36px;height:36px;line-height:36px;font-size:20px;color:var(--ink);background:#fff;box-shadow:none;border-bottom:1px solid var(--line)}
.sp-scope .leaflet-control-zoom a:last-child{border-bottom:0}
.sp-scope .leaflet-control-zoom a:hover{background:var(--bg-soft);color:var(--brand-deep)}
.sp-scope .leaflet-control-attribution{font-size:11px}

/* Leaflet-Popup-Hintergrund — das WpRentals-Theme setzt
   `.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:transparent!important}`
   (style.css) → der weiße Popup-Kasten fehlte. Hier mit !important zurückgeholt. */
.sp-scope .leaflet-popup-content-wrapper{background:#fff !important;color:var(--text) !important;border-radius:12px;box-shadow:0 6px 22px rgba(12,42,51,.22) !important}
.sp-scope .leaflet-popup-tip{background:#fff !important;box-shadow:none !important}
.sp-scope .leaflet-popup-content{margin:14px 16px}

/* Kompakte Orts-Liste unter der Karte (statt großer Karten) */
.sp-scope .nz-orte-kompakt{list-style:none;margin:26px 0 0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:2px 30px}
@media (max-width:880px){.sp-scope .nz-orte-kompakt{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.sp-scope .nz-orte-kompakt{grid-template-columns:1fr}}
.sp-scope .nz-orte-kompakt li{display:flex;align-items:center;gap:11px;font-size:16px;padding:9px 0;border-bottom:1px solid var(--line)}
.sp-scope .nz-orte-kompakt .dot{width:11px;height:11px;border-radius:50%;flex:0 0 auto}
.sp-scope .nz-orte-kompakt a{color:var(--ink);font-weight:600}
.sp-scope .nz-orte-kompakt a:hover{color:var(--brand-deep)}
.sp-scope .nz-orte-kompakt em{font-style:normal;color:var(--muted);font-size:13px;margin-left:auto;white-space:nowrap}

/* Bootstrap-Kollision: Das Theme lädt bootstrap.css mit
   `.btn:hover,.btn:focus,.btn.focus{color:#333}` — das überschrieb unsere
   Button-Textfarbe (grau/blass auf farbigem Button, v. a. bei Fokus).
   Button-Textfarben in allen Zuständen mit !important zurückgeholt. */
.sp-scope .btn-primary,.sp-scope .btn-primary:hover,.sp-scope .btn-primary:focus{color:#fff!important}
.sp-scope .btn-outline-light,.sp-scope .btn-outline-light:hover,.sp-scope .btn-outline-light:focus{color:#fff!important}
.sp-scope .btn-ghost,.sp-scope .btn-ghost:focus{color:var(--brand-deep)!important}
.sp-scope .btn-ghost:hover{color:var(--brand-deep)!important}
.sp-scope .btn-light,.sp-scope .btn-light:focus{color:var(--brand-deep)!important}
.sp-scope .btn-light:hover{color:var(--ink)!important}

/* Leichter WYSIWYG-Editor (Frontend-Formulare, [data-rich]) */
.sp-scope .nz-rich{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff}
.sp-scope .nz-rich-bar{display:flex;flex-wrap:wrap;gap:4px;padding:8px;background:var(--bg-soft);border-bottom:1px solid var(--line)}
.sp-scope .nz-rich-btn{min-height:36px;padding:6px 12px;border:1px solid var(--line);background:#fff;border-radius:8px;font-size:14px;font-weight:600;color:var(--ink);cursor:pointer;line-height:1}
.sp-scope .nz-rich-btn:hover{background:var(--bg-tint);border-color:var(--brand);color:var(--brand-deep)}
.sp-scope .nz-rich-ed{min-height:200px;padding:16px 18px;font-size:17px;line-height:1.7;color:var(--text);outline:none}
.sp-scope .nz-rich-ed:focus{box-shadow:inset 0 0 0 2px var(--brand)}
.sp-scope .nz-rich-ed h2{font-size:24px;margin:14px 0 6px}
.sp-scope .nz-rich-ed h3{font-size:20px;margin:12px 0 6px}
.sp-scope .nz-rich-ed p{margin:0 0 10px}
.sp-scope .nz-rich-ed ul,.sp-scope .nz-rich-ed ol{margin:0 0 10px 22px}
.sp-scope .nz-rich-ed a{color:var(--brand-deep);text-decoration:underline}

/* Community-Feed (Aktivitäts-Stream, BuddyBoss-artig) */
.sp-scope .nz-feed{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:900px){.sp-scope .nz-feed{grid-template-columns:1fr 1fr;gap:22px;align-items:start}}
.sp-scope .nz-feed-empty{background:var(--bg-soft);border:1px dashed var(--line);border-radius:12px;padding:28px;text-align:center;color:var(--muted)}
.sp-scope .nz-feed-item{display:flex;gap:16px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);padding:18px 20px}
.sp-scope .nz-feed-ic{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;color:#fff;border:2px solid #fff;box-shadow:0 2px 8px rgba(12,42,51,.18)}
.sp-scope .nz-feed-ic svg{width:22px;height:22px;color:#fff;stroke:#fff}
.sp-scope .nz-feed-body{flex:1;min-width:0}
.sp-scope .nz-feed-meta{font-size:14px;color:var(--muted);margin:0 0 4px}
.sp-scope .nz-feed-type{font-weight:700}
.sp-scope .nz-feed-title{font-size:20px;margin:0 0 8px}
.sp-scope .nz-feed-title a{color:var(--ink)}
.sp-scope .nz-feed-title a:hover{color:var(--brand-deep)}
.sp-scope .nz-feed-media{display:block;border-radius:10px;overflow:hidden;margin:0 0 10px}
.sp-scope .nz-feed-media img{width:100%;max-height:320px;object-fit:cover}
.sp-scope .nz-feed-text{font-size:16px;color:var(--text);margin:0 0 12px}
.sp-scope .nz-feed-actions{margin:0}
@media (max-width:560px){.sp-scope .nz-feed-item{flex-direction:column;gap:10px}}

/* Veranstaltungs-Übersicht */
.sp-scope .nz-ev-bar{display:flex;flex-wrap:wrap;gap:22px 32px;align-items:flex-start;margin:0 0 26px;padding:0 0 20px;border-bottom:1px solid var(--line)}
.sp-scope .nz-ev-sort,.sp-scope .nz-ev-filter{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.sp-scope .nz-ev-barlabel{font-size:14px;font-weight:700;color:var(--muted);margin-right:2px}
.sp-scope .nz-chip{display:inline-block;padding:7px 14px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--ink);font-size:14px;font-weight:600;line-height:1.2;text-decoration:none;transition:background .15s,color .15s,border-color .15s}
.sp-scope .nz-chip:hover{border-color:var(--brand);color:var(--brand-deep)}
.sp-scope .nz-chip.is-active{background:var(--brand);border-color:var(--brand);color:#fff}
.sp-scope .nz-ev-group{font-size:22px;margin:34px 0 16px}
.sp-scope .nz-ev-group:first-of-type{margin-top:0}
/* Kompakte Listen-Darstellung: kleines Thumbnail links, Text rechts */
.sp-scope .nz-events{display:flex;flex-direction:column;gap:14px}
.sp-scope .nz-ev{display:flex;flex-direction:row;align-items:stretch;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-sm);overflow:hidden}
.sp-scope .nz-ev-media{flex:0 0 168px;width:168px;display:block;overflow:hidden;background:var(--bg-soft)}
.sp-scope .nz-ev-media img{width:100%;height:100%;min-height:130px;object-fit:cover;display:block;transition:transform .4s}
.sp-scope .nz-ev:hover .nz-ev-media img{transform:scale(1.04)}
.sp-scope .nz-ev-body{display:flex;flex-direction:column;flex:1;min-width:0;padding:14px 18px}
.sp-scope .nz-ev-meta{font-size:12px;color:var(--muted);margin:0 0 4px;text-transform:uppercase;letter-spacing:.04em}
.sp-scope .nz-ev-typ{font-weight:700;color:#e67e22}
.sp-scope .nz-ev-date{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--ink);margin:0 0 4px}
.sp-scope .nz-ev-cal{display:inline-flex;color:#e67e22}
.sp-scope .nz-ev-cal svg{width:16px;height:16px}
.sp-scope .nz-ev-title{font-size:17px;margin:0 0 6px;line-height:1.3}
.sp-scope .nz-ev-title a{color:var(--ink)}
.sp-scope .nz-ev-title a:hover{color:var(--brand-deep)}
.sp-scope .nz-ev-text{font-size:14px;color:var(--text);margin:0 0 10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sp-scope .nz-ev-actions{margin:auto 0 0}
@media(max-width:560px){
  .sp-scope .nz-ev-media{flex:0 0 104px;width:104px}
  .sp-scope .nz-ev-body{padding:12px 14px}
  .sp-scope .nz-ev-text{display:none}
}
/* Gitter-Ansicht (umschaltbar via ?ansicht=gitter): große Karten, Bild oben */
.sp-scope .nz-events.is-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:680px){.sp-scope .nz-events.is-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1040px){.sp-scope .nz-events.is-grid{grid-template-columns:1fr 1fr 1fr}}
.sp-scope .nz-events.is-grid .nz-ev{flex-direction:column}
.sp-scope .nz-events.is-grid .nz-ev-media{flex:0 0 auto;width:100%}
.sp-scope .nz-events.is-grid .nz-ev-media img{height:180px;min-height:0}
.sp-scope .nz-events.is-grid .nz-ev-body{padding:16px 18px 18px}
.sp-scope .nz-events.is-grid .nz-ev-text{-webkit-line-clamp:4}
@media(max-width:560px){.sp-scope .nz-events.is-grid .nz-ev-text{display:-webkit-box}}

/* Kleinanzeigen */
.sp-scope .nz-anz-filter{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:0 0 24px;padding:0 0 22px;border-bottom:1px solid var(--line)}
.sp-scope .nz-anz-filter input[type="search"]{flex:1 1 220px;min-width:180px}
.sp-scope .nz-anz-filter select{flex:0 1 auto}
.sp-scope .nz-anz-filter .btn{flex:0 0 auto}
.sp-scope .nz-anz-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:600px){.sp-scope .nz-anz-grid{grid-template-columns:1fr 1fr}}
@media(min-width:960px){.sp-scope .nz-anz-grid{grid-template-columns:1fr 1fr 1fr}}
@media(min-width:1240px){.sp-scope .nz-anz-grid{grid-template-columns:repeat(4,1fr)}}
.sp-scope .nz-anz-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.sp-scope .nz-anz-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.sp-scope .nz-anz-media{position:relative;display:block;aspect-ratio:4/3;background:var(--bg-tint);overflow:hidden}
.sp-scope .nz-anz-media img{width:100%;height:100%;object-fit:cover;display:block}
.sp-scope .nz-anz-noimg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--brand-light)}
.sp-scope .nz-anz-noimg svg{width:42px;height:42px}
.sp-scope .nz-anz-badge{position:absolute;top:10px;left:10px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;color:#fff;background:#2e9e4f}
.sp-scope .nz-anz-badge-suche{background:#2563a8}
.sp-scope .nz-anz-body{display:flex;flex-direction:column;gap:4px;padding:13px 15px 15px}
.sp-scope .nz-anz-title{font-size:16px;margin:0;line-height:1.3}
.sp-scope .nz-anz-title a{color:var(--ink)}
.sp-scope .nz-anz-title a:hover{color:var(--brand-deep)}
.sp-scope .nz-anz-price{margin:0;font-size:17px;font-weight:800;color:var(--brand-deep)}
.sp-scope .nz-anz-meta{margin:0;font-size:13px;color:var(--muted)}

/* Vorteile & Coupons (Perfect-Day-Kooperation) */
.sp-scope .icon-card .step-num{position:absolute;top:18px;right:20px;font-size:34px;font-weight:800;line-height:1;color:var(--brand-light);opacity:.45}
.sp-scope .icon-card{position:relative}
.sp-scope .nz-vorteil-band{text-align:center}
.sp-scope .nz-vorteil-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;border-radius:999px;background:rgba(255,255,255,.16);color:#fff;font-weight:700;font-size:14px;margin-bottom:14px}
.sp-scope .nz-vorteil-badge svg{width:18px;height:18px}
.sp-scope .nz-vorteil-slim{display:flex;flex-wrap:wrap;align-items:center;gap:14px 18px;background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:16px 20px;margin:30px 0}
.sp-scope .nz-vorteil-slim .nz-vorteil-ic{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--brand);color:#fff}
.sp-scope .nz-vorteil-slim .nz-vorteil-ic svg{width:22px;height:22px}
.sp-scope .nz-vorteil-slim .nz-vorteil-txt{flex:1;min-width:200px;font-size:16px;color:var(--text)}
.sp-scope .nz-vorteil-slim .btn{flex:0 0 auto}

/* Inline-Hinweis im Formular-Label */
.sp-scope .form-hint{font-weight:400;color:var(--muted);font-size:.85em}

/* Startseite: drei Einstiegs-Hubs (Sublink-Listen) */
.sp-scope .nz-pathlinks{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-direction:column;gap:9px}
.sp-scope .nz-pathlinks li{margin:0}
.sp-scope .nz-pathlinks a{display:inline-flex;align-items:center;gap:8px;color:var(--brand-deep);font-weight:600;text-decoration:none}
.sp-scope .nz-pathlinks a::before{content:"\203A";color:var(--brand);font-weight:700;font-size:18px;line-height:1}
.sp-scope .nz-pathlinks a:hover{color:var(--brand)}
.sp-scope .nz-pathlinks a:hover::before{transform:translateX(2px)}

/* Perfect-Day-App: Sprach-Banner (reines CSS-Umschalten) + Store-Badges */
.sp-scope .nz-applang{max-width:760px;margin:0 auto}
.sp-scope .nz-applang-r{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;clip:rect(0 0 0 0)}
.sp-scope .nz-applang-tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:0 0 18px}
.sp-scope .nz-applang-tabs label{display:inline-block;padding:8px 16px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--ink);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.sp-scope .nz-applang-tabs label:hover{border-color:var(--brand);color:var(--brand-deep)}
.sp-scope .nz-applang-stage{border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);background:var(--bg-soft)}
.sp-scope .nz-applang-img{display:none;width:100%;height:auto}
.sp-scope #al-de:checked ~ .nz-applang-tabs label[for="al-de"],
.sp-scope #al-en:checked ~ .nz-applang-tabs label[for="al-en"],
.sp-scope #al-tr:checked ~ .nz-applang-tabs label[for="al-tr"],
.sp-scope #al-ru:checked ~ .nz-applang-tabs label[for="al-ru"],
.sp-scope #al-es:checked ~ .nz-applang-tabs label[for="al-es"]{background:var(--brand);border-color:var(--brand);color:#fff}
.sp-scope #al-de:checked ~ .nz-applang-stage .b-de,
.sp-scope #al-en:checked ~ .nz-applang-stage .b-en,
.sp-scope #al-tr:checked ~ .nz-applang-stage .b-tr,
.sp-scope #al-ru:checked ~ .nz-applang-stage .b-ru,
.sp-scope #al-es:checked ~ .nz-applang-stage .b-es{display:block}
.sp-scope .nz-store-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin:24px 0 0}
.sp-scope .nz-store-badge{display:inline-flex;align-items:center;gap:11px;padding:10px 18px;border-radius:12px;background:var(--ink);color:#fff;text-decoration:none;transition:transform .2s var(--ease),background .2s}
.sp-scope .nz-store-badge:hover{background:#000;transform:translateY(-2px);color:#fff}
.sp-scope .nz-store-badge svg{width:26px;height:26px;flex:0 0 auto;color:#fff}
.sp-scope .nz-store-badge span{display:flex;flex-direction:column;line-height:1.12;text-align:left}
.sp-scope .nz-store-badge small{font-size:11px;opacity:.85;text-transform:uppercase;letter-spacing:.5px}
.sp-scope .nz-store-badge strong{font-size:18px;font-weight:700}

/* ============================================================================
 * THEME-HEADER FIX (GLOBAL, NICHT .sp-scope!) — WpRentals-Hauptmenü-Überlauf.
 * Mit 8 Menüpunkten lief das Menü unter „Anmeldung/Registrieren". Verifiziert
 * live bei 1727px (65px Luft). Liegt bewusst außerhalb von .sp-scope, da der
 * Header zum Theme gehört. Siehe auch Customizer-Hinweis im Verlauf.
 * ========================================================================== */
@media (min-width:1101px){
  .master_header .header_wrapper nav.main-navigation ul.menu > li > a{
    padding-left:9px !important;
    padding-right:9px !important;
    letter-spacing:.2px !important;
    font-size:13px !important;
  }
}
/* Schmaler als ~1660px: auf das theme-eigene Burger-Menü umschalten, da das
   8-Punkte-Menü dort nicht mehr neben Login + Button passt. */
@media (max-width:1660px){
  .master_header .header_wrapper{ display:none !important; }
  .master_header .mobile_header{ display:block !important; }
}

/* ==========================================================================
   Formular-Popups (Modals). Öffnen via [data-nz-open="id"], schließen via
   [data-nz-close] / Overlay-Klick / ESC. Fokus-Trap + Scroll-Lock in content.js.
   ========================================================================== */
.sp-scope .nz-modal[hidden]{display:none}
.sp-scope .nz-modal{position:fixed;inset:0;z-index:100000;display:flex;align-items:flex-start;justify-content:center;padding:28px 16px;background:rgba(8,28,34,.55);overflow-y:auto;-webkit-overflow-scrolling:touch}
.sp-scope .nz-modal__panel{position:relative;background:#fff;color:var(--text);border-radius:14px;max-width:680px;width:100%;margin:auto;padding:38px clamp(20px,4vw,40px);box-shadow:0 24px 70px rgba(8,28,34,.4)}
.sp-scope .nz-modal__panel h2{margin:0 0 8px}
.sp-scope .nz-modal__intro{color:var(--muted);margin:0 0 18px}
.sp-scope .nz-modal__close{position:absolute;top:12px;right:12px;width:44px;height:44px;border:0;border-radius:10px;background:var(--bg-tint);color:var(--brand-deep);font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.sp-scope .nz-modal__close:hover{background:var(--line)}
.sp-scope .nz-modal__close:focus-visible{outline:3px solid var(--gold,#d2a86d);outline-offset:2px}
html.nz-modal-lock{overflow:hidden}
@media (max-width:560px){
  .sp-scope .nz-modal{padding:0}
  .sp-scope .nz-modal__panel{border-radius:0;min-height:100vh;padding-top:60px}
}

/* Partnerseite — Persönliche Einladung (ersetzt den Bild-Hero). */
.sp-scope .nz-invite{max-width:760px}
.sp-scope .nz-invite-hello{font-size:18px;font-weight:600;color:#33474d;margin:0 0 6px}
.sp-scope .nz-invite-why{font-size:18px;line-height:1.6;color:var(--muted);margin:14px 0 24px}
.sp-scope .nz-invite-focus{display:flex;gap:16px;align-items:flex-start;background:var(--bg-tint,#eef3f4);border-left:4px solid var(--brand-deep,#1b5163);border-radius:0 14px 14px 0;padding:20px 22px;margin:0 0 24px}
.sp-scope .nz-invite-focus .icon{flex:0 0 auto;color:var(--brand-deep,#1b5163)}
.sp-scope .nz-invite-focus-title{margin:0 0 6px;font-size:20px;color:#0c2a33}
.sp-scope .nz-invite-focus-text{margin:0;color:#33474d;line-height:1.55}
.sp-scope .nz-invite-cta{margin:0}
@media (max-width:560px){
  .sp-scope .nz-invite-focus{flex-direction:column;gap:10px;padding:18px}
}

/* „Was ist heute los?" — KI-Tagestext (linksbündig statt zentriertem cta-band). */
.sp-scope .nz-heute-intro{text-align:left}
.sp-scope .nz-heute-intro h2,.sp-scope .nz-heute-intro h3{margin:0 0 8px}
.sp-scope .nz-heute-intro p{margin:0 0 12px;font-size:17px;line-height:1.6}
.sp-scope .nz-heute-intro :last-child{margin-bottom:0}

/* [nz_mitmachen]-Wrapper (.nz-mm) in Button-Reihen als reines Flex-Item behandeln,
   damit sein .btn sauber neben den übrigen CTAs sitzt. */
.subhero-cta .nz-mm,.hero-cta .nz-mm,.cta-band .nz-mm{display:contents}
/* Auf dem dunklen CTA-Band den [nz_mitmachen]-Primary als helle Variante (Kontrast). */
.sp-scope .cta-band .nz-mm .btn,.sp-scope .cta-band .nz-mm .btn-primary{background:#fff!important;color:var(--brand-deep)!important;border-color:#fff!important}
.sp-scope .cta-band .nz-mm .btn:hover,.sp-scope .cta-band .nz-mm .btn-primary:hover{background:#eef4f5!important;color:var(--brand-deep)!important}
