@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@500;600;700;800&family=Inter:wght@400;500;600;700&display=swap');
:root{--font:'Inter',system-ui,-apple-system,sans-serif}

/* ============== TOKENS — GoCamping CI (Grün #00A057 / Navy #003244) ============== */
:root{
  --green:#00A057; --green-600:#008a4c; --green-700:#00713e; --green-50:#e9f7ef; --green-100:#d2f0e0;
  --navy:#003244; --navy-2:#0a4254; --navy-soft:#10242b;
  --ink:#14282f; --muted:#5d7177; --faint:#8aa0a4;
  --line:#e6ece9; --line-2:#eef3f0; --bg:#fff; --bg-soft:#f4f8f5;
  --amber:#ffb43a; --coral:#ff6a45;
  --lg1:#00A057; --lg2:#003244;
  --r:18px; --r-sm:12px; --r-lg:26px; --pill:999px;
  --sh-sm:0 1px 2px rgba(16,40,38,.06),0 2px 8px rgba(16,40,38,.05);
  --sh:0 6px 18px rgba(16,40,38,.08),0 2px 6px rgba(16,40,38,.04);
  --sh-lg:0 24px 50px -18px rgba(0,50,68,.35);
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --display:'Plus Jakarta Sans',var(--font);
  --hdr-h:65px; --sw-h:0px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);font-size:15.5px;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:clip}
h1,h2,h3,h4{font-family:var(--display);margin:0;line-height:1.12;letter-spacing:-.02em;color:var(--navy-soft)}
p{margin:0}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:0;background:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 clamp(20px,3.5vw,44px)}
.eyebrow{font-family:var(--display);font-weight:700;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--green-700)}
.muted{color:var(--muted)}
section{scroll-margin-top:90px}

/* logo */
.brand-logo{height:28px;width:auto;display:block}
.brand-logo--light{--lg1:#23d486;--lg2:#fff}

/* ============== MOCKUP SWITCHER ============== */
.sw{position:sticky;top:0;z-index:95;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.sw-in{max-width:1200px;margin:0 auto;padding:8px clamp(20px,3.5vw,44px);display:flex;align-items:center;gap:12px}
.sw-tag{font-size:12px;font-weight:600;color:var(--faint);display:flex;align-items:center;gap:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sw-dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex:0 0 auto}
.sw-btns{margin-left:auto;display:flex;gap:4px;background:var(--bg-soft);padding:4px;border-radius:var(--pill);border:1px solid var(--line);flex:0 0 auto}
.sw-btn{font-size:12.5px;font-weight:600;color:var(--muted);padding:6px 13px;border-radius:var(--pill);white-space:nowrap}
.sw-btn.on{background:var(--navy);color:#fff;box-shadow:var(--sh-sm)}

.view,.view.on{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ============== BUTTONS ============== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--display);font-weight:700;font-size:14.5px;border-radius:var(--pill);padding:11px 20px;transition:.18s;white-space:nowrap;min-height:44px}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 6px 16px -4px rgba(0,160,87,.5)}
.btn-primary:hover{background:var(--green-600)}
.btn-ghost{background:rgba(255,255,255,.16);color:#fff;border:1px solid rgba(255,255,255,.28)}
.btn-ghost:hover{background:rgba(255,255,255,.26)}
.btn-outline{background:#fff;color:var(--navy);border:1.5px solid var(--line)}
.btn-outline:hover{border-color:var(--green);color:var(--green-700)}
.btn-lg{padding:14px 26px;font-size:15.5px}
.btn-block{width:100%}

/* ============== HEADER ============== */
.hdr{position:absolute;top:var(--sw-h);left:0;right:0;z-index:40}
.hdr--solid{position:sticky;top:var(--sw-h);background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;gap:24px;padding:14px 0;min-height:var(--hdr-h)}
.nav{display:flex;gap:22px;align-items:center}
.nav a{font-size:14.5px;font-weight:500;color:var(--ink);opacity:.86;transition:.15s}
.nav a:hover{opacity:1;color:var(--green-700)}
.hdr--hero .nav a,.hdr--hero .lang{color:#fff;opacity:.94}
.hdr-act{margin-left:auto;display:flex;align-items:center;gap:14px}
.lang{font-size:13px;font-weight:600;color:var(--muted);display:flex;gap:6px;align-items:center}
.burger{display:none;width:44px;height:44px;border-radius:12px;align-items:center;justify-content:center;flex-direction:column;gap:5px;border:1px solid var(--line);background:#fff}
.hdr--hero .burger{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.3)}
.burger span{width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}
.hdr--hero .burger span{background:#fff}
/* mobile menu */
.mnav{display:none;position:fixed;inset:0;z-index:120;background:rgba(16,36,43,.5);backdrop-filter:blur(3px)}
.mnav.open{display:block}
.mnav-panel{position:absolute;top:0;right:0;width:min(82vw,330px);height:100%;background:#fff;box-shadow:var(--sh-lg);padding:18px;display:flex;flex-direction:column;gap:4px;animation:slidein .25s ease}
@keyframes slidein{from{transform:translateX(100%)}to{transform:none}}
.mnav-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.mnav-close{width:42px;height:42px;border-radius:12px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--ink)}
.mnav a{padding:14px 12px;border-radius:12px;font-family:var(--display);font-weight:700;font-size:16px;color:var(--navy-soft)}
.mnav a:hover{background:var(--bg-soft)}
.mnav .btn{margin-top:12px}

/* ============== HERO ============== */
.hero{position:relative;min-height:640px;display:flex;align-items:center;padding:148px 0 84px;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:linear-gradient(120deg,#04323f,#075b4e 55%,#0a7d57)}
.hero-bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.82}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,40,50,.45),rgba(0,40,50,.15) 40%,rgba(0,40,50,.66))}
.hero-in{position:relative;z-index:2;width:100%;max-width:960px}
/* keep the headline/intro text block at its original measure so only the search row widens */
.hero h1{max-width:760px}
.hero .hero-sub,.hero .eyebrow{max-width:620px}
.hero h1{color:#fff;font-size:clamp(34px,5.4vw,62px);font-weight:800;letter-spacing:-.03em}
.hero h1 em{font-style:normal;color:#9af0c4}
.hero-sub{font-size:clamp(16px,2.2vw,18px);margin-top:16px;max-width:560px;color:rgba(255,255,255,.92)}
.hero-pills{display:flex;gap:9px;flex-wrap:wrap;margin-top:20px}
.hero-pill{font-size:13px;font-weight:600;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);padding:7px 13px;border-radius:var(--pill);backdrop-filter:blur(4px)}

/* search */
.search-toggle{display:flex;gap:6px;margin-bottom:14px}
.seg{font-size:13.5px;font-weight:600;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);padding:9px 16px;border-radius:var(--pill);display:inline-flex;gap:8px;align-items:center;min-height:42px}
.seg.on{background:#fff;color:var(--navy);border-color:#fff}
.search{position:relative;z-index:3;margin-top:26px;background:#fff;border-radius:var(--r-lg);padding:8px;box-shadow:var(--sh-lg);display:flex;align-items:stretch;gap:2px;max-width:1030px}
.search-field{flex:1;padding:13px 18px;border-radius:18px;transition:.15s;cursor:pointer;min-width:0}
.search-field:hover{background:var(--bg-soft)}
.search-field label{display:block;font-family:var(--display);font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--green-700);margin-bottom:3px}
.search-field .val{font-size:15px;font-weight:600;color:var(--navy-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-field .val.ph{color:var(--faint);font-weight:500}
.search-sep{width:1px;background:var(--line);margin:10px 0}
.search-go{flex:0 0 auto;align-self:center;margin:4px;min-width:58px;height:58px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px -4px rgba(0,160,87,.6);font-family:var(--display);font-weight:700;gap:8px}
.search-go:hover{background:var(--green-600)}
.search-go .lbl{display:none}

/* trust strip */
.trust{background:var(--bg-soft);border-bottom:1px solid var(--line)}
.trust-in{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:20px 0}
.trust-item{display:flex;align-items:center;gap:12px;min-width:0}
.trust-ic{width:42px;height:42px;border-radius:12px;background:var(--green-50);color:var(--green-700);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.trust-num{font-family:var(--display);font-weight:800;font-size:19px;color:var(--navy-soft);line-height:1}
.trust-lbl{font-size:12.5px;color:var(--muted)}

/* section heads */
.sec{padding:60px 0}
.shead{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:24px}
.shead h2{font-size:clamp(24px,3.2vw,36px);font-weight:800}
.shead p{color:var(--muted);margin-top:8px;max-width:520px}
.link-more{font-family:var(--display);font-weight:700;font-size:14px;color:var(--green-700);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.link-more:hover{gap:9px}

/* categories */
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cat{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:1/1.06;color:#fff;display:flex;align-items:flex-end;padding:18px;box-shadow:var(--sh-sm);transition:.22s;background:linear-gradient(135deg,#0a7d57,#04323f)}
.cat:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.cat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cat::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,40,50,.78))}
.cat span{position:relative;z-index:2;font-family:var(--display);font-weight:700;font-size:17px}
.cat small{position:relative;z-index:2;display:block;font-size:12.5px;opacity:.86;margin-top:2px}

/* cards */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.22s;cursor:pointer;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);box-shadow:var(--sh);border-color:transparent}
.card-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:linear-gradient(135deg,#0a7d57,#04323f)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .card-img img{transform:scale(1.05)}
.card-fav{position:absolute;top:11px;right:11px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:var(--navy);z-index:2}
.card-fav:hover{color:var(--coral);background:#fff}
.badge{position:absolute;top:12px;left:12px;z-index:2;font-size:11.5px;font-weight:700;font-family:var(--display);padding:5px 11px;border-radius:var(--pill);box-shadow:var(--sh-sm);display:inline-flex;gap:5px;align-items:center}
.badge--anfrage{background:#fff;color:var(--navy)}
.badge--buchbar{background:var(--green);color:#fff}
.card-body{padding:15px 16px 17px;display:flex;flex-direction:column;gap:7px;flex:1}
.card-loc{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--muted);font-weight:500}
.card-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.card h3{font-size:17.5px;font-weight:700}
.rating{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:700;color:var(--navy);background:var(--green-50);padding:4px 9px;border-radius:9px;white-space:nowrap;flex:0 0 auto}
.rating .star{color:var(--amber)}
.revs{font-size:12px;color:var(--muted)}
.card-amen{display:flex;gap:6px;flex-wrap:wrap}
.chip{font-size:11.5px;font-weight:500;color:var(--muted);background:var(--bg-soft);border:1px solid var(--line);padding:3px 9px;border-radius:var(--pill)}
.card-foot{margin-top:auto;padding-top:12px;border-top:1px solid var(--line-2);display:flex;align-items:center;justify-content:space-between;gap:10px}
.price .from{font-size:11px;color:var(--faint);font-weight:500}
.price .amt{font-family:var(--display);font-weight:800;font-size:20px;color:var(--navy-soft)}
.price .amt small{font-size:12.5px;font-weight:500;color:var(--muted)}

/* regions */
.regions{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.region{position:relative;border-radius:var(--r);overflow:hidden;height:200px;color:#fff;display:flex;align-items:flex-end;padding:20px;background:linear-gradient(135deg,#0a7d57,#04323f)}
.region img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.region::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(0,40,50,.8))}
.region b{position:relative;z-index:2;font-family:var(--display);font-size:19px;font-weight:700}
.region small{position:relative;z-index:2;opacity:.86;font-size:13px;margin-left:auto}

/* app band */
.band{background:linear-gradient(115deg,var(--navy),var(--navy-2) 60%,var(--green-700) 130%);border-radius:var(--r-lg);padding:48px 50px;color:#fff;display:flex;align-items:center;gap:40px;overflow:hidden;position:relative}
.band-txt{flex:1;position:relative;z-index:2}
.band h2{color:#fff;font-size:clamp(26px,3.4vw,32px);font-weight:800}
.band p{color:rgba(255,255,255,.88);margin-top:12px;max-width:440px}
.band-actions{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap}
.store{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.24);padding:11px 18px;border-radius:14px;font-weight:600;font-size:14px;min-height:44px}
.band-deco{position:absolute;right:-40px;bottom:-60px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(154,240,196,.22),transparent 70%)}

/* footer */
.foot{background:var(--navy-soft);color:rgba(255,255,255,.72);padding:54px 0 26px;margin-top:6px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot h4{color:#fff;font-size:14px;font-weight:700;margin-bottom:14px}
.foot a{display:block;font-size:14px;color:rgba(255,255,255,.66);padding:6px 0}
.foot a:hover{color:#23d486}
.foot-intro p{font-size:14px;margin:14px 0 16px;max-width:280px}
.foot-soc{display:flex;gap:10px}
.foot-soc a{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#fff;padding:0}
.foot-soc a:hover{background:var(--green)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:22px;gap:14px;flex-wrap:wrap;font-size:13px}
.foot-partners{display:flex;gap:16px;align-items:center;opacity:.6;font-weight:600;font-size:12.5px}

/* ============== LISTINGS ============== */
.lpage{background:var(--bg-soft);min-height:100vh}
.lhero{background:#fff;border-bottom:1px solid var(--line);padding-top:14px}
.crumb{font-size:13px;color:var(--muted);padding:16px 0 6px}.crumb a{color:var(--green-700)}.crumb b{color:var(--ink)}
.lhead{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;padding-bottom:16px;flex-wrap:wrap}
.lhead h1{font-size:clamp(24px,3.4vw,30px);font-weight:800}
.lhead .lsub{color:var(--muted);margin-top:6px;font-size:14.5px}
.lintro{color:var(--muted);font-size:14.5px;line-height:1.6;max-width:840px;padding-bottom:18px}
.fbar{position:sticky;top:calc(var(--sw-h) + var(--hdr-h));z-index:30;background:rgba(244,248,245,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:12px 0}
.fbar-in{display:flex;align-items:center;gap:9px}
.fbar-scroll{display:flex;gap:9px;overflow-x:auto;flex:1;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}
.fbar-scroll::-webkit-scrollbar{display:none}
.fbtn{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:var(--ink);background:#fff;border:1px solid var(--line);padding:9px 14px;border-radius:var(--pill);white-space:nowrap;flex:0 0 auto;min-height:40px}
.fbtn:hover{border-color:var(--green);color:var(--green-700)}
.fbtn.on{background:var(--green-50);border-color:var(--green);color:var(--green-700)}
.fbar-right{display:flex;align-items:center;gap:9px;flex:0 0 auto}
.sel{font-size:13.5px;font-weight:600;color:var(--ink);background:#fff;border:1px solid var(--line);padding:9px 14px;border-radius:var(--pill);white-space:nowrap}
.maptoggle{display:none}
.lbody{display:grid;grid-template-columns:1fr 380px;gap:24px;padding:22px 0 60px;align-items:start}
.lcount{font-size:14px;color:var(--muted);margin-bottom:14px}.lcount b{color:var(--ink)}
.rlist{display:grid;gap:18px}
.rcard{display:grid;grid-template-columns:280px 1fr;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:.2s}
.rcard:hover{box-shadow:var(--sh);border-color:transparent;transform:translateY(-2px)}
.rcard .card-img{aspect-ratio:auto;height:100%;min-height:210px}
.rcard-body{padding:16px 18px;display:flex;flex-direction:column;gap:8px}
.rcard-desc{font-size:13.5px;color:var(--muted);line-height:1.5}
.rcard-body .card-foot{border-top:0;padding-top:6px}
.maprail{position:sticky;top:calc(var(--sw-h) + var(--hdr-h) + 60px);height:calc(100vh - 180px);min-height:520px;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh-sm)}
.map-canvas{position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,#cfe8d8,transparent 45%),radial-gradient(circle at 75% 65%,#cde6ef,transparent 50%),linear-gradient(135deg,#eaf3ee,#dbeae2)}
.map-canvas::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(0,114,62,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(0,114,62,.06) 1px,transparent 1px);background-size:38px 38px}
.map-river{position:absolute;left:0;right:0;top:55%;height:30px;background:#a9d3e6;transform:rotate(-8deg);opacity:.65}
.pin{position:absolute;transform:translate(-50%,-100%);z-index:2}
.pin b{display:flex;align-items:center;gap:4px;background:#fff;color:var(--navy);font-family:var(--display);font-weight:800;font-size:13px;padding:6px 11px;border-radius:var(--pill);box-shadow:var(--sh);border:1.5px solid #fff}
.pin.hot b{background:var(--navy);color:#fff}
.pin.book b{background:var(--green);color:#fff}
.pin::after{content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);border:6px solid transparent;border-top-color:#fff}
.map-badge{position:absolute;top:14px;left:14px;z-index:3;background:#fff;border-radius:var(--pill);padding:8px 14px;font-size:13px;font-weight:700;box-shadow:var(--sh-sm);display:flex;gap:7px;align-items:center}
.pager{display:flex;justify-content:center;gap:6px;margin-top:30px;flex-wrap:wrap}
.pager a{min-width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;background:#fff;border:1px solid var(--line)}
.pager a.on{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ============== DETAIL ============== */
.dpage{background:#fff}.dwrap{max-width:1140px;margin:0 auto;padding:0 clamp(20px,3.5vw,44px)}
.dtop{padding:20px 0 12px}
.dtitle-row{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;flex-wrap:wrap}
.dtitle h1{font-size:clamp(25px,3.5vw,40px);font-weight:800}
.dmeta{display:flex;align-items:center;gap:12px;margin-top:10px;flex-wrap:wrap;font-size:14px;color:var(--muted)}
.dmeta .rpill{display:inline-flex;align-items:center;gap:5px;background:var(--green);color:#fff;font-weight:700;padding:4px 10px;border-radius:9px;font-size:13.5px}
.dmeta .dloc{display:inline-flex;align-items:center;gap:5px;font-weight:500;color:var(--ink)}
.dtop-act{display:flex;gap:8px}
.icobtn{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:var(--ink);border:1px solid var(--line);background:#fff;padding:10px 14px;border-radius:var(--pill);min-height:44px}
.icobtn:hover{border-color:var(--green);color:var(--green-700)}
.gal{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:8px;height:430px;border-radius:var(--r);overflow:hidden;margin-top:8px}
.gal>div{position:relative;overflow:hidden;background:linear-gradient(135deg,#0a7d57,#04323f);cursor:pointer}
.gal>div:first-child{grid-row:span 2}
.gal img{width:100%;height:100%;object-fit:cover;transition:.4s}.gal>div:hover img{transform:scale(1.05)}
.gal-more{position:absolute;right:14px;bottom:14px;background:#fff;color:var(--navy);font-weight:700;font-size:13px;padding:9px 15px;border-radius:var(--pill);box-shadow:var(--sh);display:flex;gap:7px;align-items:center}
.dquick{display:flex;gap:9px;flex-wrap:wrap;margin-top:16px}
.dquick .q{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink);background:var(--bg-soft);border:1px solid var(--line);padding:8px 14px;border-radius:var(--pill)}.dquick .q b{color:var(--green-700)}
.dbody{display:grid;grid-template-columns:1fr 372px;gap:46px;padding:34px 0 20px;align-items:start}
.dsection{padding:26px 0;border-bottom:1px solid var(--line)}.dsection:first-child{padding-top:0}
.dsection h2{font-size:22px;font-weight:800;margin-bottom:6px}
.dsection .lead{color:var(--muted);font-size:15.5px;line-height:1.65;margin-top:12px}
.high{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}
.high-item{display:flex;gap:12px;align-items:flex-start}
.high-ic{width:40px;height:40px;border-radius:11px;background:var(--green-50);color:var(--green-700);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.high-item b{display:block;font-family:var(--display);font-size:14.5px;color:var(--navy-soft)}
.high-item span{font-size:13px;color:var(--muted)}
/* echte Ausstattungs-Icons */
.amen{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:18px}
.amen .a{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:14px 6px;border:1px solid var(--line);border-radius:14px;background:var(--bg-soft)}
.amen .a img{width:30px;height:30px}
.amen .a .ph{width:30px;height:30px;color:var(--green-700);display:flex;align-items:center;justify-content:center}
.amen .a span{font-size:12px;font-weight:600;color:var(--ink);line-height:1.2}
.amen .a.off{opacity:.34}
/* komplette Ausstattungsliste (alle 77, gruppiert) */
.amen-all{margin-top:14px;border:1px solid var(--line);border-radius:16px;overflow:hidden}
.amen-all>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:10px;padding:15px 18px;font-family:var(--display);font-weight:700;font-size:15px;color:var(--navy-soft);background:var(--bg-soft)}
.amen-all>summary::-webkit-details-marker{display:none}
.amen-all>summary .chev{margin-left:auto;transition:transform .25s;color:var(--green-700)}
.amen-all[open]>summary .chev{transform:rotate(180deg)}
.amen-cats{padding:4px 18px 18px}
.amen-cat{padding:15px 0;border-top:1px solid var(--line)}
.amen-cat:first-child{border-top:0}
.amen-cat h4{font-family:var(--display);font-size:13.5px;color:var(--green-700);margin:0 0 9px;text-transform:uppercase;letter-spacing:.03em}
.amen-cat h4 span{color:var(--muted);font-weight:600;text-transform:none;letter-spacing:0}
.amen-cat ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:5px 20px}
.amen-cat li{font-size:13.5px;color:var(--ink);padding:3px 0 3px 22px;position:relative;line-height:1.3}
.amen-cat li::before{content:"✓";position:absolute;left:0;top:2px;color:var(--green);font-weight:800}
.facts{display:grid;grid-template-columns:1fr 1fr;gap:11px 18px;margin-top:18px}
.facts div{display:flex;align-items:center;gap:10px;font-size:14px}
.facts .ai{width:30px;height:30px;border-radius:8px;background:var(--green-50);color:var(--green-700);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.facts b{color:var(--navy-soft);font-weight:700}
.ptable{width:100%;border-collapse:collapse;margin-top:14px;font-size:14.5px}
.ptable th,.ptable td{text-align:left;padding:12px 12px;border-bottom:1px solid var(--line)}
.ptable thead th{font-family:var(--display);font-size:12px;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);font-weight:700}
.ptable td.num{text-align:right;font-weight:600;font-family:var(--display);color:var(--navy-soft)}
.ptable tbody tr:hover{background:var(--bg-soft)}
.season-tag{font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--pill);background:var(--green-50);color:var(--green-700)}
.note-card{display:flex;gap:12px;align-items:flex-start;background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:15px;margin-top:16px;font-size:13.5px;color:var(--muted)}
.note-card .ai{width:34px;height:34px;border-radius:9px;background:#fff;color:var(--green-700);display:flex;align-items:center;justify-content:center;flex:0 0 auto;border:1px solid var(--green-100)}
.note-card b{color:var(--ink)}
.dmap{height:230px;border-radius:var(--r);overflow:hidden;position:relative;margin-top:16px;border:1px solid var(--line)}.dmap .map-canvas{position:absolute;inset:0}
/* reviews */
.rev-summary{display:grid;grid-template-columns:auto 1fr;gap:30px;align-items:center;background:var(--bg-soft);border-radius:var(--r);padding:22px 26px;margin-top:16px}
.rev-big{text-align:center}
.rev-big .n{font-family:var(--display);font-size:48px;font-weight:800;color:var(--navy-soft);line-height:1}
.rev-big .s{color:var(--amber);font-size:15px;letter-spacing:2px;margin-top:4px}
.rev-big small{display:block;color:var(--muted);font-size:12.5px;margin-top:5px}
.rev-bars{display:grid;gap:9px}
.rbar{display:grid;grid-template-columns:120px 1fr 36px;align-items:center;gap:12px;font-size:13px}
.rbar .track{height:7px;background:#e4ece7;border-radius:4px;overflow:hidden}
.rbar .fill{height:100%;background:var(--green);border-radius:4px}
.rbar .v{font-weight:600;color:var(--navy);text-align:right}
/* sticky booking */
.book{position:sticky;top:calc(var(--sw-h) + var(--hdr-h) + 14px);background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);padding:20px}
.book-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:700;font-size:12px;border-radius:8px;padding:5px 11px;margin-bottom:12px;background:var(--bg-soft);color:var(--muted);border:1px solid var(--line)}
.book-price{display:flex;align-items:baseline;gap:8px}
.book-price .amt{font-family:var(--display);font-size:28px;font-weight:800;color:var(--navy-soft)}
.book-price small{color:var(--muted);font-size:14px}
.book-rate{font-size:13px;color:var(--muted);margin:7px 0 15px}
.bform{border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden}
.brow{display:grid;grid-template-columns:1fr 1fr}
.bcell{padding:11px 14px;border-bottom:1px solid var(--line)}.brow .bcell+.bcell{border-left:1px solid var(--line)}
.bcell label{display:block;font-family:var(--display);font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--green-700);margin-bottom:2px}
.bcell .v{font-size:14px;font-weight:600;color:var(--navy-soft)}
.book .btn{margin-top:15px}
.book-note{text-align:center;font-size:12.5px;color:var(--muted);margin-top:11px;display:flex;gap:6px;align-items:center;justify-content:center}
.book-sum{margin-top:15px;padding-top:15px;border-top:1px solid var(--line);display:grid;gap:9px;font-size:13px}
.book-sum div{display:flex;gap:9px;align-items:center}.book-sum .ti{color:var(--green);flex:0 0 auto}
.book-alt{margin-top:12px;background:var(--green-50);border:1px solid var(--green-100);border-radius:var(--r);padding:15px}
.book-alt .h{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.book-alt .b{background:var(--green);color:#fff;font-family:var(--display);font-weight:700;font-size:11px;padding:3px 9px;border-radius:7px}
.book-alt p{font-size:12.5px;color:var(--muted)}
/* mobile sticky booking bar (detail) */
.mbook{display:none;position:fixed;left:0;right:0;bottom:0;z-index:80;background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 20px -8px rgba(16,40,38,.25);padding:10px 16px calc(10px + env(safe-area-inset-bottom));align-items:center;gap:12px}
.mbook .p{flex:1}
.mbook .p .a{font-family:var(--display);font-weight:800;font-size:18px;color:var(--navy-soft)}
.mbook .p .a small{font-size:12px;font-weight:500;color:var(--muted)}
.mbook .p .r{font-size:11.5px;color:var(--muted)}
/* echtes Anfrage-/Kontaktformular — Felder 1:1 wie auf der Live-Seite */
.aform{margin-top:18px}
.aform-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.ff{display:flex;flex-direction:column;gap:6px}
.ff.c2{grid-column:span 2}.ff.c3{grid-column:span 3}.ff.c4{grid-column:span 4}.ff.c6{grid-column:span 6}
.ff label{font-family:var(--display);font-size:12.5px;font-weight:700;color:var(--navy-soft)}
.ff .req{color:var(--coral)}
.ff input,.ff select,.ff textarea{font-family:var(--font);font-size:15px;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:10px;padding:11px 13px;min-height:46px;width:100%;transition:.15s;-webkit-appearance:none;appearance:none}
.ff select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none' stroke='%235d7177' stroke-width='2'%3E%3Cpath d='M5 8l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:34px}
.ff input:focus,.ff select:focus,.ff textarea:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 3px var(--green-50)}
.ff input::placeholder,.ff textarea::placeholder{color:var(--faint)}
.ff textarea{min-height:96px;resize:vertical;line-height:1.5}
.aform-foot{display:flex;align-items:center;gap:16px;margin-top:18px;flex-wrap:wrap}
.aform-note{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:7px}
.aform-trigger{display:none;width:100%;margin-top:12px}

svg.i{width:1em;height:1em;display:block}

/* ================= RESPONSIVE ================= */
@media(max-width:1080px){
  .lbody{grid-template-columns:1fr}.maprail{display:none}
  .dbody{grid-template-columns:1fr}.book{position:static}
  .grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  :root{--hdr-h:60px}
  .wrap,.dwrap{padding:0 16px}
  .nav,.lang,.hdr-act .btn{display:none}.burger{display:flex}
  .sw-tag{font-size:11px}.sw-in{padding:7px 14px}
  .sw-btn{padding:6px 11px;font-size:12px}
  .hero{min-height:auto;padding:120px 0 54px}
  .hero h1{font-size:clamp(30px,8vw,40px)}
  .search{flex-direction:column;gap:4px;padding:10px;border-radius:20px}
  .search-field{padding:11px 14px;border-radius:14px}
  .search-sep{display:none}
  .search .search-field{border-top:1px solid var(--line-2)}.search .search-field:first-child{border-top:0}
  .search-go{width:100%;height:52px;border-radius:14px;margin:6px 0 0}.search-go .lbl{display:inline}
  .trust-in{display:grid;grid-template-columns:1fr 1fr;gap:16px 12px}
  .trust-num{font-size:17px}
  .sec{padding:42px 0}
  .shead{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:18px}
  .cats{grid-template-columns:1fr 1fr;gap:12px}
  .grid{grid-template-columns:1fr;gap:16px}
  .regions{grid-template-columns:1fr}
  .band{flex-direction:column;text-align:center;padding:32px 22px;gap:20px}
  .band-actions{justify-content:center}
  .foot-grid{grid-template-columns:1fr 1fr;gap:24px}
  /* listings mobile: card wird vertikal */
  .lhead{flex-direction:column;align-items:flex-start}
  .fbar{top:calc(var(--sw-h) + var(--hdr-h))}
  .fbar-right .sel{display:none}
  .maptoggle{display:inline-flex;align-items:center;gap:7px;background:var(--navy);color:#fff;border-radius:var(--pill);padding:9px 15px;font-family:var(--display);font-weight:700;font-size:13px;flex:0 0 auto;min-height:40px}
  .rcard{grid-template-columns:1fr}
  .rcard .card-img{height:200px;min-height:0}
  /* detail mobile */
  .dtitle-row{flex-direction:column}
  .gal{display:flex;overflow-x:auto;height:260px;grid-template-columns:none;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .gal::-webkit-scrollbar{display:none}
  .gal>div{flex:0 0 88%;scroll-snap-align:center;grid-row:auto!important;border-radius:14px}
  .gal-more{right:8px;bottom:8px}
  .high{grid-template-columns:1fr}
  .amen{grid-template-columns:1fr 1fr}
  .amen-cat ul{grid-template-columns:1fr}
  .facts{grid-template-columns:1fr}
  .rev-summary{grid-template-columns:1fr;gap:18px}
  .brow{grid-template-columns:1fr}.brow .bcell+.bcell{border-left:0;border-top:1px solid var(--line)}
  .dbody{padding-bottom:96px}    /* Platz für mobile booking bar */
  .book{display:none}            /* Sidebar-Box wird durch mobile bar ersetzt */
  .view.on[data-view=detail] .mbook{display:flex}
  .ptable{font-size:13.5px}.ptable th,.ptable td{padding:11px 8px}
  .aform-grid{grid-template-columns:1fr}.aform-grid .ff{grid-column:auto!important}
  #anfrage .aform{display:none}
  #anfrage .aform-trigger{display:inline-flex}
  #anfrage.open .aform{display:block;animation:fade .3s ease}
  #anfrage.open .aform-trigger{display:none}
}
@media(max-width:380px){
  .sw-tag{display:none}
  .cats{grid-template-columns:1fr}
}

/* ===== real-site adaptations (no demo switcher; logo is an <img>, not the inline symbol) ===== */
.brand-logo{height:30px;width:auto;display:block}
.hdr--hero .brand-logo{filter:brightness(0) invert(1)}            /* whiten the logo over the photo hero */
.hdr--solid{box-shadow:var(--sh-sm)}
.mnav .brand-logo{filter:none}
/* beat redesign-a.css's generic !important button rules for the header pills */
.hdr .btn.btn-ghost{background:rgba(255,255,255,.16)!important;color:#fff!important;border:1px solid rgba(255,255,255,.35)!important}
.hdr .btn.btn-ghost:hover{background:rgba(255,255,255,.26)!important}
.hdr .btn.btn-outline{background:#fff!important;color:var(--navy)!important;border:1px solid var(--line)!important}
.hdr .btn.btn-outline:hover{border-color:var(--green)!important;color:var(--green-700)!important}

/* footer logo: whiten on the dark footer (mockup uses brand-logo--light) */
.foot .brand-logo{filter:brightness(0) invert(1);opacity:.95}

/* "Ausgewählte Campingplätze" → single-row horizontal scroller (overrides the .grid grid) */
.grid.grid-scroll{ display:flex !important; grid-template-columns:none !important; gap:20px; overflow-x:auto; overflow-y:hidden; scroll-snap-type:x mandatory; padding:4px 2px 14px; -webkit-overflow-scrolling:touch; }
.grid.grid-scroll > .card{ flex:0 0 clamp(268px,27vw,322px); scroll-snap-align:start; }
.grid.grid-scroll::-webkit-scrollbar{ height:8px; }
.grid.grid-scroll::-webkit-scrollbar-thumb{ background:var(--line); border-radius:99px; }
.grid.grid-scroll::-webkit-scrollbar-track{ background:transparent; }

/* detail title: mixed-case like the mockup (legacy theme forced uppercase) */
.dtitle h1,.dhead h1,.dpage h1,#roominfo_section h1{ text-transform:none !important; }

/* ===== Header booking-cart icon + count badge (shown only when cart non-empty) ===== */
.hdr-cart{position:relative;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;color:var(--navy);text-decoration:none;transition:background .15s,color .15s}
.hdr-cart:hover{background:var(--bg-soft);color:var(--green-700)}
.hdr-cart-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--green);color:#fff;font:700 11px/18px var(--font);text-align:center;box-shadow:0 0 0 2px #fff}
/* on the transparent photo-hero header the icon must read on a dark photo */
.hdr--hero .hdr-cart{color:#fff}
.hdr--hero .hdr-cart:hover{background:rgba(255,255,255,.16);color:#fff}
.hdr--hero .hdr-cart-badge{box-shadow:0 0 0 2px rgba(0,0,0,.18)}

/* ===== jQuery-UI dialog popup (core myAlert(): e.g. "Erfolgreich in der Wunschliste!") → Konzept-A
   The dialog is built by shared core js/main.js (untouched); we only re-skin its jQuery-UI markup. */
.ui-dialog.ui-widget{
  border:0 !important; border-radius:18px !important; padding:0 !important; overflow:hidden;
  background:#fff !important; font-family:var(--font) !important; max-width:calc(100vw - 32px);
  box-shadow:0 24px 60px -16px rgba(0,50,68,.4),0 4px 14px rgba(16,40,38,.12) !important;
}
.ui-dialog .ui-dialog-titlebar{
  background:none !important; border:0 !important; border-radius:0 !important; padding:16px 22px 0 !important;
  color:var(--navy) !important; font-family:var(--display) !important; font-weight:800 !important; min-height:0;
}
.ui-dialog .ui-dialog-title{ font-size:18px; }
.ui-dialog .ui-dialog-titlebar-close{
  position:absolute; right:14px; top:14px; width:32px; height:32px; margin:0; padding:0;
  border:0 !important; border-radius:50% !important; background:var(--bg-soft) !important; cursor:pointer;
  transition:background .12s ease;
}
.ui-dialog .ui-dialog-titlebar-close:hover{ background:var(--green-50) !important; }
.ui-dialog .ui-dialog-content{
  padding:18px 24px 8px !important; color:var(--ink) !important; font-size:15.5px !important; line-height:1.5;
}
.ui-dialog .ui-dialog-content span{ font-size:15.5px !important; color:var(--ink) !important; }
.ui-dialog .ui-dialog-buttonpane{
  border:0 !important; margin:0 !important; padding:6px 24px 20px !important; background:none !important;
}
.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset{ float:none !important; text-align:right; }
.ui-dialog .ui-dialog-buttonpane button{
  font-family:var(--display) !important; font-weight:700 !important; font-size:15px !important;
  background:var(--green) !important; color:#fff !important; border:0 !important; border-radius:999px !important;
  padding:11px 28px !important; min-height:44px; cursor:pointer; box-shadow:none !important;
  transition:background .14s ease;
}
.ui-dialog .ui-dialog-buttonpane button:hover{ background:var(--green-700) !important; }
.ui-dialog .ui-dialog-buttonpane button:focus,
.ui-dialog .ui-dialog-buttonpane button:focus-visible{
  outline:0 !important; box-shadow:0 0 0 3px var(--green-100) !important;
}
.ui-widget-overlay{ background:rgba(3,30,40,.45) !important; opacity:1 !important; }
