:root{
  --sonnengelb:#F7A50A; --orange:#E47C05; --tiefgold:#D9820A;
  --himmelblau:#1FA6E0; --wiesengruen:#57B84F; --koralle:#F2664E;
  --tiefbraun:#33240F; --creme:#FFF7E8; --weiss:#fff;
  --ink:#33240F; --muted:#7a6648; --line:#efe2cc;
  --disp:'Luckiest Guy',cursive; --body:'Nunito',sans-serif;
  --radius:16px; --shadow:0 4px 14px rgba(51,36,15,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--weiss);line-height:1.55}
img{max-width:100%;display:block;height:auto}
a{color:var(--orange);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1080px;margin:0 auto;padding:0 18px}

/* ---------- Kopf ---------- */
.site-head{background:var(--weiss);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:1000}
.head-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 18px}
.logo img{width:200px}
.wchip{display:flex;align-items:center;gap:9px;background:var(--creme);border:1px solid var(--line);
  border-radius:12px;padding:6px 12px}
.wchip .ic{font-size:1.35rem;line-height:1}
.wchip .txt strong{font-size:1.05rem;font-weight:900}
.wchip .txt small{display:block;color:var(--muted);font-size:.72rem;font-weight:700}
.mainnav{background:var(--sonnengelb)}
.nav-inner{display:flex;gap:6px;overflow-x:auto;padding:0 18px}
.mainnav a{color:#fff;font-weight:800;font-size:.92rem;padding:11px 12px;white-space:nowrap;border-radius:0}
.mainnav a:hover{text-decoration:none;background:rgba(0,0,0,.08)}
.mainnav a.cta{margin-left:auto;background:var(--tiefbraun)}

/* ---------- Hero / Berater ---------- */
.hero{background:radial-gradient(circle at 50% -20%, #FFC23C 0%, var(--sonnengelb) 60%, var(--tiefgold) 130%);
  color:#fff;padding:34px 0 40px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;opacity:.16;
  background:repeating-linear-gradient(45deg,#fff 0 3px,transparent 3px 14px)}
.hero .wrap{position:relative}
.hero h1{font-family:var(--disp);font-weight:400;font-size:2rem;line-height:1.05;letter-spacing:.5px;
  text-shadow:0 2px 0 rgba(51,36,15,.25)}
.hero h1 span{color:var(--tiefbraun)}
.hero .lead{margin:10px 0 22px;font-weight:700;font-size:1.02rem;max-width:36ch}

.berater{background:#fff;color:var(--ink);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}
.berater fieldset{border:0;padding:8px 0;border-bottom:1px dashed var(--line)}
.berater fieldset:last-of-type{border-bottom:0}
.berater legend{font-weight:900;font-size:.95rem;margin-bottom:8px}
.opts{display:flex;flex-wrap:wrap;gap:8px}
.opt{font-family:var(--body);font-weight:800;font-size:.9rem;cursor:pointer;
  background:var(--creme);border:2px solid transparent;border-radius:999px;padding:9px 14px;color:var(--ink)}
.opt:hover{border-color:var(--sonnengelb)}
.opt.is-active{background:var(--sonnengelb);color:#fff;border-color:var(--tiefgold)}
.btn-go{display:inline-block;margin-top:14px;font-family:var(--body);font-weight:900;font-size:1rem;cursor:pointer;
  background:var(--koralle);color:#fff;border:0;border-radius:12px;padding:13px 22px;box-shadow:0 3px 0 #c94d3a}
.btn-go:hover{text-decoration:none;filter:brightness(1.05)}

/* ---------- Sektionen ---------- */
.section{padding:34px 0}
.section.alt{background:var(--creme)}
.section h1,.section h2{font-family:var(--disp);font-weight:400;letter-spacing:.5px;line-height:1.1}
.section h1{font-size:1.7rem}
.section h2{font-size:1.4rem}
.section .sub{color:var(--muted);font-weight:700;margin-top:2px}
.more{margin-top:18px;font-weight:800}

/* ---------- Kategorie-Kacheln ---------- */
.cat-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:16px}
.tile{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:14px;font-weight:800;color:var(--ink)}
.tile:hover{text-decoration:none;border-color:var(--sonnengelb);box-shadow:var(--shadow)}
.tile .te{font-size:1.4rem}

/* ---------- Karten-Grid ---------- */
.grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:18px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  display:flex;flex-direction:column}
.card-media{position:relative;aspect-ratio:16/10;display:block;background:#eadbbf}
.card-media img{width:100%;height:100%;object-fit:cover}
.card-media.is-ph{display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#FFD27A,var(--sonnengelb))}
.ph-emoji{font-size:3.4rem}
.match{position:absolute;top:10px;left:10px;background:var(--wiesengruen);color:#fff;font-weight:900;
  font-size:.78rem;padding:4px 10px;border-radius:999px;box-shadow:0 2px 0 rgba(0,0,0,.15)}
.card-body{padding:14px;display:flex;flex-direction:column;gap:6px}
.card-body h3{font-size:1.12rem;font-weight:900;line-height:1.2}
.card-body h3 a{color:var(--ink)}
.meta{color:var(--muted);font-size:.85rem;font-weight:700}
.teaser{font-size:.92rem}
.badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.badge{font-size:.74rem;font-weight:800;padding:4px 9px;border-radius:999px;background:var(--creme);color:var(--ink)}
.badge.io-outdoor{background:#e3f3e1;color:#2f7a2a}
.badge.io-indoor{background:#fde3de;color:#b8402e}
.badge.io-beides{background:#e1f1fb;color:#16729c}
.badge.wf{background:#e1f1fb;color:#16729c}
.badge.kosten{background:#fff0d4;color:#9a6b00}

/* ---------- Filter / Karte ---------- */
.filters{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.filters select{font-family:var(--body);font-weight:700;padding:10px 12px;border:2px solid var(--line);
  border-radius:10px;background:#fff;color:var(--ink)}
.map{height:300px;border-radius:var(--radius);margin-top:16px;border:1px solid var(--line);z-index:1}
.count{margin-top:14px;font-weight:800;color:var(--muted)}
.empty,.empty-state{padding:24px 0;color:var(--muted);font-weight:700}

/* ---------- Detail ---------- */
.detail{padding:28px 0}
.crumbs{font-size:.85rem;color:var(--muted);font-weight:700;margin-bottom:10px}
.detail h1{font-family:var(--disp);font-weight:400;font-size:1.9rem;line-height:1.1}
.detail .desc{margin:16px 0;font-size:1.02rem}
.facts{list-style:none;display:grid;grid-template-columns:1fr;gap:6px;margin:14px 0;font-weight:700}
.facts li{background:var(--creme);border-radius:10px;padding:9px 12px}
.tagchips{display:flex;flex-wrap:wrap;gap:7px;margin:6px 0 14px}
.tagchip{background:#e1f1fb;color:#16729c;font-weight:800;font-size:.8rem;padding:5px 11px;border-radius:999px}

/* ---------- Würfel ---------- */
.wuerfel-hero{background:radial-gradient(circle at 50% -20%, #79d0f4 0%, var(--himmelblau) 70%, #1488bb 130%);
  color:#fff;padding:30px 0 34px;text-align:center}
.wuerfel-hero h1{font-family:var(--disp);font-weight:400;font-size:2rem;letter-spacing:.5px;text-shadow:0 2px 0 rgba(0,40,60,.25)}
.wuerfel-hero .lead{margin:8px 0 20px;font-weight:700}
.wuerfel-form{background:#fff;color:var(--ink);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:16px;display:grid;grid-template-columns:1fr 1fr;gap:10px;max-width:560px;margin:0 auto;text-align:left}
.wuerfel-form select{font-family:var(--body);font-weight:700;padding:10px 11px;border:2px solid var(--line);
  border-radius:10px;background:#fff;color:var(--ink);width:100%}
.wf-check{display:flex;align-items:center;gap:8px;font-weight:700;font-size:.9rem;grid-column:1/-1}
.wf-check input{width:auto}
.btn-dice{grid-column:1/-1;font-family:var(--body);font-weight:900;font-size:1.05rem;cursor:pointer;
  background:var(--sonnengelb);color:#fff;border:0;border-radius:12px;padding:14px 22px;box-shadow:0 3px 0 var(--tiefgold)}
.btn-dice:hover{text-decoration:none;filter:brightness(1.05)}

.dice-card{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);
  padding:26px 20px;text-align:center;max-width:520px;margin:0 auto}
.dice-card.empty{color:var(--muted)}
.dice-emoji{font-size:3.4rem;line-height:1}
.dice-kicker{color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:1px;font-size:.78rem;margin-top:6px}
.dice-card h2{font-family:var(--disp);font-weight:400;font-size:1.6rem;line-height:1.1;margin:2px 0 4px}
.dice-card h2 a{color:var(--ink)}
.dice-card .teaser{margin:10px 0}
.dice-card .badges{justify-content:center}
.dice-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;align-items:center;margin-top:16px}
.dice-actions form{margin:0}
.btn-ghost{font-weight:800;padding:13px 18px;border-radius:12px;border:2px solid var(--line);color:var(--ink)}
.btn-ghost:hover{text-decoration:none;border-color:var(--sonnengelb)}
.pool{margin-top:14px;color:var(--muted);font-size:.82rem;font-weight:700}

/* ---------- Fuß ---------- */
.site-foot{background:var(--tiefbraun);color:#f3e6cf;margin-top:10px}
.foot-grid{display:grid;grid-template-columns:1fr;gap:22px;padding:32px 18px}
.site-foot strong{display:block;font-size:.95rem;margin-bottom:10px;color:#fff}
.site-foot ul{list-style:none}
.site-foot li{margin:5px 0}
.site-foot a{color:#f3e6cf;font-weight:700;font-size:.9rem}
.site-foot .claim{font-family:var(--disp);color:var(--sonnengelb);font-size:1.1rem;margin-bottom:6px}
.site-foot .disc{font-size:.85rem;opacity:.8}
.foot-bottom{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;
  border-top:1px solid rgba(255,255,255,.12);padding:14px 18px;font-size:.82rem;font-weight:700}

/* ---------- ab Tablet ---------- */
@media(min-width:680px){
  .hero h1{font-size:2.7rem}
  .cat-tiles{grid-template-columns:repeat(3,1fr)}
  .grid{grid-template-columns:repeat(2,1fr)}
  .facts{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr 1.4fr}
  .map{height:420px}
}
@media(min-width:980px){
  .grid{grid-template-columns:repeat(3,1fr)}
  .cat-tiles{grid-template-columns:repeat(5,1fr)}
}

/* ---------- Erweiterungen: Merken/Bild/Affiliate/Reviews/Forms ---------- */
.fav{position:absolute;top:10px;right:10px;width:38px;height:38px;border:0;border-radius:50%;
  background:rgba(255,255,255,.92);color:var(--koralle);font-size:1.25rem;line-height:1;cursor:pointer;
  box-shadow:0 2px 6px rgba(0,0,0,.18);display:flex;align-items:center;justify-content:center;z-index:2}
.fav.on{background:var(--koralle);color:#fff}
.fav:hover{transform:scale(1.08)}
.dist{position:absolute;bottom:10px;left:10px;background:var(--tiefbraun);color:#fff;font-weight:800;
  font-size:.76rem;padding:4px 9px;border-radius:999px}

.detail-hero{width:100%;max-height:380px;object-fit:cover;border-radius:var(--radius);margin:8px 0 6px}
.stars{color:var(--sonnengelb);letter-spacing:1px}

/* Affiliate */
.aff-block{margin:22px 0;padding:16px;background:var(--creme);border-radius:var(--radius)}
.aff-block h2{font-family:var(--disp);font-weight:400;font-size:1.2rem;margin-bottom:10px}
.aff-grid{display:grid;grid-template-columns:1fr;gap:10px}
.aff-card{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:12px 14px;font-weight:800;color:var(--ink)}
.aff-card:hover{text-decoration:none;border-color:var(--sonnengelb)}
.aff-ic{font-size:1.3rem}
.aff-disc{margin-top:10px;font-size:.78rem;color:var(--muted)}

/* Reviews */
.reviews{margin:24px 0}
.reviews h2{font-family:var(--disp);font-weight:400;font-size:1.3rem;margin-bottom:10px}
.rlist{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.rlist li{background:var(--creme);border-radius:10px;padding:10px 12px}
.rflash{background:#e3f3e1;color:#2f7a2a;border-radius:10px;padding:10px 12px;font-weight:700;margin-bottom:12px}
.rform{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:10px}
.rform textarea{width:100%;padding:10px 12px;border:2px solid var(--line);border-radius:10px;font:inherit;min-height:70px}
.rstars{display:flex;align-items:center;gap:10px;font-weight:700}
.star-wrap{display:inline-flex;flex-direction:row-reverse}
.star-wrap input{display:none}
.star-wrap label{font-size:1.7rem;color:#d8cdb5;cursor:pointer;padding:0 1px}
.star-wrap label:hover,.star-wrap label:hover ~ label{color:var(--sonnengelb)}
.star-wrap input:checked ~ label{color:var(--sonnengelb)}

/* Vorschlag-Formular */
.vform{display:flex;flex-direction:column;gap:6px;margin-top:14px}
.vform label{font-weight:700;font-size:.92rem;display:flex;flex-direction:column;gap:4px}
.vform input,.vform select,.vform textarea{padding:10px 12px;border:2px solid var(--line);border-radius:10px;font:inherit}
.vform .btn-go{align-self:flex-start;margin-top:6px}

/* Honeypot */
.hp{position:absolute !important;left:-9999px !important;width:1px;height:1px;opacity:0}

/* Wetter-Aufhänger */
.weather-hook{background:#eaf6fc}

@media(min-width:680px){
  .aff-grid{grid-template-columns:repeat(3,1fr)}
}

/* ---------- Detail: Infobox + Button-Reihe ---------- */
.btn-row{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0}
.infobox{background:var(--creme);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin:16px 0}
.infobox h2{font-family:var(--disp);font-weight:400;font-size:1.2rem;margin-bottom:8px}
.infobox dl{display:grid;grid-template-columns:auto 1fr;gap:6px 14px;margin:0}
.infobox dt{font-weight:800;color:var(--muted)}
.infobox dd{margin:0}
.infobox .hint{margin-top:10px;font-size:.8rem;color:var(--muted)}
