/* Lokal gehostete, frei lizenzierte Fonts (SIL OFL) – keine Verbindung zu Google */
  @font-face{font-family:'Fraunces';font-style:normal;font-weight:400 700;font-display:swap;src:url('../fonts/fraunces-latin.woff2') format('woff2')}
  @font-face{font-family:'Inter';font-style:normal;font-weight:400 700;font-display:swap;src:url('../fonts/inter-latin.woff2') format('woff2')}
  :root{
    --bg:#f5f7f0; --bg-2:#eef1e6; --surface:#ffffff; --surface-2:#f0f3ea;
    --text:#1c2620; --muted:#5e6d63; --faint:#8a9a8e;
    --primary:#2f7d4f; --primary-2:#3d9b63; --primary-soft:#e3f1e7;
    --accent:#c97b3c; --accent-soft:#f6e8d8;
    --heart:#e05a6d;
    --border:#e3e7da; --border-2:#d3dac9;
    --shadow:0 1px 2px rgba(28,38,32,.04), 0 8px 24px rgba(28,38,32,.07);
    --shadow-lg:0 12px 40px rgba(28,38,32,.16);
    --radius:18px; --radius-sm:12px;
    --serif:'Fraunces',Georgia,'Times New Roman',serif;
    --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  }
  html[data-theme="dark"]{
    --bg:#0f1410; --bg-2:#131a14; --surface:#19211a; --surface-2:#202a21;
    --text:#e8efe6; --muted:#a3b3a7; --faint:#76867b;
    --primary:#5cc285; --primary-2:#6fd197; --primary-soft:#1d2e23;
    --accent:#e0995a; --accent-soft:#2e2418;
    --heart:#f07489;
    --border:#27322a; --border-2:#324036;
    --shadow:0 1px 2px rgba(0,0,0,.3), 0 10px 28px rgba(0,0,0,.35);
    --shadow-lg:0 18px 50px rgba(0,0,0,.5);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:var(--sans); background:var(--bg); color:var(--text);
    line-height:1.55; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
    min-height:100vh; overflow-x:hidden;
  }
  body::before{
    content:""; position:fixed; inset:0; z-index:-1; pointer-events:none;
    background:
      radial-gradient(900px 500px at 85% -8%, color-mix(in srgb,var(--primary) 14%, transparent), transparent 60%),
      radial-gradient(800px 600px at -10% 10%, color-mix(in srgb,var(--accent) 9%, transparent), transparent 55%);
  }
  a{color:inherit}
  button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
  ::selection{background:var(--primary);color:#fff}

  /* ---------- Header ---------- */
  header.site{
    position:sticky; top:0; z-index:50;
    backdrop-filter:saturate(140%) blur(14px);
    background:color-mix(in srgb,var(--bg) 82%, transparent);
    border-bottom:1px solid var(--border);
  }
  .header-inner{
    max-width:1240px;margin:0 auto;padding:14px 22px;
    display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  }
  .brand{display:flex;align-items:center;gap:12px;margin-right:auto;text-decoration:none}
  .brand .logo{
    width:42px;height:42px;border-radius:13px;display:grid;place-items:center;
    background:linear-gradient(150deg,var(--primary),var(--primary-2));
    box-shadow:0 6px 16px color-mix(in srgb,var(--primary) 40%,transparent);
    flex:none;
  }
  .brand .logo svg{width:24px;height:24px;color:#fff}
  .brand h1{font-family:var(--serif);font-size:1.34rem;font-weight:600;line-height:1.05;letter-spacing:-.01em}
  .brand small{display:block;color:var(--muted);font-size:.72rem;font-weight:500;letter-spacing:.02em;margin-top:1px}

  .header-actions{display:flex;align-items:center;gap:8px}
  .icon-btn{
    width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
    background:var(--surface);border:1px solid var(--border);color:var(--text);
    transition:transform .15s, border-color .2s, background .2s;
  }
  .icon-btn:hover{transform:translateY(-2px);border-color:var(--border-2)}
  .icon-btn svg{width:20px;height:20px}
  .icon-btn.active{background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}
  .icon-btn .fav-count{
    position:absolute;transform:translate(14px,-14px);background:var(--heart);color:#fff;
    font-size:.62rem;font-weight:700;min-width:17px;height:17px;border-radius:9px;
    display:grid;place-items:center;padding:0 4px;
  }
  .icon-btn{position:relative}

  /* ---------- Hero / Vogel des Tages ---------- */
  main{max-width:1240px;margin:0 auto;padding:0 22px 90px}
  .hero{
    margin:30px 0 8px; border-radius:26px; overflow:hidden; position:relative;
    background:var(--surface); border:1px solid var(--border); box-shadow:var(--shadow);
    display:grid; grid-template-columns:minmax(0,1.05fr) 1fr;
  }
  .hero-media{position:relative;min-height:230px;background:var(--surface-2)}
  .hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .hero-media .grad{position:absolute;inset:0;background:linear-gradient(90deg,transparent 55%,color-mix(in srgb,var(--surface) 92%,transparent))}
  html[data-theme="dark"] .hero-media .grad{background:linear-gradient(90deg,transparent 45%,color-mix(in srgb,var(--surface) 88%,transparent))}
  .hero-body{padding:28px 40px;display:flex;flex-direction:column;justify-content:center;gap:10px}
  .hero-badge{
    display:inline-flex;align-items:center;gap:7px;align-self:flex-start;
    background:var(--accent-soft);color:var(--accent);font-weight:600;font-size:.78rem;
    padding:7px 13px;border-radius:999px;letter-spacing:.02em;
  }
  .hero-badge svg{width:15px;height:15px}
  .hero-body h2{font-family:var(--serif);font-size:2.1rem;font-weight:600;line-height:1.04;letter-spacing:-.02em}
  .hero-body .sci{font-style:italic;color:var(--muted);font-size:1.02rem;margin-top:-4px}
  .hero-body p{color:var(--muted);max-width:46ch;font-size:.95rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
  .hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:4px}

  .btn{
    display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.92rem;
    padding:12px 20px;border-radius:13px;transition:transform .15s, box-shadow .2s, background .2s;
    border:1px solid transparent;white-space:nowrap;
  }
  .btn svg{width:18px;height:18px}
  .btn-primary{background:linear-gradient(150deg,var(--primary),var(--primary-2));color:#fff;box-shadow:0 8px 20px color-mix(in srgb,var(--primary) 35%,transparent)}
  .btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 26px color-mix(in srgb,var(--primary) 45%,transparent)}
  .btn-ghost{background:var(--surface-2);border-color:var(--border);color:var(--text)}
  .btn-ghost:hover{transform:translateY(-2px);border-color:var(--border-2)}

  /* ---------- Controls ---------- */
  .controls{position:sticky;top:72px;z-index:40;padding:18px 0 10px;background:linear-gradient(var(--bg) 72%,transparent)}
  .searchbar{position:relative;margin-bottom:14px}
  .searchbar svg.s-ic{position:absolute;left:18px;top:50%;transform:translateY(-50%);width:21px;height:21px;color:var(--faint)}
  .searchbar input{
    width:100%;font-size:1.02rem;font-family:inherit;color:var(--text);
    padding:16px 50px 16px 52px;border-radius:16px;border:1px solid var(--border);
    background:var(--surface);box-shadow:var(--shadow);transition:border-color .2s, box-shadow .2s;
  }
  .searchbar input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}
  .searchbar .clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:9px;display:none;place-items:center;color:var(--muted)}
  .searchbar .clear:hover{background:var(--surface-2)}
  .searchbar.has-text .clear{display:grid}

  .filters{display:flex;gap:9px;flex-wrap:wrap;align-items:center}
  .chip{
    display:inline-flex;align-items:center;gap:7px;font-weight:500;font-size:.86rem;
    padding:9px 15px;border-radius:999px;border:1px solid var(--border);
    background:var(--surface);color:var(--muted);transition:all .18s;white-space:nowrap;
  }
  .chip:hover{border-color:var(--border-2);color:var(--text);transform:translateY(-1px)}
  .chip .dot{width:9px;height:9px;border-radius:50%;background:var(--g-color,var(--primary))}
  .chip.active{background:var(--text);color:var(--bg);border-color:var(--text)}
  .chip.active .dot{background:var(--bg)}
  .chip .cnt{font-size:.74rem;opacity:.65;font-weight:600}
  .chip.fav-chip.active{background:var(--heart);border-color:var(--heart);color:#fff}

  .result-meta{margin:18px 2px 14px;color:var(--muted);font-size:.88rem;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}

  /* ---------- Grid ---------- */
  .grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
  .card{
    background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
    overflow:hidden;box-shadow:var(--shadow);cursor:pointer;position:relative;
    transition:transform .2s cubic-bezier(.2,.7,.3,1), box-shadow .2s, border-color .2s;
    display:flex;flex-direction:column;
  }
  .card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--border-2)}
  .card-media{position:relative;aspect-ratio:4/3;background:var(--surface-2);overflow:hidden}
  .card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;opacity:0}
  .card-media img.loaded{opacity:1}
  .card:hover .card-media img{transform:scale(1.06)}
  .skeleton{position:absolute;inset:0;background:linear-gradient(100deg,var(--surface-2) 30%,color-mix(in srgb,var(--surface-2) 50%,#fff 14%) 50%,var(--surface-2) 70%);background-size:200% 100%;animation:shimmer 1.4s infinite}
  html[data-theme="dark"] .skeleton{background:linear-gradient(100deg,var(--surface-2) 30%,#2a352b 50%,var(--surface-2) 70%);background-size:200% 100%;animation:shimmer 1.4s infinite}
  @keyframes shimmer{to{background-position:-200% 0}}
  .card-media .grp{
    position:absolute;left:12px;top:12px;font-size:.72rem;font-weight:600;
    padding:5px 11px;border-radius:999px;color:#fff;display:inline-flex;align-items:center;gap:6px;
    background:color-mix(in srgb,var(--g-color) 88%, #000 6%);backdrop-filter:blur(4px);
    box-shadow:0 3px 10px rgba(0,0,0,.18);
  }
  .fav-toggle{
    position:absolute;right:11px;top:11px;width:38px;height:38px;border-radius:50%;
    display:grid;place-items:center;background:color-mix(in srgb,#000 32%,transparent);
    backdrop-filter:blur(6px);color:#fff;transition:transform .15s, background .2s;
  }
  .fav-toggle:hover{transform:scale(1.12)}
  .fav-toggle svg{width:20px;height:20px;transition:transform .2s}
  .fav-toggle.on{color:var(--heart)}
  .fav-toggle.on svg{transform:scale(1.05)}

  .play-fab{
    position:absolute;right:13px;bottom:-22px;width:52px;height:52px;border-radius:50%;
    display:grid;place-items:center;background:linear-gradient(150deg,var(--primary),var(--primary-2));
    color:#fff;box-shadow:0 8px 20px color-mix(in srgb,var(--primary) 50%,transparent);
    transition:transform .2s, opacity .2s;z-index:3;
  }
  .play-fab:hover{transform:scale(1.08)}
  .play-fab svg{width:23px;height:23px;margin-left:2px}
  .play-fab.playing svg{margin-left:0}
  .play-fab.loading{pointer-events:none}
  .play-fab.loading .spin{width:21px;height:21px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:rot .7s linear infinite}
  @keyframes rot{to{transform:rotate(360deg)}}

  .card-body{padding:24px 18px 18px;display:flex;flex-direction:column;gap:5px;flex:1}
  .card-body h3{font-family:var(--serif);font-size:1.22rem;font-weight:600;letter-spacing:-.01em;line-height:1.1}
  .card-body .sci{font-style:italic;color:var(--faint);font-size:.84rem;margin-top:-2px}
  .card-body p{color:var(--muted);font-size:.88rem;margin-top:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

  .eq{display:inline-flex;gap:2px;align-items:flex-end;height:13px}
  .eq span{width:3px;background:currentColor;border-radius:2px;height:30%;animation:eq .9s ease-in-out infinite}
  .eq span:nth-child(2){animation-delay:.2s}
  .eq span:nth-child(3){animation-delay:.4s}
  .eq span:nth-child(4){animation-delay:.1s}
  @keyframes eq{0%,100%{height:25%}50%{height:100%}}

  /* ---------- Empty state ---------- */
  .empty{text-align:center;padding:70px 20px;color:var(--muted)}
  .empty svg{width:60px;height:60px;color:var(--faint);margin-bottom:14px}
  .empty h3{font-family:var(--serif);font-size:1.4rem;color:var(--text);margin-bottom:6px}
  .loading-state .loader{display:inline-block;width:38px;height:38px;margin-bottom:14px;border:3px solid var(--surface-2);border-top-color:var(--primary);border-radius:50%;animation:rot .8s linear infinite}

  /* ---------- Modal ---------- */
  .modal-backdrop{
    position:fixed;inset:0;z-index:100;background:color-mix(in srgb,#0a0f0b 55%,transparent);
    backdrop-filter:blur(6px);display:flex;align-items:flex-start;justify-content:center;
    padding:40px 20px;overflow-y:auto;opacity:0;pointer-events:none;transition:opacity .25s;
  }
  .modal-backdrop.open{opacity:1;pointer-events:auto}
  .modal{
    background:var(--surface);border:1px solid var(--border);border-radius:24px;
    max-width:760px;width:100%;box-shadow:var(--shadow-lg);overflow:hidden;
    transform:translateY(20px) scale(.98);transition:transform .28s cubic-bezier(.2,.8,.3,1);
  }
  .modal-backdrop.open .modal{transform:translateY(0) scale(1)}
  .modal-hero{position:relative;aspect-ratio:16/8;background:var(--surface-2)}
  .modal-hero img{width:100%;height:100%;object-fit:cover}
  .modal-hero .grad{position:absolute;inset:0;background:linear-gradient(0deg,color-mix(in srgb,var(--surface) 96%,transparent),transparent 55%)}
  .modal-close{
    position:absolute;right:14px;top:14px;width:40px;height:40px;border-radius:50%;
    background:color-mix(in srgb,#000 38%,transparent);backdrop-filter:blur(6px);color:#fff;
    display:grid;place-items:center;transition:transform .15s,background .2s;z-index:4;
  }
  .modal-close:hover{transform:rotate(90deg);background:color-mix(in srgb,#000 55%,transparent)}
  .modal-close svg{width:22px;height:22px}
  .modal-hero .titles{position:absolute;left:26px;bottom:18px;right:26px}
  .modal-hero .grp-m{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:600;color:#fff;padding:5px 11px;border-radius:999px;background:color-mix(in srgb,var(--g-color) 90%,#000);margin-bottom:9px}
  .modal-hero h2{font-family:var(--serif);font-size:2.1rem;font-weight:600;color:#fff;line-height:1.05;text-shadow:0 2px 14px rgba(0,0,0,.5)}
  .modal-hero .sci{font-style:italic;color:rgba(255,255,255,.92);font-size:1rem;text-shadow:0 2px 10px rgba(0,0,0,.5)}
  .modal-body{padding:24px 28px 30px}
  .audio-wrap{background:var(--surface-2);border:1px solid var(--border);border-radius:16px;padding:16px 18px;margin-bottom:22px}
  .audio-wrap .a-head{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-weight:600;font-size:.92rem}
  .audio-wrap .a-head svg{width:19px;height:19px;color:var(--primary)}
  .audio-wrap audio{width:100%;height:42px}
  .audio-note{color:var(--faint);font-size:.8rem;margin-top:10px}
  .audio-note a{color:var(--primary);font-weight:600;text-decoration:none}
  .modal-body > p.desc{color:var(--text);font-size:1rem;margin-bottom:22px}
  .facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:22px}
  .fact{background:var(--surface-2);border:1px solid var(--border);border-radius:13px;padding:13px 15px}
  .fact .k{font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--faint);display:flex;align-items:center;gap:6px}
  .fact .k svg{width:14px;height:14px}
  .fact .v{font-size:.95rem;font-weight:500;margin-top:3px}
  .modal-links{display:flex;gap:12px;flex-wrap:wrap}
  .modal-links a,.modal-links button{display:inline-flex;align-items:center;gap:8px;font-size:.88rem;font-weight:600;color:var(--primary);text-decoration:none;padding:10px 15px;border-radius:11px;border:1px solid var(--border);background:var(--surface-2);transition:transform .15s,border-color .2s;cursor:pointer}
  .modal-links a:hover,.modal-links button:hover{transform:translateY(-2px);border-color:var(--primary)}
  .modal-links a svg,.modal-links button svg{width:16px;height:16px;flex:none}
  .modal-links button.lnk-fav.is-fav{color:var(--heart);border-color:var(--heart)}

  /* ---------- Footer ---------- */
  footer{border-top:1px solid var(--border);background:var(--bg-2)}
  .foot-inner{max-width:1240px;margin:0 auto;padding:34px 22px;color:var(--muted);font-size:.86rem;display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:center}
  .foot-inner a{color:var(--primary);text-decoration:none;font-weight:600}
  .foot-inner strong{color:var(--text);font-family:var(--serif);font-weight:600}

  /* ---------- Toast ---------- */
  .toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,80px);z-index:200;
    background:var(--text);color:var(--bg);padding:12px 20px;border-radius:13px;font-weight:500;font-size:.9rem;
    box-shadow:var(--shadow-lg);opacity:0;transition:transform .3s,opacity .3s;display:flex;align-items:center;gap:9px}
  .toast.show{transform:translate(-50%,0);opacity:1}
  .toast svg{width:18px;height:18px;color:var(--primary-2)}

  /* ---------- Responsive ---------- */
  @media (max-width:820px){
    .hero{grid-template-columns:1fr}
    .hero-media{min-height:190px;aspect-ratio:16/9}
    .hero-media .grad{background:linear-gradient(0deg,color-mix(in srgb,var(--surface) 94%,transparent),transparent 60%)}
    .hero-body{padding:22px}
    .hero-body h2{font-size:1.7rem}
    .hero-body p{-webkit-line-clamp:2}
  }
  @media (max-width:560px){
    .header-inner{padding:12px 16px;gap:10px}
    .brand h1{font-size:1.12rem}
    .brand small{display:none}
    main{padding:0 14px 70px}
    .controls{top:66px}
    .grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}
    .card-body{padding:20px 14px 14px}
    .card-body h3{font-size:1.05rem}
    .card-body p{display:none}
    .modal-body{padding:20px 18px 24px}
    .modal-hero h2{font-size:1.6rem}
    .filters{flex-wrap:nowrap;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
    .filters::-webkit-scrollbar{display:none}
  }
  @media (prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;transition-duration:.001ms!important}}