/* ==========================================================================
   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}}

.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}

/* 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}
.sp-scope .field-checkbox input{width:auto;min-height:auto;margin-top:5px}
.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 */
.sp-scope .reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.sp-scope .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.sp-scope .reveal{opacity:1!important;transform:none!important;transition:none!important}}

/* ==========================================================================
   Fullwidth-Fallback — NUR Startseite (body.nz-fullbleed).
   ========================================================================== */
body.nz-fullbleed .widget-area-sidebar,
body.nz-fullbleed aside.sidebar,
body.nz-fullbleed #sidebar{display:none!important}
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}
body.nz-fullbleed .sp-scope{width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);position:relative;overflow-x:hidden}
body.nz-fullbleed .single-title,
body.nz-fullbleed h1.entry-title{display:none!important}
body.nz-fullbleed .single-content{padding-top:0!important;margin-top:0!important}

/* ==========================================================================
   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}
.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}
@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}
.sp-scope .nz-events{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:680px){.sp-scope .nz-events{grid-template-columns:1fr 1fr}}
@media(min-width:1040px){.sp-scope .nz-events{grid-template-columns:1fr 1fr 1fr}}
.sp-scope .nz-ev{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden}
.sp-scope .nz-ev-media{display:block;overflow:hidden}
.sp-scope .nz-ev-media img{width:100%;height:180px;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;padding:16px 18px 18px}
.sp-scope .nz-ev-meta{font-size:13px;color:var(--muted);margin:0 0 6px;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:15px;font-weight:600;color:var(--ink);margin:0 0 6px}
.sp-scope .nz-ev-cal{display:inline-flex;color:#e67e22}
.sp-scope .nz-ev-cal svg{width:17px;height:17px}
.sp-scope .nz-ev-title{font-size:19px;margin:0 0 8px}
.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:15px;color:var(--text);margin:0 0 14px}
.sp-scope .nz-ev-actions{margin:auto 0 0}

/* 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}

/* ============================================================================
 * 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; }
}
