/* ============================================================
   Nilkreuzfahrten.de 2026 — Design-Layer
   Wird NACH der ts24-Basis (style.css) geladen und ueberschreibt
   Farben/Typografie + stylt die [section]-Content-Komponenten und
   die Homepage-/Artikel-Templates. Quelle: prototype_homepage.html
   + prototype_article.html (abgenommen). Siehe design_system.md.
   ============================================================ */

:root{
  --nil:#16233f; --nil-deep:#0e1830; --nil-soft:#33406a;
  --sand:#e6d6ad; --sand-light:#efe7d4; --sand-deep:#d8c190;
  --terra:#c2a04e; --terra-deep:#a07f33;  /* Gold-Akzent (Konzept B) */
  --grey:#5b554c; --grey-soft:#8a8275;
  --bg:#faf5ec; --bg-warm:#f4ecdd; --ink:#221d17; --white:#fffdf9;
  --shadow-sm:0 2px 8px rgba(60,42,20,.08); --shadow:0 12px 32px rgba(60,42,20,.14);
  --r:6px;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Source Sans 3',system-ui,-apple-system,sans-serif;
  --label:'Montserrat',sans-serif;
}

/* ---- Grundlagen ---- */
body{ font-family:var(--sans); color:var(--ink); background:var(--bg); line-height:1.75; }
h1,h2,h3,h4,.h1,.h2,.h3{ font-family:var(--serif); color:var(--nil); font-weight:600; letter-spacing:-.01em; }
a{ color:var(--terra-deep); }
a:hover,a:focus{ color:var(--terra); }

/* ============================================================
   Content-Seiten ([section class="section-text"])
   ============================================================ */
.section-text{ font-size:1.05rem; }
.section-text h2{ font-size:1.8rem; margin:2.4rem 0 1rem; }
.section-text h3{ font-size:1.28rem; color:var(--nil-soft); margin:1.6rem 0 .6rem; }
.section-text p{ margin-bottom:1.2rem; }
.section-text img.size-full{ border-radius:var(--r); box-shadow:var(--shadow-sm); margin-bottom:1.6rem; }

/* "Kurz erklaert"-Kapsel (Answer-Capsule) */
.section-text p.lead{
  font-family:var(--serif); font-style:italic; font-weight:500;
  font-size:1.24rem; line-height:1.6; color:var(--nil);
  border-left:4px solid var(--terra); padding:.2rem 0 .2rem 1.3rem;
  margin:0 0 1.6rem; background:none;
}
.section-text p.lead strong{ font-style:normal; color:var(--terra-deep); }

/* Byline */
.section-text p em:only-child{ color:var(--grey-soft); font-size:.92rem; }

/* Schnellfakten-Box (table.table-striped) -> "Auf einen Blick" */
.section-text table.table-striped{
  width:100%; border-collapse:separate; border-spacing:0; margin:1.4rem 0 2rem;
  background:var(--white); border:1px solid var(--sand-deep);
  border-left:4px solid var(--terra); border-radius:var(--r);
  box-shadow:var(--shadow-sm); overflow:hidden;
}
.section-text table.table-striped td{ padding:.7rem 1rem; border-top:1px solid var(--bg-warm); vertical-align:top; }
.section-text table.table-striped tr:first-child td{ border-top:none; }
.section-text table.table-striped td:first-child{
  font-family:var(--label); font-size:.82rem; font-weight:600;
  color:var(--nil); width:40%; text-transform:none; letter-spacing:.02em;
}
.section-text table.table-striped tbody tr:nth-child(odd){ background:var(--bg-warm); }

/* FAQ-Block (h2 "Haeufige Fragen" + h3/p) */
.section-text h2 + h3{ margin-top:1rem; }
.section-text h3{ position:relative; }

/* Fragenbox (TOC der Frage-H2, direkt nach den Schnellfakten) */
.section-text .nk-fragenbox{
  background:var(--bg-warm); border:1px solid var(--sand-deep); border-radius:var(--r);
  padding:18px 22px 14px; margin:1.6rem 0 2rem; box-shadow:none;
}
.section-text .nk-fragenbox > .panel-body{ padding:0; }
.section-text .nk-fragenbox p{ margin:0 0 .6rem; }
.section-text .nk-fragenbox p strong{ font-family:var(--label); font-size:.82rem; letter-spacing:.04em;
  text-transform:uppercase; color:var(--terra-deep); }
.section-text .nk-fragenbox ul{ list-style:none; margin:0; padding:0;
  column-count:2; column-gap:30px; }
.section-text .nk-fragenbox li{ margin:.3rem 0; break-inside:avoid; }
.section-text .nk-fragenbox li a{ color:var(--nil-soft); font-weight:500; }
.section-text .nk-fragenbox li a:hover{ color:var(--terra); }
@media(max-width:600px){ .section-text .nk-fragenbox ul{ column-count:1; } }

/* CTA-Bridge zur Region/Money-Page */
.section-text .nk-cta{
  background:linear-gradient(135deg,var(--nil) 0%,var(--nil-soft) 100%);
  border:none; border-radius:var(--r); margin:2rem 0; box-shadow:var(--shadow-sm);
}
.section-text .nk-cta > .panel-body{ padding:20px 24px; color:var(--white); font-size:1.02rem; }
.section-text .nk-cta a{ color:var(--sand); font-weight:600; text-decoration:underline; }
.section-text .nk-cta a:hover{ color:var(--white); }

/* Anker-Offset, damit Sprungmarken nicht unter der Sticky-Nav landen */
.section-text h2[id]{ scroll-margin-top:90px; }

/* ============================================================
   Homepage (front-page.php) — Komponentenklassen aus Prototyp
   ============================================================ */
.nk-hero{ position:relative; min-height:88vh; display:flex; align-items:flex-end; overflow:hidden; }
.nk-hero__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.nk-hero::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(15,41,66,.12) 0%,rgba(15,41,66,.78) 100%); }
.nk-hero__in{ position:relative; z-index:2; max-width:1180px; margin:0 auto; padding:0 28px 8vh; width:100%; }
.nk-hero h1{ font-size:clamp(2.4rem,5vw,4rem); color:var(--white); line-height:1.08; font-weight:700; max-width:16ch;
  text-shadow:0 2px 30px rgba(0,0,0,.35); }
.nk-hero p{ color:rgba(255,253,249,.92); font-size:1.2rem; max-width:46ch; margin:1.2rem 0 2rem; }
.nk-btn{ display:inline-block; font-family:var(--label); font-weight:600; font-size:.86rem; letter-spacing:.04em;
  padding:.85rem 1.7rem; border-radius:var(--r); text-decoration:none; transition:transform .2s,background .2s; }
.nk-btn--primary{ background:var(--terra); color:var(--white); }
.nk-btn--primary:hover{ background:var(--terra-deep); color:var(--white); transform:translateY(-2px); }
.nk-btn--ghost{ border:1.5px solid rgba(255,253,249,.7); color:var(--white); margin-left:.8rem; }
.nk-btn--ghost:hover{ background:rgba(255,253,249,.12); color:var(--white); }

/* Reiseziel-Cards */
.nk-cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; max-width:1180px; margin:0 auto; padding:70px 28px; }
.nk-card{ background:var(--white); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-sm);
  transition:transform .35s,box-shadow .35s; }
.nk-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.nk-card__img{ aspect-ratio:4/3; width:100%; object-fit:cover; transition:transform .5s; }
.nk-card:hover .nk-card__img{ transform:scale(1.07); }
.nk-card__body{ padding:18px 20px 22px; }
.nk-card .tag,.nk-mag .tag{ font-family:var(--label); font-size:.64rem; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:var(--terra); }
.nk-card h3{ font-size:1.2rem; margin:.4rem 0; line-height:1.25; }

/* Highlight-Banner (Terrakotta) */
.nk-banner{ background:var(--terra); color:var(--white); }
.nk-banner__in{ max-width:1180px; margin:0 auto; padding:54px 28px; display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.nk-banner h3{ color:var(--white); font-size:1.25rem; }
.nk-banner p{ color:rgba(255,253,249,.9); }

/* ============================================================
   Artikel (single.php / page.php) — Lesespalte + Sticky-Sidebar
   ============================================================ */
.nk-article{ max-width:740px; }
.nk-shell{ max-width:1180px; margin:0 auto; padding:48px 28px 80px; }
@media(min-width:1200px){
  .nk-shell{ display:grid; grid-template-columns:minmax(0,1fr) 300px; gap:50px; }
  .nk-side{ position:sticky; top:90px; align-self:start; }
}
.nk-toc{ background:var(--white); border-radius:var(--r); padding:22px 24px; box-shadow:var(--shadow-sm); }
.nk-toc a{ display:block; color:var(--nil-soft); padding-left:14px; border-left:2px solid var(--sand-deep);
  margin-bottom:9px; font-size:.92rem; }
.nk-toc a:hover{ border-color:var(--terra); color:var(--terra); padding-left:18px; }

/* ---- Responsive ---- */
@media(max-width:980px){ .nk-cards{ grid-template-columns:1fr 1fr; } .nk-banner__in{ grid-template-columns:1fr; gap:18px; } }
@media(max-width:560px){ .nk-cards{ grid-template-columns:1fr; } }

/* ============================================================
   Magazin-Navigation (ersetzt ts24-Header/Navbar) — 2026-06-04
   nk-praefixiert; Hooks: assets/nilkreuzfahrten-nav.js
   (body.nk-scrolled, [data-nk-nav-toggle]/[data-nk-nav] .is-open)
   ============================================================ */

/* ts24-Header-Wrapper neutralisieren (navbar.php rendert darin) */
#header{ background:none !important; border:none !important; box-shadow:none !important; min-height:0 !important; padding:0 !important; }
#header .container-fluid{ padding:0 !important; }
#header .searchmask_container,
.searchmask_container,
#section-search{ display:none !important; }

.nk-nav{ position:fixed; top:0; left:0; right:0; z-index:1050; padding:20px 0;
  transition:background .4s, padding .4s, box-shadow .4s; }
body.nk-scrolled .nk-nav{ background:var(--white); box-shadow:0 4px 24px rgba(60,42,20,.1); padding:10px 0; }
.nk-nav-in{ max-width:1200px; margin:0 auto; padding:0 24px; display:flex; align-items:center; justify-content:space-between; }
.nk-logo{ font-family:var(--serif); font-size:1.6rem; font-weight:700; color:var(--white);
  letter-spacing:-.02em; text-decoration:none; transition:color .4s; }
.nk-logo b{ color:var(--sand); }
body.nk-scrolled .nk-logo{ color:var(--nil); }
body.nk-scrolled .nk-logo b{ color:var(--terra); }
.nk-menu{ display:flex; gap:30px; align-items:center; }
.nk-menu a{ font-family:var(--label); font-size:.82rem; font-weight:600; letter-spacing:.04em;
  text-transform:uppercase; color:rgba(255,253,249,.92); position:relative; padding:4px 0;
  text-decoration:none; transition:color .3s; }
.nk-menu a::after{ content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background:var(--terra); transition:width .3s; }
.nk-menu a:hover::after{ width:100%; }
body.nk-scrolled .nk-menu a{ color:var(--nil); }
.nk-nav-right{ display:flex; align-items:center; gap:18px; }
.nk-burger{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; }
.nk-burger span{ width:26px; height:2px; background:var(--white); display:block; transition:all .3s; }
body.nk-scrolled .nk-burger span{ background:var(--nil); }

@media (max-width:860px){
  .nk-menu{ display:none; }
  .nk-burger{ display:flex; }
  .nk-menu.is-open{ display:flex; position:fixed; top:0; right:0; bottom:0; width:78%; max-width:320px;
    background:var(--nil-deep); flex-direction:column; align-items:flex-start; justify-content:center;
    gap:28px; padding:0 40px; z-index:1060; box-shadow:-10px 0 40px rgba(0,0,0,.3); }
  .nk-menu.is-open a{ color:var(--white) !important; font-size:1.1rem; }
  body.nk-scrolled .nk-menu.is-open a{ color:var(--white) !important; }
  .nk-burger.is-open span{ background:var(--white); }
  .nk-burger.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nk-burger.is-open span:nth-child(2){ opacity:0; }
  .nk-burger.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
}

/* ============================================================
   Header-Feinschliff (2026-06-04, Nachtrag):
   ts24-Hintergrund-Reste im Header-Bereich neutralisieren +
   Nav-Kontrast auf hellem Seitenanfang sichern.
   ============================================================ */

/* 1) Header-Wrapper transparent erzwingen (auch der umschliessende .tt) */
body header#header,
body .tt:has(> #header){
  background:transparent !important; background-image:none !important;
  box-shadow:none !important; border:0 !important; min-height:0 !important;
  height:auto !important; padding:0 !important;
}

/* 2) Magazin-Nav fixiert + transparent erzwingen (gegen ts24-Spezifitaet) */
body header#header nav.nk-nav{
  position:fixed !important; top:0 !important; left:0 !important; right:0 !important;
  width:100% !important; background:transparent !important; background-image:none !important;
  box-shadow:none !important;
}
body.nk-scrolled header#header nav.nk-nav{
  background:var(--white) !important; box-shadow:0 4px 24px rgba(60,42,20,.1) !important;
}

/* 3) Lesbarkeits-Scrim: dezenter dunkler Verlauf hinter der transparenten Nav,
      damit weisse Logo-/Menue-Schrift auf hellem Seitenanfang lesbar bleibt.
      Verschwindet, sobald die Nav beim Scrollen weiss wird. */
body header#header nav.nk-nav::before{
  content:""; position:absolute; left:0; right:0; top:0; bottom:0; z-index:-1;
  background:linear-gradient(to bottom, rgba(15,41,66,.55), rgba(15,41,66,0));
  transition:opacity .4s; pointer-events:none;
}
body.nk-scrolled header#header nav.nk-nav::before{ opacity:0; }

/* ============================================================
   Artikel-/News-Hero kompakter (2026-06-04 Nachtrag):
   Der Vollbild-Hero (88vh) ist nur fuer die Startseite gedacht.
   Artikel-/News-/Spot-Seiten bekommen einen kompakten Hero,
   damit man zuegig zum Text kommt.
   ============================================================ */
.nk-hero.nk-hero--article{ min-height:42vh !important; max-height:480px; }
.nk-hero.nk-hero--article .nk-hero__in{ padding-bottom:2.4rem; }
.nk-hero.nk-hero--article h1{ font-size:clamp(1.9rem,3.4vw,2.9rem); }

/* Ohne Beitragsbild: eleganter Nil-Verlauf statt leerer Flaeche */
.nk-hero.nk-hero--plain{ min-height:32vh !important; max-height:360px;
  background:linear-gradient(135deg,var(--nil) 0%,var(--nil-deep) 100%); }
.nk-hero.nk-hero--plain::after{ background:linear-gradient(180deg,rgba(15,41,66,.1),rgba(15,41,66,.45)); }

/* ============================================================
   Breadcrumb (2026-06-04 Nachtrag):
   Den oberen ts24-Breadcrumb komplett ausblenden — der Hero hat
   bereits einen eigenen, lesbaren Breadcrumb (.nk-crumb). Damit
   verdeckt die fixe Nav nichts mehr und das Magazin-Layout bleibt
   sauber (Nav transparent ueber dem Hero, wie auf der Startseite).
   ============================================================ */
#content > #breadcrumbs,
#breadcrumbs,
.tt #breadcrumbs{ display:none !important; }

/* Lesbarkeit der transparenten Nav ueber dem Hero zusaetzlich absichern */
.nk-hero .nk-crumb a{ color:rgba(255,253,249,.95); }
.nk-hero .nk-crumb a:hover{ color:var(--sand); }

/* ============================================================
   Hero-Lesbarkeit (2026-06-04 Nachtrag):
   Redaktions-Byline (.nk-meta) + Hero-Breadcrumb liegen ueber
   dem Hero-Foto -> helle Schrift + Textschatten, und der untere
   Hero-Bereich bekommt ein staerkeres Overlay.
   ============================================================ */
.nk-hero .nk-meta{
  color:rgba(255,253,249,.94); font-family:var(--label); font-size:.9rem; font-weight:500;
  margin-top:.9rem; display:flex; flex-wrap:wrap; align-items:center; gap:.55rem;
  text-shadow:0 1px 14px rgba(0,0,0,.6), 0 1px 3px rgba(0,0,0,.5);
}
.nk-hero .nk-meta strong{ color:#fff; font-weight:700; }
.nk-hero .nk-meta .nk-dot{
  width:4px; height:4px; border-radius:50%; background:var(--sand); display:inline-block; opacity:.85;
}
.nk-hero .nk-crumb{ text-shadow:0 1px 12px rgba(0,0,0,.55); }

/* Staerkeres Overlay im unteren Hero-Bereich (dort liegen H1 + Byline) */
.nk-hero.nk-hero--article::after{
  background:linear-gradient(180deg, rgba(15,41,66,.12) 0%, rgba(15,41,66,.5) 52%, rgba(15,41,66,.86) 100%) !important;
}

/* ============================================================
   Highlight-Banner dezenter (2026-06-04 Nachtrag):
   Statt grossem Vollflaechen-Terrakotta -> schlanker heller
   Streifen (Wuestensand) mit Terrakotta nur als Akzent.
   ============================================================ */
.nk-banner{ background:var(--bg-warm) !important; color:var(--grey) !important;
  border-top:3px solid var(--terra); }
.nk-banner__in{ padding:26px 28px !important; gap:26px; }
.nk-banner h3{ color:var(--terra-deep) !important; font-family:var(--label);
  font-size:1rem !important; text-transform:uppercase; letter-spacing:.04em; margin-bottom:.35rem; }
.nk-banner p{ color:var(--grey) !important; font-size:.92rem; line-height:1.55; margin:0; }

/* ============================================================
   REDESIGN 2026-06-04 — Layout B · Farbwelt „Nachtblau & Gold"
   (vom Auftraggeber gewählt). Ueberschreibt Farben + Content-Layout.
   ============================================================ */
:root{
  --nil:#1d2746; --nil2:#141b33; --nil-soft:#33406a;
  --sand:#e6d6ad; --sand-light:#efe7d4; --sand-deep:#d8c190;
  --terra:#bf9b4e; --terra-deep:#a07f33;     /* Gold-Akzent */
  --grey:#5e574a; --grey-soft:#8a8275;
  --bg:#faf6ec; --bg-warm:#f1ead9; --ink:#23201a; --white:#fffdf9;
  --sandbg:#f1ead9; --line:#e7ddc9;
}

/* ---- Breadcrumb-Band (Schema.org), direkt unter der fixen Nav ---- */
body:not(.home) #content{ padding-top:0 !important; }
.nk-bcband{ background:var(--sandbg); border-bottom:1px solid var(--line); margin-top:62px; }
.nk-bc-in{ max-width:1200px; margin:0 auto; padding:11px 30px; }
.nk-bc{ display:flex; align-items:center; flex-wrap:wrap; gap:6px; font-family:var(--label);
  font-size:.74rem; font-weight:600; letter-spacing:.03em; color:var(--grey); }
.nk-bc a{ text-decoration:none; color:var(--terra-deep); }
.nk-bc a:hover{ color:var(--terra); }
.nk-bc-cur span{ color:var(--nil); font-weight:700; }
.nk-bc-sep{ width:14px; height:14px; fill:none; stroke:var(--sand-deep); stroke-width:2.4; flex:0 0 auto; }
.nk-bc-home{ width:14px; height:14px; fill:none; stroke:var(--terra-deep); stroke-width:2; margin-right:2px; flex:0 0 auto; }

/* ---- Kopf: Titel + Byline (kompakt) ---- */
.nk-head{ max-width:1200px; margin:0 auto; padding:26px 30px 0; }
.nk-head .nk-eyebrow{ font-family:var(--label); font-size:.72rem; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--terra-deep); }
.nk-head h1{ font-family:var(--serif); font-weight:700; color:var(--nil);
  font-size:clamp(2rem,4.4vw,3.1rem); line-height:1.07; margin:.25rem 0 .5rem; max-width:22ch; }
.nk-head .nk-meta{ font-family:var(--label); font-size:.78rem; color:var(--grey);
  display:flex; flex-wrap:wrap; align-items:center; gap:.5rem; }
.nk-head .nk-dot{ width:4px; height:4px; border-radius:50%; background:var(--sand-deep); display:inline-block; }

/* ---- Kopf-Bild ---- */
.nk-figure{ max-width:1200px; margin:18px auto 0; padding:0 30px; }
.nk-figure img{ width:100%; height:auto; max-height:420px; object-fit:cover; border-radius:8px; box-shadow:var(--shadow-sm); }

/* ---- Zweispaltiges Layout: Lesespalte (frei, KEINE Box) + Sidebar ---- */
.content.nk-page .nk-shell{ max-width:1200px; margin:0 auto; padding:30px 30px 80px;
  display:block; }
@media(min-width:900px){
  .content.nk-page .nk-shell{ display:grid; grid-template-columns:minmax(0,1fr) 290px; gap:54px; align-items:start; }
}
.content.nk-page .nk-article{ max-width:760px; background:none; box-shadow:none; padding:0; }
.nk-article.section-text{ font-size:1.06rem; }
.nk-article h2{ font-family:var(--serif); font-weight:700; color:var(--nil); font-size:1.7rem;
  line-height:1.2; margin:36px 0 12px; }
.nk-article h2::before{ content:""; display:block; width:30px; height:2px; background:var(--terra); margin-bottom:12px; }
.nk-article h3{ font-family:var(--serif); font-size:1.18rem; color:var(--nil-soft); margin:22px 0 6px; }
.nk-article p{ margin-bottom:16px; } .nk-article a{ color:var(--terra-deep); }
.nk-article p.lead{ font-family:var(--serif); font-style:italic; font-weight:500; font-size:1.3rem;
  line-height:1.6; color:var(--nil); border:0; background:none; padding:0; margin-bottom:26px; }
.nk-article p.lead strong{ font-style:normal; }

/* Inline-Fragenbox ausblenden (Sidebar-Inhalt ersetzt sie) */
.nk-article .nk-fragenbox{ display:none !important; }
/* CTA bleibt als farbiger Block (kein „Text in Box"-Problem, gewollt) */
.nk-article .nk-cta{ background:linear-gradient(135deg,var(--nil),var(--nil2)); color:#fff;
  border:0; border-radius:8px; padding:6px 4px; margin:34px 0; }
.nk-article .nk-cta .panel-body{ color:#fff; } .nk-article .nk-cta a{ color:var(--sand); font-weight:600; }

/* ---- Sidebar ---- */
.content.nk-page .nk-side{ position:sticky; top:84px; align-self:start; }
.nk-side-card{ border-top:3px solid var(--terra); padding-top:14px; margin-bottom:26px; }
.nk-side-t{ font-family:var(--label); font-size:.7rem; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:var(--nil); margin-bottom:10px; }
/* Schnellfakten-Tabelle in der Sidebar: zeilen statt Box */
.nk-side-card table.table-striped{ width:100%; }
.nk-side-card table.table-striped tr{ display:flex; flex-direction:column; padding:8px 0; border-bottom:1px solid var(--line); }
.nk-side-card table.table-striped td{ border:0; padding:0; }
.nk-side-card table.table-striped td:first-child{ font-family:var(--label); font-size:.66rem; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase; color:var(--terra-deep); }
.nk-side-card table.table-striped td:first-child strong{ font-weight:700; }
.nk-side-card table.table-striped td:last-child{ color:var(--ink); font-size:.95rem; }
.nk-toc nav{ display:block; }
.nk-toc nav a{ display:block; color:var(--nil); text-decoration:none; font-size:.9rem;
  padding:6px 0 6px 14px; border-left:2px solid var(--sand-light); }
.nk-toc nav a:hover{ border-color:var(--terra); color:var(--terra); }

@media(max-width:900px){ .content.nk-page .nk-side{ position:static; } }

/* ---- Content-Sektion NICHT als graue Box absetzen (Auftraggeber-Wunsch) ---- */
.nk-article .section,
.nk-article div.section-text{
  background:none !important; background-color:transparent !important;
  box-shadow:none !important; border:0 !important; padding:0 !important; margin:0 !important;
}

/* ---- Sidebar-Boxen ohne Hintergrund/Streifen (wie Mockup) ---- */
.nk-side-card table,
.nk-side-card table.table-striped,
.nk-side-card table.table-striped tbody,
.nk-side-card table.table-striped tr,
.nk-side-card table.table-striped td{
  background:none !important; background-color:transparent !important; box-shadow:none !important;
}
.nk-side .nk-toc,
.nk-side-card.nk-toc{
  background:none !important; background-color:transparent !important; box-shadow:none !important;
  border-radius:0 !important; padding:14px 0 0 0 !important; border-top:3px solid var(--terra) !important;
}

/* ============================================================
   STARTSEITE 2026 (Nachtblau & Gold) — Hubs / Reiseziele / Band
   ============================================================ */
.nk-hero--home .nk-hero__eyebrow{ font-family:var(--label); font-size:.8rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase; color:var(--terra); }
.nk-hero--home::after{ background:linear-gradient(120deg,rgba(20,27,51,.82) 0%,rgba(20,27,51,.45) 55%,rgba(20,27,51,.22) 100%); }

.nk-shell2{ max-width:1200px; margin:0 auto; padding:0 30px; }
.nk-sec{ padding:76px 0; }
.nk-sec-h{ text-align:center; margin-bottom:46px; }
.nk-sec-h .nk-eyebrow{ font-family:var(--label); font-size:.74rem; font-weight:700; letter-spacing:.18em;
  text-transform:uppercase; color:var(--terra-deep); }
.nk-sec-h h2{ font-family:var(--serif); font-weight:700; color:var(--nil); font-size:clamp(2rem,3.6vw,2.7rem); margin-top:.4rem; }
.nk-sec-h p{ color:var(--grey); max-width:54ch; margin:.6rem auto 0; }

/* Hub-Grid */
.nk-hubs{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.nk-hub{ background:var(--white); border:1px solid #ece3d2; border-top:3px solid var(--terra); border-radius:8px;
  padding:30px 26px; text-decoration:none; color:var(--ink); transition:transform .2s,box-shadow .2s; display:block; }
.nk-hub:hover{ transform:translateY(-4px); box-shadow:0 18px 40px rgba(60,42,20,.12); }
.nk-hubico{ width:34px; height:34px; fill:none; stroke:var(--terra-deep); stroke-width:1.6; margin-bottom:14px; }
.nk-hub h3{ font-family:var(--serif); font-size:1.35rem; color:var(--nil); margin-bottom:6px; }
.nk-hub p{ color:var(--grey); font-size:.95rem; margin-bottom:14px; }
.nk-hublink{ font-family:var(--label); font-size:.76rem; font-weight:700; letter-spacing:.04em;
  text-transform:uppercase; color:var(--terra-deep); }

/* Reiseziele (Nachtblau-Sektion) */
.nk-sec--dark{ background:var(--nil); color:#fff; }
.nk-sec--dark .nk-sec-h h2{ color:#fff; }
.nk-sec--dark .nk-sec-h .nk-eyebrow{ color:var(--terra); }
.nk-sec--dark .nk-sec-h p{ color:rgba(255,253,249,.8); }
.nk-zgrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.nk-zcard{ border-radius:8px; overflow:hidden; text-decoration:none; background:var(--nil-soft);
  box-shadow:0 10px 30px rgba(0,0,0,.25); transition:transform .2s; }
.nk-zcard:hover{ transform:translateY(-4px); }
.nk-zimg{ height:150px; background-size:cover; background-position:center; }
.nk-zbody{ padding:14px 16px; }
.nk-ztag{ font-family:var(--label); font-size:.64rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--terra); }
.nk-zbody h3{ font-family:var(--serif); font-size:1.2rem; color:#fff; margin-top:2px; }
.nk-zmore{ text-align:center; margin-top:34px; }
.nk-zmore a{ font-family:var(--label); font-weight:700; font-size:.8rem; letter-spacing:.06em; text-transform:uppercase;
  color:var(--terra); text-decoration:none; border-bottom:2px solid var(--terra); padding-bottom:4px; }

/* Highlight-Band (Gold) */
.nk-band{ background:var(--terra); color:var(--nil2); }
.nk-band__in{ max-width:1100px; margin:0 auto; padding:40px 30px; display:grid; grid-template-columns:repeat(3,1fr); gap:34px; }
.nk-band h3{ font-family:var(--serif); font-size:1.3rem; margin-bottom:4px; color:var(--nil2); }
.nk-band p{ font-size:.95rem; opacity:.85; }

/* Magazin */
.nk-mag2{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.nk-mcard{ border-radius:8px; overflow:hidden; text-decoration:none; background:var(--white); border:1px solid #ece3d2; display:block; }
.nk-mcard:hover{ box-shadow:0 14px 32px rgba(60,42,20,.12); }
.nk-mimg{ height:140px; background-size:cover; background-position:center; }
.nk-mbody{ padding:14px 16px; }
.nk-mtag{ font-family:var(--label); font-size:.62rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--terra-deep); }
.nk-mbody h3{ font-family:var(--serif); font-size:1.05rem; color:var(--nil); margin-top:3px; }

@media(max-width:900px){
  .nk-hubs,.nk-zgrid,.nk-mag2{ grid-template-columns:1fr 1fr; }
  .nk-band__in{ grid-template-columns:1fr; gap:20px; }
}

/* ============================================================
   KONZEPT B — Logo (Bildmarke „Segel & Sonne" + Wortmarke) in der Nav
   ============================================================ */
.nk-logo{ display:inline-flex; align-items:center; gap:11px; text-decoration:none; }
.nk-logo-mark{ width:38px; height:38px; flex:0 0 auto; color:#fff; transition:color .3s; }
.nk-logo-wm{ font-family:var(--serif); font-size:1.5rem; font-weight:700; line-height:1; color:#fff; letter-spacing:-.01em; transition:color .3s; }
.nk-logo-wm b{ color:var(--terra); font-weight:700; }
body.nk-scrolled .nk-logo-mark,
body.nk-scrolled .nk-logo-wm{ color:var(--nil); }
@media(max-width:600px){ .nk-logo-wm{ font-size:1.25rem; } .nk-logo-mark{ width:32px; height:32px; } }

/* ============================================================
   HOMEPAGE (Konzept B: Tiefblau & Gold) — nkh-* nach Mockup nk_home_final.html
   ============================================================ */
.nkh-wrap{ max-width:1200px; margin:0 auto; padding:0 30px; }
.nkh-eyebrow{ font-family:var(--label); font-size:.72rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--terra); }
.nkh-h2{ font-family:var(--serif); font-weight:700; color:var(--nil); font-size:1.95rem; line-height:1.12; margin:.15rem 0; }
.nkh-sech{ margin-bottom:18px; } .nkh-sech p{ color:var(--grey); max-width:62ch; margin-top:.3rem; }
.nkh-sec{ padding:42px 0; }

/* Hero */
.nkh-hero{ position:relative; min-height:74vh; display:flex; align-items:flex-end; overflow:hidden; background:var(--nil); }
.nkh-hero__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.nkh-hero::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.4) 0%,rgba(0,0,0,.12) 40%,var(--nil-deep) 100%); opacity:.94; }
.nkh-hero--noimg::after{ background:linear-gradient(135deg,var(--nil) 0%,var(--nil-deep) 100%); opacity:1; }
.nkh-in{ position:relative; z-index:2; max-width:1200px; margin:0 auto; width:100%; padding:120px 30px 6vh; }
.nkh-hero h1{ font-family:var(--serif); font-weight:700; color:#fff; font-size:clamp(2.4rem,5.4vw,4.2rem);
  line-height:1.05; margin:.5rem 0 .6rem; max-width:20ch; text-shadow:0 4px 40px rgba(0,0,0,.5); }
.nkh-hero p{ color:rgba(255,255,255,.92); font-size:1.18rem; max-width:46ch; margin-bottom:1.6rem; }
.nkh-cta{ display:flex; flex-wrap:wrap; gap:12px; }
.nkh-btn{ display:inline-flex; align-items:center; gap:8px; font-family:var(--label); font-weight:700;
  font-size:.84rem; letter-spacing:.04em; padding:.9rem 1.7rem; border-radius:6px; text-decoration:none; }
.nkh-btn--gold{ background:var(--terra); color:var(--nil-deep); }
.nkh-btn--gold:hover{ background:var(--sand); color:var(--nil-deep); }
.nkh-btn--ghost{ border:1.5px solid rgba(255,255,255,.6); color:#fff; }
.nkh-btn--ghost:hover{ border-color:var(--terra); color:var(--terra); }

/* 6 Bild-Hubs */
.nkh-hubs{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.nkh-hub{ position:relative; height:194px; border-radius:10px; overflow:hidden; display:block;
  text-decoration:none; background:var(--nil) center/cover no-repeat; }
.nkh-hub__ov{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(14,24,48,.18) 25%,rgba(10,17,36,.9)); transition:background .3s; }
.nkh-hub:hover .nkh-hub__ov{ background:linear-gradient(180deg,rgba(22,35,63,.35),rgba(10,17,36,.94)); }
.nkh-hub__tx{ position:absolute; left:0; bottom:0; padding:18px; z-index:2; display:block; }
.nkh-hub__h{ display:block; font-family:var(--serif); color:#fff; font-size:1.35rem; line-height:1.15; }
.nkh-hub__p{ display:block; color:rgba(255,255,255,.82); font-size:.85rem; margin:3px 0 7px; }
.nkh-hub__l{ font-family:var(--label); font-size:.7rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--terra); }

/* dunkle Section (Top-Schiffe) */
.nkh-sec--dark{ background:var(--nil); }
.nkh-sec--dark .nkh-h2{ color:#fff; } .nkh-sec--dark .nkh-sech p{ color:rgba(255,255,255,.72); }
.nkh-ships{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.nkh-ship{ background:var(--nil-deep); border:1px solid rgba(255,255,255,.12); border-radius:10px;
  overflow:hidden; text-decoration:none; transition:transform .25s,border-color .25s; display:block; }
.nkh-ship:hover{ transform:translateY(-4px); border-color:var(--terra); }
.nkh-ship__img{ display:block; width:100%; height:140px; background:var(--nil) center/cover no-repeat; }
.nkh-ship__b{ display:block; padding:13px 15px; }
.nkh-ship__tag{ display:block; font-family:var(--label); font-size:.6rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--terra); }
.nkh-ship__h{ display:block; font-family:var(--serif); color:#fff; font-size:1.08rem; margin-top:3px; }
.nkh-more{ margin-top:20px; }
.nkh-more a{ font-family:var(--label); font-size:.8rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--terra); text-decoration:none; }
.nkh-more a:hover{ color:var(--sand); }

/* Stationen-Grid */
.nkh-zg{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.nkh-zc{ position:relative; height:220px; border-radius:10px; overflow:hidden; display:block;
  text-decoration:none; background:var(--nil) center/cover no-repeat; }
.nkh-zc__ov{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(0,0,0,0) 38%,rgba(0,0,0,.82)); }
.nkh-zc__tx{ position:absolute; left:0; bottom:0; padding:18px; z-index:2; display:block; }
.nkh-zc__s{ display:block; font-family:var(--label); font-size:.62rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--sand); }
.nkh-zc__h{ display:block; font-family:var(--serif); color:#fff; font-size:1.4rem; }

/* Reiseinfo-Band */
.nkh-band{ background:var(--sand-light); border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:30px 0; }
.nkh-bandg{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.nkh-bandg a{ text-decoration:none; display:block; }
.nkh-bandg h3{ font-family:var(--serif); color:var(--nil); font-size:1.15rem; margin-bottom:.2rem; }
.nkh-bandg p{ color:var(--grey); font-size:.95rem; }
.nkh-bandg a:hover h3{ color:var(--terra-deep); }

@media(max-width:900px){ .nkh-hubs,.nkh-ships,.nkh-zg,.nkh-bandg{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .nkh-hubs,.nkh-ships,.nkh-zg,.nkh-bandg{ grid-template-columns:1fr; } }

/* ts24-Standard-Header-Elemente auf der Magazin-Startseite ausblenden:
   eigener Hero + 6 Bild-Hubs ersetzen sie; fm720-Angebotsboxen + ts24-Headerbild
   + ts24-Breadcrumb passen nicht zum redaktionellen Startseiten-Look. */
body.home #section-search,
body.home #top-boxes,
body.home #breadcrumbs{ display:none !important; }

/* ============================================================
   Layout-B-Feinschliff Unterseiten
   ============================================================ */
/* ts24-Standard-Breadcrumb generell ausblenden — eigenes Schema.org-Band (.nk-bcband) ersetzt ihn */
#breadcrumbs{ display:none !important; }

/* ts24-Child-Page-Übersicht (Hub-Seiten mit Kindern) als Magazin-Karten (Tiefblau & Gold) */
#list-child-pages{ max-width:1200px; margin:6px auto 64px; padding:0 30px; }
#list-child-pages .container-fluid{ padding:0; max-width:none; }
#list-child-pages .row{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin:0; }
#list-child-pages .h3{ grid-column:1/-1; width:auto; float:none; font-family:var(--serif);
  font-size:1.7rem; font-weight:700; color:var(--nil); margin:0; }
#list-child-pages .h3::before{ content:""; display:block; width:30px; height:2px; background:var(--terra); margin-bottom:12px; }
#list-child-pages [class*="col-"]{ width:auto; max-width:none; padding:0; float:none; }
#list-child-pages .child-thumbs-box{ position:relative; display:block; background:var(--nil);
  border-radius:10px; overflow:hidden; box-shadow:var(--shadow-sm); height:100%;
  transition:transform .25s,box-shadow .25s; }
#list-child-pages .child-thumbs-box:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
#list-child-pages .child-thumbs-box img{ width:100%; height:184px; object-fit:cover; display:block; margin:0; }
#list-child-pages .child-thumbs-box > div{ padding:14px 16px 16px; }
#list-child-pages .child-thumbs-box .h2{ font-family:var(--serif); font-size:1.18rem; line-height:1.2;
  color:#fff !important; display:block; margin:0 0 8px !important; }
#list-child-pages .child-thumbs-box a{ font-family:var(--label); font-size:.72rem; font-weight:700;
  letter-spacing:.05em; text-transform:uppercase; color:var(--terra) !important; text-decoration:none; }
#list-child-pages .child-thumbs-box a:hover{ color:var(--sand) !important; }
@media(max-width:900px){ #list-child-pages .row{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ #list-child-pages .row{ grid-template-columns:1fr; } }

/* ============================================================
   Nav-Lesbarkeit: größeres Logo + größere Menüschrift + Kontrast
   (User-Feedback Juni 2026 — „kaum lesbar" auf hellem Hero)
   ============================================================ */
.nk-nav{ padding:16px 0; }
.nk-logo{ gap:13px; }
.nk-logo-mark{ width:50px; height:50px; }
.nk-logo-wm{ font-size:2.4rem; }
.nk-menu{ gap:26px; }
.nk-menu a{ font-size:1.4rem; letter-spacing:.02em; }
/* Lesbarkeit über hellem Hero: Schatten, solange nicht gescrollt */
.nk-logo-wm,
.nk-menu a{ text-shadow:0 1px 16px rgba(0,0,0,.6), 0 0 2px rgba(0,0,0,.35); }
.nk-logo-mark{ filter:drop-shadow(0 1px 9px rgba(0,0,0,.5)); }
body.nk-scrolled .nk-logo-wm,
body.nk-scrolled .nk-menu a{ text-shadow:none; }
body.nk-scrolled .nk-logo-mark{ filter:none; }
@media(max-width:1024px){ .nk-menu{ gap:20px; } .nk-menu a{ font-size:.92rem; } }
@media(max-width:600px){ .nk-logo-wm{ font-size:1.6rem; } .nk-logo-mark{ width:42px; height:42px; } }

/* ============================================================
   Größere, lesbare Content-Schrift (User-Feedback Juni 2026)
   Theme-root = 10px (62.5%) → Body war 10,6px, deutlich zu klein
   ============================================================ */
.nk-article.section-text{ font-size:1.72rem; line-height:1.8; }
.nk-article p{ margin-bottom:1.5rem; }
.nk-article h2{ font-size:2.55rem; line-height:1.18; margin:3.2rem 0 1.1rem; }
.nk-article h3{ font-size:1.95rem; margin:2.2rem 0 .7rem; }
.nk-article p.lead{ font-size:2.05rem; line-height:1.58; }
.nk-article li{ font-size:1.72rem; margin-bottom:.55rem; }
.nk-article blockquote{ font-size:1.9rem; }
.nk-head h1{ font-size:clamp(3.2rem,5vw,4.8rem); }
.nk-head .nk-meta{ font-size:1.3rem; }
.nk-bc{ font-size:1.2rem; }
.nk-side-card .nk-side-t{ font-size:1.2rem; }
.nk-side-card table.table-striped td:first-child{ font-size:1.1rem; }
.nk-side-card table.table-striped td:last-child{ font-size:1.55rem; }
.nk-toc nav a{ font-size:1.45rem; }

/* ============================================================
   Fragenbox SICHTBAR + strukturiert (User: „vermisse die Frageboxen")
   Sprungmarken-Übersicht der Frage-H2 als Tiefblau&Gold-Box im Content
   ============================================================ */
.nk-article .nk-fragenbox{ display:block !important;
  background:var(--sand-light); border:1px solid var(--line); border-left:4px solid var(--terra);
  border-radius:8px; padding:1.6rem 1.9rem; margin:2.2rem 0 2.8rem; box-shadow:var(--shadow-sm); }
.nk-article .nk-fragenbox .panel-heading,
.nk-article .nk-fragenbox > .nk-fragenbox-t,
.nk-article .nk-fragenbox > strong:first-child{ font-family:var(--label); font-size:1.2rem; font-weight:700;
  letter-spacing:.05em; text-transform:uppercase; color:var(--terra-deep); display:block; margin:0 0 1rem;
  background:none; border:0; padding:0; }
.nk-article .nk-fragenbox ul,
.nk-article .nk-fragenbox ol{ list-style:none; margin:0; padding:0; column-count:2; column-gap:2.2rem; }
.nk-article .nk-fragenbox li{ margin:.5rem 0; break-inside:avoid; font-size:1.58rem; line-height:1.4; }
.nk-article .nk-fragenbox li a{ color:var(--nil-soft); font-weight:600; text-decoration:none;
  border-bottom:1px solid transparent; }
.nk-article .nk-fragenbox li a:hover{ color:var(--terra-deep); border-color:var(--sand-deep); }
@media(max-width:600px){ .nk-article .nk-fragenbox ul,.nk-article .nk-fragenbox ol{ column-count:1; } }

/* Frage-H2 mit Sprungmarken-Ankerziel-Abstand (sticky Nav) */
.nk-article h2[id]{ scroll-margin-top:96px; }

/* CTA-Block größer/lesbarer */
.nk-article .nk-cta{ font-size:1.7rem; }
.nk-article .nk-cta .panel-body{ padding:1.6rem 1.9rem; }

/* ============================================================
   Nil-Streckenkarte [nilkarte] — Konzept B
   ============================================================ */
.nk-article .nk-map{ float:right; width:340px; max-width:42%; margin:.4rem 0 1.6rem 2.2rem;
  background:linear-gradient(165deg,#fbf7ee,#f1e7d2); border:1px solid var(--line);
  border-radius:14px; padding:16px 18px 18px; box-shadow:var(--shadow-sm); }
.nk-map__s{ display:block; font-family:var(--label); font-size:1.05rem; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase; color:var(--terra-deep); }
.nk-map__h{ display:block; font-family:var(--serif); font-weight:700; color:var(--nil);
  font-size:1.5rem; line-height:1.15; margin:2px 0 8px; }
.nk-map svg{ display:block; width:100%; height:auto; }
.nk-map__leg{ display:flex; flex-wrap:wrap; gap:14px; margin-top:8px; }
.nk-map__lg{ display:inline-flex; align-items:center; gap:6px; font-family:var(--label);
  font-size:1.15rem; font-weight:600; color:var(--grey); }
.nk-map__dot{ width:11px; height:11px; border-radius:50%; background:var(--terra); border:2px solid #fff; box-shadow:0 0 0 1px var(--sand-deep); flex:0 0 auto; }
.nk-map__line{ width:16px; height:4px; border-radius:2px; background:var(--terra); flex:0 0 auto; }
@media(max-width:680px){ .nk-article .nk-map{ float:none; width:100%; max-width:none; margin:1.4rem 0 2rem; } }

/* ============================================================
   National-Geographic-Lesetypografie (User-Wunsch Juni 2026)
   großzügiger Body, große Headlines, viel Zeilenabstand
   ============================================================ */
.nk-article.section-text{ font-size:2.1rem; line-height:1.85; }
.nk-article p{ margin-bottom:1.8rem; }
.nk-article li{ font-size:2.1rem; line-height:1.6; margin-bottom:.6rem; }
.nk-article h2{ font-size:3.2rem; line-height:1.16; margin:3.8rem 0 1.3rem; }
.nk-article h3{ font-size:2.4rem; margin:2.6rem 0 .8rem; }
.nk-article p.lead{ font-size:2.5rem; line-height:1.55; }
.nk-article blockquote{ font-size:2.4rem; }
.nk-article .nk-fragenbox li{ font-size:1.85rem; }
.nk-head h1{ font-size:clamp(3.6rem,5.5vw,5.6rem); line-height:1.06; }
.nk-map__h{ font-size:1.7rem; }
