@charset "UTF-8";

:root {
  --tn-blue: #4581b9;
  --tn-blue-dark: #2f5e8a;
  --tn-blue-light: #e8f0f8;
  --tn-blue-soft: #f3f7fb;
  --tn-ink: #14202b;
  --tn-text: #2a3744;
  --tn-muted: #6b7785;
  --tn-line: #e3e8ee;
  --tn-line-soft: #eef1f5;
  --tn-bg: #ffffff;
  --tn-bg-soft: #fafbfc;
  --tn-accent: #c84630; /* warmer Akzent für „Anzeige" und besondere Trenner */
  /* Lese-Schriftgröße: --fz-body voll (Lesetext/Teaser), --fz-head gedämpft (Headlines/Nav) */
  --fz-body: 1;
  --fz-head: 1;
}
/* Stufen des Schriftgrößen-Reglers (Zahnrad). Stufe 0 = Default = 1/1 */
html[data-tn-fz="1"] { --fz-body: 1.15; --fz-head: 1.06; }
html[data-tn-fz="2"] { --fz-body: 1.30; --fz-head: 1.12; }
html[data-tn-fz="3"] { --fz-body: 1.50; --fz-head: 1.18; }

/* Base resets scoped to artboard */
*, *::before, *::after { box-sizing: border-box; }
body { font-family: Arial, "Helvetica Neue", Helvetica, sans-serif; color: var(--tn-text); background: var(--tn-bg); -webkit-font-smoothing: antialiased; margin: 0; }
html { max-width: 100%; } body { max-width: 100%; }
/* Boxed layout für Adnami-Skin: body-background sichtbar neben main-wrap */
body.boxed { background: #fff; }
.main-wrap { background: var(--tn-bg); width: 100%; max-width: 1228px; margin: 0 auto; }
/* Breadcrumb bricht aus dem main-wrap aus → volle Viewport-Breite */
.main-wrap .breadcrumbs-wrap {
    margin-left:  min(0px, calc((1228px - 100vw) / 2));
    margin-right: min(0px, calc((1228px - 100vw) / 2));
}
/* Themen-Quicklinks: volle Viewport-Breite via position-Trick */
.main-wrap .tn-home-quicklinks {
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    width: 100vw;
}
/* Overflow-Schutz auf einem Inner-Wrapper, nicht body - sonst bricht position:sticky */
h1,.tn-h1, h2, .tn-h2, h3, .tn-h3, h4, .tn-h4, .tn-h1, .tn-h2, .tn-h3, .tn-h4 { color: var(--tn-ink); margin: 0; line-height: 1.25; font-weight: 700; font-family: Georgia, 'Times New Roman', serif; display: block; }
p { margin: 0 0 1em; }
a { color: var(--tn-blue); text-decoration: none; }
a:hover { text-decoration: underline; }
ul.tn-clean, .tn-nav ul, .tn-mobile-nav, .tn-mobile-subnav, .tn-popular ul, .tn-side-list, .tn-h-meinung-list, .tn-h-insel-side, .tn-flyout ul, .tn-h-ten-content .list { list-style: none; padding: 0; margin: 0; }
img { max-width: 100%; height: auto; display: block; }

/* ----------- Header (geteilt zwischen Varianten) ----------- */
/* Topbar - dunkel mit Brand-Farbe als Hintergrund (mehr Kontrast für Social-Icons) */
.tn-topbar { background: var(--tn-blue-dark); border-bottom: 1px solid rgba(255,255,255,0.08); font-size: 12.5px; color: rgba(255,255,255,0.85); }
.tn-topbar-inner { max-width: 1180px; margin: 0 auto; padding: 7px 24px; display: flex; justify-content: space-between; align-items: center; gap: 16px; height: 38px; }
.tn-topbar a { color: rgba(255,255,255,0.85); transition: color .15s; }
.tn-topbar a:hover { color: #fff; text-decoration: none; }
.tn-topbar-date { letter-spacing: 0.3px; opacity: 0.95; font-weight: 500; }
.tn-topbar-right { display: flex; gap: 8px; align-items: center; white-space: nowrap; }
.tn-topbar-sep { color: rgba(255,255,255,0.55); padding: 0 2px; }
.tn-topbar-greet-link { display: inline-flex; align-items: center; gap: 6px; }
.tn-topbar-greet-link strong { color: #fff; font-weight: 700; }
.tn-topbar-greet-cta { opacity: 0.7; font-size: 11.5px; }
.tn-topbar-greet-link:hover .tn-topbar-greet-cta { opacity: 1; }
.tn-topbar-social { display: flex; align-items: center; padding-right: 4px; }

.tn-brand { background: #fff; border-bottom: 1px solid var(--tn-line); }
.tn-brand-inner { max-width: 1180px; margin: 0 auto; padding: 18px 24px; display: flex; align-items: center; gap: 24px; }
.tn-burger { display: none; flex-direction: column; gap: 4px; background: transparent; border: 0; padding: 8px; cursor: pointer; }
.tn-burger span { display: block; width: 22px; height: 2px; background: var(--tn-ink); border-radius: 1px; }
.tn-brand-logo { display: block; flex-shrink: 0; line-height: 0; }
.tn-brand-logo svg, .tn-brand-logo img { display: block; height: 96px; width: auto; }
.tn-brand-subline { display: flex; flex-direction: column; gap: 3px; font-family: Georgia, 'Times New Roman', serif; border-left: 2px solid var(--tn-line); padding-left: 18px; max-width: 360px; line-height: 1.35; }
.tn-brand-claim { font-style: italic; font-size: 16px; color: var(--tn-ink); font-weight: 500; }
.tn-brand-claim-sub { font-style: italic; font-size: 14px; color: var(--tn-muted); opacity: 0.85; }
.tn-brand-actions { margin-left: auto; display: flex; gap: 10px; align-items: center; }
.tn-search { display: flex; align-items: center; background: var(--tn-blue-soft); border: 1px solid transparent; border-radius: 999px; padding: 9px 18px; gap: 10px; min-width: 240px; transition: border-color .15s, background .15s; }
.tn-search:focus-within { border-color: var(--tn-blue); background: #fff; }
.tn-search input { background: transparent; border: 0; outline: 0; flex: 1; font: inherit; color: var(--tn-ink); font-size: 14px; }
.tn-search input::placeholder { color: var(--tn-muted); }
.tn-search-icon { display: inline-flex; align-items: center; color: var(--tn-blue); flex-shrink: 0; }

/* ----------- Mobile menu drawer ----------- */
.tn-mobile-overlay { position: fixed; inset: 0; background: rgba(20,32,43,0.6); z-index: 100000; display: flex; }
.tn-mobile-overlay[hidden] { display: none !important; }
.tn-mobile-drawer { width: 320px; max-width: 85vw; background: #fff; height: 100%; display: flex; flex-direction: column; box-shadow: 2px 0 24px rgba(0,0,0,0.2); animation: tn-slide-in .2s ease-out; }
@keyframes tn-slide-in { from { transform: translateX(-100%); } to { transform: translateX(0); } }
.tn-mobile-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px; border-bottom: 1px solid var(--tn-line); }
.tn-mobile-head svg { height: 36px; width: auto; }
.tn-mobile-close { background: transparent; border: 0; font-size: 28px; line-height: 1; color: var(--tn-muted); cursor: pointer; padding: 4px 8px; }
.tn-mobile-search { padding: 14px 20px; border-bottom: 1px solid var(--tn-line); display: flex; align-items: center; gap: 10px; background: var(--tn-blue-soft); }
.tn-mobile-search input { flex: 1; border: 0; background: transparent; outline: 0; font: inherit; color: var(--tn-ink); padding: 6px 0; }
.tn-mobile-nav { padding: 12px 0; flex: 1; overflow-y: auto; }
.tn-mobile-nav > li > a { display: block; padding: 13px 24px; color: var(--tn-ink); font-weight: 500; font-size: calc(17px * var(--fz-head)); border-bottom: 1px solid var(--tn-line-soft); }
.tn-mobile-nav > li.active > a { color: var(--tn-blue); background: var(--tn-blue-soft); }
.tn-mobile-subnav { display: none; background: var(--tn-bg-soft); border-bottom: 1px solid var(--tn-line-soft); }
.tn-mobile-nav li.is-open > .tn-mobile-subnav { display: block; }
.tn-mobile-subnav li a { display: block; padding: 9px 24px 9px 40px; color: var(--tn-text); font-size: calc(14px * var(--fz-head)); font-weight: 500; border: 0; }
.tn-mobile-subnav li a::before { content: "›"; margin-right: 8px; color: var(--tn-blue); }
.tn-mobile-subnav-l3 li a { padding-left: 56px; font-size: 13px; }
.tn-mobile-nav li.has-children > a { position: relative; padding-right: 44px; }
.tn-mobile-nav li.has-children > a::after { content: ""; position: absolute; right: 20px; top: 50%; transform: translateY(-50%); width: 0; height: 0; border-left: 5px solid transparent; border-right: 5px solid transparent; border-top: 5px solid var(--tn-muted); transition: transform .2s; }
.tn-mobile-nav li.has-children.is-open > a::after { transform: translateY(-50%) rotate(180deg); }
.tn-mobile-footer { padding: 20px; border-top: 1px solid var(--tn-line); display: flex; flex-direction: column; gap: 10px; background: var(--tn-bg-soft); }
.tn-mobile-greet { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; font-size: 14px; color: var(--tn-text); padding: 10px 14px; background: var(--tn-blue-soft); border-radius: 6px; border-left: 3px solid var(--tn-blue); }
.tn-mobile-greet strong { color: var(--tn-blue-dark); font-weight: 700; }
.tn-mobile-greet-cta { font-size: 12.5px; color: var(--tn-blue); font-weight: 600; margin-left: auto; }
.tn-mobile-btn-primary { display: block; padding: 12px 16px; background: var(--tn-blue); color: #fff !important; border-radius: 6px; text-align: center; font-weight: 700; font-size: 14px; text-transform: uppercase; letter-spacing: 0.5px; }
.tn-mobile-btn-primary:hover { text-decoration: none; opacity: 0.95; }
.tn-mobile-btn-secondary { display: block; padding: 11px 16px; background: #fff; color: var(--tn-ink) !important; border: 1px solid var(--tn-line); border-radius: 6px; text-align: center; font-weight: 600; font-size: 14px; }
.tn-mobile-btn-secondary:hover { text-decoration: none; border-color: var(--tn-blue); color: var(--tn-blue) !important; }
.tn-mobile-social { display: flex; justify-content: center; gap: 18px; padding-top: 14px; margin-top: 6px; border-top: 1px solid var(--tn-line); }
.tn-mobile-social .tn-social-strip { gap: 22px !important; }

/* Sticky-Shell wrappt Topbar + Brand + Navi + Breadcrumb gemeinsam - Desktop: alles sticky */
.tn-sticky-shell { position: sticky; top: 0; z-index: 10000; background: #fff; }

/* Mobile: Shell bleibt sticky als ganzes - einfachste und zuverlässigste Lösung */
@media (max-width: 900px) {
  .tn-sticky-shell { position: sticky; top: 0; }
}

.tn-nav { background: #fff; border-bottom: 2px solid var(--tn-blue); z-index: 5; }
.tn-nav-inner { max-width: 1180px; margin: 0 auto; padding: 0 24px; display: flex; align-items: center; gap: 4px; }
.tn-nav-item { position: relative; }
.tn-nav-item .tn-nav-link { display: inline-flex; align-items: center; padding: 14px 14px; font-size: calc(15px * var(--fz-head)); font-weight: 600; color: var(--tn-ink); letter-spacing: 0; cursor: pointer; }
.tn-nav-item.active .tn-nav-link { color: var(--tn-blue); }
.tn-nav-item:hover .tn-nav-link { color: var(--tn-blue); text-decoration: none; }
.tn-nav-item.has-children:hover .tn-nav-link svg { transform: rotate(180deg); }

/* Mega Flyout */
.tn-flyout { position: absolute; top: 100%; left: 0; min-width: 240px; background: #fff; border: 1px solid var(--tn-line); border-top: 3px solid var(--tn-blue); box-shadow: 0 12px 32px rgba(20,32,43,0.12); padding: 16px 20px; opacity: 0; visibility: hidden; transform: translateY(4px); transition: opacity .15s, transform .15s, visibility .15s; pointer-events: none; z-index: 10001; }
.tn-nav-item:hover .tn-flyout, .tn-nav-item:focus-within .tn-flyout { opacity: 1; visibility: visible; transform: translateY(0); pointer-events: auto; }
.tn-flyout-simple ul li a { display: block; padding: 8px 4px; font-size: calc(14px * var(--fz-head)); color: var(--tn-ink); border-bottom: 1px solid var(--tn-line-soft); font-weight: 500; }
.tn-flyout-simple ul li:last-child a { border-bottom: 0; }
.tn-flyout-simple ul li a:hover { color: var(--tn-blue); }
.tn-flyout-mega { min-width: 560px; padding: 22px 26px; }
.tn-flyout-mega-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px 36px; }
.tn-flyout-mega-col { min-width: 0; }
.tn-flyout-mega-head { display: block; font-size: 12px; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-blue-dark); font-weight: 800; padding-bottom: 8px; margin-bottom: 8px; border-bottom: 1px solid var(--tn-line); }
.tn-flyout-mega-head:hover { color: var(--tn-blue); text-decoration: none; }
.tn-flyout-mega-col ul li a { display: block; padding: 5px 0; font-size: 13.5px; color: var(--tn-text); font-weight: 500; }
.tn-flyout-mega-col ul li a:hover { color: var(--tn-blue); }

/* Burger only mobile */
@media (max-width: 900px) {
  .tn-burger { display: flex; }
  .tn-brand-subline { display: flex; border-left-width: 1.5px; padding-left: 12px; gap: 1px; }
  .tn-brand-claim { font-size: 12px; }
  .tn-brand-claim-sub { font-size: 12px; }
  .tn-brand-actions { display: none; }
  /* Topbar: Datum + Social + erste Pipe ausblenden, nur Login/Greeting bleibt */
  .tn-topbar-date { display: none; }
  .tn-topbar-social { display: none; }
  .tn-topbar-sep-social { display: none; }
  .tn-topbar-sep { color: rgba(255,255,255,0.9); font-weight: 300; font-size: 14px; }
  .tn-topbar-inner { padding: 5px 14px; justify-content: space-between; }
  .tn-brand-inner { padding: 12px 14px; gap: 0; justify-content: flex-start; position: relative; }
  .tn-brand-inner .tn-burger { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); }
  .tn-brand-logo { flex: 1; display: flex; justify-content: center; margin-left: 52px; margin-right: 52px; min-width: 0; }
  .tn-brand-logo svg, .tn-brand-logo .custom-logo, .tn-brand-logo img { height: auto !important; width: auto !important; max-height: 56px !important; max-width: 100% !important; }
}

/* Mobile Quick-Nav - horizontaler Scroll-Strip (Voll-Modus) */
.tn-mobile-quicknav { display: none; background: #fff; border-bottom: 2px solid var(--tn-blue); position: relative; }
.tn-mobile-quicknav::after { content: ''; position: absolute; top: 0; right: 0; width: 48px; height: 100%; background: linear-gradient(to right, transparent, #fff); pointer-events: none; }
.tn-mobile-quicknav-track { display: flex; gap: 0; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; padding: 0 12px; list-style: none; margin: 0; }
.tn-mobile-quicknav-track::-webkit-scrollbar { display: none; }
.tn-mobile-quicknav-item { flex: 0 0 auto; display: flex; align-items: center; white-space: nowrap; border-bottom: 2px solid transparent; margin-bottom: -2px; }
.tn-mobile-quicknav-link { padding: 11px 4px 11px 14px; font-size: 15px; font-weight: 600; color: var(--tn-ink); text-decoration: none; }
.tn-mobile-quicknav-item:not(.has-children) .tn-mobile-quicknav-link { padding-right: 14px; }
.tn-mobile-quicknav-item.active { border-bottom-color: var(--tn-blue); }
.tn-mobile-quicknav-item.active .tn-mobile-quicknav-link { color: var(--tn-blue); }
.tn-mobile-quicknav-chev { background: transparent; border: 0; padding: 11px 12px 11px 4px; color: var(--tn-muted); display: inline-flex; align-items: center; cursor: pointer; transition: transform .2s; }
.tn-mobile-quicknav-item.is-open .tn-mobile-quicknav-chev { transform: rotate(180deg); color: var(--tn-blue); }
.tn-mobile-quicknav-flyout { position: absolute; left: 0; right: 0; top: 100%; background: #fff; border-top: 1px solid var(--tn-line); border-bottom: 1px solid var(--tn-line); box-shadow: 0 10px 24px rgba(20,32,43,0.10); z-index: 1200; max-height: 70vh; overflow-y: auto; }
.tn-mobile-quicknav-flyout[hidden] { display: none; }
.tn-mobile-quicknav-flyout > ul, .tn-mobile-quicknav-flyout ul.tn-mobile-quicknav-sub { list-style: none; padding: 0; margin: 0; }
.tn-mobile-quicknav-flyout > ul > li > a { display: block; padding: 12px 24px; color: var(--tn-ink); font-size: 15px; font-weight: 600; border-bottom: 1px solid var(--tn-line-soft); text-decoration: none; }
.tn-mobile-quicknav-flyout > ul > li.has-sub > a { font-weight: 700; color: var(--tn-blue-dark); }
.tn-mobile-quicknav-flyout ul.tn-mobile-quicknav-sub > li > a { display: block; padding: 9px 24px 9px 40px; color: var(--tn-text); font-size: 14px; font-weight: 500; border-bottom: 1px solid var(--tn-line-soft); text-decoration: none; }
.tn-mobile-quicknav-flyout ul.tn-mobile-quicknav-sub > li > a::before { content: "›"; margin-right: 8px; color: var(--tn-blue); }
.tn-mobile-quicknav-search { display: flex; align-items: center; gap: 8px; padding: 8px 12px; border-bottom: 1px solid var(--tn-line); background: var(--tn-blue-soft); }
.tn-mobile-quicknav-search .tn-search-icon { display: flex; color: var(--tn-blue); }
.tn-mobile-quicknav-search input { flex: 1; border: 0; background: transparent; outline: 0; font: inherit; color: var(--tn-ink); font-size: 14px; padding: 4px 0; }
.tn-mobile-quicknav-search input::placeholder { color: var(--tn-muted); }
@media (max-width: 900px) {
  .tn-mobile-quicknav { display: block; }
}

.tn-breadcrumb { max-width: 1180px; margin: 0 auto; padding: 14px 0; font-size: 13px; color: var(--tn-muted); }
.tn-breadcrumb a { color: var(--tn-muted); }
.tn-breadcrumb .sep { margin: 0 8px; color: #c4cad1; }
.tn-breadcrumb .here { color: var(--tn-ink); font-weight: 600; }
.tn-breadcrumb-current, .breadcrumbs .tn-breadcrumb-current { display: inline; font: inherit; color: var(--tn-ink); font-weight: 600; margin: 0; padding: 0; line-height: inherit; letter-spacing: 0; }

/* ----------- Layout ----------- */
.tn-main { max-width: 1180px; margin: 0 auto; padding: 24px; display: grid; grid-template-columns: 1fr 320px; gap: 40px; }
.tn-content { min-width: 0; }
.tn-sidebar { min-width: 0; }

/* ----------- Trenner / Werbung ----------- */
.tn-ad-slot { margin: 24px 0 32px; padding: 22px 20px; background: var(--tn-bg-soft); border: 1px dashed var(--tn-line); border-radius: 4px; text-align: center; color: var(--tn-muted); font-size: 12px; letter-spacing: 0.3px; text-transform: uppercase; position: relative; }
.tn-ad-slot::before { content: "Anzeige"; position: absolute; top: -9px; left: 16px; background: #fff; padding: 0 8px; font-size: 11px; color: var(--tn-muted); }
.tn-ad-slot .ad-box { height: 90px; background: repeating-linear-gradient(45deg, #f1f3f5, #f1f3f5 10px, #e9ecef 10px, #e9ecef 20px); border-radius: 2px; display: flex; align-items: center; justify-content: center; font-size: 14px; color: #adb5bd; }

.tn-divider { display: flex; align-items: center; gap: 16px; margin: 36px 0; color: var(--tn-muted); font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 700; }
.tn-divider::before, .tn-divider::after { content: ""; flex: 1; height: 1px; background: var(--tn-line); }
.tn-divider .dot { width: 6px; height: 6px; background: var(--tn-blue); border-radius: 50%; }

/* ----------- Cat-Link-Blocks (eingebettet zwischen Artikeln) ----------- */
.tn-catlinks { margin: 28px 0; padding: 22px 24px; background: var(--tn-blue-soft); border-left: 4px solid var(--tn-blue); border-radius: 0 6px 6px 0; }
.tn-catlinks-title { font-size: 13px; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-blue-dark); font-weight: 700; margin-bottom: 12px; }
.tn-catlinks-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 6px 28px; font-size: 14px; }
.tn-catlinks-grid a { color: var(--tn-text); padding: 4px 0; border-bottom: 1px dotted var(--tn-line); }
.tn-catlinks-grid a:hover { color: var(--tn-blue); }

/* ----------- Popular Posts ----------- */
.tn-popular { margin: 32px 0; padding: 22px 24px; background: #fff; border: 1px solid var(--tn-line); border-radius: 6px; }
.tn-popular-title { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; text-transform: uppercase; letter-spacing: 1.5px; font-weight: 800; color: var(--tn-accent); margin-bottom: 14px; }
.tn-popular-title::before { content: "▸"; }
.tn-popular ul { display: grid; grid-template-columns: 1fr 1fr; gap: 0 24px; counter-reset: tn-popular-counter; }
.tn-popular li { font-size: 14.5px; line-height: 1.45; padding: 9px 0 9px 32px; position: relative; border-bottom: 1px solid var(--tn-line-soft); counter-increment: tn-popular-counter; }
.tn-popular li::before { content: counter(tn-popular-counter); position: absolute; left: 0; top: 8px; width: 22px; height: 22px; border-radius: 50%; background: var(--tn-blue); color: #fff; font-size: 11px; font-weight: 800; display: flex; align-items: center; justify-content: center; line-height: 1; }
.tn-popular li:nth-child(-n+3)::before { background: var(--tn-accent); }
.tn-popular li a { color: var(--tn-ink); font-weight: 600; text-decoration: none; }
.tn-popular li a:hover { color: var(--tn-blue); }
@media (max-width: 600px) { .tn-popular ul { grid-template-columns: 1fr; } }

/* ----------- Derzeit beliebt Strip (tn_render_popular_strip + Ad Inserter) ----------- */
.code-block-default { border-top: 1px solid var(--tn-line); border-bottom: 1px solid var(--tn-line); padding: 12px 0; margin: 20px 0; }
.code-block-default hr { display: none; }
/* In-Content-Ad: rechts floaten, Text umfließt */
.contentad-top-wrap { float: right; width: 340px; margin: 0 0 20px 24px; clear: right; display: flex; flex-direction: column; }
.contentad-top-wrap .symplr-ad-holder,
.contentad-top-wrap > div { width: 340px !important; max-width: 100%; }
/* "Werbung hier ausblenden" - direkt über dem Block, gleicher Hintergrund */
.contentad-top-wrap { gap: 0; }
.contentad-top-wrap > br { display: none; }
.contentad-top-hint { font-size: 11px; text-align: center; background: var(--tn-bg-soft); padding: 4px 8px 0; margin: 0; line-height: 1; }
.contentad-top { margin: 0 !important; padding: 0; }
.contentad-top-wrap .contentad-top-hint { margin: 0 !important; padding-bottom: 4px; }
.contentad-top-hint a { color: var(--tn-muted); text-decoration: none; }
.contentad-top-hint a:hover { text-decoration: underline; }
/* CLS: Hintergrundfarbe im Placeholder solange Ad noch lädt */
.symplr-ad-holder { background: var(--tn-bg-soft); }
@media (max-width: 640px) {
  .contentad-top-wrap { float: none; width: 100%; margin: 16px 0; }
  .contentad-top-wrap .symplr-ad-holder, .contentad-top-wrap > div { width: 100% !important; }
}
.popular-posts-headline { font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-blue-dark); margin-bottom: 6px; }
.popular-posts-block ul { display: flex; flex-wrap: wrap; gap: 4px 0; list-style: none; padding: 0; margin: 0; }
.popular-posts-block li { font-size: 15px; }
.popular-posts-block li::after { content: "·"; margin: 0 8px; color: var(--tn-muted); }
.popular-posts-block li:last-child::after { display: none; }
.popular-posts-block li a { color: var(--tn-ink); font-weight: 600; text-decoration: none; }
.popular-posts-block li a:hover { color: var(--tn-blue); text-decoration: underline; }

/* ----------- Derzeit beliebt Strip ----------- */
.tn-popular-strip { display: flex; align-items: baseline; flex-wrap: wrap; gap: 6px 16px; padding: 14px 0; margin: 24px 0; border-top: 1px solid var(--tn-line); border-bottom: 1px solid var(--tn-line); }
.cat-link-list { margin: 24px 0; }
.tn-popular-strip-label { font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-blue-dark); white-space: nowrap; }
.tn-popular-strip ul { display: flex; flex-wrap: wrap; gap: 4px 0; list-style: none; padding: 0; margin: 0; }
.tn-popular-strip li { font-size: 15px; }
.tn-popular-strip li::after { content: "·"; margin: 0 8px; color: var(--tn-muted); }
.tn-popular-strip li:last-child::after { display: none; }
@media (max-width: 900px) {
  .tn-popular-strip ul { flex-direction: column; gap: 6px 0; }
  .tn-popular-strip li::after { display: none; }
}
.tn-popular-strip li a { color: var(--tn-ink); font-weight: 600; text-decoration: none; }
.tn-popular-strip li a:hover { color: var(--tn-blue); text-decoration: underline; }

/* ----------- Pagination ----------- */
.tn-pagination { margin: 40px 0 8px; }
.tn-pagination__list { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; list-style: none; margin: 0; padding: 0; }
.tn-pagination__item a, .tn-pagination__item span { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 14px; border-radius: 8px; background: #fff; border: 1px solid var(--tn-line); color: var(--tn-text); font-weight: 600; font-size: 14px; text-decoration: none; }
.tn-pagination__item--current span { background: var(--tn-blue); border-color: var(--tn-blue); color: #fff; }
.tn-pagination__item a:hover { border-color: var(--tn-blue); color: var(--tn-blue); }
.tn-pagination__item--gap { display: inline-flex; align-items: center; padding: 0 6px; color: var(--tn-muted); font-size: 14px; }

/* ----------- Sidebar ----------- */
.tn-side-section { margin-bottom: 32px; }
.tn-side-title { font-size: 12px; text-transform: uppercase; letter-spacing: 1.5px; font-weight: 800; color: var(--tn-blue-dark); padding-bottom: 10px; border-bottom: 2px solid var(--tn-blue); margin-bottom: 16px; }
.tn-side-list li { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--tn-line-soft); }
.tn-side-thumb { width: 64px; height: 56px; border-radius: 6px; flex-shrink: 0; }
.tn-side-list a { font-size: 14px; line-height: 1.4; color: var(--tn-ink); font-weight: 600; }

/* ----------- Footer ----------- */
.tn-footer { background: var(--tn-ink); color: #c2cad3; padding: 36px 24px 24px; margin-top: 60px; }
.tn-footer-inner { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; font-size: 14px; }
.tn-footer h4 ,.tn-footer .tn-h4 { color: #fff; font-size: 14px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; }
.tn-footer a { color: #c2cad3; }
.tn-footer a:hover { color: #fff; }
.tn-footer-social { margin-top: 4px; }
.tn-footer-bottom { max-width: 1180px; margin: 24px auto 0; padding-top: 18px; border-top: 1px solid #2a3744; font-size: 12px; color: #8590a0; text-align: center; }

/* ============================================================
   Variante A - Konservativ
   Klassisch-redaktionell modernisiert: 2-Spalten-Karten, klare
   Typografie, dezente Hierarchie. Nahe am Original.
   ============================================================ */
.tn-a .tn-page-header { padding: 8px 0 24px; border-bottom: 1px solid var(--tn-line); margin-bottom: 28px; }
.tn-a .tn-page-title { font-size: 38px; font-weight: 800; letter-spacing: -0.5px; }
.tn-a .tn-page-desc { font-size: 16px; line-height: 1.6; color: var(--tn-muted); margin-top: 12px; max-width: 680px; }

.tn-a .tn-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px 24px; }
.tn-a .tn-card { display: flex; flex-direction: column; }
.tn-a .tn-card .img { aspect-ratio: 16/9; border-radius: 6px; overflow: hidden; position: relative; margin-bottom: 14px; display: flex; align-items: flex-end; padding: 12px; color: #fff; font-size: 11px; text-transform: uppercase; letter-spacing: 1px; }
.tn-a .tn-card .img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.5), rgba(0,0,0,0) 50%); pointer-events: none; }
.tn-a .tn-card .img-label { position: relative; z-index: 1; opacity: 0.85; }
.tn-a .tn-card .cat { display: inline-block; background: var(--tn-blue); color: #fff; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; padding: 4px 10px; border-radius: 3px; margin-bottom: 10px; }
.tn-a .tn-card h2 ,.tn-a .tn-card .tn-h2 { font-size: 21px; line-height: 1.3; margin-bottom: 8px; font-weight: 700; }
.tn-a .tn-card h2 a ,.tn-a .tn-card .tn-h2 a { color: var(--tn-ink); }
.tn-a .tn-card .excerpt { font-size: 14.5px; line-height: 1.6; color: var(--tn-text); }
.tn-a .tn-card .meta { display: flex; gap: 12px; font-size: 12px; color: var(--tn-muted); margin-top: 10px; }

/* ============================================================
   Variante B - Mittel
   Magazin-Hybrid: 1 Lead-Story groß, dann gemischtes Listen-Grid
   mit horizontalen Karten. Mehr Hierarchie + Whitespace.
   ============================================================ */
.tn-b .tn-page-header { padding: 8px 0 28px; margin-bottom: 28px; position: relative; }
.tn-b .tn-page-eyebrow { font-size: 11px; text-transform: uppercase; letter-spacing: 2px; color: var(--tn-blue); font-weight: 700; margin-bottom: 12px; }
.tn-b .tn-page-title { font-size: 48px; font-weight: 800; letter-spacing: -1px; line-height: 1.1; }
.tn-b .tn-page-desc { font-size: 17px; line-height: 1.6; color: var(--tn-text); margin-top: 14px; max-width: 720px; }
.tn-b .tn-page-meta { font-size: 13px; color: var(--tn-muted); margin-top: 16px; display: flex; gap: 18px; }
.tn-b .tn-page-meta strong { color: var(--tn-ink); }

.tn-b .tn-lead { display: grid; grid-template-columns: 1.2fr 1fr; gap: 28px; margin-bottom: 36px; }
.tn-b .tn-lead .img { aspect-ratio: 16/9; border-radius: 8px; overflow: hidden; position: relative; }
.tn-b .tn-lead .img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.4), transparent 60%); }
.tn-b .tn-lead-body { display: flex; flex-direction: column; justify-content: center; }
.tn-b .tn-lead .cat { display: inline-block; background: var(--tn-blue); color: #fff; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; padding: 5px 12px; border-radius: 3px; margin-bottom: 16px; align-self: flex-start; }
.tn-b .tn-lead h2 ,.tn-b .tn-lead .tn-h2 { font-size: 32px; line-height: 1.2; margin-bottom: 14px; letter-spacing: -0.3px; }
.tn-b .tn-lead h2 a ,.tn-b .tn-lead .tn-h2 a { color: var(--tn-ink); }
.tn-b .tn-lead .excerpt { font-size: 16px; line-height: 1.65; color: var(--tn-text); margin-bottom: 16px; }
.tn-b .tn-lead .meta { font-size: 13px; color: var(--tn-muted); display: flex; gap: 14px; }

.tn-b .tn-list-group { display: grid; grid-template-columns: 1fr 1fr; gap: 0 32px; }
.tn-b .tn-list-card { display: grid; grid-template-columns: 140px 1fr; gap: 16px; padding: 20px 0; border-bottom: 1px solid var(--tn-line-soft); }
.tn-b .tn-list-card:first-child { padding-top: 0; }
.tn-b .tn-list-card .img { aspect-ratio: 16/9; border-radius: 6px; overflow: hidden; }
.tn-b .tn-list-card .cat { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-blue); margin-bottom: 6px; }
.tn-b .tn-list-card h3 ,.tn-b .tn-list-card .tn-h3 { font-size: 17px; line-height: 1.35; margin-bottom: 6px; }
.tn-b .tn-list-card h3 a ,.tn-b .tn-list-card .tn-h3 a { color: var(--tn-ink); }
.tn-b .tn-list-card .excerpt { font-size: 13.5px; line-height: 1.5; color: var(--tn-muted); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.tn-b .tn-list-card .meta { font-size: 11.5px; color: var(--tn-muted); margin-top: 6px; }

/* ============================================================
   Variante C - Mutig
   Editorial Big-Type, asymmetrisches Layout, prominente Ziffer
   pro Karte, Zeitungsanmutung. Modern, mit Charakter.
   ============================================================ */
.tn-c .tn-page-header { padding: 16px 0 36px; border-bottom: 4px double var(--tn-ink); margin-bottom: 36px; }
.tn-c .tn-page-eyebrow { display: inline-flex; align-items: center; gap: 10px; font-size: 12px; text-transform: uppercase; letter-spacing: 3px; color: var(--tn-blue); font-weight: 800; margin-bottom: 16px; }
.tn-c .tn-page-eyebrow::before { content: ""; width: 32px; height: 2px; background: var(--tn-blue); }
.tn-c .tn-page-title { font-size: 64px; font-weight: 900; letter-spacing: -2px; line-height: 1; color: var(--tn-ink); }
.tn-c .tn-page-desc { font-size: 18px; line-height: 1.6; color: var(--tn-text); margin-top: 20px; max-width: 720px; font-style: italic; }
.tn-c .tn-page-stats { display: flex; gap: 32px; margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--tn-line); }
.tn-c .tn-page-stats .stat { display: flex; flex-direction: column; gap: 2px; }
.tn-c .tn-page-stats .num { font-size: 22px; font-weight: 800; color: var(--tn-ink); letter-spacing: -0.5px; }
.tn-c .tn-page-stats .lab { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-muted); }

.tn-c .tn-hero-row { display: grid; grid-template-columns: 1.6fr 1fr; gap: 32px; margin-bottom: 40px; padding-bottom: 36px; border-bottom: 1px solid var(--tn-line); }
.tn-c .tn-hero { position: relative; }
.tn-c .tn-hero .img { aspect-ratio: 16/10; border-radius: 4px; overflow: hidden; position: relative; }
.tn-c .tn-hero .img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.7), transparent 50%); }
.tn-c .tn-hero .body { position: absolute; bottom: 0; left: 0; right: 0; padding: 28px; color: #fff; }
.tn-c .tn-hero .cat { display: inline-block; background: var(--tn-blue); color: #fff; font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; padding: 6px 12px; margin-bottom: 14px; }
.tn-c .tn-hero h2 ,.tn-c .tn-hero .tn-h2 { font-size: 32px; line-height: 1.15; color: #fff; letter-spacing: -0.5px; margin-bottom: 10px; }
.tn-c .tn-hero h2 a ,.tn-c .tn-hero .tn-h2 a { color: #fff; }
.tn-c .tn-hero .excerpt { font-size: 15px; opacity: 0.92; max-width: 540px; }

.tn-c .tn-secondary { display: flex; flex-direction: column; gap: 18px; }
.tn-c .tn-secondary .item { padding-bottom: 18px; border-bottom: 1px solid var(--tn-line); }
.tn-c .tn-secondary .item:last-child { border-bottom: 0; padding-bottom: 0; }
.tn-c .tn-secondary .cat { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; color: var(--tn-blue); margin-bottom: 6px; }
.tn-c .tn-secondary h3 ,.tn-c .tn-secondary .tn-h3 { font-size: 18px; line-height: 1.3; }
.tn-c .tn-secondary h3 a ,.tn-c .tn-secondary .tn-h3 a { color: var(--tn-ink); }

.tn-c .tn-num-list { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.tn-c .tn-num-card { display: grid; grid-template-columns: 56px 1fr; gap: 18px; padding: 18px 0; border-top: 1px solid var(--tn-line); }
.tn-c .tn-num-card:first-child, .tn-c .tn-num-card:nth-child(2) { border-top: 0; padding-top: 0; }
.tn-c .tn-num-card .num { font-family: Georgia, "Times New Roman", serif; font-size: 44px; font-weight: 700; color: var(--tn-blue); line-height: 1; letter-spacing: -2px; font-style: italic; }
.tn-c .tn-num-card .cat { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; color: var(--tn-muted); margin-bottom: 6px; }
.tn-c .tn-num-card h3 ,.tn-c .tn-num-card .tn-h3 { font-size: 19px; line-height: 1.3; margin-bottom: 6px; }
.tn-c .tn-num-card h3 a ,.tn-c .tn-num-card .tn-h3 a { color: var(--tn-ink); }
.tn-c .tn-num-card .excerpt { font-size: 13.5px; line-height: 1.55; color: var(--tn-muted); }

.tn-c .tn-feature-band { margin: 36px 0; padding: 28px 0; border-top: 4px double var(--tn-ink); border-bottom: 4px double var(--tn-ink); display: grid; grid-template-columns: 200px 1fr; gap: 28px; align-items: center; }
.tn-c .tn-feature-band .img { aspect-ratio: 1/1; border-radius: 50%; }
.tn-c .tn-feature-band .cat { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; color: var(--tn-blue); margin-bottom: 8px; }
.tn-c .tn-feature-band h3 ,.tn-c .tn-feature-band .tn-h3 { font-size: 28px; line-height: 1.2; margin-bottom: 10px; letter-spacing: -0.3px; }
.tn-c .tn-feature-band h3 a ,.tn-c .tn-feature-band .tn-h3 a { color: var(--tn-ink); }
.tn-c .tn-feature-band .excerpt { font-size: 15px; color: var(--tn-text); line-height: 1.6; max-width: 560px; }

/* Tweaks */
.tn[data-density="compact"] .tn-card h2 ,.tn[data-density="compact"] .tn-card .tn-h2 { font-size: 18px; }
.tn[data-density="compact"] .tn-grid { gap: 20px 16px; }
.tn[data-cols="3"] .tn-grid { grid-template-columns: repeat(3, 1fr); }
.tn[data-cols="3"] .tn-a .tn-card h2 ,.tn[data-cols="3"] .tn-a .tn-card .tn-h2 { font-size: 17px; }
.tn[data-cols="3"] .tn-a .tn-card .img { aspect-ratio: 16/9; }


/* ============================================================
   Home-spezifische Stile (Top-Hero, Ticker, Meinung, Inseln,
   Wetter, Teneriffa-Hub, SEO-Footer)
   ============================================================ */
/* ============================================================
   Teneriffa News - Startseite
   Kategorie-Vorschauen, Live-Ticker, Wetter, Teneriffa-Hub
   ============================================================ */

.tn-home { background: var(--tn-bg); }
.tn-h-container { max-width: 1180px; margin: 0 auto; padding: 0 24px; }

/* ── TOP HERO ──────────────────────────────────────────────────── */
.tn-h-top { padding: 28px 0 8px; }
.tn-h-hero { display: grid; grid-template-columns: 1.55fr 1fr; gap: 24px; }
.tn-h-hero-main { display: flex; flex-direction: column; }
.tn-h-hero-main .img { aspect-ratio: 16/9; border-radius: 6px; overflow: hidden; position: relative; display: flex; align-items: flex-end; padding: 14px; color: #fff; font-size: 11px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 14px; }
.tn-h-hero-main .img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.55), rgba(0,0,0,0) 55%); }
.tn-h-hero-main .img-label { position: relative; z-index: 1; opacity: 0.85; }
.tn-h-hero-main .body .cat { display: inline-block; background: var(--tn-blue); color: #fff; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; padding: 4px 10px; border-radius: 3px; margin-bottom: 10px; }
.tn-h-hero-main .body h2 ,.tn-h-hero-main .body .tn-h2 { font-size: calc(30px * var(--fz-head)); line-height: 1.18; color: var(--tn-ink); margin-bottom: 10px; letter-spacing: -0.3px; }
.tn-h-hero-main .body p { font-size: calc(17px * var(--fz-body)); color: var(--tn-text); line-height: 1.55; }

.tn-h-hero-side { display: flex; flex-direction: column; gap: 14px; }
.tn-h-hero-side-item { display: grid; grid-template-columns: 130px 1fr; gap: 14px; padding-bottom: 14px; border-bottom: 1px solid var(--tn-line-soft); }
.tn-h-hero-side-item:last-child { border-bottom: 0; padding-bottom: 0; }
.tn-h-hero-side-item .img { aspect-ratio: 4/3; border-radius: 5px; }
.tn-h-hero-side-item .body .cat { font-size: 10.5px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-blue); margin-bottom: 5px; display: block; }
.tn-h-hero-side-item .body h3 ,.tn-h-hero-side-item .body .tn-h3 { font-size: calc(15px * var(--fz-head)); line-height: 1.3; color: var(--tn-ink); font-weight: 700; }
.tn-h-hero-side-item:hover h3 ,.tn-h-hero-side-item:hover .tn-h3 { color: var(--tn-blue); }

/* ── LIVE-TICKER STRIP ─────────────────────────────────────────── */
.tn-h-ticker { background: var(--tn-ink); color: #fff; padding: 14px 0 18px; margin: 28px 0; }
.tn-h-ticker-head { display: flex; align-items: center; gap: 16px; margin-bottom: 12px; }
.tn-h-ticker-head .live { font-size: 11px; font-weight: 800; letter-spacing: 1.5px; color: #ff5454; animation: tn-pulse 2s ease-in-out infinite; }
@keyframes tn-pulse { 50% { opacity: 0.5; } }
.tn-h-ticker-head .title { font-size: 14px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; color: #fff; }
.tn-h-ticker-head .all { margin-left: auto; font-size: 12px; color: rgba(255,255,255,0.7); }
.tn-h-ticker-head .all:hover { color: #fff; }
.tn-h-ticker-track { display: flex; gap: 12px; overflow-x: auto; scrollbar-width: thin; scrollbar-color: rgba(255,255,255,0.2) transparent; padding-bottom: 4px; }
.tn-h-ticker-track::-webkit-scrollbar { height: 4px; }
.tn-h-ticker-track::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.2); border-radius: 2px; }
.tn-h-ticker-item { flex: 0 0 280px; display: flex; flex-direction: column; gap: 5px; padding: 12px 14px; background: rgba(255,255,255,0.05); border-left: 3px solid var(--tn-blue); border-radius: 0 4px 4px 0; transition: background .15s; color: #fff; }
.tn-h-ticker-item:hover { background: rgba(255,255,255,0.1); text-decoration: none; }
.tn-h-ticker-item .lbl { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; color: #6db3e8; }
.tn-h-ticker-item .txt { font-size: 13.5px; line-height: 1.35; color: #fff; font-weight: 600; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.tn-h-ticker-item .dt { font-size: 11px; color: rgba(255,255,255,0.55); }

/* ── LIVETICKER PLUGIN: HOME ─────────────────────────────────────── */
.tn-h-ticker--plugin { padding: 20px 0 28px; }
.tn-h-ticker-plugin-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid rgba(255,255,255,0.1);
}

.tn-h-ticker--plugin .tn-ticker {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 9px;
  padding: 18px 20px;
  border-left: 1px solid rgba(255,255,255,0.1);
  border-bottom: 1px solid rgba(255,255,255,0.1);
  color: #fff;
  overflow: hidden;
  transition: background .15s;
}
.tn-h-ticker--plugin .tn-ticker:first-child { border-left: none; }
.tn-h-ticker--plugin .tn-ticker:nth-child(4n+1) { border-left: none; }
.tn-h-ticker--plugin .tn-ticker:hover { background: rgba(255,255,255,0.05); text-decoration: none; }

.tn-h-ticker--plugin .tn-ticker-dachzeile { display: flex; align-items: center; gap: 8px; }
.tn-h-ticker--plugin .tn-ticker-dachzeile-left {
  font-size: 10px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 1.5px; color: var(--tn-blue);
}
.tn-h-ticker--plugin .tn-ticker-live-badge {
  font-size: 9px; font-weight: 800; letter-spacing: 1px;
  color: #ff5454; animation: tn-pulse 2s ease-in-out infinite;
}
.tn-h-ticker--plugin .tn-ticker-headline-link { color: #fff; text-decoration: none; display: block; }
.tn-h-ticker--plugin .tn-ticker-headline-text {
  font-size: 14px; font-weight: 600; line-height: 1.5;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.tn-h-ticker--plugin .tn-ticker-card-overlay { position: absolute; inset: 0; z-index: 1; }

/* Insel-Akzentfarben: Dachzeile statt Border */
.tn-h-ticker--plugin .tn-ticker.tn-ticker--blaulicht    .tn-ticker-dachzeile-left { color: #7b9dd4; }
.tn-h-ticker--plugin .tn-ticker.tn-ticker--gran-canaria  .tn-ticker-dachzeile-left { color: #e2a84b; }
.tn-h-ticker--plugin .tn-ticker.tn-ticker--fuerteventura .tn-ticker-dachzeile-left { color: #d4a040; }
.tn-h-ticker--plugin .tn-ticker.tn-ticker--lanzarote     .tn-ticker-dachzeile-left { color: #e05c4b; }
.tn-h-ticker--plugin .tn-ticker.tn-ticker--la-palma      .tn-ticker-dachzeile-left { color: #4ecb82; }
.tn-h-ticker--plugin .tn-ticker.tn-ticker--la-gomera     .tn-ticker-dachzeile-left { color: #7aba5a; }
.tn-h-ticker--plugin .tn-ticker.tn-ticker--el-hierro     .tn-ticker-dachzeile-left { color: #5aa8d4; }

.tn-ticker-grid .tn-ticker.tn-ticker--blaulicht { border-left-color: #3d5a99; }

@media (max-width: 900px) {
  .tn-h-ticker-plugin-grid { grid-template-columns: repeat(2, 1fr); }
  .tn-h-ticker--plugin .tn-ticker:nth-child(4n+1) { border-left: 1px solid rgba(255,255,255,0.1); }
  .tn-h-ticker--plugin .tn-ticker:nth-child(2n+1) { border-left: none; }
}
@media (max-width: 560px) {
  .tn-h-ticker-plugin-grid { grid-template-columns: 1fr 1fr; }
  .tn-h-ticker--plugin .tn-ticker { padding: 14px 14px; }
}

/* ── LEADERBOARD-ADS (Startseite) ────────────────────────────── */
.tn-h-ad-lb { display: flex; justify-content: center; padding: 24px 0; min-height: 260px; align-items: center; position: relative; }
.tn-h-ad-sitebar { display: flex; justify-content: center; padding: 24px 0; }
.tn-h-ad-lb::before { content: "Anzeige"; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--tn-line); pointer-events: none; z-index: 0; }
.tn-h-ad-lb > * { position: relative; z-index: 1; }
.qm-side-tall { display: flex; justify-content: center; }

/* ── VIDEO-BLOCK (Startseite) ─────────────────────────────────── */
.tn-h-video { padding: 32px 0; background: var(--tn-bg); }
.tn-h-section-title { font-size: calc(18px * var(--fz-head)); font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-ink); padding-bottom: 10px; border-bottom: 2px solid var(--tn-blue); margin: 0 0 20px; font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif; }
.tn-h-video-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.tn-h-video-label { font-size: 15px; font-weight: 700; color: var(--tn-ink); margin: 0 0 10px; }
@media (max-width: 700px) { .tn-h-video-grid { grid-template-columns: 1fr; gap: 20px; } }

/* ── LIVETICKER PLUGIN: ÜBERSICHTSSEITE (hell, 1-Spalte) ──────── */
.tn-ticker-grid {
  display: flex;
  flex-direction: column;
  margin: 28px 0;
  border-top: 1px solid var(--tn-line);
}
.tn-ticker-grid .tn-ticker {
  position: relative;
  display: grid;
  grid-template-columns: 180px 1fr;
  align-items: center;
  gap: 0 32px;
  padding: 26px 0;
  border-bottom: 1px solid var(--tn-line-soft);
  color: var(--tn-ink);
  overflow: hidden;
  transition: background .15s;
}
.tn-ticker-grid .tn-ticker:hover { background: var(--tn-bg-soft); text-decoration: none; }
.tn-ticker-grid .tn-ticker-dachzeile { display: flex; align-items: center; gap: 8px; padding-left: 16px; border-left: 3px solid var(--tn-blue); }
.tn-ticker-grid .tn-ticker-dachzeile-left { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; color: var(--tn-blue); }
.tn-ticker-grid .tn-ticker-live-badge { font-size: 9px; font-weight: 800; letter-spacing: 1px; color: #e74c3c; animation: tn-pulse 2s ease-in-out infinite; }
.tn-ticker-grid .tn-ticker-headline { min-height: 0; }
.tn-ticker-grid .tn-ticker-headline-link { color: var(--tn-ink); text-decoration: none; display: block; }
.tn-ticker-grid .tn-ticker-headline-link:hover { color: var(--tn-blue); }
.tn-ticker-grid .tn-ticker-headline-text { font-size: 17px; font-weight: 700; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.tn-ticker-grid .tn-ticker-card-overlay { position: absolute; inset: 0; z-index: 1; }

/* Insel-Akzentfarben am Label-Border */
.tn-ticker-grid .tn-ticker.tn-ticker--blaulicht    .tn-ticker-dachzeile { border-left-color: #3d5a99; }
.tn-ticker-grid .tn-ticker.tn-ticker--blaulicht    .tn-ticker-dachzeile-left { color: #3d5a99; }
.tn-ticker-grid .tn-ticker.tn-ticker--gran-canaria  .tn-ticker-dachzeile { border-left-color: #c8963a; }
.tn-ticker-grid .tn-ticker.tn-ticker--gran-canaria  .tn-ticker-dachzeile-left { color: #c8963a; }
.tn-ticker-grid .tn-ticker.tn-ticker--fuerteventura .tn-ticker-dachzeile { border-left-color: #b88a2e; }
.tn-ticker-grid .tn-ticker.tn-ticker--fuerteventura .tn-ticker-dachzeile-left { color: #b88a2e; }
.tn-ticker-grid .tn-ticker.tn-ticker--lanzarote     .tn-ticker-dachzeile { border-left-color: #c0392b; }
.tn-ticker-grid .tn-ticker.tn-ticker--lanzarote     .tn-ticker-dachzeile-left { color: #c0392b; }
.tn-ticker-grid .tn-ticker.tn-ticker--la-palma      .tn-ticker-dachzeile { border-left-color: #27ae60; }
.tn-ticker-grid .tn-ticker.tn-ticker--la-palma      .tn-ticker-dachzeile-left { color: #27ae60; }
.tn-ticker-grid .tn-ticker.tn-ticker--la-gomera     .tn-ticker-dachzeile { border-left-color: #4a8a30; }
.tn-ticker-grid .tn-ticker.tn-ticker--la-gomera     .tn-ticker-dachzeile-left { color: #4a8a30; }
.tn-ticker-grid .tn-ticker.tn-ticker--el-hierro     .tn-ticker-dachzeile { border-left-color: #2471a3; }
.tn-ticker-grid .tn-ticker.tn-ticker--el-hierro     .tn-ticker-dachzeile-left { color: #2471a3; }

@media (max-width: 700px) {
  .tn-ticker-grid .tn-ticker { grid-template-columns: 1fr; gap: 10px 0; padding: 16px 0; }
  .tn-ticker-grid .tn-ticker-dachzeile { padding-left: 12px; }
}

/* Ticker in Kategoriebeschreibung - gleiche Optik wie /ticker */
.cat-description .tn-ticker {
  position: relative;
  display: grid;
  grid-template-columns: 180px 1fr;
  align-items: center;
  gap: 0 32px;
  padding: 20px 0;
  border-top: 1px solid var(--tn-line);
  border-bottom: 1px solid var(--tn-line-soft);
  color: var(--tn-ink);
  overflow: hidden;
  margin: 16px 0;
}
.cat-description .tn-ticker-dachzeile { display: flex; align-items: center; gap: 8px; padding-left: 16px; border-left: 3px solid var(--tn-blue); }
.cat-description .tn-ticker-dachzeile-left { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; color: var(--tn-blue); }
.cat-description .tn-ticker-live-badge { font-size: 9px; font-weight: 800; letter-spacing: 1px; color: #e74c3c; animation: tn-pulse 2s ease-in-out infinite; }
.cat-description .tn-ticker-headline-link { color: var(--tn-ink); text-decoration: none; display: block; }
.cat-description .tn-ticker-headline-link:hover { color: var(--tn-blue); }
.cat-description .tn-ticker-headline-text { font-size: 17px; font-weight: 700; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.cat-description .tn-ticker-card-overlay { position: absolute; inset: 0; z-index: 1; }
.cat-description .tn-ticker.tn-ticker--blaulicht    .tn-ticker-dachzeile { border-left-color: #3d5a99; }
.cat-description .tn-ticker.tn-ticker--blaulicht    .tn-ticker-dachzeile-left { color: #3d5a99; }
.cat-description .tn-ticker.tn-ticker--teneriffa    .tn-ticker-dachzeile { border-left-color: var(--tn-blue); }
.cat-description .tn-ticker.tn-ticker--gran-canaria  .tn-ticker-dachzeile { border-left-color: #c8963a; }
.cat-description .tn-ticker.tn-ticker--gran-canaria  .tn-ticker-dachzeile-left { color: #c8963a; }
.cat-description .tn-ticker.tn-ticker--fuerteventura .tn-ticker-dachzeile { border-left-color: #b88a2e; }
.cat-description .tn-ticker.tn-ticker--fuerteventura .tn-ticker-dachzeile-left { color: #b88a2e; }
.cat-description .tn-ticker.tn-ticker--lanzarote     .tn-ticker-dachzeile { border-left-color: #c0392b; }
.cat-description .tn-ticker.tn-ticker--lanzarote     .tn-ticker-dachzeile-left { color: #c0392b; }
.cat-description .tn-ticker.tn-ticker--la-palma      .tn-ticker-dachzeile { border-left-color: #27ae60; }
.cat-description .tn-ticker.tn-ticker--la-palma      .tn-ticker-dachzeile-left { color: #27ae60; }
.cat-description .tn-ticker.tn-ticker--la-gomera     .tn-ticker-dachzeile { border-left-color: #4a8a30; }
.cat-description .tn-ticker.tn-ticker--la-gomera     .tn-ticker-dachzeile-left { color: #4a8a30; }
.cat-description .tn-ticker.tn-ticker--el-hierro     .tn-ticker-dachzeile { border-left-color: #2471a3; }
.cat-description .tn-ticker.tn-ticker--el-hierro     .tn-ticker-dachzeile-left { color: #2471a3; }
@media (max-width: 700px) {
  .cat-description .tn-ticker { grid-template-columns: 1fr; gap: 10px 0; padding: 14px 0; }
  .cat-description .tn-ticker-dachzeile { padding-left: 12px; }
}

/* ── SECTION HEADER ────────────────────────────────────────────── */
.tn-h-sec { margin: 32px 0 20px; }
.tn-h-sec .row { display: flex; justify-content: space-between; align-items: baseline; padding-bottom: 10px; border-bottom: 2px solid var(--tn-blue); }
.tn-h-sec h2 ,.tn-h-sec .tn-h2 { font-size: calc(22px * var(--fz-head)); font-weight: 800; color: var(--tn-ink); letter-spacing: -0.2px; font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif; }
.tn-h-sec a h2 ,.tn-h-sec a .tn-h2 { color: var(--tn-ink); }
.tn-h-sec a:hover h2 ,.tn-h-sec a:hover .tn-h2 { color: var(--tn-blue); text-decoration: none; }
.tn-h-sec .all { font-size: 13px; font-weight: 600; color: var(--tn-blue); }
.tn-h-sec .sub { font-size: 14px; color: var(--tn-muted); margin-top: 10px; max-width: 720px; }
.tn-h-sec.big h2 ,.tn-h-sec.big .tn-h2 { font-size: calc(30px * var(--fz-head)); letter-spacing: -0.5px; }
.tn-h-sec.big .row { padding-bottom: 14px; }
.tn-h-sec.accent .row { border-bottom-color: var(--tn-accent); }
.tn-h-sec.accent h2 ,.tn-h-sec.accent .tn-h2 { color: var(--tn-accent); }
.tn-h-sec.light h2 ,.tn-h-sec.light .tn-h2 { color: var(--tn-ink); }
.tn-h-sec.light .all { color: var(--tn-blue); }
.tn-h-sec.light .row { border-bottom-color: var(--tn-blue); }
.tn-h-sec.light .sub { color: var(--tn-muted); }

/* ── 3er Grid (kleine Cards) ───────────────────────────────────── */
.tn-h-grid3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px 24px; margin-bottom: 32px; }
.tn-h-grid4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px 20px; margin-bottom: 32px; }

.tn-h-card-sm { display: flex; flex-direction: column; color: var(--tn-ink); }
.tn-h-card-sm:hover { text-decoration: none; }
.tn-h-card-sm .img { aspect-ratio: 16/10; border-radius: 5px; overflow: hidden; position: relative; display: flex; align-items: flex-end; padding: 10px; color: #fff; font-size: 10px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; background: #dfe6ed; }
.tn-h-card-sm .img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.tn-h-card-sm .img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.5), rgba(0,0,0,0) 55%); }
.tn-h-card-sm .img-label { position: relative; z-index: 1; opacity: 0.85; }
.tn-h-card-sm .cat { display: inline-block; font-size: 10.5px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-blue); margin-bottom: 6px; }
.tn-h-card-sm h3 ,.tn-h-card-sm .tn-h3 { font-size: calc(17px * var(--fz-head)); line-height: 1.3; color: var(--tn-ink); font-weight: 700; margin-bottom: 6px; }
.tn-h-card-sm:hover h3 ,.tn-h-card-sm:hover .tn-h3 { color: var(--tn-blue); }
.tn-h-card-sm .excerpt { font-size: calc(15.5px * var(--fz-body)); line-height: 1.5; color: var(--tn-muted); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.tn-h-card-sm .meta { font-size: 11.5px; color: var(--tn-muted); margin-top: 8px; }

/* ── FOTOS ──────────────────────────────────────────────────────── */
.tn-h-photo { display: flex; flex-direction: column; color: var(--tn-ink); }
.tn-h-photo:hover { text-decoration: none; }
.tn-h-photo .img { aspect-ratio: 4/3; border-radius: 5px; overflow: hidden; position: relative; display: flex; align-items: flex-end; padding: 10px; color: #fff; font-size: 10px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; }
.tn-h-photo .img::after { content: "📷"; position: absolute; top: 10px; right: 10px; font-size: 16px; opacity: 0.9; }
.tn-h-photo .img::before { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.5), rgba(0,0,0,0) 55%); }
.tn-h-photo .img-label { position: relative; z-index: 1; opacity: 0.85; }
.tn-h-photo h3 ,.tn-h-photo .tn-h3 { font-size: calc(14.5px * var(--fz-head)); line-height: 1.35; color: var(--tn-ink); font-weight: 700; }
.tn-h-photo:hover h3 ,.tn-h-photo:hover .tn-h3 { color: var(--tn-blue); }

/* ── MEINUNG ────────────────────────────────────────────────────── */
.tn-h-meinung { display: grid; grid-template-columns: 1.4fr 1fr; gap: 32px; margin-bottom: 32px; padding: 24px; background: var(--tn-bg-soft); border-left: 4px solid var(--tn-accent); border-radius: 0 6px 6px 0; }
.tn-h-meinung-hero { display: flex; flex-direction: column; color: var(--tn-ink); }
.tn-h-meinung-hero:hover { text-decoration: none; }
.tn-h-meinung-hero .img { aspect-ratio: 16/9; border-radius: 5px; overflow: hidden; position: relative; display: flex; align-items: flex-end; padding: 12px; color: #fff; font-size: 10px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; }
.tn-h-meinung-hero .img-label { position: relative; z-index: 1; opacity: 0.85; }
.tn-h-meinung-hero .img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.45), rgba(0,0,0,0) 55%); }
.tn-h-meinung-hero .cat { display: inline-block; font-size: 10.5px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; color: var(--tn-accent); margin-bottom: 6px; }
.tn-h-meinung-hero h3 ,.tn-h-meinung-hero .tn-h3 { font-size: calc(22px * var(--fz-head)); line-height: 1.25; color: var(--tn-ink); font-weight: 800; margin-bottom: 8px; letter-spacing: -0.2px; }
.tn-h-meinung-hero:hover h3 ,.tn-h-meinung-hero:hover .tn-h3 { color: var(--tn-accent); }
.tn-h-meinung-hero p { font-size: calc(16px * var(--fz-body)); color: var(--tn-muted); line-height: 1.5; }
.tn-h-meinung-list { display: flex; flex-direction: column; }
.tn-h-meinung-list li { display: grid; grid-template-columns: 70px 1fr; gap: 12px; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--tn-line-soft); }
.tn-h-meinung-list li:first-child { padding-top: 0; }
.tn-h-meinung-list li:last-child { border-bottom: 0; padding-bottom: 0; }
.tn-h-meinung-list .thumb { width: 70px; height: 60px; border-radius: 4px; }
.tn-h-meinung-list a { font-size: 14px; line-height: 1.35; color: var(--tn-ink); font-weight: 600; }
.tn-h-meinung-list a:hover { color: var(--tn-accent); }

/* ── INSEL-REISEFÜHRER (Hero-Style pro Insel) ──────────────────── */
.tn-h-inseln { background: var(--tn-blue-soft); padding: 8px 0 36px; margin-top: 36px; }
.tn-h-inseln-grid { display: flex; flex-direction: column; gap: 24px; margin-top: 18px; }

.tn-h-insel { background: #fff; border-radius: 6px; border: 1px solid var(--tn-line-soft); border-top: 3px solid var(--insel, var(--tn-blue)); overflow: hidden; }
.tn-h-insel[data-insel="gran-canaria"]  { --insel: #d4a373; }
.tn-h-insel[data-insel="fuerteventura"] { --insel: #c9a66b; }
.tn-h-insel[data-insel="lanzarote"]     { --insel: #7d2e0a; }
.tn-h-insel[data-insel="la-palma"]      { --insel: #27ae60; }
.tn-h-insel[data-insel="la-gomera"]     { --insel: #5a8a3a; }
.tn-h-insel[data-insel="el-hierro"]     { --insel: #1a5490; }
.tn-h-insel-head { display: flex; justify-content: space-between; align-items: center; padding: 14px 18px 12px; border-bottom: 1px solid var(--tn-line-soft); }
.tn-h-insel-head > a { color: var(--tn-ink); display: flex; align-items: baseline; }
.tn-h-insel-head .kicker { display: inline-block; font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; color: var(--insel, var(--tn-blue)); margin-right: 12px; }
.tn-h-insel-head .name { font-size: 18px; font-weight: 800; color: var(--tn-ink); letter-spacing: -0.3px; font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif; }
.tn-h-insel-head > a:hover .name { color: var(--insel, var(--tn-blue)); }
.tn-h-insel-head .all { font-size: 12.5px; font-weight: 600; color: var(--insel, var(--tn-blue)); white-space: nowrap; }
.tn-h-insel-head .all:hover { text-decoration: underline; }

.tn-h-insel-body { display: grid; grid-template-columns: 1.4fr 1fr; gap: 18px; padding: 16px 18px 18px; align-items: stretch; }
.tn-h-insel.is-rev .tn-h-insel-body { grid-template-columns: 1fr 1.4fr; }
.tn-h-insel.is-rev .tn-h-insel-main { order: 2; }
.tn-h-insel.is-rev .tn-h-insel-side { order: 1; }
.tn-h-insel-main { display: flex; flex-direction: column; color: var(--tn-ink); }
.tn-h-insel-main:hover { text-decoration: none; }
.tn-h-insel-main .img { width: 100%; aspect-ratio: 16/9; border-radius: 4px; overflow: hidden; position: relative; display: flex; align-items: flex-end; padding: 10px; color: #fff; font-size: 10px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; box-sizing: border-box; }
.tn-h-insel-main .img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.tn-h-insel-main .img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.45), rgba(0,0,0,0) 55%); }
.tn-h-insel-main .img-label { position: relative; z-index: 1; opacity: 0.85; }
.tn-h-insel-main h3 ,.tn-h-insel-main .tn-h3 { font-size: calc(17px * var(--fz-head)); line-height: 1.3; color: var(--tn-ink); font-weight: 700; font-family: Georgia, 'Times New Roman', serif; }
.tn-h-insel-main:hover h3 ,.tn-h-insel-main:hover .tn-h3 { color: var(--insel, var(--tn-blue)); }

.tn-h-insel-side { display: grid; grid-template-rows: repeat(5, 1fr); align-self: stretch; }
.tn-h-insel-side li { border-bottom: 1px solid var(--tn-line-soft); display: flex; }
.tn-h-insel-side li:last-child { border-bottom: 0; }
.tn-h-insel-side a { display: grid; grid-template-columns: 92px 1fr; gap: 12px; align-items: center; padding: 6px 0; color: var(--tn-ink); width: 100%; }
.tn-h-insel-side a:hover { text-decoration: none; }
.tn-h-insel-side a:hover span { color: var(--insel, var(--tn-blue)); }
.tn-h-insel-side .thumb { width: 92px; aspect-ratio: 16/10; border-radius: 3px; }
.tn-h-insel-side a span { font-size: 14.5px; line-height: 1.32; color: var(--tn-ink); font-weight: 700; font-family: Georgia, 'Times New Roman', serif; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.tn-h-insel-side li:first-child a { padding-top: 0; }
.tn-h-insel-side li:last-child a { padding-bottom: 0; }

/* ── WETTER (Text-Liste) ──────────────────────────────────────── */
.tn-h-wetter { padding: 28px 0 36px; margin: 36px 0 0; background: var(--tn-bg-soft); border-top: 1px solid var(--tn-line-soft); border-bottom: 1px solid var(--tn-line-soft); }
.tn-h-wetter-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0 24px; margin-top: 6px; }
.tn-h-wetter-card { display: grid; grid-template-columns: 1fr auto; grid-template-rows: auto auto; gap: 4px 12px; align-items: baseline; padding: 14px 4px; border-bottom: 1px solid var(--tn-line); color: var(--tn-ink); }
.tn-h-wetter-card:hover { text-decoration: none; background: transparent; }
.tn-h-wetter-card .lbl { font-size: 15px; font-weight: 700; color: var(--tn-ink); grid-column: 1; }
.tn-h-wetter-card:hover .lbl { color: var(--tn-blue); }
.tn-h-wetter-card .temp { font-size: 22px; font-weight: 700; color: var(--tn-ink); letter-spacing: -0.5px; grid-column: 2; grid-row: 1 / span 2; align-self: center; }
.tn-h-wetter-card .note { font-size: 12.5px; color: var(--tn-muted); grid-column: 1; text-align: left; min-width: 0; }

/* ── TENERIFFA-TABS ────────────────────────────────────────────── */
.tn-h-teneriffa { padding: 8px 0 16px; margin-top: 36px; }
.tn-h-ten-tabs { margin-top: 18px; }
.tn-h-ten-tabbar { display: flex; flex-wrap: wrap; gap: 4px; padding: 4px; background: var(--tn-bg-soft); border-radius: 8px; margin-bottom: 24px; }
.tn-h-ten-tabbar .tab { background: transparent; border: 0; padding: 9px 14px; font: inherit; font-size: 13px; font-weight: 600; color: var(--tn-text); border-radius: 5px; cursor: pointer; transition: background .15s, color .15s; }
.tn-h-ten-tabbar .tab:hover { color: var(--tn-blue); }
.tn-h-ten-tabbar .tab.active { background: var(--tn-blue); color: #fff; }
.tn-h-ten-content { display: grid; grid-template-columns: 1.4fr 1fr; gap: 32px; }
.tn-h-ten-content .hero { display: flex; flex-direction: column; color: var(--tn-ink); }
.tn-h-ten-content .hero:hover { text-decoration: none; }
.tn-h-ten-content .hero .img { aspect-ratio: 16/9; border-radius: 6px; overflow: hidden; position: relative; display: flex; align-items: flex-end; padding: 12px; color: #fff; font-size: 10px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 14px; }
.tn-h-ten-content .hero .img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.45), rgba(0,0,0,0) 55%); }
.tn-h-ten-content .hero .img-label { position: relative; z-index: 1; opacity: 0.85; }
.tn-h-ten-content .hero .cat { display: inline-block; font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; color: var(--tn-blue); margin-bottom: 6px; }
.tn-h-ten-content .hero h3 ,.tn-h-ten-content .hero .tn-h3 { font-size: 22px; line-height: 1.25; color: var(--tn-ink); font-weight: 800; letter-spacing: -0.2px; }
.tn-h-ten-content .hero:hover h3 ,.tn-h-ten-content .hero:hover .tn-h3 { color: var(--tn-blue); }
.tn-h-ten-content .list { display: flex; flex-direction: column; }
.tn-h-ten-content .list li { display: grid; grid-template-columns: 80px 1fr; gap: 14px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--tn-line-soft); }
.tn-h-ten-content .list li:first-child { padding-top: 0; }
.tn-h-ten-content .list li:last-child  { border-bottom: 0; }
.tn-h-ten-content .list .thumb { width: 80px; height: 64px; border-radius: 4px; }
.tn-h-ten-content .list a { font-size: 14.5px; line-height: 1.35; color: var(--tn-ink); font-weight: 600; }
.tn-h-ten-content .list a:hover { color: var(--tn-blue); }

/* ── SEO TEXT ───────────────────────────────────────────────────── */
.tn-h-foot-text { margin: 48px 0 20px; padding: 28px 0; border-top: 1px solid var(--tn-line); }
.tn-h-foot-text h1,.tn-h-foot-text .tn-h1, .tn-h-foot-text h2 , .tn-h-foot-text .tn-h2 { font-size: 24px; color: var(--tn-ink); margin-bottom: 14px; font-weight: 800; }
.tn-h-foot-text p, .tn-h-foot-text .excerpt { font-size: calc(19.5px * var(--fz-body)); line-height: 1.7; color: var(--tn-muted); max-width: 980px; margin-bottom: 20px; }
.tn-h-foot-text .excerpt a { color: var(--tn-muted); text-decoration: underline; text-underline-offset: 2px; }
.tn-h-foot-text .excerpt a:hover { color: var(--tn-blue); }
.tn-h-foot-text-links { display: flex; flex-wrap: wrap; gap: 6px 14px; font-size: 13px; }
.tn-h-foot-text-links a { color: var(--tn-blue); }

/* ── RESPONSIVE ─────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .tn-h-top { padding: 28px 0 24px; }
  .tn-h-hero { grid-template-columns: 1fr; }
  .tn-h-hero-main .body h2 ,  .tn-h-hero-main .body .tn-h2 { font-size: 25px; }
  .tn-h-hero-side-item { grid-template-columns: 110px 1fr; }
  .tn-h-hero-side-item .body h3 ,  .tn-h-hero-side-item .body .tn-h3 { font-size: 16px; }
  .tn-h-card-sm h3 ,  .tn-h-card-sm .tn-h3 { font-size: calc(19px * var(--fz-head)); }
  .tn-h-card-sm .excerpt { font-size: calc(17px * var(--fz-body)); }
  .tn-h-photo h3 ,  .tn-h-photo .tn-h3 { font-size: calc(16px * var(--fz-head)); }
  .tn-h-grid3 { grid-template-columns: 1fr; gap: 22px; }
  .tn-h-grid4 { grid-template-columns: repeat(2, 1fr); }
  .tn-h-meinung { grid-template-columns: 1fr; padding: 18px; }
  .tn-h-insel, .tn-h-insel.rev { grid-template-columns: 1fr; gap: 14px; padding: 22px 0; }
  .tn-h-insel.rev .tn-h-insel-label { order: 0; text-align: left; }
  .tn-h-insel.rev .tn-h-insel-list  { order: 2; }
  .tn-h-insel.rev .tn-h-insel-hero  { order: 1; }
  .tn-h-insel-label .name { font-size: 22px; margin-bottom: 6px; }
  .tn-h-insel-body { grid-template-columns: 1fr; gap: 14px; }
  .tn-h-insel.is-rev .tn-h-insel-body { grid-template-columns: 1fr; }
  .tn-h-insel.is-rev .tn-h-insel-main { order: 0; }
  .tn-h-insel.is-rev .tn-h-insel-side { order: 1; }
  .tn-h-insel-side { grid-template-rows: none; }
  .tn-h-wetter-grid { grid-template-columns: repeat(2, 1fr); gap: 0 16px; }
  .tn-h-ten-content { grid-template-columns: 1fr; gap: 22px; }
  .tn-h-sec.big h2 ,  .tn-h-sec.big .tn-h2 { font-size: 24px; }
  .tn-h-ticker-item { flex: 0 0 240px; }
}

@media (max-width: 560px) {
  .tn-h-grid4 { grid-template-columns: 1fr 1fr; }
  .tn-h-wetter-grid { grid-template-columns: repeat(2, 1fr); gap: 0 12px; }
  .tn-h-hero-side-item { grid-template-columns: 96px 1fr; gap: 10px; }
  .tn-h-hero-side-item .body h3 ,  .tn-h-hero-side-item .body .tn-h3 { font-size: 15px; }
  .tn-h-card-sm h3 ,  .tn-h-card-sm .tn-h3 { font-size: calc(18px * var(--fz-head)); }
}


/* ============================================================
   Theme-spezifische WP-Brücken (kein Mockup-Pendant)
   ============================================================ */

/* WP Custom-Logo Bridge - fügt sich in .tn-brand-logo ein */
.tn-brand-logo .custom-logo { height: 96px; width: auto; display: block; }
.tn-brand-logo img { max-height: 96px; width: auto; }

/* WP wp_nav_menu Bridge - der Default-Walker erzeugt <ul class="nav-list"><li class="menu-item"><a> */
.tn-nav .nav-list, .tn-nav-inner > ul { list-style: none; padding: 0; margin: 0; display: flex; align-items: center; gap: 4px; }
.tn-nav .menu-item, .tn-nav-inner > ul > li { position: relative; }
.tn-nav .menu-item > a, .tn-nav-inner > ul > li > a { display: inline-flex; align-items: center; padding: 14px 14px; font-size: 15px; font-weight: 600; color: var(--tn-ink); letter-spacing: 0; text-decoration: none; }
.tn-nav .menu-item > a:hover, .tn-nav-inner > ul > li > a:hover { color: var(--tn-blue); text-decoration: none; }
.tn-nav .current-menu-item > a, .tn-nav .current-menu-ancestor > a { color: var(--tn-blue); }
.tn-nav .menu-item-has-children > a::after { content: ""; display: inline-block; margin-left: 6px; width: 0; height: 0; border-left: 4px solid transparent; border-right: 4px solid transparent; border-top: 4px solid currentColor; transform: translateY(-1px); transition: transform .15s; }
.tn-nav .menu-item-has-children:hover > a::after { transform: translateY(-1px) rotate(180deg); }

/* Submenu (Standard-WP-Walker) - als einfacher Flyout */
.tn-nav .sub-menu { position: absolute; top: 100%; left: 0; min-width: 240px; background: #fff; border: 1px solid var(--tn-line); border-top: 3px solid var(--tn-blue); box-shadow: 0 12px 32px rgba(20,32,43,0.12); padding: 12px 16px; opacity: 0; visibility: hidden; transform: translateY(4px); transition: opacity .15s, transform .15s, visibility .15s; pointer-events: none; z-index: 20; list-style: none; margin: 0; }
.tn-nav .menu-item-has-children:hover > .sub-menu, .tn-nav .menu-item-has-children:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); pointer-events: auto; }
.tn-nav .sub-menu li { display: block; position: relative; }
.tn-nav .sub-menu li a { display: block; padding: 8px 4px; font-size: 14px; color: var(--tn-ink); border-bottom: 1px solid var(--tn-line-soft); font-weight: 500; text-transform: none; letter-spacing: 0; text-decoration: none; }
.tn-nav .sub-menu li:last-child a { border-bottom: 0; }
.tn-nav .sub-menu li a:hover { color: var(--tn-blue); }
.tn-nav .sub-menu .sub-menu { position: absolute; top: -3px; left: 100%; min-width: 220px; margin: 0; padding: 12px 16px; opacity: 0; visibility: hidden; transform: translateX(4px); transition: opacity .15s, transform .15s, visibility .15s; pointer-events: none; }
.tn-nav .sub-menu li:hover > .sub-menu, .tn-nav .sub-menu li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: translateX(0); pointer-events: auto; }
/* Chevron für Ebene-2-Items mit Untermenü: nach rechts, vertikal mittig */
.tn-nav .sub-menu .menu-item-has-children > a::after { border-top: 4px solid transparent; border-bottom: 4px solid transparent; border-left: 4px solid currentColor; border-right: 0; transform: translateY(0); margin-left: 8px; }
.tn-nav .sub-menu .menu-item-has-children:hover > a::after { transform: translateY(0) rotate(0); }

/* Mobile WP-Nav Bridge */
.tn-mobile-nav .menu-item > a { display: block; padding: 13px 24px; color: var(--tn-ink); font-weight: 500; font-size: 17px; border-bottom: 1px solid var(--tn-line-soft); text-decoration: none; }
.tn-mobile-nav .current-menu-item > a, .tn-mobile-nav .current-menu-ancestor > a { color: var(--tn-blue); background: var(--tn-blue-soft); }
.tn-mobile-nav .sub-menu { background: var(--tn-bg-soft); border-bottom: 1px solid var(--tn-line-soft); list-style: none; margin: 0; padding: 0; }
.tn-mobile-nav .sub-menu li a { display: block; padding: 9px 24px 9px 40px; color: var(--tn-text); font-size: 14px; font-weight: 500; border: 0; }
.tn-mobile-nav .sub-menu li a::before { content: "›"; margin-right: 8px; color: var(--tn-blue); }

/* Body-bg Anpassung - sonst keine Sticky-Hintergrund-Lücke */
body { background: var(--tn-bg); }

/* WP-Search-Form (get_search_form) - angleichen an .tn-search */
.tn-brand-actions .search-form,
.tn-mobile-search form { display: flex; align-items: center; gap: 8px; flex: 1; }
.tn-brand-actions .search-form { background: var(--tn-blue-soft); border: 1px solid transparent; border-radius: 999px; padding: 9px 18px; min-width: 240px; transition: border-color .15s, background .15s; }
.tn-brand-actions .search-form:focus-within { border-color: var(--tn-blue); background: #fff; }
.tn-brand-actions .search-form .search-field { background: transparent; border: 0; outline: 0; flex: 1; font: inherit; color: var(--tn-ink); font-size: 14px; }
.tn-brand-actions .search-form .search-field::placeholder { color: var(--tn-muted); }
.tn-brand-actions .search-form .search-submit, .tn-mobile-search form .search-submit { background: transparent; border: 0; padding: 0; cursor: pointer; color: var(--tn-blue); font-size: 14px; font-weight: 600; }
.tn-brand-actions .search-form label { flex: 1; display: flex; }
.tn-brand-actions .search-form .screen-reader-text { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }

/* Skip-link */
.screen-reader-text { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.screen-reader-text:focus { background: #fff; clip: auto; height: auto; width: auto; padding: 12px 16px; color: var(--tn-blue); z-index: 100; top: 8px; left: 8px; outline: 2px solid var(--tn-blue); }


/* ============================================================
   Theme-Templates Bridge - alte Klassen aus single/archive/sidebar/footer
   auf Mockup-Optik mappen (kein Markup-Refactoring nötig)
   ============================================================ */

/* ---- MAIN-Wrapper (single.php / archive.php) ---- */
.main { max-width: 1180px; margin: 0 auto; padding: 24px; display: grid; grid-template-columns: 1fr 320px; gap: 40px; }
.main-content { min-width: 0; }
.main--full { grid-template-columns: 1fr; max-width: 860px; }
@media (max-width: 900px) {
  .main { grid-template-columns: 1fr; padding: 16px; gap: 24px; }
}

/* ---- BREADCRUMBS ---- */
.breadcrumbs-wrap { background: var(--tn-bg-soft); border-bottom: 1px solid var(--tn-line-soft); position: relative; display: flex; align-items: center; }
.breadcrumbs { max-width: 1180px; width: 100%; margin: 0 auto; padding: 6px 24px; font-size: 13.5px; color: var(--tn-muted); line-height: 1.4; }
@media (max-width: 900px) { .breadcrumbs-wrap .breadcrumbs { padding: 4px 14px; font-size: 12.5px; } }
.breadcrumbs a { color: var(--tn-muted); text-decoration: none; }
.breadcrumbs a:hover { color: var(--tn-blue); }
.breadcrumbs .separator, .breadcrumbs span[aria-current] { color: var(--tn-ink); }
/* TN Just-Published Banner - überdeckt die Breadcrumb */
.tn-just-published-banner { position: absolute; inset: 0; background: #d32f2f; color: #fff; font-size: 15px; font-weight: 600; padding: 0 24px 0 max(24px, calc((100vw - 1180px) / 2 + 38px)); display: flex; align-items: center; gap: 10px; z-index: 10; }
#tn-jp-below { position: static; height: auto; inset: auto; margin: 20px 0; border-radius: 6px; padding: 12px 20px; }
.tn-just-published-banner a { color: #fff; text-decoration: underline; text-underline-offset: 2px; flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
@media (max-width: 900px) {
  /* Breadcrumb bleibt im Fluss → Wrap behält Höhe → kein CLS beim Banner-Inject */
  .breadcrumbs-wrap:has(.tn-just-published-banner) .tn-just-published-banner,
  .breadcrumbs-wrap.tn-jp-on .tn-just-published-banner {
    position: absolute;
    inset: 0;
    transform: none;
    display: flex;
    align-items: center;
    padding: 2px 14px;
    font-size: 12px; line-height: 1.25;
  }
  .breadcrumbs-wrap:has(.tn-just-published-banner) .tn-just-published-banner .tn-jp-inner,
  .breadcrumbs-wrap.tn-jp-on .tn-just-published-banner .tn-jp-inner {
    display: block; flex: 1; min-width: 0;
    padding-left: 86px; text-indent: -72px;
  }
  .breadcrumbs-wrap:has(.tn-just-published-banner) .tn-just-published-banner strong,
  .breadcrumbs-wrap.tn-jp-on .tn-just-published-banner strong { margin-right: 4px; }
  .breadcrumbs-wrap:has(.tn-just-published-banner) .tn-just-published-banner a,
  .breadcrumbs-wrap.tn-jp-on .tn-just-published-banner a {
    white-space: normal; overflow: visible; text-overflow: clip;
    display: inline;
  }
}
.tn-just-published-banner a:hover { opacity: .85; }
.tn-just-published-banner strong { white-space: nowrap; flex-shrink: 0; font-weight: 800; letter-spacing: .2px; }
/* Unter-Artikel-Banner (zweite Instanz) */
.tn-jp-under-article { background: #d32f2f; color: #fff; font-size: 13.5px; font-weight: 600; padding: 12px 20px; margin: 24px 0; display: flex; align-items: center; gap: 6px; border-radius: 4px; }
.tn-jp-under-article a { color: #fff; text-decoration: none; flex: 1; }
.tn-jp-under-article a:hover { text-decoration: underline; }

/* ---- ARCHIVE / SEARCH / AUTHOR - page-header ---- */
.page-header { margin-bottom: 28px; padding-bottom: 18px; border-bottom: 2px solid var(--tn-blue); }
.page-header h1 ,.page-header .tn-h1 { font-size: 32px; line-height: 1.15; color: var(--tn-ink); margin: 0 0 6px; letter-spacing: -0.4px; font-weight: 800; }
.page-header .cat-description { color: var(--tn-text); font-size: 15px; line-height: 1.6; margin-top: 8px; }

/* ---- ARCHIVE / SEARCH cards-grid ---- */
.cards-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px 24px; margin-bottom: 24px; }
@media (max-width: 700px) { .cards-grid { grid-template-columns: 1fr; gap: 22px; } }
.card { display: flex; flex-direction: column; }
.card .card-img, .card-img { aspect-ratio: 16/10; border-radius: 6px; overflow: hidden; margin-bottom: 14px; background: var(--tn-bg-soft); }
.card .card-img img, .card-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.card-cat { display: inline-block; background: var(--tn-blue); color: #fff; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; padding: 4px 10px; border-radius: 3px; margin-bottom: 10px; align-self: flex-start; }
.card h3 ,.card .tn-h3 { font-size: calc(20px * var(--fz-head)); line-height: 1.3; color: var(--tn-ink); font-weight: 700; margin-bottom: 8px; }
.card h3 a ,.card .tn-h3 a { color: inherit; text-decoration: none; }
.card:hover h3 a ,.card:hover .tn-h3 a { color: var(--tn-blue); }
.card-excerpt { font-size: calc(17px * var(--fz-body)); line-height: 1.55; color: var(--tn-muted); display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.card-meta { font-size: 13px; color: var(--tn-muted); margin-top: 10px; }
.card-byline { display: block; font-style: italic; font-size: 14px; color: var(--tn-muted); margin: 6px 0 8px; line-height: 1.35; }

/* Stretched-Link: ganze Karte/Zeile per EINEM internen Link (Headline) klickbar - entfernt Doppel-Link Bild+Schlagzeile (SEO + A11y) */
.card, .list-card, .schlagzeilen-item, .tn-h-hero-main { position: relative; }
.card .tn-card-link::after,
.list-card .tn-card-link::after,
.schlagzeilen-title a.tn-card-link::after,
.tn-h-hero-main .tn-h2 a.tn-card-link::after { content: ""; position: absolute; inset: 0; z-index: 1; }
.schlagzeilen-cat { position: relative; z-index: 2; }
.tn-h-hero-main .img-label { z-index: 2; }

/* ---- SINGLE - post-header / lede / meta / featured ---- */
.post-header { margin-bottom: 24px; }
.post-header .card-cat { margin-bottom: 14px; }
.post-header h1 ,.post-header .tn-h1 { font-size: calc(39px * var(--fz-head)); line-height: 1.15; color: var(--tn-ink); font-weight: 800; letter-spacing: -0.5px; margin: 0 0 14px; }
@media (max-width: 700px) { .post-header h1 { font-size: calc(28px * var(--fz-head)); } }
.post-header .lede { font-size: calc(20px * var(--fz-body)); line-height: 1.55; color: var(--tn-text); margin: 0 0 18px; font-weight: 400; }
/* Responsive 16:9-Wrap für eingebettete Videos im Teaser-Lede (Legacy "miframe") */
.lede .miframe, .post-content .miframe { position: relative; width: 100%; aspect-ratio: 16/9; margin: 12px 0 16px; background: #000; }
.lede .miframe iframe, .post-content .miframe iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.post-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 14px; padding: 14px 0; border-top: 1px solid var(--tn-line-soft); border-bottom: 1px solid var(--tn-line-soft); font-size: 14px; color: var(--tn-muted); }
.post-meta .author { display: inline-flex; align-items: center; gap: 8px; color: var(--tn-ink); font-weight: 600; }
.post-meta .author-avatar { width: 32px; height: 32px; border-radius: 50%; background: var(--tn-blue); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-weight: 700; font-size: 12px; }
.post-meta .reading-time, .post-meta .comments-count { color: var(--tn-muted); }
.author-mehr { background: none; border: 1px solid var(--tn-line); border-radius: 20px; padding: 1px 9px; font-size: 11.5px; color: var(--tn-blue); cursor: pointer; font-weight: 600; line-height: 1.8; }
.author-mehr:hover { background: var(--tn-blue); color: #fff; border-color: var(--tn-blue); }
.author-short-bio { width: 100%; font-size: 13.5px; line-height: 1.6; color: var(--tn-text); padding: 10px 14px; background: var(--tn-bg-soft); border-radius: 6px; margin-top: -4px; animation: tn-fadein .2s ease; }
.author-short-bio a { color: var(--tn-blue); }
@keyframes tn-fadein { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
.post-meta .meta-spacer { flex: 1; }
.post-share { display: inline-flex; gap: 6px; }
.share-btn { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 50%; color: #fff; text-decoration: none; transition: opacity .15s, background .15s, color .15s, border-color .15s; }
.share-btn:hover { opacity: .85; }
.share-fb   { background: #1877f2; }
.share-x    { background: #000; }
.share-wa   { background: #25d366; }
.share-mail { background: #6b7280; }
.share-google { background: #fff; border: 1px solid var(--tn-line); }
.share-google:hover { background: var(--tn-blue-soft); border-color: var(--tn-blue); opacity: 1; }
/* Teilen-Toggle: invertiert (weiss/blau), fuellt sich bei Hover blau */
.share-toggle { background: #fff; border: 1px solid var(--tn-blue); color: var(--tn-blue); padding: 0; cursor: pointer; }
.share-toggle:hover { background: var(--tn-blue); color: #fff; opacity: 1; }
.share-wrap { position: relative; display: inline-flex; }
.share-menu { position: absolute; top: 100%; left: 0; padding-top: 6px; display: flex; flex-direction: column; gap: 6px; z-index: 5; opacity: 0; visibility: hidden; transform: translateY(-6px); transition: opacity .18s ease, transform .18s ease, visibility .18s; }
.share-wrap:hover .share-menu, .share-wrap:focus-within .share-menu, .share-wrap.is-open .share-menu { opacity: 1; visibility: visible; transform: none; }

/* ---- SINGLE - featured image + caption ---- */
.featured { margin: 24px 0; }
.featured-img-wrap { position: relative; line-height: 0; }
.featured img { width: 100%; height: auto; display: block; border-radius: 6px; }
.featured-credit { display: block; text-align: right; font-size: 13px; color: var(--tn-muted); margin-top: 2px; line-height: 1.4; }
.featured-caption { margin-top: 8px; font-size: 16px; line-height: 1.45; color: var(--tn-muted); font-style: italic; }

/* ---- SINGLE - Audio-Player ---- */
.audioplayer { display: flex; align-items: center; gap: 14px; padding: 14px 16px; background: var(--tn-blue-soft); border: 1px solid var(--tn-line); border-radius: 8px; margin: 18px 0; }
.audioplayer-icon { width: 40px; height: 40px; border-radius: 50%; background: var(--tn-blue); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 16px; }
.audioplayer-body { flex: 1; }
.audioplayer-label { font-size: 13px; color: var(--tn-ink); font-weight: 600; margin-bottom: 6px; }
.audioplayer-track { height: 4px; background: rgba(0,0,0,0.08); border-radius: 2px; overflow: hidden; }
.audioplayer-track-fill { width: 30%; height: 100%; background: var(--tn-blue); border-radius: 2px; }
.audioplayer--full audio { display: block; width: 100%; margin-top: 6px; }
.audioplayer--locked { background: var(--tn-blue-soft); }
.audioplayer-icon--locked { background: rgba(0,0,0,0.12); font-style: normal; }
.audioplayer-locked-hint { display: flex; align-items: center; gap: 8px; margin-top: 4px; font-size: 13px; }
.audioplayer-locked-cta { font-weight: 600; color: var(--tn-blue); text-decoration: none; }
.audioplayer-locked-cta:hover { text-decoration: underline; }
.audioplayer-locked-sep { color: var(--tn-ink-muted, #888); }

/* ---- SINGLE - post-content (Artikel-Body) ---- */
.post-content { font-size: calc(19px * var(--fz-body)); line-height: 1.7; color: var(--tn-text); }
.post-content > * { margin: 10px 0 18px; }
.post-content > *:first-child { margin-top: 0; }
.post-content h2 ,.post-content .tn-h2 { font-size: calc(27px * var(--fz-head)); line-height: 1.25; color: var(--tn-ink); font-weight: 800; margin: 32px 0 32px; }
.post-content h3 ,.post-content .tn-h3 { font-size: calc(22px * var(--fz-head)); line-height: 1.3; color: var(--tn-ink); font-weight: 700; margin: 28px 0 28px; }
.post-content p { font-size: calc(19px * var(--fz-body)); line-height: 1.7; margin: 10px 0 18px; }
.post-content a { color: var(--tn-blue); text-decoration: underline; text-underline-offset: 3px; }
.post-content .wp-caption-text, .post-content .wp-element-caption { font-size: 16px; line-height: 1.45; color: var(--tn-muted); }
.post-content a:hover { color: var(--tn-blue-dark); }
.post-content blockquote { border-left: 4px solid var(--tn-blue); padding: 4px 0 4px 20px; margin: 24px 0; font-size: calc(20px * var(--fz-body)); line-height: 1.55; color: var(--tn-ink); font-style: italic; }
.post-content img { max-width: 100%; height: auto; border-radius: 6px; }
/* WP-Editor-Ausrichtung (alignleft/right/center) - Text umfließt das Bild */
.post-content .alignleft, .lede .alignleft { float: left; margin: 6px 20px 12px 0; }
.post-content .alignright, .lede .alignright { float: right; margin: 6px 0 12px 20px; }
.post-content .aligncenter, .lede .aligncenter { display: block; margin-left: auto; margin-right: auto; float: none; }
.post-content .alignnone, .lede .alignnone { float: none; }
@media (max-width: 600px) {
  .post-content .alignleft, .post-content .alignright,
  .lede .alignleft, .lede .alignright { float: none; display: block; margin-left: auto; margin-right: auto; }
}
.post-content ul, .post-content ol { padding-left: 24px; }
.post-content li { margin-bottom: 6px; }

/* ---- SINGLE - Pagination + sponsored ---- */
.pagination { display: flex; gap: 8px; align-items: center; padding: 14px 0; font-size: 13px; color: var(--tn-muted); }
.pagination a, .pagination .post-page-numbers { padding: 6px 12px; border: 1px solid var(--tn-line); border-radius: 4px; color: var(--tn-text); text-decoration: none; }
.pagination .post-page-numbers.current { background: var(--tn-blue); color: #fff; border-color: var(--tn-blue); }
.sponsored_post_hr_below { border: 0; border-top: 1px solid var(--tn-accent); margin: 24px 0 8px; }
.sponsored_post_below { display: block; font-size: 12px; color: var(--tn-accent); font-style: italic; }
/* Anzeigen-/Hinweis-Kennzeichnung oben (kleine Versalien, rechtsbündig + dünner Akzent-Trenner) */
.sponsored_post_above { display: block; text-align: right; font-size: 11px; line-height: 1.2; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 700; color: var(--tn-accent); }
.sponsored_post_hr_above { border: 0; border-top: 1px solid var(--tn-accent); margin: 4px 0 16px; }
.ugc_post_above, .extra_above_home { display: block; font-size: 12px; line-height: 1.4; color: var(--tn-muted); font-style: italic; }
/* Anzeige-Hinweis auf Karten/Listen (Index + Home) - wie Artikelebene: Wort rechtsbuendig + schmaler Streifen */
.card-anzeige { display: block; text-align: right; font-size: 10px; line-height: 1.3; letter-spacing: .06em; text-transform: uppercase; font-weight: 700; color: var(--tn-accent); border-bottom: 1px solid var(--tn-accent); padding-bottom: 3px; margin-bottom: 8px; }
/* "Sehen Sie jetzt" Related-CTA (ACF related_manuell) - Ueberschrift wie .section-head, Balken links (kantig), ohne Hintergrund, Bild in voller Groesse */
#related-cta { margin: 1.4em 0; }
#related-cta > strong { display: block; font-size: 17px; font-weight: 800; color: var(--tn-ink); margin-bottom: 12px; }
.tn-related-cta-item { display: block; text-decoration: none; margin: 0 0 1.4em; border-left: 3px solid var(--tn-blue); padding-left: 16px; }
.tn-related-cta-item:last-child { margin-bottom: 0; }
.tn-related-cta-title { display: block; font-family: Georgia, 'Times New Roman', serif; font-size: calc(22px * var(--fz-head)); font-weight: 700; color: var(--tn-ink); line-height: 1.3; margin-bottom: .5em; }
.tn-related-cta-img { display: block; line-height: 0; }
.tn-related-cta-img img { width: 100%; height: auto; display: block; border-radius: 0; }
#related-cta a { color: var(--tn-blue-dark); text-decoration: none; }

/* ---- SINGLE - Author-Box ---- */
.author-box { display: grid; grid-template-columns: 80px 1fr; gap: 18px; padding: 24px; background: var(--tn-bg-soft); border-radius: 8px; margin: 32px 0; }
.author-box .avatar { width: 80px; height: 80px; border-radius: 50%; background: var(--tn-blue); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-weight: 800; font-size: 28px; }
.author-box h3 ,.author-box .tn-h3 { font-size: 17px; color: var(--tn-ink); margin: 0 0 4px; font-weight: 800; }
.author-box .author-role { font-size: 12.5px; color: var(--tn-muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px; }
.author-box .author-bio { font-size: 14px; line-height: 1.6; color: var(--tn-text); margin: 0 0 10px; }
.author-box .author-links { display: flex; gap: 14px; font-size: 13px; }
.author-box .author-links a { color: var(--tn-blue); text-decoration: none; font-weight: 600; }

/* ---- SINGLE - Related Posts ---- */
.related-posts { margin-top: 40px; }
.section-head { font-size: 19px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-ink); padding-bottom: 10px; border-bottom: 2px solid var(--tn-blue); margin: 0 0 20px; font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif; }
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 700px) { .related-grid { grid-template-columns: 1fr; } }

/* ---- SIDEBAR ---- */
/* position:relative wird per JS gesetzt; kein CSS-sticky - theiaStickySidebar-Logik in tn-header.js */
.sidebar { min-width: 0; }
.sidebar .sticky-target { display: flex; flex-direction: column; gap: 24px; }
.side-section,
.sidebar .widget { background: #fff; border: 1px solid var(--tn-line-soft); border-radius: 6px; padding: 18px; }
.sidebar .widget_ai_widget,
.sidebar .widget.block-widget { background: none; border: none; border-radius: 0; padding: 0; }
.sidebar .code-block-default { border: none; padding: 0; margin: 0; }
.side-title,
.sidebar .widget-title { font-size: 14px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-ink); padding-bottom: 10px; border-bottom: 2px solid var(--tn-blue); margin: 0 0 14px; font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif; }
.side-list,
.sidebar .posts-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.side-list li,
.sidebar .posts-list li { display: grid; grid-template-columns: 70px 1fr; gap: 12px; align-items: start; }
.sidebar .posts-list li img { width: 70px; height: 50px; border-radius: 4px; object-fit: cover; display: block; }
.sidebar .posts-list .content { font-size: 14.5px; line-height: 1.35; font-weight: 700; }
.sidebar .posts-list .content a { color: var(--tn-ink); text-decoration: none; }
.sidebar .posts-list .content a:hover { color: var(--tn-blue); }
.side-thumb { width: 70px; height: 50px; border-radius: 4px; background-size: cover; background-position: center; background-color: var(--tn-bg-soft); }
.side-list-body h4 ,.side-list-body .tn-h4 { font-size: 14.5px; line-height: 1.35; margin: 0 0 4px; font-weight: 700; }
.side-list-body h4 a ,.side-list-body .tn-h4 a { color: var(--tn-ink); text-decoration: none; }
.side-list-body h4 a:hover ,.side-list-body .tn-h4 a:hover { color: var(--tn-blue); }
.side-list-body .meta { font-size: 12.5px; color: var(--tn-muted); }
.ad-slot { margin: 18px 0; padding: 10px; background: var(--tn-bg-soft); border: 1px dashed var(--tn-line); text-align: center; font-size: 11px; color: var(--tn-muted); position: relative; }
.ad-slot::before { content: "Anzeige"; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--tn-line); pointer-events: none; z-index: 0; }
.ad-slot > * { position: relative; z-index: 1; }

/* ---- FOOTER (alte Klassen) Bridge auf Mockup-Optik ---- */
.main-footer { background: #14202b; color: #c2cad3; padding: 36px 24px 24px; margin-top: 60px; }
.main-footer-inner { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; font-size: 14px; }
.main-footer h4 ,.main-footer .tn-h4 { color: #fff; font-size: 14px; text-transform: uppercase; letter-spacing: 1px; margin: 0 0 12px; }
.main-footer a { color: #c2cad3; text-decoration: none; }
.main-footer a:hover { color: #fff; }
.main-footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.footer-brand p { font-size: 13px; line-height: 1.6; color: #8590a0; }
.footer-social { margin-top: 14px; padding: 0; }
.footer-social li { list-style: none; }
.footer-social a { width: 34px; height: 34px; border-radius: 50%; background: rgba(255,255,255,0.06); display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; }
.footer-social a:hover { background: var(--tn-blue); color: #fff; }
.lower-foot { max-width: 1180px; margin: 24px auto 0; padding-top: 18px; border-top: 1px solid #2a3744; font-size: 12px; color: #8590a0; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
@media (max-width: 700px) {
  .main-footer-inner { grid-template-columns: 1fr 1fr; gap: 24px; }
  .lower-foot { flex-direction: column; text-align: center; }
}

/* ---- SEARCH-FORM (get_search_form) - Standard-Output ---- */
.search-form { display: flex; align-items: center; gap: 8px; }
.search-form .search-field { flex: 1; padding: 9px 14px; border: 1px solid var(--tn-line); border-radius: 999px; font: inherit; }
.search-form .search-submit { padding: 9px 18px; background: var(--tn-blue); color: #fff; border: 0; border-radius: 999px; font-weight: 700; cursor: pointer; }

/* ---- Brand-Search (searchform.php) - Inline-Variante für Suchseite ---- */
.brand-search { display: flex; align-items: center; gap: 10px; background: var(--tn-blue-soft); border: 1px solid transparent; border-radius: 999px; padding: 10px 18px; transition: border-color .15s, background .15s; }
.brand-search:focus-within { border-color: var(--tn-blue); background: #fff; }
.brand-search input[type="search"] { flex: 1; background: transparent; border: 0; outline: 0; font: inherit; font-size: 15px; color: var(--tn-ink); min-width: 0; padding: 4px 0; }
.brand-search input[type="search"]::placeholder { color: var(--tn-muted); }
.brand-search button { flex: 0 0 auto; background: transparent; border: 0; cursor: pointer; color: var(--tn-blue); font-weight: 700; font-size: 18px; padding: 0 4px; }

/* ---- LEGACY [list style="..."]-Shortcodes ---- */
.tn-list { list-style: none; padding: 0; margin: 14px 0; }
.tn-list li { position: relative; padding: 4px 0 4px 30px; line-height: 1.5; }
.tn-list--check li::before { content: "✓"; position: absolute; left: 4px; top: 4px; color: var(--tn-blue); font-weight: 800; font-size: 17px; line-height: 1.5; }
.tn-list--star  li::before { content: "★"; position: absolute; left: 4px; top: 4px; color: #f5a623; font-size: 15px; line-height: 1.5; }
.tn-list--arrow li::before { content: "▸"; position: absolute; left: 6px; top: 4px; color: var(--tn-blue); font-weight: 800; line-height: 1.5; }
.tn-list--dot   li::before { content: "•"; position: absolute; left: 8px; top: 4px; color: var(--tn-muted); font-size: 18px; line-height: 1.4; }

/* ---- LEGACY [columns]/[column]-Shortcodes ---- */
.tn-cols { display: flex; flex-wrap: wrap; gap: 16px; margin: 24px 0; }
.tn-col { flex: 1 1 100%; min-width: 0; }
.tn-col--1-2 { flex: 0 1 calc(50% - 8px); }
.tn-col--1-3 { flex: 0 1 calc(33.333% - 11px); }
.tn-col--2-3 { flex: 0 1 calc(66.666% - 5px); }
.tn-col--1-4 { flex: 0 1 calc(25% - 12px); }
.tn-col--3-4 { flex: 0 1 calc(75% - 4px); }
.tn-col--1-1 { flex: 0 1 100%; }
.tn-col img { max-width: 100%; height: auto; }
@media (max-width: 900px) {
  .tn-col--1-4 { flex: 0 1 calc(50% - 8px); }
  .tn-col--1-3 { flex: 0 1 calc(50% - 8px); }
}
@media (max-width: 500px) {
  .tn-col--1-4, .tn-col--1-3, .tn-col--1-2, .tn-col--2-3, .tn-col--3-4 { flex: 0 1 100%; }
}

/* ---- POST TAGS ---- */
.post-tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 20px 0 4px; }

/* ---- SCHLAGZEILEN-LISTE ---- */
.schlagzeilen-list { display: flex; flex-direction: column; gap: 0; }
.schlagzeilen-item { display: flex; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--tn-line); align-items: flex-start; }
.schlagzeilen-thumb { flex-shrink: 0; width: 100px; height: 68px; border-radius: 5px; overflow: hidden; display: block; background: var(--tn-bg-soft); }
.schlagzeilen-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.schlagzeilen-body { flex: 1; min-width: 0; }
.schlagzeilen-cat { font-size: 10.5px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-blue); text-decoration: none; display: inline-block; margin-bottom: 4px; }
.schlagzeilen-title { font-size: 16px; line-height: 1.35; font-weight: 700; margin: 0 0 6px; }
.schlagzeilen-title a { color: var(--tn-ink); text-decoration: none; }
.schlagzeilen-title a:hover { color: var(--tn-blue); }
.schlagzeilen-meta { font-size: 12px; color: var(--tn-muted); display: flex; gap: 10px; }
@media (max-width: 600px) {
  .schlagzeilen-thumb { width: 80px; height: 56px; }
  .schlagzeilen-title { font-size: 15px; }
}
.post-tag { display: inline-block; padding: 5px 13px; background: var(--tn-bg-soft); border: 1px solid var(--tn-line); border-radius: 20px; font-size: 13px; color: var(--tn-text); text-decoration: none; transition: background .15s, border-color .15s; }
.post-tag:hover { background: var(--tn-blue-soft); border-color: var(--tn-blue); color: var(--tn-blue); text-decoration: none; }

/* ---- QUELLENANGABE (ACF-Repeater 'quellen') ---- */
.tn-quellen { margin: 28px 0 4px; padding: 15px 18px 16px; background: var(--tn-bg-soft); border: 1px solid var(--tn-line); }
.tn-quellen-head { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-muted); margin-bottom: 9px; }
.tn-quellen-list { margin: 0; padding-left: 20px; display: flex; flex-direction: column; gap: 6px; }
.tn-quellen-list--single { list-style: none; padding-left: 0; }
.tn-quellen-item { font-size: 14px; line-height: 1.5; color: var(--tn-text); }
.tn-quellen-src { font-weight: 700; color: var(--tn-ink); }
.tn-quellen-item a { color: var(--tn-blue); text-decoration: none; word-break: break-word; }
.tn-quellen-item a:hover { text-decoration: underline; }
.tn-quellen-date { color: var(--tn-muted); font-size: 12.5px; }

/* ---- RELATED POSTS (Cached Related Posts Plugin) ---- */
.related-posts { margin: 28px 0; }
.crp-related-posts { width: 100%; }
.crp-row { display: flex; gap: 18px; margin-bottom: 18px; }
.crp-row:last-child { margin-bottom: 0; }
.crp-row-3 .crp-item { flex: 1 1 calc(33.333% - 12px); max-width: calc(33.333% - 12px); }
.crp-row-2 .crp-item { flex: 1 1 calc(50% - 9px); max-width: calc(50% - 9px); }
.crp-item { display: flex; flex-direction: column; text-decoration: none; color: var(--tn-ink); border-radius: 6px; overflow: hidden; background: var(--tn-bg-soft); transition: box-shadow .15s; }
.crp-item:hover { box-shadow: 0 4px 16px rgba(20,32,43,.10); text-decoration: none; }
.crp-thumbnail { width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block; }
.crp-title { padding: 10px 12px 12px; font-size: 15px; font-weight: 600; line-height: 1.4; color: var(--tn-ink); flex: 1; }
.crp-item:hover .crp-title { color: var(--tn-blue); }
.crp-item--ad { background: var(--tn-bg-soft); display: flex; align-items: center; justify-content: center; min-height: 120px; }
@media (max-width: 700px) {
  .crp-row { flex-direction: column; gap: 14px; }
  .crp-row-3 .crp-item, .crp-row-2 .crp-item { max-width: 100%; flex-basis: auto; }
}

/* ---- GALLERY / BILDERSTRECKE ---- */
/* Galerie-Block nimmt volle Breite des .post-content ein */
.post-content .tn-gallery { margin-left: calc(-1 * var(--tn-content-pad, 0px)); margin-right: calc(-1 * var(--tn-content-pad, 0px)); }
.tn-gallery { border-radius: 8px; overflow: hidden; background: #111; margin: 28px 0; font-size: 0; width: 100%; }
.tn-gallery-head { background: #1a1a1a; padding: 12px 18px; display: flex; align-items: center; justify-content: space-between; }
.tn-gallery-head h3 ,.tn-gallery-head .tn-h3 { font-size: 15px; font-weight: 700; color: #fff; margin: 0; }
.tn-gallery-head-count { font-size: 13px; color: #bbb; font-weight: 500; }
.tn-gallery-stage { position: relative; overflow: hidden; background: #000; line-height: 0; }
.tn-gallery-track { display: flex; transition: transform .35s ease; will-change: transform; }
.tn-gallery-slide { flex: 0 0 100%; max-width: 100%; overflow: hidden; }
.tn-gallery-slide img { width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block; }
.tn-gallery-slide--ad { display: flex; flex-direction: column; align-items: center; justify-content: center; aspect-ratio: 16/10; background: #f7f7f7; position: relative; }
.tn-gallery-ad-inner { display: flex; align-items: center; justify-content: center; flex: 1; width: 100%; }
.tn-gallery-ad-hint { position: absolute; bottom: 0; left: 0; right: 0; display: flex; align-items: center; justify-content: space-between; background: rgba(0,0,0,.72); color: #fff; padding: 10px 18px; cursor: pointer; transition: background .15s; }
.tn-gallery-ad-hint:hover { background: rgba(0,0,0,.88); }
.tn-gallery-ad-hint-label { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,.6); }
.tn-gallery-ad-hint-next { font-size: 14px; font-weight: 700; color: #fff; letter-spacing: .5px; }
.is-ad-slide .tn-gallery-arrow--next { background: var(--tn-blue); }
.is-ad-slide .tn-gallery-arrow--next:hover { background: var(--tn-blue-dark); }
.tn-gallery-counter { position: absolute; bottom: 12px; right: 14px; background: rgba(0,0,0,.55); color: #fff; font-size: 12px; font-weight: 600; padding: 4px 10px; border-radius: 20px; z-index: 3; line-height: 1.4; }
.tn-gallery-arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 4; background: rgba(0,0,0,.42); color: #fff; border: none; width: 48px; height: 64px; font-size: 28px; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .15s; padding: 0; }
.tn-gallery-arrow:hover { background: rgba(0,0,0,.65); }
.tn-gallery-arrow:disabled { opacity: .3; pointer-events: none; }
.tn-gallery-arrow--prev { left: 0; border-radius: 0 6px 6px 0; }
.tn-gallery-arrow--next { right: 0; border-radius: 6px 0 0 6px; }
.tn-gallery-caption { padding: 12px 18px; background: #1a1a1a; color: #ccc; font-size: 13.5px; line-height: 1.5; min-height: 44px; }
.tn-gallery-credit { display: inline; color: #888; font-size: 12px; margin-left: 6px; }
.tn-gallery-thumbs { display: flex; gap: 4px; padding: 8px; background: #111; overflow-x: auto; scroll-behavior: smooth; -webkit-overflow-scrolling: touch; }
.tn-gallery-thumbs::-webkit-scrollbar { height: 4px; }
.tn-gallery-thumbs::-webkit-scrollbar-thumb { background: #444; border-radius: 2px; }
.tn-gallery-thumb { flex: 0 0 64px; height: 42px; border: 2px solid transparent; border-radius: 3px; overflow: hidden; padding: 0; cursor: pointer; background: #222; font-size: 11px; color: #aaa; }
.tn-gallery-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.tn-gallery-thumb--active, .tn-gallery-thumb.is-active { border-color: var(--tn-blue); }
.tn-gallery-thumb--ad { display: flex; align-items: center; justify-content: center; }
@media (max-width: 700px) { .tn-gallery-arrow { width: 40px; height: 52px; font-size: 22px; } }

/* ---- COMMENTS ---- */
.comments-area { margin: 32px 0 0; padding-top: 28px; border-top: 2px solid var(--tn-line); }
.comments-area > h3 ,.comments-area > .tn-h3 { font-size: 22px; font-weight: 700; color: var(--tn-ink); margin: 0 0 20px; }
.comments-list { list-style: none; padding: 0; margin: 0 0 28px; }
.comments-list > li { padding: 18px 0; border-bottom: 1px solid var(--tn-line-soft); }
.comments-list > li:last-child { border-bottom: 0; }
.comment-author { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; font-size: 14px; }
.comment-avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--tn-blue); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; flex-shrink: 0; }
.comment-date { font-size: 12px; color: var(--tn-muted); margin-left: auto; white-space: nowrap; }
.comment-body { font-size: 15px; line-height: 1.65; color: var(--tn-text); }
.comment-body p { margin: 0; }
.comment-reply { margin-top: 8px; }
.comment-reply a { font-size: 13px; color: var(--tn-blue); font-weight: 600; text-decoration: none; }
.comment-paywall-notice { padding: 16px 20px; background: var(--tn-bg-soft); border: 1px solid var(--tn-line); border-radius: 8px; font-size: 15px; line-height: 1.55; margin: 20px 0; }
.comment-paywall-notice a { color: var(--tn-blue); font-weight: 600; }
/* WP comment_form() output */
.comment-form { display: grid; gap: 16px; margin-top: 28px; }
.comment-form p { margin: 0; }
.comment-form label { display: block; font-size: 13.5px; font-weight: 600; color: var(--tn-ink); margin-bottom: 5px; }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea { width: 100%; padding: 9px 13px; border: 1px solid var(--tn-line); border-radius: 8px; font: inherit; font-size: 14px; color: var(--tn-ink); background: #fff; box-sizing: border-box; transition: border-color .15s; }
.comment-form input:focus, .comment-form textarea:focus { outline: none; border-color: var(--tn-blue); box-shadow: 0 0 0 3px var(--tn-blue-soft); }
.comment-form textarea { min-height: 130px; resize: vertical; }
.comment-submit, .comment-form input[type="submit"] { padding: 10px 24px; background: var(--tn-blue); color: #fff; border: none; border-radius: 8px; font-size: 14px; font-weight: 700; cursor: pointer; transition: background .15s; }
.comment-submit:hover, .comment-form input[type="submit"]:hover { background: var(--tn-blue-dark); }

/* ---- AUTHOR-PAGE FORMMAILER (author-contact-and-social plugin) ---- */
.acs-block .acs-form { display: grid; gap: 14px; margin: 16px 0 0; }
.acs-block .acs-row { display: grid; gap: 14px; grid-template-columns: 1fr 1fr; }
@media (max-width: 640px) { .acs-block .acs-row { grid-template-columns: 1fr; } }
.acs-block .acs-form label { display: grid; gap: 5px; font-size: 13.5px; font-weight: 600; color: var(--tn-ink); }
.acs-block .acs-form input,
.acs-block .acs-form textarea { padding: 9px 13px; border: 1px solid var(--tn-line); border-radius: 8px; font: inherit; font-size: 14px; color: var(--tn-ink); background: #fff; transition: border-color .15s; }
.acs-block .acs-form input:focus,
.acs-block .acs-form textarea:focus { outline: none; border-color: var(--tn-blue); box-shadow: 0 0 0 3px var(--tn-blue-soft); }
.acs-block .acs-form textarea { min-height: 120px; resize: vertical; }
.acs-block .acs-form button { align-self: start; padding: 10px 22px; background: var(--tn-blue); color: #fff; border: none; border-radius: 8px; font-size: 14px; font-weight: 700; cursor: pointer; transition: background .15s; }
.acs-block .acs-form button:hover { background: var(--tn-blue-dark); }
.acs-block .acs-note { font-size: 12px; color: var(--tn-muted); margin: 0; }
.acs-block .acs-social, .acs-social { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0 20px; }
.acs-block .acs-social-link, .acs-social .acs-social-link { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border: 1px solid var(--tn-line); border-radius: 8px; color: var(--tn-ink); text-decoration: none; font-size: 13px; transition: background .15s, border-color .15s; }
.acs-block .acs-social-link:hover, .acs-social .acs-social-link:hover { background: var(--tn-bg-soft); border-color: var(--tn-blue); }
.acs-success { border: 1px solid var(--tn-blue); border-radius: 8px; padding: 14px 18px; margin: 16px 0; background: var(--tn-blue-soft); color: var(--tn-blue-dark); font-weight: 600; }

/* ---- AUTOR KONTAKTFORMULAR (natives Theme-Form) ---- */
.author-contact { margin: 0 0 36px; }
.author-contact-fields { display: flex; flex-direction: column; gap: 14px; margin: 16px 0 20px; }
.author-contact-label { font-size: 13.5px; font-weight: 600; color: var(--tn-ink); margin-bottom: -8px; }
.author-contact-input { padding: 10px 13px; border: 1px solid var(--tn-line); border-radius: 8px; font: inherit; font-size: 14.5px; color: var(--tn-ink); background: #fff; transition: border-color .15s; width: 100%; box-sizing: border-box; }
.author-contact-input:focus { outline: none; border-color: var(--tn-blue); box-shadow: 0 0 0 3px var(--tn-blue-soft); }
.author-contact-textarea { min-height: 140px; resize: vertical; }
.author-contact-submit { padding: 11px 24px; background: var(--tn-blue); color: #fff; border: none; border-radius: 8px; font-size: 14.5px; font-weight: 700; cursor: pointer; transition: background .15s; }
.author-contact-submit:hover { background: var(--tn-blue-dark); }
.author-contact-success { border: 1px solid var(--tn-blue); border-radius: 8px; padding: 14px 18px; background: var(--tn-blue-soft); color: var(--tn-blue-dark); font-weight: 600; }
.author-contact-error { border: 1px solid #d32f2f; border-radius: 8px; padding: 12px 16px; background: #fff3f3; color: #b71c1c; font-size: 14px; }

/* ---- FOTOSTRECKEN (nextpage-Slideshow) ---- */
/* ---- FOTOSTRECKEN (nextpage-Slideshow) ---- */
.tn-fotostrecke { margin: 28px 0; background: #111; overflow: hidden; width: 100%; }
/* Desktop: Content-Breite; Mobile: full-bleed */
.post-content .tn-fotostrecke { width: 100%; border-radius: 6px; }
@media (max-width: 700px) {
  .post-content .tn-fotostrecke { width: calc(100% + 32px); margin-left: -16px; border-radius: 0; }
}
.tn-fs-stage { position: relative; background: #000; line-height: 0; }
.tn-fs-slide { display: none; }
.tn-fs-slide.is-active { display: block; }
.tn-fs-figure { margin: 0; position: relative; }
.tn-fs-img-wrap { position: relative; line-height: 0; }
.tn-fs-embed-wrap { padding: 16px; background: #111; display: flex; justify-content: center; align-items: center; min-height: 300px; }
.tn-fs-embed-wrap > * { max-width: 550px; width: 100%; }
.tn-fs-embed-wrap .wp-block-embed-youtube .wp-block-embed__wrapper,
.tn-fs-embed-wrap .wp-block-embed-vimeo .wp-block-embed__wrapper { width: 100%; aspect-ratio: 16/9; }
.tn-fs-embed-wrap .wp-block-embed__wrapper iframe { width: 100%; height: 100%; }
.tn-fs-embed-wrap iframe { width: 100%; max-width: 550px; height: auto; }
.tn-fs-embed-wrap blockquote.twitter-tweet { margin: 0 auto !important; max-width: 550px !important; }
.tn-fs-figure img { width: 100%; height: auto; display: block; object-fit: contain; max-height: 75vh; background: #111; }
.tn-fs-credit { position: absolute; bottom: 0; right: 0; background: rgba(0,0,0,.55); color: rgba(255,255,255,.75); font-size: 11px; padding: 3px 8px; line-height: 1.4; pointer-events: none; }
.tn-fs-caption { display: block; padding: 12px 64px; background: #1a1a1a; color: #d8d8d8; font-size: 15px; line-height: 1.5; font-style: normal; text-align: center; }
/* Pfeile: absolut über dem Bild */
.tn-fs-arrow { position: absolute; top: 0; bottom: 0; z-index: 10; border: none; background: transparent; color: #fff; width: 20%; cursor: pointer; display: flex; align-items: center; padding: 0; transition: background .15s; }
.tn-fs-arrow:hover:not(:disabled) { background: rgba(0,0,0,.08); }
.tn-fs-arrow:disabled { opacity: 0; pointer-events: none; cursor: default; }
.tn-fs-prev { left: 0; justify-content: flex-start; }
.tn-fs-next { right: 0; justify-content: flex-end; }
/* Sichtbare Pfeil-Badges innerhalb der klickbaren Zone */
.tn-fs-arrow::after { content: ''; display: flex; align-items: center; justify-content: center; width: 48px; height: 72px; background: rgba(0,0,0,.48); font-size: 36px; border-radius: 4px; transition: background .15s; flex-shrink: 0; }
.tn-fs-prev::after { content: '‹'; border-radius: 0 4px 4px 0; }
.tn-fs-next::after { content: '›'; border-radius: 4px 0 0 4px; }
.tn-fs-arrow:hover:not(:disabled)::after { background: rgba(0,0,0,.72); }
.tn-fs-counter { position: absolute; bottom: 10px; right: 12px; background: rgba(0,0,0,.55); color: #fff; font-size: 12px; font-weight: 700; padding: 3px 10px; border-radius: 20px; line-height: 1.5; }
.tn-fs-ad-slide { position: relative; }
.tn-fs-ad-slide .tn-fs-ad-wrap { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 500px; padding: 20px; background: #f5f5f5; }
.tn-fs-ad-label { font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: #999; margin-bottom: 12px; }
.tn-fs-ad-hint { position: absolute; bottom: 0; left: 0; right: 0; display: flex; align-items: center; justify-content: space-between; background: rgba(0,0,0,.72); color: #fff; padding: 10px 18px; cursor: pointer; transition: background .15s; }
.tn-fs-ad-hint:hover { background: rgba(0,0,0,.88); }
.tn-fs-ad-hint-label { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,.6); }
.tn-fs-ad-hint-next { font-size: 14px; font-weight: 700; color: #fff; letter-spacing: .5px; }
/* ---- Weitere Fotostrecken - letzte Slide ---- */
.tn-fs-more-slide { background: #111; }
.tn-fs-more { padding: 28px 24px 32px; min-height: 360px; display: flex; flex-direction: column; }
.tn-fs-more-head { margin: 0 0 20px; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,.5); }
.tn-fs-more-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; flex: 1; }
.tn-fs-more-card { display: flex; flex-direction: column; gap: 8px; text-decoration: none; border-radius: 6px; overflow: hidden; background: #1e1e1e; transition: opacity .15s; }
.tn-fs-more-card:hover { opacity: .85; text-decoration: none; }
.tn-fs-more-img { aspect-ratio: 16/9; background-size: cover; background-position: center; flex-shrink: 0; }
.tn-fs-more-title { font-size: 13px; font-weight: 600; color: #e8e8e8; line-height: 1.35; padding: 0 10px 10px; }
@media (max-width: 560px) {
  .tn-fs-arrow { width: 36px; height: 56px; font-size: 26px; }
  .tn-fs-caption { padding: 8px 44px; font-size: 14px; }
}

/* =========================================================
   STARTSEITE HEADER-QUICKLINKS
   Gleiche Optik wie .breadcrumbs-wrap auf anderen Seiten
   ========================================================= */
.tn-home-quicklinks {
  display: block;
  width: 100%;
  background: var(--tn-bg-soft);
  border-bottom: 1px solid var(--tn-line-soft);
  position: relative;
}
.tn-home-quicklinks::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 48px;
  height: 100%;
  background: linear-gradient(to right, rgba(255,255,255,0), var(--tn-bg-soft));
  pointer-events: none;
}
.tn-home-quicklinks-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 20px 24px 20px 36px;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0 4px;
  font-size: 14.5px;
  line-height: 1.4;
  color: var(--tn-muted);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  white-space: nowrap;
}
.tn-home-quicklinks-inner::-webkit-scrollbar { display: none; }
.tn-home-quicklinks-label { flex: 0 0 auto; }
.tn-home-quicklinks a { flex: 0 0 auto; }
.tn-home-quicklinks-label {
  font-weight: 700;
  margin-right: 6px;
  color: var(--tn-muted);
}
.tn-home-quicklinks a {
  color: var(--tn-muted);
  text-decoration: none;
  white-space: nowrap;
}
.tn-home-quicklinks a:hover { color: var(--tn-blue); }
.tn-home-quicklinks a + a::before {
  content: '|';
  margin: 0 6px;
  color: #c4cad1;
}
@media (max-width: 900px) {
  .tn-home-quicklinks-inner { padding: 14px 14px 14px 22px; font-size: 13.5px; }
}

/* =========================================================
   FOTOSTRECKEN-STÖRER
   ========================================================= */
.tn-h-foto-stoerer {
  background: #19232d;
  padding: 28px 0 32px;
  margin: 0;
}
.tn-h-foto-stoerer .tn-h-container {
  max-width: var(--tn-content-w, 1280px);
  margin: 0 auto;
  padding: 0 20px;
}
.tn-h-foto-stoerer .tn-h-sec .row a,
.tn-h-foto-stoerer .tn-h-sec .row h2 ,.tn-h-foto-stoerer .tn-h-sec .row .tn-h2 {
  color: #fff;
}
.tn-h-foto-stoerer .tn-h-sec .row .all {
  color: rgba(255,255,255,0.6);
}
.tn-h-foto-stoerer .tn-h-card-sm h3 ,.tn-h-foto-stoerer .tn-h-card-sm .tn-h3 {
  color: #fff;
  font-size: 14px;
}
.tn-h-foto-stoerer .tn-h-card-sm:hover h3 ,.tn-h-foto-stoerer .tn-h-card-sm:hover .tn-h3 {
  color: var(--tn-blue);
}

/* =====================================================
   LEAKY PAYWALL - alle UI-Elemente
   ===================================================== */

/* ---------- Paywall-Box (Subscribe) ---------- */
#mp-paywall-visible.tn-pw { position: relative; width: 100%; margin: 0; padding: 2rem 1.8rem; background: #fff; border-radius: 14px; box-shadow: 0 16px 40px rgba(0,0,0,0.07); color: var(--tn-ink); }
#mp-paywall-visible.tn-pw .tn-pw-fade { position: absolute; left: 0; right: 0; top: -140px; height: 140px; background: linear-gradient(to bottom, rgba(255,255,255,0), #fff); pointer-events: none; z-index: 50; }
#mp-paywall-visible.tn-pw h2,#mp-paywall-visible.tn-pw .tn-h2, #mp-paywall-visible.tn-pw h3 , #mp-paywall-visible.tn-pw .tn-h3 { font-family: inherit; margin-top: 0; }
#mp-paywall-visible.tn-pw a { color: var(--tn-blue); text-decoration: none; }
#mp-paywall-visible.tn-pw a:hover { text-decoration: underline; }
#mp-paywall-visible.tn-pw .tn-pw-header { text-align: center; margin-bottom: 1.6rem; }
#mp-paywall-visible.tn-pw .tn-pw-title { font-size: 1.6rem; line-height: 1.3; margin: 0 0 .35rem; }
#mp-paywall-visible.tn-pw .tn-pw-claim { margin: 0 0 .2rem; font-size: 1.05rem; font-weight: 600; color: var(--tn-muted); }
#mp-paywall-visible.tn-pw .tn-pw-subline { margin: .2rem 0 0; font-size: .95rem; color: var(--tn-muted); }
#mp-paywall-visible.tn-pw .tn-pw-plans { display: flex; gap: 1rem; align-items: stretch; }
#mp-paywall-visible.tn-pw .tn-pw-plan { background: var(--tn-bg-soft); border-radius: 12px; padding: 1.2rem 1.2rem 1.3rem; border: 1px solid var(--tn-line); display: flex; flex-direction: column; }
#mp-paywall-visible.tn-pw .tn-pw-plan--year { flex: 1.2; background: #fffdf7; border-color: #f1c348; box-shadow: 0 8px 24px rgba(0,0,0,0.04); position: relative; }
#mp-paywall-visible.tn-pw .tn-pw-badge { position: absolute; top: -.85rem; left: 1.2rem; background: #f1c348; color: var(--tn-ink); font-size: .72rem; font-weight: 800; padding: .2rem .7rem; border-radius: 999px; }
#mp-paywall-visible.tn-pw .tn-pw-column { flex: .9; display: flex; flex-direction: column; gap: .85rem; }
#mp-paywall-visible.tn-pw .tn-pw-plan--medium { background: var(--tn-blue-soft); }
#mp-paywall-visible.tn-pw .tn-pw-plan--small { background: var(--tn-bg-soft); }
#mp-paywall-visible.tn-pw .tn-pw-plan-title { font-size: 1.25rem; margin: 0 0 .2rem; }
#mp-paywall-visible.tn-pw .tn-pw-plan-price { margin: 0 0 .25rem; }
#mp-paywall-visible.tn-pw .tn-pw-plan-price-main { font-size: 1.25rem; color: var(--tn-muted); }
#mp-paywall-visible.tn-pw .tn-pw-plan-price-sub { font-size: .9rem; color: var(--tn-muted); }
#mp-paywall-visible.tn-pw .tn-pw-plan-save { font-size: .9rem; color: var(--tn-muted); margin: .1rem 0 .6rem; }
#mp-paywall-visible.tn-pw .tn-pw-benefits { list-style: none; margin: 0 0 .9rem; padding: 0; font-size: .875rem; color: var(--tn-ink); flex: 1; }
#mp-paywall-visible.tn-pw .tn-pw-benefits li { position: relative; padding-left: 1.3rem; margin-bottom: .35rem; }
#mp-paywall-visible.tn-pw .tn-pw-benefits li::before { content: "✓"; position: absolute; left: 0; color: #27ae60; font-weight: 700; }
#mp-paywall-visible.tn-pw .tn-pw-btn { display: flex; align-items: center; justify-content: center; min-height: 46px; padding: 0 16px; border-radius: 10px; font-size: 14.5px; font-weight: 700; text-decoration: none !important; border: none; cursor: pointer; transition: background .12s, transform .12s, box-shadow .12s; margin-top: auto; }
#mp-paywall-visible.tn-pw .tn-pw-btn--primary { background: var(--tn-blue); color: #fff !important; box-shadow: 0 4px 14px rgba(69,129,185,.3); }
#mp-paywall-visible.tn-pw .tn-pw-btn--primary:hover { background: var(--tn-blue-dark); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(69,129,185,.35); }
#mp-paywall-visible.tn-pw .tn-pw-btn--secondary { background: #fff; color: var(--tn-blue) !important; border: 1.5px solid var(--tn-blue-light); }
#mp-paywall-visible.tn-pw .tn-pw-btn--secondary:hover { background: var(--tn-blue-soft); transform: translateY(-2px); }
#mp-paywall-visible.tn-pw .tn-pw-plan-hint { font-size: .74rem; color: var(--tn-muted); margin: .5rem 0 0; text-align: center; }
#mp-paywall-visible.tn-pw .tn-pw-payment-icons { margin: 1.2rem 0 .2rem; text-align: center; }
#mp-paywall-visible.tn-pw .tn-pw-payment-icons img { display: block; margin: 0 auto; max-width: 100%; }
#mp-paywall-visible.tn-pw .tn-pw-payment-icons svg { display: block; border-radius: 4px; box-shadow: 0 1px 3px rgba(0,0,0,.15); }
#mp-paywall-visible.tn-pw .tn-pw-footer { margin-top: 1.2rem; text-align: center; font-size: .82rem; color: var(--tn-muted); }
#mp-paywall-visible.tn-pw .tn-pw-login { margin-top: .4rem; }
#mp-paywall-visible.tn-pw .tn-pw-login a { color: var(--tn-blue); font-weight: 600; }
@media (max-width: 680px) {
  #mp-paywall-visible.tn-pw { margin: 1rem 0 1.5rem; padding: 1.3rem 1rem; border-radius: 10px; box-shadow: none; border: 1px solid var(--tn-line); }
  #mp-paywall-visible.tn-pw .tn-pw-plans { flex-direction: column; }
  #mp-paywall-visible.tn-pw .tn-pw-badge { position: static; display: inline-block; margin-bottom: .5rem; }
  #mp-paywall-visible.tn-pw .tn-pw-title { font-size: 1.35rem; }
}

/* ---------- Profil-Begrüßung / Logout-Links ---------- */
.meter-pro-logout-link { margin-bottom: 1rem; }
#sliderlinks { display: flex; align-items: center; gap: 16px; margin-top: 10px; flex-wrap: wrap; }
#sliderlinks .button { background: none; padding: 0; border: none; box-shadow: none; }
#sliderlinks .button a,
#sliderlinks a { color: var(--tn-blue) !important; font-weight: 600; font-size: 14px; text-decoration: none; }
#sliderlinks .button a:hover,
#sliderlinks a:hover { text-decoration: underline; }

/* ---------- TLDR-Box ---------- */
.tldr-box { position: relative; margin: 0 0 2rem; padding: .875rem 1rem 1.25rem; border: 1px solid rgba(69,129,185,.24); background: rgba(69,129,185,.08); overflow: hidden; }
.tldr-box::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: rgba(69,129,185,.5); }
.tldr-heading { margin: 0 0 .75rem; font-weight: 700; font-size: 1.05rem; color: #2b5d88; }
.tldr-box ul { margin: .25rem 0 0 1.1rem; padding: 0; list-style: disc; }
.tldr-box li { margin: .25rem 8px; line-height: 1.5; }
.tldr-box.blurred .tldr-content { filter: blur(5px); user-select: none; pointer-events: none; opacity: .85; }
.tldr-content { position: relative; }
.tldr-box .tldr-overlay { position: absolute; inset: 5rem 0 0 5px; display: flex; align-items: center; justify-content: center; font-size: 1.05rem; color: #244663; background: rgba(255,255,255,.6); backdrop-filter: blur(2px); z-index: 1; }
.tldr-box > summary.tldr-toggle { position: relative; left: 0; right: 0; bottom: .5rem; display: block; text-align: center; cursor: pointer; padding: .5rem 0 2.25rem; font-size: 1rem; color: var(--tn-blue); list-style: none; user-select: none; z-index: 2; }
.tldr-box > summary::-webkit-details-marker { display: none; }
.tldr-box > summary:focus { outline: none; }
.tldr-box > summary .toggle-show, .tldr-box > summary .toggle-hide { position: absolute; left: 0; right: 0; bottom: .5rem; text-align: center; font-size: .9rem; color: var(--tn-blue); }
.tldr-box > summary .toggle-show:hover, .tldr-box > summary .toggle-hide:hover { text-decoration: underline; }
.tldr-box:not([open]) .toggle-show { display: inline; }
.tldr-box:not([open]) .toggle-hide { display: none; }
.tldr-box[open] .toggle-show { display: none; }
.tldr-box[open] .toggle-hide { display: inline; }
@media (max-width: 768px) { .tldr-box .tldr-overlay { text-align: center; font-size: 1rem; padding: 1rem; line-height: 1.4; } }

/* ---------- Smart Ticker Promo ---------- */
.tn-smart-ticker-promo { margin: 28px 0; padding: 14px 16px 16px; border: 1px solid #f0e1d2; background: #fffaf5; border-radius: 6px; box-shadow: 0 1px 3px rgba(0,0,0,.05); transition: transform .15s, box-shadow .15s; }
.tn-smart-ticker-promo:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,.08); border-color: #e4d1bf; }
.tn-smart-ticker-promo .tn-ticker-dachzeile { margin-bottom: 8px; }
.tn-smart-ticker-promo__text { font-size: 17px; line-height: 1.5; font-weight: 600; color: var(--tn-ink); margin-bottom: 10px; }
.tn-smart-ticker-promo__link { font-size: 17px; font-weight: 700; color: var(--tn-blue); text-decoration: none; }
.tn-smart-ticker-promo__link:hover { text-decoration: underline; }
@media (max-width: 600px) { .tn-smart-ticker-promo { padding: 12px 14px 14px; } .tn-smart-ticker-promo__text, .tn-smart-ticker-promo__link { font-size: 15px; } }

/* ---------- Rätsel-Promo ---------- */
.tn-raetsel-promo { display: flex; gap: 20px; align-items: center; background: #f4f8fc; border: 1px solid rgba(69,129,185,.3); border-radius: 10px; padding: 20px; margin: 24px 0; }
.tn-raetsel-promo img { width: 100px; height: auto; border-radius: 6px; flex-shrink: 0; }
.tn-raetsel-promo-title { font-size: 1.1rem; font-weight: 700; margin-bottom: 6px; color: var(--tn-ink); }
.tn-raetsel-promo-right { font-size: .95rem; line-height: 1.5; color: var(--tn-muted); margin-bottom: 10px; }
.tn-raetsel-promo-cta { margin-top: 10px; }
.tn-raetsel-promo-button { display: inline-block; background: var(--tn-blue); color: #fff !important; padding: 9px 18px; border-radius: 6px; text-decoration: none !important; font-size: .95rem; font-weight: 700; }
.tn-raetsel-promo-button:hover { background: var(--tn-blue-dark); }
@media (max-width: 600px) { .tn-raetsel-promo { flex-direction: column; } .tn-raetsel-promo img { width: 80px; } }

/* ---------- Login-Form ---------- */
#meter-pro-login-form { border: 1px solid var(--tn-line); border-radius: 10px; padding: 24px; max-width: 360px; background: #fff; box-shadow: 0 2px 12px rgba(0,0,0,.05); }
#meter-pro-login-form #loginform label { display: block; font-size: 13px; font-weight: 600; color: var(--tn-muted); margin-bottom: 4px; }
#meter-pro-login-form #loginform .input { width: 100%; box-sizing: border-box; border: 1.5px solid var(--tn-line); border-radius: 7px; padding: 9px 12px; font-size: 14.5px; color: var(--tn-ink); transition: border-color .15s; }
#meter-pro-login-form #loginform .input:focus { outline: none; border-color: var(--tn-blue); }

/* ---------- Account-Wrapper (Profil-Seite) ---------- */
#meter-pro-account-wrapper { display: flex; gap: 24px; align-items: flex-start; margin: 24px 0; }
#meter-pro-account-wrapper .meter-pro-account-navigation-wrapper { width: 220px; flex-shrink: 0; background: var(--tn-bg-soft); border: 1px solid var(--tn-line); border-radius: 10px; overflow: hidden; }
#meter-pro-account-wrapper .meter-pro-account-navigation-wrapper ul { margin: 0; padding: 0; list-style: none; }
#meter-pro-account-wrapper .meter-pro-account-navigation-wrapper li { margin: 0; padding: 0; border-bottom: 1px solid var(--tn-line); }
#meter-pro-account-wrapper .meter-pro-account-navigation-wrapper li:last-child { border-bottom: none; }
#meter-pro-account-wrapper .meter-pro-account-navigation-wrapper a { display: block; padding: 11px 16px; font-size: 13.5px; font-weight: 600; color: var(--tn-ink); text-decoration: none; transition: background .1s; }
#meter-pro-account-wrapper .meter-pro-account-navigation-wrapper a:hover { background: var(--tn-blue-soft); }
#meter-pro-account-wrapper .meter-pro-account-navigation-wrapper a.active { background: var(--tn-blue); color: #fff; }
#meter-pro-account-wrapper .meter-pro-account-details-wrapper { flex: 1; border: 1px solid var(--tn-line); border-radius: 10px; padding: 24px; background: #fff; }
#meter-pro-account-wrapper .meter-pro-account-page-title { margin-top: 0; font-size: 1.2rem; }
@media (max-width: 640px) {
  #meter-pro-account-wrapper { flex-direction: column; }
  #meter-pro-account-wrapper .meter-pro-account-navigation-wrapper { width: 100%; }
}

/* ---------- Ad-Slots: Billboard + Skin ---------- */
/* Platzhalter nur wenn User Werbung sieht (body-Klasse via PHP) */
/* Ad-Slot-Reservierung gegen CLS - gilt nur für User, die Werbung sehen.
   Werbefreie Member haben kein .tn-show-ads → keine Höhenreservierung. */
.tn-show-ads [id^="teneriffa-news.com_"] { display: block; }
.tn-show-ads [id^="teneriffa-news.com_mr_"],
.tn-show-ads [id^="teneriffa-news.com_incontent_"],
.tn-show-ads [id^="teneriffa-news.com_tag_incontent_"] { min-height: 280px; }
.tn-show-ads [id^="teneriffa-news.com_lb_"]      { min-height: 90px; }
.tn-show-ads [id^="teneriffa-news.com_bb_"]      { min-height: 250px; }
.tn-show-ads [id^="teneriffa-news.com_sky_"],
.tn-show-ads [id^="teneriffa-news.com_sitebar_"] { min-height: 600px; }
.tn-show-ads .contentad-top,
.tn-show-ads .contentad-mid,
.tn-show-ads .contentad-bottom { position: relative; min-height: 280px; display: flex; align-items: center; justify-content: center; background: var(--tn-bg-soft); margin: 18px 0; }
.tn-show-ads .contentad-top::before,
.tn-show-ads .contentad-mid::before,
.tn-show-ads .contentad-bottom::before { content: "Anzeige"; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--tn-line); pointer-events: none; z-index: 0; }
.tn-show-ads .contentad-top > *,
.tn-show-ads .contentad-mid > *,
.tn-show-ads .contentad-bottom > * { position: relative; z-index: 1; }
.tn-show-ads .contentad-top-hint { position: relative; z-index: 2; text-align: center; margin-bottom: 4px; font-size: 12px; color: var(--tn-muted); }
.tn-show-ads .contentad-top-hint a { color: var(--tn-blue); text-decoration: none; }

.qm-head { display: flex; align-items: center; justify-content: center; background: none; }
.tn-show-ads .qm-head { height: 250px; } /* Billboard-Platzhalter 250px; 267px-Ads dürfen in die 17px darunter ragen */
.qm-head-login { height: 0; }
/* 17px-Puffer nach dem Billboard: Ads bis 267px können überlappen ohne CLS */
.tn-show-ads .qm-head + .main,
.tn-show-ads .qm-head + .tn-home { margin-top: 17px; }
/* Skin: fixed, rechts neben dem 1180px-Content (rechte Kante = 50% + 590px) */
.sky-ad { position: fixed; top: 30px; left: calc(50% + 595px); z-index: 9000; background: none; }
.sky-ad .symplr-ad-holder { all: unset; }
/* Nur anzeigen wenn genug Platz rechts neben der Seite */
@media (max-width: 1500px) { .sky-ad { display: none; } }
/* Sky-Ad ausblenden wenn Sidebar im Layout vorhanden */
body:has(.sidebar) .sky-ad { display: none; }

/* ---------- Profil-Tabelle ---------- */
.meter-pro-account-table { width: 100%; border-collapse: collapse; margin-bottom: 20px; }
.meter-pro-account-table tr { border-bottom: 1px solid var(--tn-line-soft); }
.meter-pro-account-table td { padding: 10px 6px; font-size: 14px; width: 50%; }
.meter-pro-account-table td.profile-table-label { color: var(--tn-muted); font-weight: 600; }
.meter-pro-account-table td.profile-table-value { color: var(--tn-ink); }

/* ---------- Formular-Inputs (Profil / Registrierung) ---------- */
#meter-pro-account-edit-profile-form input,
.meter-pro-user-fields input,
.meter-pro-account-fields input,
.meter-pro-custom-reg-fields input,
.meter-pro-custom-reg-fields textarea,
.meter-pro-custom-reg-fields select { width: 100%; box-sizing: border-box; border: 1.5px solid var(--tn-line); border-radius: 7px; padding: 9px 12px; font-size: 14.5px; color: var(--tn-ink); background: #fff; transition: border-color .15s; }
#meter-pro-account-edit-profile-form input:focus,
.meter-pro-user-fields input:focus,
.meter-pro-account-fields input:focus,
.meter-pro-custom-reg-fields input:focus { outline: none; border-color: var(--tn-blue); }
.meter-pro-custom-reg-fields .checkboxes input { width: auto; }
.meter-pro-custom-reg-fields .checkboxes label { display: inline-block; }
.meter-pro-account-fields h3 ,.meter-pro-account-fields .tn-h3 { margin-top: 20px; font-size: 1rem; }
.meter-pro-field-label { display: block; font-size: 13px; font-weight: 600; color: var(--tn-muted); margin-bottom: 4px; }
.meter-pro-subscriber-info { margin-bottom: 20px; font-size: 14px; }
#meter-pro-profile .meter-pro-field-input { min-width: 280px; }

/* ---------- Buttons (Submit / Weiter / Checkout) ---------- */
#meter-pro-submit,
#meter-pro-registration-next,
#meter-pro-payment-form #checkout { display: inline-flex; align-items: center; justify-content: center; min-width: 180px; padding: .75rem 2rem; background: var(--tn-blue); color: #fff !important; border: none; border-radius: 8px; font-size: 14.5px; font-weight: 700; cursor: pointer; text-decoration: none; transition: background .12s, transform .12s; margin-top: .75rem; }
#meter-pro-submit:hover,
#meter-pro-registration-next:hover,
#meter-pro-payment-form #checkout:hover { background: var(--tn-blue-dark); transform: translateY(-1px); text-decoration: none; }

/* ---------- Fehlermeldungen / Erfolg ---------- */
.meter_pro_message { border-radius: 7px; margin-bottom: 1rem; }
.meter_pro_message.error { background: #fef2f2; border: 1px solid #fecaca; padding: 10px 14px; }
.meter_pro_message.error p { margin: 0 0 4px; font-size: .875rem; color: #b91c1c; }
.meter_pro_message.success { background: #f0fdf4; border: 1px solid #bbf7d0; padding: 10px 14px; }
.meter_pro_message.success p { margin: 0 0 4px; font-size: .875rem; color: #15803d; }
.meter-pro-input-error { color: #b91c1c; font-size: 12px; margin-top: 3px; }

/* ---------- Registrierungs-Stepper ---------- */
.meter-pro-form-steps { display: flex; justify-content: space-around; margin: 32px auto 20px; border-bottom: 2px solid var(--tn-line); padding-bottom: 12px; }
.meter-pro-form-steps .meter-pro-form-step { width: 50%; text-align: center; font-size: 13px; text-transform: uppercase; letter-spacing: .5px; color: var(--tn-muted); }
.meter-pro-form-steps .meter-pro-form-step.active { font-weight: 800; color: var(--tn-ink); }
.meter-pro-form-steps .meter-pro-form-step .step-number { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 50%; background: var(--tn-line); color: var(--tn-ink); font-size: 12px; font-weight: 800; vertical-align: middle; margin-bottom: 4px; }
.meter-pro-form-steps .meter-pro-form-step.active .step-number { background: var(--tn-blue); color: #fff; }
.meter-pro-form-steps .meter-pro-form-step .step-title { display: block; margin-top: 4px; }

/* ---------- Stripe-Element ---------- */
.StripeElement { background: #fff; padding: 10px 12px; border-radius: 7px; border: 1.5px solid var(--tn-line); box-shadow: 0 1px 3px rgba(0,0,0,.06); transition: box-shadow .15s; margin-bottom: 16px; }
.StripeElement--focus { border-color: var(--tn-blue); box-shadow: 0 0 0 3px rgba(69,129,185,.15); }
.StripeElement--invalid { border-color: #ef4444; }
#card-errors { color: #b91c1c; font-size: 13px; margin-bottom: 16px; }

/* ---------- Abonnement-Optionen (Manage-Seite) ---------- */
.meter_pro_subscription_options { display: flex; flex-wrap: wrap; gap: 14px; }
.meter_pro_subscription_option { flex: 1 1 200px; padding: 1.1rem; border: 1.5px solid var(--tn-line); border-radius: 10px; background: var(--tn-bg-soft); text-align: center; box-sizing: border-box; font-size: .95rem; line-height: 1.55; }
.meter_pro_subscription_option.current-level { border-color: var(--tn-blue); box-shadow: 0 0 0 3px rgba(69,129,185,.12); }
.meter_pro_subscription_option h3 ,.meter_pro_subscription_option .tn-h3 { font-size: 1.2rem; margin-bottom: 6px; }
.meter_pro_subscription_allowed_content { border-top: 1px solid var(--tn-line); border-bottom: 1px solid var(--tn-line); margin: .9rem 0; padding: .9rem 0; font-size: .9rem; color: var(--tn-muted); }
.meter_pro_subscription_price p { margin-bottom: .75rem; line-height: 1.3; }
.meter_pro_subscription_limit_details { display: block; width: 100%; margin-top: 20px; font-size: .85rem; color: var(--tn-muted); }
.meter-pro-payment-button { display: block; margin: 6px 0; text-align: center; }
.meter-pro-payment-button a { display: inline-flex; align-items: center; justify-content: center; background: var(--tn-blue); color: #fff !important; padding: 8px 20px; border-radius: 7px; text-decoration: none; font-size: 14px; font-weight: 700; transition: background .12s; }
.meter-pro-payment-button a:hover { background: var(--tn-blue-dark); }
.meter-pro-subscriber-info { margin-bottom: 16px; }

/* ---------- Modal (zeen101) ---------- */
.zeen101-modal { display: none; }
.zeen101-modal.is-open { display: block; z-index: 99999; }
.zeen101-modal .modal__overlay { position: fixed; inset: 0; background: rgba(0,0,0,.55); display: flex; justify-content: center; align-items: center; z-index: 9999; overflow: auto; }
.zeen101-modal .modal__container { background: #fff; padding: 28px; max-width: 480px; width: 90%; border-radius: 12px; overflow-y: auto; max-height: 90vh; box-shadow: 0 24px 60px rgba(0,0,0,.15); }
.zeen101-modal .modal__header { display: none; }
.zeen101-modal .modal__content { margin: 1.5rem 0; line-height: 1.55; color: var(--tn-ink); }
.zeen101-modal .modal__btn-primary, .zeen101-modal .modal__btn-primary:visited { background: var(--tn-blue); color: #fff; padding: 9px 18px; border-radius: 7px; text-decoration: none; font-size: 14px; font-weight: 700; }
.zeen101-modal .modal__btn-secondary, .zeen101-modal .modal__btn-secondary:visited { background: var(--tn-bg-soft); color: var(--tn-ink); padding: 9px 18px; border-radius: 7px; text-decoration: none; font-size: 14px; border: 1px solid var(--tn-line); }
@keyframes mmfadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes mmfadeOut { from { opacity: 1; } to { opacity: 0; } }
@keyframes mmslideIn { from { transform: translateY(12%); } to { transform: translateY(0); } }
.zeen101-modal[aria-hidden="false"] .modal__overlay { animation: mmfadeIn .25s ease; }
.zeen101-modal[aria-hidden="false"] .modal__container { animation: mmslideIn .25s ease; }

/* ================================================================
   Newsletter Flyout
   ================================================================ */
.survey_modal {
    background: #fff;
    box-shadow: 0 0 15px 1px rgba(0,0,0,.2);
    position: fixed;
    right: 35px;
    bottom: 140px;
    top: auto;
    left: auto;
    max-width: 400px;
    width: 90%;
    z-index: 20000;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: opacity .3s ease, transform .3s ease, visibility .3s ease;
    border-radius: 6px;
    overflow: visible;
}
.survey_modal.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    z-index: 20000000;
}
.more_info_container {
    font-size: 17px;
    line-height: 1.6;
    max-height: 85vh;
    padding-top: 10px;
    background-image: linear-gradient(to bottom, rgb(69 129 185), rgb(64 126 184 / .15));
}
.more_info_container .scrollable {
    max-height: 77vh;
    overflow-y: auto;
    padding: 0 24px 14px;
    box-sizing: border-box;
}
.more_info_container .scrollable > * { max-width: 100%; box-sizing: border-box; }
.more_info_container .nldm-iframe-slot { width: 100%; max-width: 100%; height: 195px; box-sizing: border-box; overflow: hidden; }
.more_info_container .nldm-iframe-slot iframe { width: 100% !important; max-width: 100% !important; height: 100% !important; display: block; box-sizing: border-box; }
.more_info_container .nldmimg {
    text-align: center;
    margin-top: -80px;
    padding: 0 0 6px;
    position: relative;
    z-index: 1;
}
.more_info_container .nldmimg img {
    max-width: 100%;
    height: auto;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,.25));
}
.more_info_container .nldm {
    color: #fff;
    font-weight: 700;
    font-size: 18px;
    margin-bottom: 10px;
    text-align: center;
}
.more_info_container .nldmrate {
    text-align: center;
    font-size: 14px;
    color: #fff;
    margin-top: -30px;
    margin-bottom: 0;
}
.more_info_container iframe {
    width: 100%;
    display: block;
}
.more_info_container .close_button {
    cursor: pointer;
    font-size: 24px;
    font-weight: 700;
    position: absolute;
    right: 8px;
    top: 4px;
    color: #fff;
    background: none;
    border: none;
    line-height: 1;
    padding: 4px 8px;
    z-index: 10;
}
.trigger_more_info_container {
    bottom: 260px;
    position: fixed;
    right: -30px;
    transform: rotate(-90deg);
    z-index: 99999;
}
body.show-trigger:not(.modal-open) .trigger_more_info_container {
    display: block !important;
}
.show_survey_button {
    background: var(--tn-blue);
    color: #fff;
    border: none;
    padding: 8px 16px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    border-radius: 4px 4px 0 0;
}
@media (max-width: 767px) {
    .survey_modal {
        right: 50%;
        bottom: 130px;
        transform: translate(50%, 20px);
    }
    .survey_modal.active {
        transform: translate(50%, 0);
    }
    .trigger_more_info_container {
        bottom: 180px;
        right: -38px;
    }
}

/* ================================================================
   SALES FUNNEL - body.salesfunnel
   Eigenständiges Layout ohne Nav/Sidebar/Werbung
   ================================================================ */
body.salesfunnel { background: var(--tn-bg-soft); margin: 0; }
.sf-shell { min-height: 100vh; display: flex; flex-direction: column; max-width: 860px; margin: 0 auto; padding: 0 20px 60px; }

/* Header */
.sf-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 0 28px; border-bottom: 1px solid var(--tn-line-soft); margin-bottom: 40px; }
.sf-logo img, .sf-logo svg { height: 48px; width: auto; display: block; }
.sf-login-link { font-size: 13.5px; font-weight: 600; color: var(--tn-blue); text-decoration: none; white-space: nowrap; }
.sf-login-link:hover { text-decoration: underline; }

/* Hero / Seiteninhalt */
.sf-hero { text-align: center; margin-bottom: 40px; }
.sf-hero-title { font-size: 2rem; line-height: 1.2; letter-spacing: -.4px; color: var(--tn-ink); margin: 0 0 16px; font-family: Georgia, 'Times New Roman', serif; }
.sf-hero-body { font-size: 1.05rem; line-height: 1.7; color: var(--tn-text); max-width: 600px; margin: 0 auto; }
.sf-hero-body p { margin: 0 0 .8em; }

/* Pläne */
.sf-plans { display: flex; gap: 16px; align-items: stretch; margin-bottom: 24px; }
.sf-plan { background: #fff; border: 1px solid var(--tn-line); border-radius: 14px; padding: 24px 22px 22px; display: flex; flex-direction: column; }
.sf-plan--year { flex: 1.25; background: #fffdf7; border-color: #f1c348; box-shadow: 0 8px 28px rgba(0,0,0,.07); position: relative; }
.sf-plan--month { flex: 1; background: var(--tn-blue-soft); }
.sf-plan--day { flex: 1; }
.sf-plan-col { flex: .9; display: flex; flex-direction: column; gap: 14px; }
.sf-badge { display: inline-block; background: #f1c348; color: var(--tn-ink); font-size: 11px; font-weight: 800; padding: 3px 12px; border-radius: 999px; margin-bottom: 12px; }
.sf-plan-name { font-size: 1.2rem; font-weight: 800; color: var(--tn-ink); margin: 0 0 8px; font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif; }
.sf-plan-price { margin: 0 0 6px; line-height: 1.2; }
.sf-plan-price strong { font-size: 1.6rem; color: var(--tn-ink); font-weight: 800; }
.sf-plan-price span { font-size: .9rem; color: var(--tn-muted); margin-left: 4px; }
.sf-plan-save { font-size: .82rem; color: var(--tn-muted); margin: 0 0 14px; }
.sf-benefits { list-style: none; margin: 0 0 18px; padding: 0; font-size: .875rem; color: var(--tn-ink); flex: 1; }
.sf-benefits li { position: relative; padding-left: 1.3rem; margin-bottom: 6px; }
.sf-benefits li::before { content: "✓"; position: absolute; left: 0; color: #27ae60; font-weight: 700; }
.sf-btn { display: flex; align-items: center; justify-content: center; min-height: 48px; padding: 0 18px; border-radius: 10px; font-size: 15px; font-weight: 700; text-decoration: none; border: none; cursor: pointer; transition: background .12s, transform .12s, box-shadow .12s; margin-top: auto; text-align: center; }
.sf-btn--primary { background: var(--tn-blue); color: #fff; box-shadow: 0 4px 16px rgba(69,129,185,.3); }
.sf-btn--primary:hover { background: var(--tn-blue-dark); transform: translateY(-2px); box-shadow: 0 6px 22px rgba(69,129,185,.38); color: #fff; text-decoration: none; }
.sf-btn--secondary { background: #fff; color: var(--tn-blue); border: 1.5px solid var(--tn-line); }
.sf-btn--secondary:hover { background: var(--tn-blue-soft); transform: translateY(-1px); color: var(--tn-blue); text-decoration: none; }
.sf-plan-hint { font-size: .72rem; color: var(--tn-muted); margin: 8px 0 0; text-align: center; }

/* Zahlungsarten */
.sf-payment-row { display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap; margin-bottom: 40px; }
.sf-payment-row svg { border-radius: 4px; box-shadow: 0 1px 3px rgba(0,0,0,.15); flex-shrink: 0; }
.sf-payment-label { font-size: 12px; color: var(--tn-muted); margin-left: 6px; }

/* Footer */
.sf-footer { margin-top: auto; padding-top: 24px; border-top: 1px solid var(--tn-line-soft); display: flex; justify-content: center; gap: 12px; font-size: 12.5px; color: var(--tn-muted); flex-wrap: wrap; }
.sf-footer a { color: var(--tn-muted); text-decoration: none; }
.sf-footer a:hover { color: var(--tn-blue); text-decoration: underline; }

/* Mobile */
@media (max-width: 640px) {
  .sf-plans { flex-direction: column; }
  .sf-plan-col { flex-direction: column; gap: 14px; }
  .sf-hero-title { font-size: 1.5rem; }
  .sf-header { flex-direction: column; gap: 12px; text-align: center; }
}


/* === Unified Hauptnavigation (Desktop + Mobile-Strip) - 2026-05-30 wiederhergestellt aus bak-h2popbump-20260529 (war beim Stale-Deploy verloren) =============================
   EIN Markup, CSS schaltet Layout. Desktop: Hover-Dropdowns + Pfeil. Mobile: Horizontalstrip + Klick-Flyouts. */
.tn-nav { background: #fff; border-bottom: 2px solid var(--tn-blue); position: relative; z-index: 5; }
.tn-nav .tn-nav-list { list-style: none; margin: 0 auto; padding: 0 24px; max-width: 1180px; display: flex; align-items: center; gap: 4px; }
.tn-nav-item { position: relative; }
.tn-nav-item .tn-nav-link { display: inline-flex; align-items: center; padding: 14px; font-size: 15px; font-weight: 600; color: var(--tn-ink); text-decoration: none; }
.tn-nav-item.is-active .tn-nav-link { color: var(--tn-blue); }
.tn-nav-item:hover .tn-nav-link { color: var(--tn-blue); text-decoration: none; }
.tn-nav-item.has-children .tn-nav-link::after { content: ""; display: inline-block; margin-left: 6px; width: 0; height: 0; border-left: 4px solid transparent; border-right: 4px solid transparent; border-top: 4px solid currentColor; transform: translateY(-1px); transition: transform .15s; }
.tn-nav-item.has-children:hover .tn-nav-link::after { transform: translateY(-1px) rotate(180deg); }
.tn-nav-chev { display: none; }
.tn-nav-flyout { position: absolute; top: 100%; left: 0; min-width: 240px; background: #fff; border: 1px solid var(--tn-line); border-top: 3px solid var(--tn-blue); box-shadow: 0 12px 32px rgba(20,32,43,0.12); padding: 12px 16px; opacity: 0; visibility: hidden; transform: translateY(4px); transition: opacity .15s, transform .15s, visibility .15s; pointer-events: none; z-index: 20; display: block; }
.tn-nav-item:hover .tn-nav-flyout, .tn-nav-item:focus-within .tn-nav-flyout { opacity: 1; visibility: visible; transform: translateY(0); pointer-events: auto; }
.tn-nav-flyout ul { list-style: none; padding: 0; margin: 0; }
.tn-nav-flyout > ul > li > a { display: block; padding: 8px 4px; font-size: 14px; color: var(--tn-ink); border-bottom: 1px solid var(--tn-line-soft); font-weight: 500; text-decoration: none; }
.tn-nav-flyout > ul > li:last-child > a { border-bottom: 0; }
.tn-nav-flyout > ul > li > a:hover { color: var(--tn-blue); }
.tn-nav-flyout .tn-nav-sub { padding: 4px 0 0 12px; }
.tn-nav-flyout .tn-nav-sub > li > a { display: block; padding: 5px 0; font-size: 13.5px; color: var(--tn-text); font-weight: 500; text-decoration: none; }
.tn-nav-flyout .tn-nav-sub > li > a:hover { color: var(--tn-blue); }

@media (max-width: 900px) {
  .tn-nav .tn-nav-list { max-width: none; margin: 0; padding: 0 12px; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; gap: 0; }
  .tn-nav-list::-webkit-scrollbar { display: none; }
  .tn-nav-item { position: static; flex: 0 0 auto; display: flex; align-items: center; white-space: nowrap; border-bottom: 2px solid transparent; margin-bottom: -2px; }
  .tn-nav-item.is-active { border-bottom-color: var(--tn-blue); }
  .tn-nav-item.is-active .tn-nav-link { color: var(--tn-blue); }
  .tn-nav-item .tn-nav-link { padding: 11px 4px 11px 14px; }
  .tn-nav-item:not(.has-children) .tn-nav-link { padding-right: 14px; }
  .tn-nav-item.has-children .tn-nav-link::after { display: none; }
  .tn-nav-chev { display: inline-flex; align-items: center; padding: 11px 12px 11px 4px; background: transparent; border: 0; color: var(--tn-muted); cursor: pointer; transition: transform .2s; }
  .tn-nav-item.is-open .tn-nav-chev { transform: rotate(180deg); color: var(--tn-blue); }
  .tn-nav-item:hover .tn-nav-flyout, .tn-nav-item:focus-within .tn-nav-flyout { opacity: 0; visibility: hidden; pointer-events: none; transform: translateY(4px); }
  .tn-nav-flyout { left: 0; right: 44px; min-width: 0; max-height: 70vh; overflow-y: auto; padding: 0; border-left: 0; border-right: 1px solid var(--tn-line); border-top: 1px solid var(--tn-line); box-shadow: 0 10px 24px rgba(20,32,43,0.10); display: none; }
  .tn-nav .tn-nav-flyout:not([hidden]) { display: block !important; opacity: 1 !important; visibility: visible !important; pointer-events: auto !important; transform: none !important; }
  .tn-nav-flyout > ul > li > a { padding: 12px 24px; font-size: 15px; font-weight: 600; }
  .tn-nav-flyout > ul > li.has-sub > a { font-weight: 700; color: var(--tn-blue-dark); }
  .tn-nav-flyout .tn-nav-sub { padding: 0; }
  .tn-nav-flyout .tn-nav-sub > li > a { padding: 9px 24px 9px 40px; font-size: 14px; font-weight: 500; border-bottom: 1px solid var(--tn-line-soft); }
  .tn-nav-flyout .tn-nav-sub > li > a::before { content: "\203A"; margin-right: 8px; color: var(--tn-blue); }
}

/* === L3-Toggle: Pfeil neben L2-Eintrag im Flyout faehrt L3 aus (Desktop + Mobile) === */
.tn-nav-flyout .has-sub { display: flex; flex-wrap: wrap; align-items: center; }
.tn-nav-flyout .has-sub > a { flex: 1 1 auto; }
.tn-nav-sub-toggle { background: transparent; border: 0; padding: 6px 6px 6px 10px; color: var(--tn-muted); cursor: pointer; line-height: 1; display: inline-flex; align-items: center; transition: color .15s; }
.tn-nav-sub-toggle svg { transition: transform .2s; }
.tn-nav-sub-toggle:hover { color: var(--tn-blue); }
.tn-nav-flyout .has-sub.is-open > .tn-nav-sub-toggle { color: var(--tn-blue); }
.tn-nav-flyout .has-sub.is-open > .tn-nav-sub-toggle svg { transform: rotate(180deg); }
.tn-nav-flyout .tn-nav-sub { flex: 0 0 100%; }
/* Mobile horizontale Navi: 3.-Ebene-Pfeil dicht an den Text statt an den Rand */
@media (max-width: 900px) { .tn-nav-flyout .has-sub > a { flex: 0 1 auto; } }

/* iOS-Safari-Quirk: .tn-nav-list horizontal scrollt -> clippt absolute Children. Bei offenem Flyout overflow loesen. */
@media (max-width: 900px) {
  body.tn-nav-flyout-open .tn-nav .tn-nav-list { overflow: visible !important; }
}


/* === 2026-05-30 wiederhergestellt aus bak-h2popbump-20260529 (Stale-Deploy-Verlust; Ticker bereits vorhanden, ausgelassen) === */
/* === Smooth-Scroll & Anchor-Offset (ersetzt eztoc smooth_scroll.min.js) === */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
.entry-content :is(h2,h3,h4),
.post-content :is(h2,h3,h4),
article :is(h2,h3,h4)[id] { scroll-margin-top: 260px; }
@media (max-width: 782px) {
  .entry-content :is(h2,h3,h4),
  .post-content :is(h2,h3,h4),
  article :is(h2,h3,h4)[id] { scroll-margin-top: 170px; }
}

/* Wetter-Cards: Inselname als erkennbarer Link (Unterstreichung + ›-Pfeil) */
.tn-h-wetter-card .lbl { text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.tn-h-wetter-card .lbl::after { content: " ›"; text-decoration: none; color: var(--tn-blue); font-weight: 700; }
.tn-h-wetter-card:hover .lbl { color: var(--tn-blue); }

/* === A-Z-Liste (Shortcode [tn_az_liste]) === */
.tn-az-liste .tn-az-h { font-size: 22px; margin: 28px 0 12px; color: var(--tn-ink); font-family: Georgia, 'Times New Roman', serif; }
.tn-az-liste .tn-az-h:first-child { margin-top: 0; }
.tn-az-cols { list-style: none; padding: 0; margin: 0 0 24px; column-count: 3; column-gap: 32px; }
.tn-az-cols li { break-inside: avoid; padding: 4px 0; font-size: 15px; line-height: 1.5; }
.tn-az-cols li a { color: var(--tn-blue); text-decoration: none; }
.tn-az-cols li a:hover { text-decoration: underline; }
@media (max-width: 900px) { .tn-az-cols { column-count: 2; column-gap: 24px; } }
@media (max-width: 560px) { .tn-az-cols { column-count: 1; } }

/* ---- WETTER-Templates (Pages) ---- */
.wetter-intro-figure { float: right; margin: 0 0 12px 18px; max-width: 220px; }
.wetter-intro-figure img { width: 100%; height: auto; display: block; border-radius: 6px; }
.wetter-intro { margin: 0 0 12px; }
.wetter-localtime { color: var(--tn-muted); margin: 6px 0 18px; }
.wetter-ad-slot { min-height: 320px; text-align: center; margin: 18px 0; clear: both; }
.wetter-news-link { margin-top: 18px; }
.wetter-news-link a { text-decoration: underline; text-underline-offset: 3px; }
@media (max-width: 600px) {
  .wetter-intro-figure { float: none; margin: 0 0 12px; max-width: 100%; }
}

/* ---- SITEMAP-Template ---- */
.tn-sitemap-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 36px; margin-top: 24px; }
@media (max-width: 700px) { .tn-sitemap-grid { grid-template-columns: 1fr; gap: 24px; } }
.tn-sitemap-col h2 { font-size: 21px; margin: 28px 0 12px; padding-bottom: 6px; border-bottom: 1px solid var(--tn-line-soft); }
.tn-sitemap-col h2:first-child { margin-top: 0; }
.tn-sitemap-col ul { list-style: none; padding: 0; margin: 0 0 14px; column-count: 1; }
.tn-sitemap-col ul ul { padding-left: 16px; margin: 4px 0; }
.tn-sitemap-col li { padding: 3px 0; }
.tn-sitemap-col a { color: var(--tn-ink); }
.tn-sitemap-col a:hover { color: var(--tn-blue); }

/* ---- LESERREPORTER Onboarding ---- */
.tn-leserreporter-onboarding ol { padding-left: 22px; margin: 8px 0 14px; }
.tn-leserreporter-onboarding ol li { margin-bottom: 6px; }

/* ---- Wetter-Bericht (KI-Text aus weather-Plugin) ---- */
.tn-wetter-bericht { margin: 18px 0 22px; }
.tn-wetter-bericht h2 { font-size: 22px; margin: 0 0 10px; color: var(--tn-ink); }
.tn-wetter-bericht p { margin: 0 0 12px; line-height: 1.65; }
.tn-wetter-bericht p:last-child { margin-bottom: 0; }
.tn-wetter-bericht--kanaren { margin-top: 0; }

/* ---- 404 / Fehlerseite (Markup: .error-page > .error-code/.tn-h1/p) ---- */
.error-page { text-align: center; padding: 60px 20px; max-width: 640px; margin: 0 auto; }
.error-page .error-code { font-size: 96px; font-weight: 800; color: var(--tn-blue); line-height: 1; letter-spacing: -3px; }
.error-page .tn-h1 { font-size: 28px; margin: 8px 0 12px; font-weight: 800; color: var(--tn-ink); }
.error-page p { color: var(--tn-muted); margin: 0 auto 24px; max-width: 520px; }
@media (max-width: 760px) { .error-page .error-code { font-size: 72px; } .error-page .tn-h1 { font-size: 22px; } }

.error-search { max-width: 460px; margin: 0 auto 8px; }
.error-search .brand-search { display: flex; align-items: center; gap: 8px; border: 1px solid var(--tn-line); border-radius: 999px; padding: 8px 18px; background: #fff; }
.error-search .brand-search input { flex: 1; border: 0; outline: 0; background: transparent; font: inherit; color: var(--tn-ink); font-size: 15px; }

/* ============= Einstellungs-Zahnrad (Schriftgröße) ============= */
.tn-topbar-left { display: flex; align-items: center; gap: 14px; position: relative; }
.tn-fz-btn { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; padding: 0; margin: 0; border: 0; background: transparent; color: rgba(255,255,255,0.85); cursor: pointer; border-radius: 5px; transition: color .15s, background .15s; -webkit-appearance: none; }
.tn-fz-btn:hover, .tn-fz-btn[aria-expanded="true"] { color: #fff; background: rgba(255,255,255,0.12); }
.tn-fz-btn svg { display: block; width: 15px; height: 15px; }
.tn-fz-panel { position: absolute; top: calc(100% + 8px); left: 0; z-index: 10002; width: 232px; background: #fff; border: 1px solid var(--tn-line); border-top: 3px solid var(--tn-blue); box-shadow: 0 12px 32px rgba(20,32,43,0.18); padding: 14px 16px 16px; }
.tn-fz-panel[hidden] { display: none; }
.tn-fz-panel-title { display: block; font-size: 12px; text-transform: uppercase; letter-spacing: 1px; color: var(--tn-blue-dark); font-weight: 800; margin: 0 0 10px; font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif; }
.tn-fz-steps { display: flex; gap: 6px; }
.tn-fz-step { flex: 1; display: inline-flex; align-items: center; justify-content: center; height: 42px; padding: 0 2px; border: 1px solid var(--tn-line); background: #fff; color: var(--tn-ink); font-family: Georgia, 'Times New Roman', serif; font-weight: 700; line-height: 1; cursor: pointer; transition: border-color .12s, background .12s, color .12s; -webkit-appearance: none; }
.tn-fz-step:hover { border-color: var(--tn-blue); color: var(--tn-blue); }
.tn-fz-step[aria-pressed="true"] { border-color: var(--tn-blue); background: var(--tn-blue); color: #fff; }
.tn-fz-step span { display: inline-block; }
.tn-fz-step[data-fz="0"] { font-size: 13px; }
.tn-fz-step[data-fz="1"] { font-size: 15px; }
.tn-fz-step[data-fz="2"] { font-size: 18px; }
.tn-fz-step[data-fz="3"] { font-size: 21px; }
@media (max-width: 900px) { .tn-fz-panel { left: -8px; } }

/* Darstellung-Umschalter (Hell/Dunkel) im Panel */
.tn-fz-panel-title--2 { margin-top: 16px; }
.tn-theme-toggle { display: flex; gap: 6px; }
.tn-theme-opt { flex: 1; height: 38px; display: inline-flex; align-items: center; justify-content: center; gap: 7px; border: 1px solid var(--tn-line); background: #fff; color: var(--tn-ink); font: 600 14px/1 Arial, 'Helvetica Neue', Helvetica, sans-serif; cursor: pointer; transition: border-color .12s, background .12s, color .12s; -webkit-appearance: none; }
.tn-theme-opt:hover { border-color: var(--tn-blue); color: var(--tn-blue); }
.tn-theme-opt[aria-pressed="true"] { border-color: var(--tn-blue); background: var(--tn-blue); color: #fff; }
.tn-theme-opt[aria-pressed="true"]:hover { color: #fff; }
.tn-theme-opt svg { width: 15px; height: 15px; flex-shrink: 0; }

/* ============= Dark Mode (manuell via Zahnrad) - blaustichig ============= */
html[data-tn-theme="dark"] {
  --tn-blue: #6fb0e8;
  --tn-blue-dark: #18324f;
  --tn-blue-light: #24405a;
  --tn-blue-soft: #1b2e45;
  --tn-ink: #eaf2fb;
  --tn-text: #bccfe0;
  --tn-muted: #8ba0b6;
  --tn-line: #2e4358;
  --tn-line-soft: #213548;
  --tn-bg: #13243a;
  --tn-bg-soft: #182c43;
  --tn-accent: #e88a66;
  --tn-surface: #1c3046;
  color-scheme: dark;
}
/* Hartkodierte weiße Flächen → dunkle Surface */
html[data-tn-theme="dark"] .tn-brand,
html[data-tn-theme="dark"] .tn-sticky-shell,
html[data-tn-theme="dark"] .tn-nav,
html[data-tn-theme="dark"] .tn-nav .sub-menu,
html[data-tn-theme="dark"] .tn-nav-flyout,
html[data-tn-theme="dark"] .tn-flyout,
html[data-tn-theme="dark"] .tn-mobile-drawer,
html[data-tn-theme="dark"] .tn-mobile-quicknav,
html[data-tn-theme="dark"] .tn-mobile-quicknav-flyout,
html[data-tn-theme="dark"] .tn-mobile-btn-secondary,
html[data-tn-theme="dark"] .tn-popular,
html[data-tn-theme="dark"] .sidebar .widget,
html[data-tn-theme="dark"] .tn-h-insel,
html[data-tn-theme="dark"] .tn-pagination__item a,
html[data-tn-theme="dark"] .tn-pagination__item span,
html[data-tn-theme="dark"] .share-google,
html[data-tn-theme="dark"] .share-toggle,
html[data-tn-theme="dark"] .tn-fz-panel,
html[data-tn-theme="dark"] .comment-form textarea,
html[data-tn-theme="dark"] .author-contact-input { background: var(--tn-surface); }
/* Panel-Buttons: Basis dunkel, aktiver Zustand bleibt blau */
html[data-tn-theme="dark"] .tn-fz-step,
html[data-tn-theme="dark"] .tn-theme-opt { background: var(--tn-surface); }
html[data-tn-theme="dark"] .tn-fz-step[aria-pressed="true"],
html[data-tn-theme="dark"] .tn-theme-opt[aria-pressed="true"] { background: var(--tn-blue); color: #fff; }
/* Suchfeld-Fokus nicht weiß aufblitzen */
html[data-tn-theme="dark"] .tn-search:focus-within,
html[data-tn-theme="dark"] .brand-search:focus-within,
html[data-tn-theme="dark"] .brand-actions .search-form:focus-within { background: var(--tn-surface); }
/* boxed-Layout (Adnami-Skin) */
html[data-tn-theme="dark"] body.boxed { background: var(--tn-bg); }
/* „Anzeige"-Label des Theme-Ad-Slots */
html[data-tn-theme="dark"] .tn-ad-slot::before { background: var(--tn-bg-soft); }
/* Anzeigen dezent absetzen: heller iframe bekommt soliden dunklen Rahmen */
html[data-tn-theme="dark"] .tn-ad-slot { border-style: solid; border-color: var(--tn-line); }
/* Schatten auf dunklem Grund kräftiger, damit Overlays abheben */
html[data-tn-theme="dark"] .tn-flyout,
html[data-tn-theme="dark"] .tn-nav .sub-menu,
html[data-tn-theme="dark"] .tn-nav-flyout,
html[data-tn-theme="dark"] .tn-mobile-quicknav-flyout,
html[data-tn-theme="dark"] .tn-fz-panel { box-shadow: 0 12px 32px rgba(0,0,0,0.55); }
/* Logo provisorisch monochrom weiß (echtes helles Logo-Asset folgt) */
/* Logo: echte helle SVG-Variante im Dark (statt Filter). Custom-Logo-Fallback = monochrom weiß */
.tn-brand-logo .tn-logo-dark { display: none; }
html[data-tn-theme="dark"] .tn-brand-logo .tn-logo-light { display: none; }
html[data-tn-theme="dark"] .tn-brand-logo .tn-logo-dark { display: block; width: 530px; max-width: 100%; aspect-ratio: 353 / 64; background: url(/wp-content/themes/teneriffa-news/assets/img/logo-dark.svg) center / contain no-repeat; }
html[data-tn-theme="dark"] .custom-logo { filter: brightness(0) invert(1); }
/* Phase 2 - Texte, die im Light --tn-blue-dark als Farbe nutzen (gehen sonst dunkel-auf-dunkel unter) */
html[data-tn-theme="dark"] .tn-mobile-greet strong,
html[data-tn-theme="dark"] .tn-flyout-mega-head,
html[data-tn-theme="dark"] .tn-catlinks-title,
html[data-tn-theme="dark"] .popular-posts-headline,
html[data-tn-theme="dark"] .tn-popular-strip-label,
html[data-tn-theme="dark"] .tn-side-title,
html[data-tn-theme="dark"] .tn-fz-panel-title,
html[data-tn-theme="dark"] .acs-success,
html[data-tn-theme="dark"] .author-contact-success,
html[data-tn-theme="dark"] .tn-mobile-quicknav-flyout > ul > li.has-sub > a,
html[data-tn-theme="dark"] .tn-nav-flyout > ul > li.has-sub > a { color: var(--tn-blue); }
/* „Jetzt neu"-Banner: gedämpftes Dunkelrot statt Signalrot */
html[data-tn-theme="dark"] .tn-just-published-banner,
html[data-tn-theme="dark"] .tn-jp-under-article { background: #7a2824; }
/* Weitere helle Sonderflächen (Paywall, MeterPro, Modal, Formulare) → Surface */
html[data-tn-theme="dark"] .sf-plan,
html[data-tn-theme="dark"] .sf-btn--secondary,
html[data-tn-theme="dark"] #meter-pro-login-form,
html[data-tn-theme="dark"] #meter-pro-account-wrapper .meter-pro-account-details-wrapper,
html[data-tn-theme="dark"] .meter-pro-custom-reg-fields select,
html[data-tn-theme="dark"] .meter-pro-custom-reg-fields input,
html[data-tn-theme="dark"] .zeen101-modal .modal__container,
html[data-tn-theme="dark"] .acs-block .acs-form textarea { background: var(--tn-surface); }
html[data-tn-theme="dark"] .sf-plan--year { background: #20354c; }

/* MeterPro-Paywall-Wall - gestylt von meter-pro.min.css über .tn-pw* (KEIN #mp-paywall-visible!),
   daher hier per .tn-pw überschreiben (Spezifität 0,2,1 schlägt Plugin-0,1,0) */
html[data-tn-theme="dark"] .tn-pw { background: var(--tn-surface); color: var(--tn-ink); box-shadow: 0 16px 40px rgba(0,0,0,0.45); }
html[data-tn-theme="dark"] .tn-pw-fade,
html[data-tn-theme="dark"] .mp-wall-fade,
html[data-tn-theme="dark"] .meter-pro-paywall::before,
html[data-tn-theme="dark"] .meter-pro-upgrade::before,
html[data-tn-theme="dark"] .meter-pro-wall::before { background: linear-gradient(to bottom, rgba(19,36,58,0), var(--tn-bg)); }
html[data-tn-theme="dark"] .tn-mobile-quicknav::after { background: linear-gradient(to right, rgba(28,48,70,0), var(--tn-surface)); }
html[data-tn-theme="dark"] .tn-home-quicklinks::after { background: linear-gradient(to right, rgba(24,44,67,0), var(--tn-bg-soft)); }
html[data-tn-theme="dark"] .tn-pw-claim,
html[data-tn-theme="dark"] .tn-pw-subline,
html[data-tn-theme="dark"] .tn-pw-plan-price-sub,
html[data-tn-theme="dark"] .tn-pw-plan-save,
html[data-tn-theme="dark"] .tn-pw-plan-hint,
html[data-tn-theme="dark"] .tn-pw-footer { color: var(--tn-muted); }
html[data-tn-theme="dark"] .tn-pw-benefits { color: var(--tn-text); }
html[data-tn-theme="dark"] .tn-pw-plan { background: var(--tn-bg-soft); border-color: var(--tn-line); }
html[data-tn-theme="dark"] .tn-pw-plan--medium { background: var(--tn-blue-soft); }
html[data-tn-theme="dark"] .tn-pw-plan--small { background: var(--tn-bg-soft); }
html[data-tn-theme="dark"] .tn-pw-plan--year { background: #20354c; }
html[data-tn-theme="dark"] .tn-pw-btn,
html[data-tn-theme="dark"] .tn-pw-btn--secondary { background: var(--tn-surface); color: var(--tn-blue); border-color: var(--tn-blue-light); }
html[data-tn-theme="dark"] .tn-pw-btn--primary { background: #4581b9; color: #fff; border-color: transparent; }
/* Promo-Boxen + Ad-Platzhalter */
html[data-tn-theme="dark"] .tn-raetsel-promo { background: var(--tn-blue-soft); }
html[data-tn-theme="dark"] .tn-smart-ticker-promo { background: var(--tn-bg-soft); }
html[data-tn-theme="dark"] .tn-gallery-slide--ad,
html[data-tn-theme="dark"] .tn-fs-ad-slide .tn-fs-ad-wrap { background: var(--tn-bg-soft); }
/* Erfolg/Fehler-Meldungen: dunkel getönt, heller Text */
html[data-tn-theme="dark"] .meter_pro_message.error,
html[data-tn-theme="dark"] .author-contact-error { background: rgba(211,47,47,.12); border-color: rgba(211,47,47,.45); }
html[data-tn-theme="dark"] .meter_pro_message.error p,
html[data-tn-theme="dark"] .author-contact-error { color: #f3a9a9; }
html[data-tn-theme="dark"] .meter_pro_message.success { background: rgba(34,197,94,.12); border-color: rgba(34,197,94,.45); }
html[data-tn-theme="dark"] .meter_pro_message.success p { color: #86e0a6; }
/* TL;DR-Block dark */
html[data-tn-theme="dark"] .tldr-box { background: rgba(111,176,232,.10); border-color: rgba(111,176,232,.30); }
html[data-tn-theme="dark"] .tldr-box::before { background: rgba(111,176,232,.6); }
html[data-tn-theme="dark"] .tldr-heading { color: #8fc4f0; }
html[data-tn-theme="dark"] .tldr-box .tldr-overlay { color: var(--tn-ink); background: rgba(19,36,58,.6); }
