/* =========================================================
   NATURQUELL — Stylesheet
   Richtung: sanft & illustrativ, warmer Cream-Canvas, bespoke
   handgezeichnete Akzente. Display = Fraunces, Body = Nunito,
   Kids/Spiel-Akzent = Fredoka.
   Palette: Natur · Kräuter · Heilkunde (Grün, Terrakotta, Honig,
   Salbei) — bewusst KEIN Blau.
   REGEL: Grid-Spalten IMMER per Klasse (nie inline).
   ========================================================= */

/* ---------- Selbst gehostete Schriften (DSGVO) ---------- */
@font-face{font-family:"Display";src:url("/assets/fonts/display-var.woff2") format("woff2");font-weight:340 650;font-display:swap;font-style:normal;}
@font-face{font-family:"Sans";src:url("/assets/fonts/sans-var.woff2") format("woff2");font-weight:400 800;font-display:swap;font-style:normal;}
@font-face{font-family:"Round";src:url("/assets/fonts/round-var.woff2") format("woff2");font-weight:400 700;font-display:swap;font-style:normal;}

:root{
  /* Flaechen */
  --canvas:#F3EAD8;        /* warmes Leinen-Cream (Basis) */
  --canvas-2:#EADFC8;      /* tiefere Cream-Flaeche */
  --paper:#FBF6EA;         /* hellste Karten-Flaeche */
  /* Tinte / Text */
  --ink:#26312A;           /* tiefes Kraeuter-Schwarzgruen (Text) */
  --ink-soft:#495845;      /* zweitrangiger Text */
  --muted:#5C6A54;         /* Captions */
  /* Marke – Gruen (etwas heller als zuvor) */
  --green:#3C6A4C;         /* helleres Herbal-Gruen (Buttons) */
  --green-d:#2C5239;       /* Hover */
  --green-deep:#27432F;    /* tiefe Flaechen / Footer */
  --sage:#88A07C;          /* gedaempfte Salbei-Akzente */
  /* Marke – warm */
  --terra:#C8642F;         /* Terrakotta-Akzent */
  --terra-d:#9F4719;       /* dunkles Terrakotta (kleiner Text/Links/Focus) */
  --honey:#E3A23A;         /* Honig/Bernstein */
  --honey-d:#C5841F;
  /* Linien / Schatten */
  --line:rgba(38,49,42,.16);
  --line-soft:rgba(38,49,42,.09);
  --shadow:0 18px 40px -24px rgba(38,49,42,.5);
  --shadow-soft:0 10px 30px -22px rgba(38,49,42,.5);
  /* Schrift */
  --disp:"Display",Georgia,serif;
  --sans:"Sans",system-ui,-apple-system,sans-serif;
  --round:"Round","Sans",system-ui,sans-serif;
  /* Mass */
  --wrap:1140px;
  --radius:18px;
  --radius-lg:26px;
  --space:clamp(3.5rem,7vw,7rem);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--canvas);color:var(--ink);
  font-family:var(--sans);font-weight:450;font-size:1.0625rem;line-height:1.72;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video,svg{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
strong{font-weight:700}

/* ---------- Typografie ---------- */
h1,h2,h3,h4{font-family:var(--disp);line-height:1.06;font-weight:560;color:var(--ink);letter-spacing:-.012em;font-optical-sizing:auto}
h1{font-size:clamp(2.6rem,6.2vw,4.7rem);font-weight:540}
h2{font-size:clamp(2rem,4.2vw,3.1rem)}
h3{font-size:clamp(1.3rem,2.1vw,1.7rem);letter-spacing:-.005em}
h4{font-size:1.15rem}
p{color:var(--ink-soft);max-width:64ch}
.lead{font-size:clamp(1.12rem,1.6vw,1.32rem);color:var(--ink-soft);line-height:1.62;max-width:54ch}

/* ---------- Bausteine ---------- */
.wrap{width:min(var(--wrap),92%);margin-inline:auto}
.block{padding-block:var(--space)}
.center{text-align:center}
.center p,.center .lead{margin-inline:auto}

.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--sans);font-weight:700;font-size:.8rem;
  letter-spacing:.13em;text-transform:uppercase;color:var(--terra-d);margin-bottom:1rem;
}
.eyebrow::before{content:"";width:1.6rem;height:2px;border-radius:2px;background:var(--terra);opacity:.85}
.center .eyebrow{justify-content:center}

/* handgezeichnete Unterstreichung – sitzt UNTER den Unterlaengen */
.mark{position:relative;white-space:nowrap}
.mark>svg{position:absolute;left:-1%;width:102%;height:.34em;bottom:-.28em;overflow:visible;color:var(--terra)}
.mark.mark-honey>svg{color:var(--honey)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;cursor:pointer;
  font-family:var(--sans);font-weight:700;font-size:1rem;
  padding:.85rem 1.5rem;border-radius:999px;border:2px solid transparent;
  transition:transform .16s ease,background-color .16s ease,box-shadow .16s ease,color .16s ease;
}
.btn svg{width:1.05em;height:1.05em}
.btn-primary{background:var(--green);color:var(--paper);box-shadow:var(--shadow-soft)}
.btn-primary:hover{background:var(--green-d);transform:translateY(-2px)}
.btn-ghost{border-color:var(--green);color:var(--green)}
.btn-ghost:hover{background:rgba(60,106,76,.1);transform:translateY(-2px)}
.btn-accent{background:var(--terra);color:#fff}
.btn-accent:hover{background:var(--terra-d);transform:translateY(-2px)}
.on-dark .btn-ghost{border-color:rgba(251,246,234,.6);color:var(--paper)}
.on-dark .btn-ghost:hover{background:rgba(251,246,234,.12)}
.btn-lg{padding:1rem 1.8rem;font-size:1.08rem}
a.textlink{color:var(--terra-d);font-weight:700;display:inline-flex;align-items:center;gap:.35rem;transition:gap .16s ease}
a.textlink:hover{gap:.6rem}
.textlink svg{width:1.15em;height:1.15em;flex:0 0 auto}
.on-dark a.textlink{color:var(--honey)}

:focus-visible{outline:3px solid var(--terra-d);outline-offset:3px;border-radius:4px}

/* ---------- Header ---------- */
.site-head{position:sticky;top:0;z-index:50;background:rgba(243,234,216,.84);backdrop-filter:blur(10px);border-bottom:1px solid var(--line-soft)}
.head-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.85rem}
.logo{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--disp);font-weight:600;font-size:1.5rem;letter-spacing:-.015em;color:var(--ink)}
.logo .logo-mark{width:1.3rem;height:1.55rem;flex:0 0 auto;color:var(--green)}
.nav-links{display:flex;align-items:center;gap:1.7rem}
.nav-links a{font-family:var(--sans);font-weight:650;font-size:1rem;color:var(--ink);padding-block:.3rem;position:relative}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--terra);border-radius:2px;transition:right .22s ease}
.nav-links a:not(.btn):hover::after,.nav-links a.is-active:not(.btn)::after{right:0}
.nav-links .btn{padding:.6rem 1.2rem}
.nav-links a.nav-kids{color:var(--terra-d);font-weight:750}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:.4rem}
.burger span{width:26px;height:2.5px;border-radius:3px;background:var(--ink);display:block;transition:transform .2s ease,opacity .2s ease}
body.nav-open .burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;padding-block:clamp(3rem,6vw,5.5rem) clamp(3rem,6vw,5rem)}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.hero h1{margin-bottom:1.3rem}
.hero .lead{margin-bottom:2rem}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap}
.hero-meta{margin-top:2.2rem;display:flex;align-items:center;gap:.7rem;color:var(--muted);font-size:.95rem;font-weight:600}
.hero-meta svg{width:1.15rem;height:1.15rem;color:var(--terra);flex:0 0 auto}

/* Torbogen-Foto (Anspielung auf das Burgtor) */
.hero-art{position:relative}
.hero-photo{position:relative;z-index:2;border-radius:240px 240px 20px 20px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:16/13;border:6px solid var(--paper)}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-arch{position:absolute;z-index:1;top:-22px;left:50%;transform:translateX(-50%);width:104%;color:var(--terra);opacity:.85}
.hero-badge{position:absolute;z-index:3;right:-12px;bottom:18px;background:var(--honey);color:var(--green-deep);
  font-family:var(--round);font-weight:600;font-size:.95rem;line-height:1.15;text-align:center;
  width:7.2rem;height:7.2rem;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  box-shadow:var(--shadow-soft);transform:rotate(-8deg);padding:.5rem}
.hero-badge b{font-size:1.5rem;font-weight:700}

/* ---------- Band-Hintergruende ---------- */
.bg-cream2{background:var(--canvas-2)}
.bg-paper{background:var(--paper)}
.bg-green{background:var(--green-deep);color:#E7DFCD}
.bg-green h1,.bg-green h2,.bg-green h3{color:var(--paper)}
.bg-green p{color:rgba(231,223,205,.87)}
.bg-honey{background:var(--honey)}
.bg-honey h2,.bg-honey h3{color:var(--green-deep)}
.bg-honey p{color:var(--ink)}
.bg-honey .eyebrow{color:var(--green-deep)}
.bg-honey .eyebrow::before{background:var(--green-d)}

/* Vollbild-Medien-Band (Wald) */
.media-band{position:relative;overflow:hidden;color:var(--paper);text-align:center;display:flex;align-items:center;min-height:clamp(340px,46vh,540px)}
.media-band>.bg{position:absolute;inset:0;z-index:0}
.media-band>.bg img{width:100%;height:100%;object-fit:cover}
.media-band::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(38,49,42,.55),rgba(39,67,47,.72))}
.media-band>.wrap{position:relative;z-index:2}
.media-band .eyebrow{color:var(--honey)}
.media-band .eyebrow::before{background:var(--honey)}
.media-band h2{color:var(--paper);max-width:20ch;margin-inline:auto}
.media-band p{color:rgba(244,235,217,.92);margin-inline:auto}

/* ---------- Manifest-Zitat ---------- */
.manifest{text-align:center}
.manifest p.quote{font-family:var(--disp);font-weight:480;font-size:clamp(1.7rem,3.6vw,2.9rem);line-height:1.22;color:var(--ink);max-width:20ch;margin-inline:auto;letter-spacing:-.01em}
.manifest .small{max-width:50ch;margin:1.6rem auto 0;color:var(--muted);font-weight:600;letter-spacing:.01em}

/* ---------- Feature-Karten ---------- */
.grid{display:grid;gap:1.4rem}
.grid.three{grid-template-columns:repeat(3,1fr)}
.grid.duo{grid-template-columns:repeat(2,1fr)}
.section-head{max-width:40ch}
.section-head.center{margin-inline:auto}

.feature{
  background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  padding:2rem 1.7rem 1.8rem;box-shadow:var(--shadow-soft);
  transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;
}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.feature .ic{width:3.1rem;height:3.1rem;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem;background:rgba(200,100,47,.12);color:var(--terra)}
.feature .ic svg{width:1.65rem;height:1.65rem}
.feature.t-honey .ic{background:rgba(227,162,58,.18);color:var(--honey-d)}
.feature.t-green .ic{background:rgba(60,106,76,.14);color:var(--green)}
.feature h3{margin-bottom:.5rem}
.feature p{color:var(--ink-soft);margin-bottom:1.1rem;flex:1}

/* ---------- Split (Bild + Text, abwechselnd) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split.reverse .split-media{order:2}
.split-media{position:relative}
.split-media img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow);object-fit:cover}
.split-media.collage{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.split-media.collage img:first-child{grid-column:1 / 2;aspect-ratio:4/5;height:100%}
.split-media.collage img:last-child{margin-top:2.4rem;aspect-ratio:4/5;height:100%}
.split-text h2{margin-bottom:1rem}
.split-text .btn,.split-text .textlink{margin-top:1.4rem}
.tagline-photo{position:absolute;left:-10px;top:-14px;background:var(--paper);color:var(--terra-d);font-weight:700;font-size:.82rem;letter-spacing:.04em;padding:.5rem .9rem;border-radius:999px;box-shadow:var(--shadow-soft);z-index:3}

/* Liste mit Haken */
.ticks{list-style:none;margin:1.3rem 0 0;display:grid;gap:.7rem}
.ticks li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink-soft)}
.ticks svg{width:1.3rem;height:1.3rem;color:var(--terra);flex:0 0 auto;margin-top:.18rem}
.on-dark .ticks li{color:rgba(231,223,205,.9)}
.on-dark .ticks svg{color:var(--honey)}

/* ---------- Kids-Teaser ---------- */
.kids-teaser{position:relative;overflow:hidden}
.kids-teaser h2{font-family:var(--round);font-weight:600;font-size:clamp(2.1rem,4.5vw,3.3rem);letter-spacing:0}
.kids-teaser .lead{font-size:1.22rem}

/* ---------- Besuch / CTA ---------- */
.visit-card{background:var(--paper);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;display:grid;grid-template-columns:1.1fr .9fr}
.visit-info{padding:clamp(1.8rem,3.5vw,3rem)}
.visit-info .row{display:flex;gap:.8rem;align-items:flex-start;margin-bottom:1.1rem}
.visit-info .row svg{width:1.4rem;height:1.4rem;color:var(--terra);flex:0 0 auto;margin-top:.15rem}
.visit-info .row b{display:block;color:var(--ink)}
.visit-info .row span{color:var(--ink-soft);font-size:.97rem}
.visit-media{position:relative;min-height:240px}
.visit-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* ---------- Footer ---------- */
.site-foot{background:var(--green-deep);color:#D9D2C0;padding-block:clamp(3rem,5vw,4.5rem) 1.8rem}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2rem}
.site-foot .f-brand .logo{color:var(--paper);margin-bottom:.7rem}
.site-foot .f-brand .logo .logo-mark{color:var(--honey)}
.site-foot .f-brand p{color:rgba(217,210,192,.8);max-width:34ch}
.f-col h4{font-family:var(--sans);text-transform:uppercase;font-size:.82rem;letter-spacing:.1em;margin-bottom:.9rem;color:var(--honey)}
.f-col a,.f-col p{display:block;color:rgba(217,210,192,.85);font-size:.97rem;padding:.2rem 0}
.f-col a{transition:color .15s ease}
.f-col a:hover{color:#fff}
.foot-bottom{margin-top:2.6rem;padding-top:1.4rem;border-top:1px solid rgba(251,246,234,.14);font-size:.85rem;color:rgba(217,210,192,.7);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.foot-credits{margin-top:.8rem;font-size:.76rem;color:rgba(217,210,192,.5)}

/* ---------- Prose ---------- */
.prose{max-width:720px}
.prose h2{margin:2rem 0 .6rem}
.prose p{margin-bottom:1rem}
.prose ul{margin:0 0 1rem 1.2rem}

/* ---------- Formular (hell) ---------- */
.field{display:block;margin-bottom:1.1rem}
.field label{display:block;font-size:.9rem;font-weight:650;margin-bottom:.4rem;color:var(--ink)}
.field input,.field textarea{width:100%;padding:.85rem 1.05rem;border-radius:14px;border:1.5px solid var(--line);background:var(--paper);color:var(--ink);font:inherit}
.field input:focus,.field textarea:focus{border-color:var(--green);outline:none}
.hp{position:absolute;left:-9999px}
.notice{padding:.9rem 1.1rem;border-radius:12px;margin-bottom:1rem}
.notice.ok{background:rgba(60,106,76,.14);border:1px solid var(--green)}
.notice.err{background:rgba(200,80,47,.12);border:1px solid var(--terra)}

/* ---------- Subpage-Hero (Bild + Text) ---------- */
.page-hero{padding-block:clamp(2.4rem,5vw,4rem) clamp(1.4rem,3vw,2.4rem)}
.page-hero .split{align-items:center}
.page-hero .split-media img{aspect-ratio:4/5;object-fit:cover}

/* ---------- Termin-/Event-Liste ---------- */
.eventlist{display:grid;gap:1rem;margin-top:1.6rem}
.event{display:grid;grid-template-columns:auto 1fr auto;gap:1.3rem;align-items:center;background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius);padding:1.2rem 1.4rem;box-shadow:var(--shadow-soft)}
.event .when{text-align:center;min-width:4rem}
.event .when .d{font-family:var(--disp);font-size:1.7rem;font-weight:600;line-height:1;color:var(--terra)}
.event .when .m{font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:700}
.event .info h3{font-size:1.18rem;margin-bottom:.15rem}
.event .info p{font-size:.95rem;margin:0}
.event .go{flex:0 0 auto}
@media(max-width:640px){.event{grid-template-columns:auto 1fr}.event .go{grid-column:1/-1}}

/* ---------- Vita-Timeline ---------- */
.timeline{list-style:none;margin:1.6rem 0 0;border-left:2px solid var(--line);padding-left:1.5rem;display:grid;gap:1rem;max-width:640px}
.timeline li{position:relative}
.timeline li::before{content:"";position:absolute;left:-1.94rem;top:.5rem;width:.7rem;height:.7rem;border-radius:50%;background:var(--terra)}
.timeline b{color:var(--ink)}
.timeline span{color:var(--muted);font-weight:700;letter-spacing:.03em;margin-right:.5rem}

/* ---------- Kontakt / Anfahrt ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.map-embed{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:6px solid var(--paper);aspect-ratio:4/3;background:var(--canvas-2)}
.map-embed iframe{width:100%;height:100%;border:0;display:block}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}

/* ========================================================
   KINDERSEITE (.page-kids) — groessere Schrift, verspielt
   ======================================================== */
.page-kids{font-size:1.18rem;line-height:1.7}
.page-kids h1,.page-kids h2,.page-kids h3{font-family:var(--round);letter-spacing:0;line-height:1.12}
.page-kids h1{font-size:clamp(2.6rem,7vw,4.4rem);color:var(--green-deep)}
.page-kids h2{font-size:clamp(2rem,5vw,3rem);color:var(--green-deep)}
.page-kids h3{font-size:1.5rem}
.page-kids p{color:var(--ink);max-width:60ch}
.page-kids .lead{font-size:clamp(1.2rem,2.2vw,1.5rem);color:var(--ink)}
.kids-badge{display:inline-block;background:var(--honey);color:var(--green-deep);font-family:var(--round);font-weight:700;font-size:1.05rem;padding:.4rem 1.1rem;border-radius:999px;margin-bottom:1rem}
.kids-hero .split-media img{border-radius:30px;aspect-ratio:4/5}
.tafel-img{display:block;width:100%;max-width:430px;margin-inline:auto;border-radius:24px;box-shadow:var(--shadow)}
@media(max-width:600px){.tafel-img{max-width:280px}}

/* Steckbrief-Karten */
.steckbriefe{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin-top:1.8rem}
.steck{background:var(--paper);border-radius:24px;padding:1.6rem;box-shadow:var(--shadow-soft);border:2px solid var(--line-soft)}
.steck .emo{width:3.4rem;height:3.4rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--round);font-weight:700;font-size:1.6rem;color:#fff;margin-bottom:.8rem}
.steck h3{font-size:1.5rem;margin-bottom:.4rem;color:var(--green-deep)}
.steck p{font-size:1.08rem;color:var(--ink-soft)}
@media(max-width:600px){.steckbriefe{grid-template-columns:1fr}}

/* Quiz-Spiel */
.quiz{background:var(--green-deep);color:var(--paper);border-radius:30px;padding:clamp(1.6rem,4vw,2.8rem);box-shadow:var(--shadow);text-align:center;max-width:760px;margin:2rem auto 0}
.quiz h2{color:var(--paper)}
.quiz .progress{height:.5rem;background:rgba(251,246,234,.18);border-radius:999px;overflow:hidden;margin-bottom:1.4rem}
.quiz .progress span{display:block;height:100%;background:var(--honey);width:0;transition:width .4s ease}
.quiz .qmeta{font-family:var(--round);font-weight:700;color:var(--honey);letter-spacing:.04em;margin-bottom:.5rem}
.quiz .question{font-family:var(--round);font-weight:600;font-size:clamp(1.5rem,3.5vw,2.1rem);line-height:1.2;margin-bottom:1.5rem;color:var(--paper)}
.quiz .answers{display:grid;gap:.9rem}
.quiz .ans{font-family:var(--round);font-weight:600;font-size:1.3rem;padding:1rem 1.2rem;border-radius:18px;border:3px solid rgba(251,246,234,.25);background:rgba(251,246,234,.07);color:var(--paper);cursor:pointer;transition:transform .12s ease,background-color .15s ease,border-color .15s ease;min-height:58px}
.quiz .ans:hover{background:rgba(251,246,234,.15);transform:translateY(-2px)}
.quiz .ans.correct{background:#4E8B5A;border-color:#7cc78b;color:#fff}
.quiz .ans.wrong{background:#b5532f;border-color:#d98a6f}
.quiz .ans:disabled{cursor:default;transform:none}
.quiz .feedback{margin-top:1.3rem;font-family:var(--round);font-weight:600;font-size:1.25rem;min-height:3.2em}
.quiz .feedback .fact{display:block;font-family:var(--sans);font-weight:600;font-size:1.02rem;color:rgba(251,246,234,.86);margin-top:.4rem}
.quiz .btn-q{font-family:var(--round);font-weight:700;font-size:1.2rem;padding:.85rem 1.9rem;border-radius:999px;border:0;background:var(--honey);color:var(--green-deep);cursor:pointer;margin-top:1.1rem;min-height:52px}
.quiz .result .big{font-family:var(--round);font-weight:700;font-size:clamp(2.2rem,6vw,3.4rem);color:var(--honey);line-height:1}

/* Forscher-Checkliste */
.checklist{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem;margin-top:1.6rem;list-style:none;padding:0}
.checklist button{width:100%;display:flex;align-items:center;gap:.8rem;text-align:left;font-family:var(--round);font-weight:600;font-size:1.15rem;background:var(--paper);border:2px solid var(--line-soft);border-radius:16px;padding:.9rem 1.1rem;cursor:pointer;color:var(--ink);transition:background-color .15s ease,border-color .15s ease}
.checklist .box{width:1.9rem;height:1.9rem;border-radius:8px;border:2.5px solid var(--sage);flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:#fff}
.checklist .box svg{width:1.2rem;height:1.2rem;opacity:0;transition:opacity .15s ease}
.checklist button[aria-pressed="true"]{background:#E8F0E1;border-color:var(--green)}
.checklist button[aria-pressed="true"] .box{background:var(--green);border-color:var(--green)}
.checklist button[aria-pressed="true"] .box svg{opacity:1}
@media(max-width:560px){.checklist{grid-template-columns:1fr}}

/* Memory-Spiel */
.memory{max-width:560px;margin:1.8rem auto 0}
.memory-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem}
.mcard{position:relative;aspect-ratio:3/4;border:0;border-radius:16px;cursor:pointer;background:var(--green-deep);overflow:hidden;padding:0;font-family:var(--round)}
.mcard .m-cover{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:var(--honey);background:var(--green-deep);transition:opacity .15s ease}
.mcard .m-herb{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:.35rem;background:var(--paper);opacity:0;transition:opacity .15s ease}
.mcard .m-pic{width:100%;flex:1;min-height:0;object-fit:cover;border-radius:10px;display:block}
.mcard .m-name{font-family:var(--round);font-weight:700;font-size:.82rem;color:var(--green-deep);text-align:center;line-height:1.05;padding:.28rem .1rem .05rem;word-break:break-word}
.mcard.up .m-cover,.mcard.matched .m-cover{opacity:0}
.mcard.up .m-herb,.mcard.matched .m-herb{opacity:1}
.mcard.matched{outline:3px solid var(--green);outline-offset:-3px}
.mcard:hover .m-cover{background:#1f3a2a}
.memory-bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:1.2rem;flex-wrap:wrap}
.memory-status{font-family:var(--round);font-weight:700;color:var(--green-deep);font-size:1.05rem}
@media(max-width:520px){.memory-grid{grid-template-columns:repeat(3,1fr)}.mcard .m-name{font-size:.74rem}}

/* ---------- Mobil ---------- */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .hero-art{max-width:480px;margin-inline:auto;width:100%}
  .split{grid-template-columns:1fr;gap:2rem}
  .split.reverse .split-media{order:0}
  .visit-card{grid-template-columns:1fr}
  .visit-media{min-height:220px}
}
@media (max-width:820px){
  .grid.three,.grid.duo{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .burger{display:flex}
  .nav-links{position:fixed;inset:62px 0 auto 0;flex-direction:column;align-items:flex-start;gap:.4rem;
    background:var(--canvas);padding:1.2rem 6%;border-bottom:1px solid var(--line);box-shadow:var(--shadow);display:none}
  .nav-links a{font-size:1.15rem;padding-block:.6rem;width:100%}
  .nav-links .btn{margin-top:.4rem}
  body.nav-open .nav-links{display:flex}
}
@media (max-width:560px){
  .foot-grid{grid-template-columns:1fr}
  .split-media.collage img:last-child{margin-top:0}
  .hero-badge{width:6rem;height:6rem;font-size:.82rem}
  .hero-badge b{font-size:1.25rem}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
