/* ==================================================
   BELLA WILDHERZ – NATURMISSIONEN
   Seitenspezifische CSS-Datei für /Naturmissionen.
   /style.css bleibt als Backup erhalten und wird in der HTML deaktiviert.
================================================== */

:root {
      --ink:       #1a2416;
      --deep:      #243320;
      --forest:    #3b5e32;
      --sage:      #6b9e5e;
      --mint:      #a8d48a;
      --gold:      #d4921a;
      --amber:     #f0b840;
      --cream:     #faf4e8;
      --paper:     #f3ead6;
      --warm:      #fffdf7;
      --radius-lg: 20px;
      --radius-xl: 28px;
      --shadow:    0 18px 48px rgba(26,36,22,.12);
    }

    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      font-family: 'Nunito', sans-serif;
      background: var(--warm);
      color: var(--ink);
      overflow-x: hidden;
    }
    img { max-width: 100%; }

    /* HERO wie Startseite: großes Bild ohne Text */
    .hero {
      position: relative;
      width: 100%;
      height: 100svh;
      min-height: 480px;
      max-height: 720px;
      overflow: hidden;
      background: var(--deep);
    }
    .hero img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center 35%;
      display: block;
    }
    .hero::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(to bottom, transparent 36%, rgba(26,36,22,.28) 72%, rgba(26,36,22,.72) 100%);
      pointer-events: none;
    }

    nav {
      position: sticky;
      top: 0;
      z-index: 100;
      background: rgba(250,244,232,.94);
      backdrop-filter: blur(14px);
      border-bottom: 1px solid rgba(59,94,50,.11);
    }
    .nav-inner {
      max-width: 1080px;
      margin: 0 auto;
      padding: 0 24px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      min-height: 60px;
      gap: 16px;
    }
    .nav-brand {
      font-family: 'Fraunces', serif;
      font-size: 1.2rem;
      font-weight: 900;
      color: var(--forest);
      text-decoration: none;
      white-space: nowrap;
    }
    nav ul {
      list-style: none;
      display: flex;
      gap: 2px;
      align-items: center;
      flex-wrap: wrap;
      justify-content: flex-end;
    }
    nav a {
      text-decoration: none;
      color: var(--deep);
      font-weight: 700;
      font-size: .86rem;
      padding: 6px 12px;
      border-radius: 999px;
      transition: background .2s, color .2s;
    }
    nav a:hover,
    nav a.active { background: rgba(59,94,50,.1); color: var(--forest); }
    .nav-cta { background: var(--forest) !important; color: #fff !important; }
    .nav-cta:hover { background: var(--deep) !important; color: #fff !important; }

    .ankuendigung {
      background: var(--amber);
      color: var(--ink);
      text-align: center;
      padding: 11px 20px;
      font-size: .88rem;
      font-weight: 800;
      letter-spacing: .3px;
    }

    .page { max-width: 1080px; margin: 0 auto; padding: 0 24px 100px; }
    section { margin-top: 88px; }
    .sh { margin-bottom: 34px; }
    .sh-label {
      font-size: .7rem;
      font-weight: 800;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--sage);
      margin-bottom: 6px;
    }
    .sh-title {
      font-family: 'Fraunces', serif;
      font-size: clamp(1.9rem, 3.5vw, 2.9rem);
      font-weight: 900;
      color: var(--ink);
      line-height: 1.1;
    }
    .sh-title em { font-style: italic; color: var(--forest); }
    .intro-text {
      font-size: 1rem;
      line-height: 1.8;
      color: #5a6a54;
      max-width: 820px;
    }

    .rule-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 14px;
      margin-top: 28px;
    }
    .rule-card {
      background: var(--cream);
      border: 1.5px solid rgba(59,94,50,.1);
      border-radius: var(--radius-lg);
      padding: 20px;
    }
    .rule-icon { font-size: 1.55rem; margin-bottom: 10px; }
    .rule-title {
      font-family: 'Fraunces', serif;
      font-size: 1.05rem;
      font-weight: 900;
      margin-bottom: 6px;
    }
    .rule-text { font-size: .84rem; color: #5a6a54; line-height: 1.55; }

    .controls {
      background: var(--cream);
      border: 1.5px solid rgba(59,94,50,.1);
      border-radius: var(--radius-xl);
      padding: 18px;
      display: grid;
      grid-template-columns: 1fr auto auto;
      gap: 12px;
      align-items: center;
      margin-bottom: 24px;
    }
    .search-wrap { position: relative; }
    .search-wrap span {
      position: absolute;
      left: 14px;
      top: 50%;
      transform: translateY(-50%);
      color: #9aaa94;
      font-size: .95rem;
    }
    input[type="search"], select {
      width: 100%;
      min-height: 44px;
      border: 1.5px solid rgba(59,94,50,.14);
      background: var(--warm);
      border-radius: 999px;
      font-family: 'Nunito', sans-serif;
      font-size: .9rem;
      font-weight: 700;
      color: var(--ink);
      outline: none;
    }
    input[type="search"] { padding: 0 16px 0 42px; }
    select { padding: 0 38px 0 14px; cursor: pointer; }
    input[type="search"]:focus,
    select:focus { border-color: var(--sage); box-shadow: 0 0 0 4px rgba(107,158,94,.12); }
    .result-count { font-size: .82rem; color: #5a6a54; font-weight: 800; white-space: nowrap; }

    .mission-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(310px, 1fr));
      gap: 20px;
    }
    .mission-card {
      background: var(--cream);
      border: 1.5px solid rgba(59,94,50,.1);
      border-radius: var(--radius-xl);
      overflow: hidden;
      transition: transform .25s, box-shadow .25s;
      display: flex;
      flex-direction: column;
      min-height: 100%;
    }
    .mission-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
    .mission-image-wrap {
      position: relative;
      background: var(--paper);
    }
    .mission-image {
      width: 100%;
      aspect-ratio: 16 / 10;
      object-fit: cover;
      display: block;
    }
    .mission-badge {
      position: absolute;
      left: 14px;
      top: 14px;
      background: rgba(255,255,255,.94);
      color: var(--forest);
      border-radius: 999px;
      padding: 5px 11px;
      font-size: .66rem;
      font-weight: 900;
      letter-spacing: 1px;
      text-transform: uppercase;
      box-shadow: 0 8px 18px rgba(26,36,22,.08);
    }
    .mission-body {
      padding: 22px 22px 24px;
      display: flex;
      flex-direction: column;
      flex: 1;
    }
    .mission-meta {
      display: flex;
      gap: 8px;
      flex-wrap: wrap;
      margin-bottom: 10px;
    }
    .pill {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      background: rgba(59,94,50,.08);
      border: 1px solid rgba(59,94,50,.1);
      color: var(--forest);
      border-radius: 999px;
      padding: 5px 10px;
      font-size: .68rem;
      font-weight: 900;
    }
    .mission-title {
      font-family: 'Fraunces', serif;
      font-size: 1.35rem;
      line-height: 1.15;
      font-weight: 900;
      color: var(--ink);
      margin-bottom: 6px;
    }
    .mission-animal {
      color: var(--sage);
      font-size: .82rem;
      font-weight: 800;
      margin-bottom: 12px;
    }
    .mission-text {
      color: #5a6a54;
      font-size: .9rem;
      line-height: 1.65;
      margin-bottom: 16px;
    }
    .mission-steps {
      background: rgba(255,253,247,.62);
      border: 1px solid rgba(59,94,50,.1);
      border-radius: 16px;
      padding: 14px 16px;
      margin-bottom: 16px;
    }
    .mission-steps strong,
    .mission-box strong {
      display: block;
      color: var(--deep);
      font-size: .78rem;
      font-weight: 900;
      letter-spacing: 1.4px;
      text-transform: uppercase;
      margin-bottom: 8px;
    }
    .mission-steps ol {
      padding-left: 18px;
      color: #5a6a54;
      font-size: .86rem;
      line-height: 1.55;
    }
    .mission-box {
      background: var(--paper);
      border-radius: 16px;
      padding: 14px 16px;
      margin-top: auto;
    }
    .mission-box p {
      color: #5a6a54;
      font-size: .86rem;
      line-height: 1.55;
    }
    .mission-warning {
      margin-top: 12px;
      color: #6f4f14;
      background: rgba(240,184,64,.18);
      border: 1px solid rgba(240,184,64,.35);
      border-radius: 14px;
      padding: 11px 13px;
      font-size: .82rem;
      line-height: 1.45;
      font-weight: 800;
    }
    .empty-state {
      background: var(--cream);
      border: 1.5px solid rgba(59,94,50,.1);
      border-radius: var(--radius-xl);
      padding: 34px;
      color: #5a6a54;
      line-height: 1.75;
    }
    .empty-state h3 {
      font-family: 'Fraunces', serif;
      font-size: 1.5rem;
      color: var(--ink);
      margin-bottom: 8px;
    }

    .soft-cta {
      background: var(--deep);
      color: #fff;
      border-radius: var(--radius-xl);
      padding: 44px 46px;
      display: grid;
      grid-template-columns: 1.3fr .7fr;
      gap: 28px;
      align-items: center;
    }
    .soft-cta h2 {
      font-family: 'Fraunces', serif;
      font-size: clamp(1.8rem, 3vw, 2.55rem);
      line-height: 1.1;
      margin-bottom: 12px;
    }
    .soft-cta p {
      color: rgba(255,255,255,.68);
      line-height: 1.75;
      font-size: .95rem;
    }
    .cta-buttons { display:flex; flex-direction:column; gap:10px; }
    .cta-btn {
      display:inline-flex;
      align-items:center;
      justify-content:center;
      text-align:center;
      padding: 13px 18px;
      border-radius: 999px;
      text-decoration:none;
      font-weight:900;
      font-size:.86rem;
      transition: transform .2s, background .2s;
    }
    .cta-btn.primary { background: var(--amber); color: var(--ink); }
    .cta-btn.secondary { background: rgba(255,255,255,.09); color: #fff; border: 1px solid rgba(255,255,255,.15); }
    .cta-btn:hover { transform: translateY(-2px); }

    footer {
      background: var(--ink);
      color: rgba(255,255,255,.45);
      padding: 48px 24px 36px;
      text-align: center;
    }
    .footer-brand { font-family: 'Fraunces', serif; font-size: 1.4rem; font-weight: 900; color: #fff; margin-bottom: 8px; }
    .footer-links { display: flex; justify-content: center; gap: 24px; flex-wrap: wrap; margin: 14px 0; }
    .footer-links a { color: rgba(255,255,255,.38); text-decoration: none; font-size: .8rem; transition: color .2s; }
    .footer-links a:hover { color: var(--mint); }
    footer p { font-size: .77rem; }

    .reveal { opacity: 0; transform: translateY(28px); transition: opacity .65s ease, transform .65s ease; }
    .reveal.in { opacity: 1; transform: none; }

    @media (max-width: 900px) {
      .rule-grid { grid-template-columns: repeat(2, 1fr); }
      .controls { grid-template-columns: 1fr; }
      .result-count { white-space: normal; }
      .soft-cta { grid-template-columns: 1fr; }
    }
    @media (max-width: 760px) {
      .nav-inner { align-items: flex-start; flex-direction: column; padding: 12px 18px; }
      nav ul { justify-content: flex-start; }
      nav a { padding: 5px 9px; font-size: .82rem; }
      .hero { min-height: 480px; }
    }
    @media (max-width: 540px) {
      .page { padding: 0 16px 80px; }
      section { margin-top: 64px; }
      .rule-grid { grid-template-columns: 1fr; }
      .mission-grid { grid-template-columns: 1fr; }
      .soft-cta { padding: 34px 24px; }
    }

    /* Bella-Regelicons nur in diesen vier Naturmissionen-Regelkarten */
    .bella-rule-icon {
      width: 76px;
      height: 76px;
      margin-bottom: 12px;
      display: flex;
      align-items: center;
      justify-content: flex-start;
      font-size: 0;
    }

    .bella-rule-icon img {
      width: 76px;
      height: 76px;
      object-fit: contain;
      display: block;
    }

    @media (max-width: 540px) {
      .bella-rule-icon {
        width: 70px;
        height: 70px;
      }

      .bella-rule-icon img {
        width: 70px;
        height: 70px;
      }
    }


    /* Navigation: auf Naturmissionen dieselbe zentrale Navigation wie auf Downloads nutzen */
    #site-nav nav .nav-inner {
      max-width: 1080px;
    }

    #site-nav nav ul {
      flex-wrap: wrap;
    }

    @media (max-width: 900px) {
      #site-nav nav ul {
        justify-content: flex-start;
      }
    }
