/* ═══════════════════════════════════════════════
   fisch-lang.css — Maritime Tradition Theme
   OKLCH Color System + Typography Overhaul
   ═══════════════════════════════════════════════ */

/* ─── 1. Color Token Overrides (OKLCH) ──────── */
[data-theme="fisch-lang"] {
  /* Brand: Deep Navy */
  --color-primary:       oklch(28% 0.06 250);
  --color-primary-light: oklch(35% 0.07 250);
  --color-primary-dark:  oklch(18% 0.05 250);

  /* Accent: Warm Gold — WCAG AA verified (≥4.5:1 with white) */
  --color-secondary:       oklch(55% 0.14 80);
  --color-secondary-light: oklch(62% 0.12 80);
  --color-secondary-dark:  oklch(45% 0.14 80);
  --color-accent:          oklch(55% 0.14 80);

  /* Warm Accent: Kupfer/Grill-Orange — WCAG AA 5.21:1 on white */
  --color-warm:      oklch(55% 0.18 45);
  --color-warm-light: oklch(62% 0.16 45);
  --color-warm-dark:  oklch(48% 0.17 42);

  /* Surfaces — warm-tinted neutrals */
  --color-bg:      oklch(97% 0.005 80);
  --color-bg-alt:  oklch(94% 0.008 80);
  --color-bg-card: oklch(99% 0.003 80);
  --color-surface: oklch(92% 0.01 80);

  /* Text — high contrast, warm-tinted */
  --color-text:        oklch(22% 0.02 250);
  --color-text-muted:  oklch(40% 0.02 250);
  --color-text-subtle: oklch(55% 0.015 250);

  /* Border */
  --color-border: oklch(85% 0.008 80);

  /* Gradients — OKLCH interpolation */
  --gradient-primary: linear-gradient(in oklch 135deg, oklch(28% 0.06 250), oklch(35% 0.07 250));
  --gradient-gold:    linear-gradient(in oklch 135deg, oklch(55% 0.14 80), oklch(57% 0.13 78));

  /* Shadows — navy-tinted */
  --shadow-sm: 0 1px 3px oklch(28% 0.03 250 / 0.08);
  --shadow-md: 0 4px 12px oklch(28% 0.03 250 / 0.1);
  --shadow-lg: 0 8px 30px oklch(28% 0.03 250 / 0.12);

  /* Spacing — more generous */
  --section-gap: clamp(4rem, 8vw, 7rem);
}

/* ─── 2. Typography Refinement ──────────────── */
[data-theme="fisch-lang"] {
  font-variant-ligatures: common-ligatures contextual;
}

[data-theme="fisch-lang"] h1,
[data-theme="fisch-lang"] h2,
[data-theme="fisch-lang"] h3 {
  text-wrap: balance;
  letter-spacing: -0.02em;
  color: var(--color-primary);
  hyphens: manual;
  -webkit-hyphens: manual;
}

[data-theme="fisch-lang"] p {
  text-wrap: pretty;
  hyphens: auto;
  -webkit-hyphens: auto;
}

/* Hero title: extra large, tight tracking */
[data-theme="fisch-lang"] .hero__title {
  letter-spacing: -0.03em;
  line-height: 1.05;
  font-weight: 800;
}

/* ─── 3. Navigation ─────────────────────────── */
[data-theme="fisch-lang"] .nav {
  position: sticky;
  top: 0;
  z-index: var(--z-nav);
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
  transition: box-shadow 0.3s ease, background 0.3s ease;
}

[data-theme="fisch-lang"] .nav.is-scrolled {
  box-shadow: var(--shadow-md);
  background: oklch(97% 0.005 80 / 0.95);
  backdrop-filter: blur(12px);
  border-bottom-color: transparent;
}

[data-theme="fisch-lang"] .nav__link {
  color: var(--color-text);
  font-weight: 500;
  transition: color 0.2s ease;
}

[data-theme="fisch-lang"] .nav__link:hover,
[data-theme="fisch-lang"] .nav__link.is-active {
  color: var(--color-secondary-dark);
}

/* Hamburger-Breakpoint höher setzen (Logo + 6 Links + CTA brauchen ~1050px) */
@media (max-width: 1080px) {
  [data-theme="fisch-lang"] .nav__toggle {
    display: flex;
  }
  [data-theme="fisch-lang"] .nav__links {
    position: fixed;
    top: 0;
    right: -100%;
    width: 80%;
    max-width: 320px;
    height: 100dvh;
    flex-direction: column;
    justify-content: center;
    gap: var(--space-7);
    background: var(--color-bg);
    padding: var(--space-8);
    transition: right var(--duration-normal) var(--ease-out);
    border-left: 1px solid var(--color-border);
  }
  [data-theme="fisch-lang"] .nav__links.is-open {
    right: 0;
  }
  [data-theme="fisch-lang"] .nav__link {
    font-size: var(--text-lg);
  }
  [data-theme="fisch-lang"] .nav__cta {
    margin-top: var(--space-4);
  }
}

/* ─── 4. Hero Fullbleed ─────────────────────── */
[data-theme="fisch-lang"] .hero--fullbleed {
  min-height: 90vh;
}

/* Left-aligned layout override (engine centers by default) */
[data-theme="fisch-lang"] .hero--fullbleed .hero__grid {
  text-align: left;
  justify-items: start;
}

[data-theme="fisch-lang"] .hero--fullbleed .hero__grid-content {
  position: relative;
  z-index: 3;
  padding: clamp(4rem, 10vw, 8rem) var(--container-padding);
  max-width: 38rem;
}

[data-theme="fisch-lang"] .hero--fullbleed .hero__title {
  color: #fff;
  text-shadow: 0 2px 30px oklch(15% 0.05 250 / 0.6);
}

[data-theme="fisch-lang"] .hero--fullbleed .hero__subtitle {
  color: oklch(92% 0.01 80);
  text-shadow: 0 1px 15px oklch(15% 0.05 250 / 0.5);
  font-size: clamp(1.05rem, 1.5vw, 1.25rem);
  max-width: 40ch;
  margin-inline: 0;
}

[data-theme="fisch-lang"] .hero--fullbleed .badge {
  background: oklch(55% 0.18 45 / 0.2);
  backdrop-filter: blur(12px);
  border: 1px solid oklch(62% 0.16 45 / 0.5);
  color: #fff;
  font-weight: 600;
  letter-spacing: 0.05em;
  padding: 0.4em 1em;
}

/* Overlay: absolute within hero__grid-visual */
[data-theme="fisch-lang"] .hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(
    to right,
    oklch(18% 0.05 250 / 0.88) 0%,
    oklch(18% 0.05 250 / 0.55) 45%,
    oklch(18% 0.05 250 / 0.1) 100%
  );
}

/* ─── 5. Buttons ────────────────────────────── */
[data-theme="fisch-lang"] .btn--gold {
  background: var(--gradient-gold);
  color: #fff;
  font-weight: 650;
  border: none;
  padding: 0.7em 1.6em;
  transition: filter 0.2s ease, transform 0.2s ease;
}

[data-theme="fisch-lang"] .btn--gold:hover {
  filter: brightness(1.1);
  transform: translateY(-2px);
  box-shadow: 0 4px 16px oklch(55% 0.14 80 / 0.3);
}

[data-theme="fisch-lang"] .btn--warm {
  background: linear-gradient(in oklch 135deg, oklch(55% 0.18 45), oklch(58% 0.17 44));
  color: #fff;
  font-weight: 650;
  border: none;
  padding: 0.7em 1.6em;
  transition: filter 0.2s ease, transform 0.2s ease;
}

[data-theme="fisch-lang"] .btn--warm:hover {
  filter: brightness(1.1);
  transform: translateY(-2px);
  box-shadow: 0 4px 16px oklch(55% 0.18 45 / 0.3);
}

[data-theme="fisch-lang"] .btn--outline {
  border: 2px solid oklch(95% 0.01 80 / 0.6);
  color: #fff;
  font-weight: 500;
  padding: 0.65em 1.5em;
}

[data-theme="fisch-lang"] .btn--outline:hover {
  background: oklch(99% 0.01 80 / 0.12);
  border-color: oklch(95% 0.01 80 / 0.9);
}

/* Non-hero outline buttons (dark bg) */
[data-theme="fisch-lang"] .section--alt .btn--outline,
[data-theme="fisch-lang"] main > section:not(.hero--fullbleed):not(.cta-band) .btn--outline {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

[data-theme="fisch-lang"] main > section:not(.hero--fullbleed):not(.cta-band) .btn--outline:hover {
  background: oklch(28% 0.06 250 / 0.06);
}

/* ─── 6. Section Spacing ────────────────────── */
[data-theme="fisch-lang"] main > section,
[data-theme="fisch-lang"] main > article,
[data-theme="fisch-lang"] main > div {
  padding-block: var(--section-gap);
}

/* Remove double-padding from hero + subpage-hero */
[data-theme="fisch-lang"] .hero--fullbleed,
[data-theme="fisch-lang"] .subpage-hero {
  padding-block: 0;
}

/* Section headers */
[data-theme="fisch-lang"] main h1 {
  font-size: clamp(2.5rem, 5vw, 4rem);
  margin-bottom: 0.5em;
}

[data-theme="fisch-lang"] main h2 {
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  margin-bottom: 0.4em;
}

/* ─── 7. Events List ────────────────────────── */
[data-theme="fisch-lang"] .event-date {
  color: var(--color-secondary-dark);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--text-base);
  width: 11rem;
  flex-shrink: 0;
}

[data-theme="fisch-lang"] .event-row {
  padding: 1rem 0;
  border-bottom: 1px solid var(--color-border);
  display: flex;
  gap: 1.5rem;
  align-items: baseline;
}

[data-theme="fisch-lang"] .event-row:last-child {
  border-bottom: none;
}

[data-theme="fisch-lang"] .event-row strong {
  color: var(--color-text);
  font-weight: 650;
}

/* ─── 8. Tradition Teaser ───────────────────── */
[data-theme="fisch-lang"] #tradition img {
  border-radius: var(--img-radius);
  box-shadow: var(--shadow-lg);
}

/* ─── 9. Cards ──────────────────────────────── */
[data-theme="fisch-lang"] .card {
  border: 1px solid var(--color-border);
  border-radius: var(--card-radius);
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

[data-theme="fisch-lang"] .card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-warm-light);
}

/* ─── 10. Sections — Alt Background ─────────── */
[data-theme="fisch-lang"] .section--alt {
  background: var(--color-bg-alt);
}

/* ─── 11. CTA Band — FIXED CONTRAST ─────────── */
[data-theme="fisch-lang"] .cta-band {
  background: var(--gradient-primary);
  color: #fff;
  padding: var(--section-gap) 0;
  text-align: center;
}

[data-theme="fisch-lang"] .cta-band h2 {
  color: #fff;
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
}

[data-theme="fisch-lang"] .cta-band p {
  color: oklch(85% 0.01 80);
  font-size: clamp(1rem, 1.3vw, 1.15rem);
}

[data-theme="fisch-lang"] .cta-band a.btn {
  color: #fff;
}

[data-theme="fisch-lang"] .cta-band a.btn--outline {
  color: #fff;
  border-color: oklch(90% 0.01 80 / 0.5);
}

[data-theme="fisch-lang"] .cta-band a.btn--outline:hover {
  background: oklch(99% 0.01 80 / 0.12);
  border-color: #fff;
}

/* ─── 12. Footer ────────────────────────────── */
[data-theme="fisch-lang"] .footer--primary {
  background: var(--color-primary-dark);
  color: oklch(82% 0.01 240);
  padding-block: clamp(3rem, 5vw, 5rem) 1.5rem;
}

[data-theme="fisch-lang"] .footer--primary h3 {
  color: oklch(93% 0.01 240);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 700;
  margin-bottom: 1rem;
}

[data-theme="fisch-lang"] .footer--primary a {
  color: oklch(82% 0.01 240);
  transition: color 0.2s ease;
}

[data-theme="fisch-lang"] .footer--primary p,
[data-theme="fisch-lang"] .footer--primary a {
  line-height: 2;
}

[data-theme="fisch-lang"] .footer--primary a:hover {
  color: #fff;
}

[data-theme="fisch-lang"] .footer--primary .footer__text {
  color: oklch(80% 0.01 240);
  font-size: var(--text-sm);
  line-height: 2;
}

[data-theme="fisch-lang"] .footer__bottom {
  border-top: 1px solid oklch(30% 0.03 250);
  padding-top: 1.5rem;
  margin-top: 2rem;
  color: oklch(52% 0.01 250);
  font-size: 0.85rem;
}

[data-theme="fisch-lang"] .footer--primary .nav__logo-img {
  filter: brightness(0) invert(1);
}

/* ─── 13. Timeline (Geschichte) ─────────────── */
[data-theme="fisch-lang"] .timeline {
  position: relative;
  padding-left: 2.5rem;
  max-width: 42rem;
}

[data-theme="fisch-lang"] .timeline::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(in oklch to bottom, oklch(55% 0.14 80), oklch(45% 0.1 80));
}

[data-theme="fisch-lang"] .timeline__item {
  position: relative;
  padding-bottom: 2.5rem;
}

[data-theme="fisch-lang"] .timeline__dot {
  position: absolute;
  left: calc(-2.5rem - 6px);
  top: 6px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: oklch(55% 0.14 80);
  border: 3px solid var(--color-bg);
  box-shadow: 0 0 0 2px oklch(55% 0.14 80);
}

[data-theme="fisch-lang"] .timeline__year {
  color: var(--color-secondary-dark);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(1.3rem, 2vw, 1.6rem);
  margin-bottom: 0.25rem;
}

[data-theme="fisch-lang"] .timeline__item h3 {
  font-size: clamp(1.1rem, 1.5vw, 1.3rem);
  margin-bottom: 0.35rem;
}

[data-theme="fisch-lang"] .timeline__item p {
  color: var(--color-text-muted);
  line-height: 1.65;
}

/* ─── 14. Referenz-Logos ────────────────────── */
[data-theme="fisch-lang"] .logo-row {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 3rem;
  align-items: center;
  justify-content: center;
  padding: 1rem 0;
}

[data-theme="fisch-lang"] .logo-row span {
  color: var(--color-text-muted);
  opacity: 0.7;
  transition: opacity 0.3s ease, color 0.3s ease;
}

[data-theme="fisch-lang"] .logo-row:hover span {
  opacity: 1;
  color: var(--color-text);
}

/* ─── 15. Kontakt-Formular ──────────────────── */
[data-theme="fisch-lang"] input,
[data-theme="fisch-lang"] textarea,
[data-theme="fisch-lang"] select {
  border: 1px solid var(--color-border);
  background: var(--color-bg-card);
  border-radius: var(--btn-radius);
  padding: 0.75em 1em;
  font-size: 1rem;
  color: var(--color-text);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

[data-theme="fisch-lang"] input:focus,
[data-theme="fisch-lang"] textarea:focus,
[data-theme="fisch-lang"] select:focus {
  outline: none;
  border-color: oklch(55% 0.14 80);
  box-shadow: 0 0 0 3px oklch(55% 0.14 80 / 0.15);
}

/* ─── 17. Scroll Progress ───────────────────── */
[data-theme="fisch-lang"] .scroll-progress {
  background: linear-gradient(in oklch 90deg, var(--color-warm), var(--color-secondary));
  height: 3px;
}

/* ─── 18. Focus Styles (Keyboard Navigation) ── */
[data-theme="fisch-lang"] a:focus-visible,
[data-theme="fisch-lang"] button:focus-visible {
  outline: 2px solid var(--color-secondary);
  outline-offset: 3px;
  border-radius: 2px;
}

[data-theme="fisch-lang"] .cta-band a:focus-visible,
[data-theme="fisch-lang"] .hero--fullbleed a:focus-visible {
  outline-color: #fff;
}

/* ─── 19. Text Utilities Override ────────────── */
[data-theme="fisch-lang"] .text-muted {
  color: var(--color-text-muted) !important;
}

[data-theme="fisch-lang"] .text-secondary {
  color: var(--color-secondary-dark) !important;
}

/* ─── 20. Warm Accent Details ──────────────── */
/* "Weiterlesen →" links in cards: warm hover */
[data-theme="fisch-lang"] .card a.text-secondary:hover {
  color: var(--color-warm) !important;
}

/* Timeline dots: warm gradient instead of flat gold */
[data-theme="fisch-lang"] .timeline__dot {
  background: var(--color-warm);
  box-shadow: 0 0 0 2px var(--color-warm);
}

[data-theme="fisch-lang"] .timeline::before {
  background: linear-gradient(in oklch to bottom, var(--color-warm), var(--color-secondary-dark));
}

/* ─── 19. Responsive ────────────────────────── */
@media (max-width: 768px) {
  [data-theme="fisch-lang"] .hero--fullbleed {
    min-height: 70vh;
  }

  /* On mobile: center text, full overlay for readability */
  [data-theme="fisch-lang"] .hero--fullbleed .hero__grid {
    text-align: center;
    justify-items: center;
  }

  [data-theme="fisch-lang"] .hero--fullbleed .hero__subtitle {
    margin-inline: auto;
  }

  [data-theme="fisch-lang"] .hero__overlay {
    background: oklch(18% 0.05 250 / 0.7);
  }

  [data-theme="fisch-lang"] .hero__actions {
    justify-content: center;
  }

  [data-theme="fisch-lang"] .event-row {
    flex-direction: column;
    gap: 0.25rem;
  }

  [data-theme="fisch-lang"] .event-date {
    font-size: 0.85rem;
  }

  /* Smaller card headings on mobile — prevent mid-word breaks on long German words */
  [data-theme="fisch-lang"] .card h2,
  [data-theme="fisch-lang"] .card h3 {
    text-wrap: wrap;
    font-size: clamp(1.25rem, 4.5vw, 1.5rem);
  }

  [data-theme="fisch-lang"] .subpage-hero {
    height: 35vh;
  }

  [data-theme="fisch-lang"] .speisen-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  [data-theme="fisch-lang"] .impressionen-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ─── 21. Subpage Hero (Mini-Hero für Unterseiten) ── */
[data-theme="fisch-lang"] .subpage-hero {
  position: relative;
  width: 100%;
  height: 45vh;
  overflow: hidden;
}

[data-theme="fisch-lang"] .subpage-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

[data-theme="fisch-lang"] .subpage-hero::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 60%;
  background: linear-gradient(to top, oklch(18% 0.05 250 / 0.7), transparent);
  pointer-events: none;
}

[data-theme="fisch-lang"] .subpage-hero__title {
  position: absolute;
  bottom: 1.5rem;
  left: 0;
  right: 0;
  z-index: 2;
  padding-inline: var(--container-padding);
  max-width: var(--container-max, 1200px);
  margin-inline: auto;
}

[data-theme="fisch-lang"] .subpage-hero__title h1 {
  color: #fff;
  text-shadow: 0 2px 20px oklch(15% 0.05 250 / 0.5);
  margin-bottom: 0.25em;
}

[data-theme="fisch-lang"] .subpage-hero__title p {
  color: oklch(88% 0.01 80);
  text-shadow: 0 1px 10px oklch(15% 0.05 250 / 0.4);
  font-size: clamp(1rem, 1.3vw, 1.15rem);
  max-width: 50ch;
}

/* ─── 22. Speisen-Galerie ──────────────────── */
[data-theme="fisch-lang"] .speisen-gallery {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

[data-theme="fisch-lang"] .speisen-gallery img {
  aspect-ratio: 4/3;
}

/* ─── 23. Impressionen-Galerie ─────────────── */
[data-theme="fisch-lang"] .impressionen-gallery {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

[data-theme="fisch-lang"] .impressionen-gallery img {
  aspect-ratio: 3/2;
}

/* ─── 23b. Referenzen-Kunden ─────────────── */
[data-theme="fisch-lang"] .referenzen-clients {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  background: var(--color-border);
  border: 1px solid var(--color-border);
  border-radius: var(--card-radius, 0.5rem);
  overflow: hidden;
}

[data-theme="fisch-lang"] .referenzen-client {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 1.25rem 1.5rem;
  background: var(--color-bg-card);
  transition: background 0.2s ease;
}

[data-theme="fisch-lang"] .referenzen-client:hover {
  background: var(--color-bg-alt);
}

[data-theme="fisch-lang"] .referenzen-client__name {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--color-primary);
}

[data-theme="fisch-lang"] .referenzen-client__event {
  font-size: 0.85rem;
  color: var(--color-warm);
  font-weight: 600;
}

[data-theme="fisch-lang"] .referenzen-client__desc {
  font-size: 0.9rem;
  color: var(--color-text-muted);
  margin-top: 0.25rem;
}

@media (max-width: 768px) {
  [data-theme="fisch-lang"] .referenzen-clients {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 480px) {
  [data-theme="fisch-lang"] .referenzen-clients {
    grid-template-columns: 1fr;
  }
}

/* ─── 24. Timeline mit Bild ───────────────── */
[data-theme="fisch-lang"] .timeline__item--has-image {
  display: flex;
  gap: 2rem;
  align-items: flex-start;
}

[data-theme="fisch-lang"] .timeline__content {
  flex: 1;
  min-width: 0;
}

[data-theme="fisch-lang"] .timeline__image {
  flex-shrink: 0;
  width: 180px;
}

[data-theme="fisch-lang"] .timeline__image img {
  width: 100%;
  height: auto;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: var(--img-radius);
  box-shadow: var(--shadow-md);
}

@media (max-width: 768px) {
  [data-theme="fisch-lang"] .timeline__item--has-image {
    flex-direction: column;
  }

  [data-theme="fisch-lang"] .timeline__image {
    width: 100%;
    max-width: 300px;
  }
}

/* ─── 25. Speisen-Liste ────────────────────── */
[data-theme="fisch-lang"] .speisen-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 0.5rem;
}

[data-theme="fisch-lang"] .speisen-list li {
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text);
  font-size: 1.05rem;
}

[data-theme="fisch-lang"] .speisen-list li:last-child {
  border-bottom: none;
}
