/* ===========================================================
       BLAULICHTBOTE — Magazin / Anzeiger (Politico-inspiriert)
       Demo-Vorschau: keine Echtfälle, keine Echtmeldungen.
       Bilder: Unsplash (lizenzfrei) via source.unsplash.com (Preview)
       =========================================================== */

    :root{
      --bg:#ffffff;
      --ink:#0b1220;
      --muted:#4b5563;
      --muted2:#6b7280;
      --line:rgba(11,18,32,.12);

      /* Blaulicht-Brand */
      --red:#c5162a;
      --blue:#0d4ea6;
      --blue2:#1e6bd6;
      --amber:#b26a00;
      --green:#0c7a55;

      /* Politico-ish */
      --rail:#f5f6f8;
      --shadow: 0 10px 28px rgba(11,18,32,.10);
      --radius: 14px;
      --radius2: 10px;

      --max: 1180px;

      --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
      --serif: ui-serif, Georgia, "Times New Roman", Times, serif;

      --header-h: 110px; /* fallback until JS measures */
    }

    *{box-sizing:border-box}
    html,body{height:100%}
    body{
      margin:0;
      background:var(--bg);
      color:var(--ink);
      font-family:var(--sans);
      padding-top: var(--bb-header-h, var(--header-h));
    }
    a{color:inherit; text-decoration:none}
    .wrap{width:min(var(--max), calc(100% - 44px)); margin:0 auto}
    :target{scroll-margin-top: calc(var(--bb-header-h, var(--header-h)) + 12px);}

    /* ---------- Header (fixed, always visible) ---------- */
    .bb-header{
      position:fixed; top:0; left:0; right:0;
      z-index:80;
      background: rgba(255,255,255,.92);
      backdrop-filter: blur(10px);
      border-bottom: 1px solid var(--line);
      transition: box-shadow .18s ease;
    }
    .bb-header.is-scrolled{ box-shadow: var(--shadow); }

    .bb-topbar{
      display:grid;
      grid-template-columns: 44px 1fr 44px;
      align-items:center;
      gap:12px;
      padding: 10px 0 8px;
    }

    .bb-iconbtn{
      width:44px;height:44px;
      border-radius:999px;
      border:1px solid var(--line);
      background:#fff;
      cursor:pointer;
      font-size:16px;
      display:grid; place-items:center;
      transition: transform .12s ease, border-color .12s ease;
    }
    .bb-iconbtn:hover{transform: translateY(-1px); border-color: rgba(11,18,32,.22);}

    .bb-logo{
      display:flex; align-items:center; justify-content:center;
      gap:10px; min-width:0;
    }
    .bb-logoMark{
      width:36px;height:36px;border-radius:999px;
      display:grid;place-items:center;
      font-family:var(--serif);
      font-weight:900;
      letter-spacing:.02em;
      color:#fff;
      background: linear-gradient(135deg, var(--red), var(--blue));
      box-shadow: 0 10px 22px rgba(11,18,32,.14);
      flex: 0 0 auto;
    }
    .bb-logoText{
      font-family:var(--serif);
      font-weight:900;
      letter-spacing:.08em;
      text-transform:uppercase;
      font-size: 16px;
      line-height:1;
      white-space:nowrap;
      overflow:hidden;
      text-overflow:ellipsis;
    }

        .bb-infobar{
      display:flex; align-items:center; justify-content:space-between;
      flex-wrap:wrap;
      gap:10px;
      padding: 10px 0 12px;
      border-top:1px solid rgba(11,18,32,.06);
      font-size: 13px;
      color: rgba(11,18,32,.92);
    }
    .bb-infoLeft,.bb-infoMid,.bb-infoRight{
      display:flex; align-items:center; gap:8px; min-width:0;
    }
    .bb-infoMid{justify-content:center; flex:1;}
    .bb-label{color: rgba(11,18,32,.62); font-size:12px}
    .bb-liveDot{width:10px;height:10px;border-radius:99px;background:var(--red); box-shadow:0 0 0 6px rgba(197,22,42,.10)}
    .bb-pill{
      display:inline-flex; align-items:center; gap:8px;
      padding: 7px 10px;
      border-radius: 999px;
      border:1px solid var(--line);
      background:#fff;
      font-size: 12px;
      color: rgba(11,18,32,.88);
      white-space:nowrap;
    }
    .bb-pill strong{font-weight:800}

    /* ---------- Search overlay ---------- */
    .bb-searchOverlay{
      display:none;
      border-top:1px solid var(--line);
      background:#fff;
    }
    .bb-searchOverlay.is-open{display:block;}
    .bb-searchRow{
      display:grid;
      grid-template-columns: 1fr auto 44px;
      gap:10px;
      align-items:center;
      padding: 12px 0;
    }
    .bb-searchRow input{
      width:100%;
      border-radius: 999px;
      border:1px solid var(--line);
      background:#fff;
      padding: 12px 14px;
      font-size: 13px;
      outline:none;
    }
    .bb-searchRow input:focus{border-color: rgba(13,78,166,.30)}
    .bb-btn{
      border-radius: 999px;
      border:1px solid var(--line);
      background:#fff;
      padding: 12px 14px;
      cursor:pointer;
      font-size: 13px;
      transition: transform .12s ease;
    }
    .bb-btn:hover{transform: translateY(-1px); border-color: rgba(11,18,32,.22)}
    .bb-searchHint{
      padding: 0 0 12px;
      color: var(--muted2);
      font-size: 12px;
    }

    /* ---------- Drawer ---------- */
    .bb-drawerBackdrop{
      position:fixed; inset:0; z-index:90;
      background: rgba(11,18,32,.55);
      display:none;
    }
    .bb-drawerBackdrop.is-open{display:block;}
    .bb-drawer{
      position:fixed; top:0; left:0; z-index:95;
      height:100dvh; width:min(380px, 88vw);
      background:#fff;
      border-right:1px solid var(--line);
      box-shadow: 0 22px 70px rgba(11,18,32,.25);
      transform: translateX(-102%);
      transition: transform .18s ease;
      display:flex; flex-direction:column;
    }
    .bb-drawer.is-open{transform: translateX(0);}
    .bb-drawerHead{
      display:flex; align-items:center; justify-content:space-between;
      padding: 14px 14px;
      border-bottom:1px solid var(--line);
      background:
        linear-gradient(90deg, rgba(13,78,166,.08), #fff, rgba(197,22,42,.07));
    }
    .bb-drawerTitle{display:flex; align-items:center; gap:10px;}
    .bb-drawerBrand{
      font-family:var(--serif);
      font-weight:900;
      font-size: 16px;
      letter-spacing:.02em;
    }
    .bb-drawerSub{
      color: var(--muted2);
      font-size: 12px;
      margin-top:2px;
    }
    .bb-drawerNav{
      padding: 10px 10px;
      display:flex; flex-direction:column; gap:8px;
    }
    .bb-drawerNav a{
      padding: 12px 12px;
      border-radius: 12px;
      border:1px solid var(--line);
      background:#fff;
      font-size: 14px;
    }
    .bb-drawerNav a:hover{border-color: rgba(11,18,32,.22)}
    .bb-drawerFoot{
      margin-top:auto;
      padding: 12px 12px 16px;
      border-top:1px solid var(--line);
      background: var(--rail);
    }
    .bb-miniRule{
      border:1px dashed rgba(11,18,32,.22);
      border-radius: 12px;
      padding: 10px 12px;
      background:#fff;
      color: var(--muted);
      font-size: 12px;
      line-height:1.5;
    }

    /* ---------- Demo banner ---------- */
    .demoBanner{
      background: linear-gradient(90deg, rgba(197,22,42,.10), rgba(13,78,166,.08));
      border-bottom: 1px solid var(--line);
      padding: 10px 0;
      font-size: 13px;
      color: rgba(11,18,32,.90);
    }
    .demoBanner strong{font-weight:900}
    .demoBanner a{
      text-decoration: underline;
      color: rgba(11,18,32,.92);
    }

    /* ---------- Magazine layout ---------- */
    main{padding: 18px 0 44px}
    .grid{
      display:grid;
      grid-template-columns: 1.55fr .65fr;
      gap: 18px;
      align-items:start;
    }

    .rail{
      background: var(--rail);
      border:1px solid rgba(11,18,32,.10);
      border-radius: var(--radius);
      overflow:hidden;
    }
    .rail .block{
      padding: 14px 14px;
      border-top: 1px solid rgba(11,18,32,.10);
      background: #fff;
    }
    .rail .block:first-child{border-top:none}
    .rail h3{
      margin:0 0 8px;
      font-family:var(--serif);
      font-weight:900;
      letter-spacing:-.01em;
      font-size: 16px;
    }
    .rail p{
      margin: 0 0 12px;
      color: var(--muted);
      font-size: 12.5px;
      line-height:1.55;
    }
    .rail .btnRow{display:grid; gap:10px}
    .rail .btn{
      width:100%;
      border-radius: 999px;
      border:1px solid var(--line);
      background:#fff;
      padding: 12px 14px;
      cursor:pointer;
      font-size: 13px;
      transition: transform .12s ease, border-color .12s ease;
    }
    .rail .btn:hover{transform: translateY(-1px); border-color: rgba(11,18,32,.22)}
    .rail .btn.primary{
      border-color: rgba(197,22,42,.28);
      background: linear-gradient(180deg, rgba(197,22,42,.10), #fff);
    }

    .sectionTitle{
      display:flex; align-items:baseline; justify-content:space-between;
      gap:12px;
      margin: 0 0 10px;
      padding-bottom: 10px;
      border-bottom: 2px solid rgba(11,18,32,.08);
    }
    .sectionTitle h2{
      margin:0;
      font-family: var(--serif);
      font-weight: 900;
      letter-spacing: -.01em;
      font-size: 22px;
    }
    .sectionTitle .sub{
      color: var(--muted2);
      font-size: 12px;
    }

    /* ---------- Cards ---------- */

    /* ---------- Image fallback (for offline/local preview viewers) ---------- */
    .leadMedia, .thumb, .listThumb{
      background:
        radial-gradient(120% 90% at 30% 20%, rgba(13,78,166,.22) 0%, rgba(13,78,166,0) 55%),
        radial-gradient(120% 90% at 70% 30%, rgba(197,22,42,.18) 0%, rgba(197,22,42,0) 60%),
        linear-gradient(135deg, rgba(11,18,32,.18), rgba(11,18,32,.06));
    }
    img.is-broken{display:none !important;}
    .leadMedia.is-broken::after,
    .thumb.is-broken::after,
    .listThumb.is-broken::after{
      content:"Bildvorschau (offline)";
      position:absolute;
      left:12px; right:12px; bottom:12px;
      padding: 10px 12px;
      border-radius: 12px;
      border:1px dashed rgba(255,255,255,.45);
      background: rgba(11,18,32,.35);
      color:#fff;
      font-size: 12px;
      font-weight: 800;
      letter-spacing:.02em;
      backdrop-filter: blur(6px);
    }

    .lead{
      border:1px solid rgba(11,18,32,.10);
      border-radius: var(--radius);
      overflow:hidden;
      background:#fff;
      box-shadow: var(--shadow);
    }
    .leadMedia{
      position:relative;
      height: 320px;
      background:#111;
    }
    .leadMedia img{
      width:100%; height:100%;
      object-fit: cover;
      display:block;
      filter: contrast(1.02) saturate(1.02);
    }
    .mediaTag{
      position:absolute;
      left: 12px; top: 12px;
      display:inline-flex; align-items:center; gap:8px;
      padding: 8px 10px;
      border-radius: 999px;
      background: rgba(255,255,255,.92);
      border: 1px solid rgba(11,18,32,.16);
      font-size: 12px;
      font-weight: 800;
    }
    .mediaTag .dot{width:10px;height:10px;border-radius:99px;background:var(--red); box-shadow:0 0 0 6px rgba(197,22,42,.10)}
    .leadBody{padding: 14px 14px 16px}
    .kicker{
      display:flex; flex-wrap:wrap; gap:8px;
      align-items:center;
      margin-bottom: 8px;
      color: rgba(11,18,32,.86);
    }
    .kicker .chip{
      font-size: 11px;
      padding: 6px 9px;
      border-radius: 999px;
      border:1px solid var(--line);
      background:#fff;
      color: rgba(11,18,32,.84);
      white-space:nowrap;
    }
    .kicker .cat{
      font-weight: 900;
      letter-spacing:.04em;
      text-transform: uppercase;
      font-size: 11px;
      color: rgba(11,18,32,.78);
    }
    .leadTitle{
      margin:0;
      font-family: var(--serif);
      font-weight: 900;
      letter-spacing:-.01em;
      font-size: 26px;
      line-height: 1.08;
    }
    .leadTeaser{
      margin: 10px 0 0;
      color: var(--muted);
      font-size: 13.5px;
      line-height: 1.65;
      max-width: 78ch;
    }
    .metaRow{
      margin-top: 12px;
      display:flex; flex-wrap:wrap; gap:10px;
      align-items:center;
      color: var(--muted2);
      font-size: 12px;
    }
    .status{
      display:inline-flex; align-items:center; gap:8px;
      padding: 7px 10px;
      border-radius: 999px;
      border:1px solid rgba(11,18,32,.14);
      background:#fff;
      font-weight: 800;
      color: rgba(11,18,32,.86);
    }
    .s-demo{border-color: rgba(13,78,166,.22); background: rgba(13,78,166,.06); color: rgba(13,78,166,.95)}
    .s-ok{border-color: rgba(12,122,85,.22); background: rgba(12,122,85,.06); color: rgba(12,122,85,.95)}
    .s-warn{border-color: rgba(178,106,0,.26); background: rgba(178,106,0,.06); color: rgba(122,72,0,.95)}

    .cardGrid{
      margin-top: 14px;
      display:grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 12px;
    }
    .card{
      border:1px solid rgba(11,18,32,.10);
      border-radius: var(--radius);
      overflow:hidden;
      background:#fff;
      transition: transform .12s ease, border-color .12s ease;
    }
    .card:hover{transform: translateY(-2px); border-color: rgba(11,18,32,.18)}
    .thumb{
      height: 150px;
      background:#111;
    }
    .thumb img{
      width:100%; height:100%;
      object-fit: cover;
      display:block;
    }
    .cardBody{padding: 12px 12px 14px}
    .cardTitle{
      margin: 6px 0 0;
      font-family: var(--serif);
      font-weight: 900;
      letter-spacing:-.01em;
      font-size: 16px;
      line-height: 1.2;
    }
    .cardTeaser{
      margin: 8px 0 0;
      color: var(--muted);
      font-size: 12.5px;
      line-height: 1.55;
    }
    .cardMeta{
      margin-top: 10px;
      display:flex; flex-wrap:wrap; gap:8px;
      color: var(--muted2);
      font-size: 12px;
    }

    /* ---------- List (for remaining articles) ---------- */
    .list{
      margin-top: 14px;
      border:1px solid rgba(11,18,32,.10);
      border-radius: var(--radius);
      background:#fff;
      overflow:hidden;
    }
    .listItem{
      display:grid;
      grid-template-columns: 120px 1fr;
      gap: 12px;
      padding: 12px 12px;
      border-top:1px solid rgba(11,18,32,.10);
      align-items:start;
    }
    .listItem:first-child{border-top:none}
    .listThumb{
      width:120px; height:84px;
      border-radius: 10px;
      overflow:hidden;
      background:#111;
    }
    .listThumb img{width:100%; height:100%; object-fit:cover; display:block}
    .listTitle{
      margin: 4px 0 0;
      font-family: var(--serif);
      font-weight: 900;
      letter-spacing:-.01em;
      font-size: 15px;
      line-height: 1.25;
    }
    .listTeaser{
      margin: 6px 0 0;
      color: var(--muted);
      font-size: 12.5px;
      line-height: 1.55;
    }
    .listMeta{
      margin-top: 8px;
      display:flex; flex-wrap:wrap; gap:8px;
      color: var(--muted2);
      font-size: 12px;
    }

    /* ---------- Rail lists ---------- */
    .miniList{display:grid; gap:10px}
    .mini{
      border:1px solid rgba(11,18,32,.12);
      border-radius: 12px;
      background:#fff;
      padding: 10px 10px;
    }
    .mini .t{
      font-family:var(--serif);
      font-weight:900;
      font-size: 13px;
      line-height:1.25;
      margin:0;
    }
    .mini .m{
      margin-top:6px;
      color: var(--muted2);
      font-size: 12px;
    }
    .mini .tagRow{
      margin-top:8px;
      display:flex; gap:8px; flex-wrap:wrap;
    }
    .tag{
      font-size: 11px;
      padding: 6px 9px;
      border-radius: 999px;
      border:1px solid var(--line);
      background:#fff;
      color: rgba(11,18,32,.84);
    }

    /* ---------- Footer ---------- */
    footer{
      border-top:1px solid rgba(11,18,32,.12);
      background:#fff;
      padding: 18px 0 34px;
      color: rgba(11,18,32,.72);
      font-size: 12px;
    }
    .foot{
      display:flex; flex-wrap:wrap; gap:10px;
      align-items:center; justify-content:space-between;
    }
    .foot a{
      border:1px solid var(--line);
      background:#fff;
      padding: 8px 10px;
      border-radius: 999px;
    }
    .footnote{
      margin-top: 10px;
      color: rgba(11,18,32,.60);
      line-height: 1.55;
    }

    /* ---------- Floating actions ---------- */
    .bb-fabs{
      position: fixed;
      right: 14px;
      bottom: calc(14px + env(safe-area-inset-bottom, 0px));
      z-index: 70;
      display: grid;
      gap: 10px;
      opacity: 0;
      transform: translateY(12px);
      pointer-events: none;
      transition: opacity .16s ease, transform .16s ease;
    }
    .bb-fabs.is-on{opacity:1; transform:translateY(0); pointer-events:auto;}
    .bb-fabs.is-off{opacity:0; transform:translateY(24px); pointer-events:none;}

    .bb-fab{
      border-radius: 999px;
      border: 1px solid rgba(11,18,32,.16);
      background:#fff;
      box-shadow: 0 14px 30px rgba(11,18,32,.14);
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 12px 14px;
      cursor: pointer;
      color: rgba(11,18,32,.92);
      text-decoration: none;
      user-select: none;
      transition: transform .12s ease, border-color .12s ease;
      max-width: 170px;
    }
    .bb-fab:hover{transform: translateY(-1px); border-color: rgba(11,18,32,.24);}
    .bb-fabIcon{font-size:18px; line-height:1}
    .bb-fabLabel{font-size: 13px; white-space:nowrap;}

    .bb-fab-wa{
      border-color: rgba(11, 142, 79, .28);
      background: linear-gradient(180deg, rgba(11,142,79,.10), #fff);
    }
    .bb-fab-top{display:none;}
    .bb-fab-top.is-visible{display:inline-flex;}

    @media (max-width: 560px){
      .bb-fab{ padding: 12px; width: 52px; height: 52px; justify-content:center; }
      .bb-fabLabel{ display:none; }
      .bb-fabs{ right: 12px; bottom: calc(12px + env(safe-area-inset-bottom, 0px)); }
    }

    /* ---------- Responsive ---------- */
    
    /* ---------- Mobile header readability ---------- */
    @media (max-width: 560px){
      .bb-topbar{padding: 8px 0 6px;}
      .bb-logoText{font-size: 15px; letter-spacing:.06em;}
      .bb-logoMark{width:34px; height:34px;}

      .bb-infobar{
        display:grid;
        grid-template-columns: 1fr auto;
        grid-template-areas:
          "left right"
          "mid mid";
        row-gap: 8px;
        column-gap: 10px;
        padding: 10px 0 10px;
      }
      .bb-infoLeft{grid-area:left; flex-wrap:wrap; row-gap:6px;}
      .bb-infoRight{grid-area:right; justify-content:flex-end; white-space:nowrap;}
      .bb-infoMid{
        grid-area:mid;
        justify-content:flex-start;
        flex: 0 0 auto;
      }
      .bb-pill{font-size: 11px; padding: 6px 9px;}
      .bb-label{font-size: 11px;}
    }

    @media (min-width: 980px){
      .bb-topbar{grid-template-columns: 44px 1fr 44px;}
      .bb-logoText{font-size:18px;}
      .leadMedia{height: 360px;}
    }
    @media (max-width: 980px){
      .grid{grid-template-columns: 1fr}
      .cardGrid{grid-template-columns: 1fr}
      .leadTitle{font-size: 24px;}
    }