/* ==========================================================
   KeNaKo Festival Theme – Design System
   Logo-Farben: KE #cc2229 · NA #f7a800 · KO #3aaa35
   ========================================================== */

/* ── Variablen ── */
:root {
  --ke-red:     #cc2229;
  --ke-red-dk:  #a81b20;
  --na-gold:    #f7a800;
  --na-gold-dk: #d4900a;
  --ko-green:   #3aaa35;
  --ko-green-dk:#2d8829;

  --dark:       #1c1a17;
  --dark-2:     #2a2724;
  --sand:       #f5f3ef;
  --text:       #3a3428;
  --muted:      #6b6456;
  --rule:       #e2ddd6;
  --surface:    #ffffff;

  --font-display: 'Oswald', sans-serif;
  --font-body:    'Lora', Georgia, serif;
  --font-ui:      'Oswald', sans-serif;

  --radius:     10px;
  --radius-pill:999px;
  --shadow-sm:  0 2px 8px rgba(0,0,0,.07);
  --shadow-md:  0 4px 20px rgba(0,0,0,.10);
  --shadow-lg:  0 12px 40px rgba(0,0,0,.14);

  --max-w:      1200px;
  --header-h:   84px;
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  scroll-behavior: smooth;
  font-size: 16px;
  /* Note: overflow-x:hidden on html breaks position:fixed children.
     Use a wrapper div for horizontal overflow control instead. */
}
body {
  font-family: var(--font-body);
  color: var(--text);
  background: var(--surface);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;          /* clip doesn't break position:fixed like hidden does */
  max-width: 100vw;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }

/* ── Container ── */
.kenako-container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 2rem;
}

.kenako-main {
  min-height: 60vh;
}

/* ==========================================================
   HEADER (Fallback)
   ========================================================== */

.kenako-header {
  position: sticky;
  top: 0;
  z-index: 100;    /* lower than drawer */
  background: rgba(28,26,23,.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 1px 0 rgba(255,255,255,.06);
}

/* Tricolor bar */
.kenako-header__tricolor,
.kenako-footer__tricolor {
  display: flex;
  height: 4px;
}
.kenako-header__tricolor span:nth-child(1),
.kenako-footer__tricolor span:nth-child(1) { flex: 1; background: var(--ke-red); }
.kenako-header__tricolor span:nth-child(2),
.kenako-footer__tricolor span:nth-child(2) { flex: 1; background: var(--na-gold); }
.kenako-header__tricolor span:nth-child(3),
.kenako-footer__tricolor span:nth-child(3) { flex: 1; background: var(--ko-green); }

.kenako-header__inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: .75rem 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  height: var(--header-h);
  box-sizing: border-box;
  width: 100%;
}

/* Header: volle Breite */
.kenako-header {
  width: 100%;
  /* overflow must NOT be hidden – drawer breaks out of header */
}

/* Logo: linksbündig */
.kenako-header__logo {
  flex-shrink: 0;
  margin-right: auto; /* schiebt nav nach rechts */
}

/* Nav: rechtsbündig */
.kenako-nav {
  margin-left: auto;
}

.kenako-header__logo img,
.kenako-header__logo .custom-logo {
  height: auto;
  max-height: 70px;
  width: auto;
}

/* ── Navigation (Desktop) ── */
.kenako-nav__list {
  display: flex;
  align-items: center;
  gap: .25rem;
  list-style: none;
}

.kenako-nav__item { position: relative; }

.kenako-nav__link {
  display: flex;
  align-items: center;
  gap: .25rem;
  padding: .5rem .85rem;
  color: rgba(255,255,255,.82);
  text-decoration: none;
  font-family: var(--font-ui);
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  border-radius: var(--radius);
  transition: color .2s, background .2s;
}

.kenako-nav__link:hover,
.kenako-nav__link.is-active { color: var(--na-gold); }

.kenako-nav__link.is-active::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: .85rem;
  right: .85rem;
  height: 2px;
  background: var(--na-gold);
  border-radius: 2px;
}

.kenako-nav__arrow { font-size: .6rem; opacity: .7; transition: transform .2s; }
.kenako-nav__item.has-dropdown:hover .kenako-nav__arrow { transform: rotate(180deg); }

/* Dropdown */
.kenako-nav__dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 200px;
  background: var(--dark-2);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius);
  list-style: none;
  padding: .5rem 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity .2s, transform .2s, visibility .2s;
  box-shadow: var(--shadow-lg);
  z-index: 100;
}

.kenako-nav__item.has-dropdown:hover .kenako-nav__dropdown,
.kenako-nav__item.has-dropdown:focus-within .kenako-nav__dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.kenako-nav__dropdown li a {
  display: block;
  padding: .55rem 1.25rem;
  color: rgba(255,255,255,.75);
  text-decoration: none;
  font-family: var(--font-ui);
  font-size: .75rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  transition: color .15s, background .15s;
}

.kenako-nav__dropdown li a:hover {
  color: var(--na-gold);
  background: rgba(255,255,255,.04);
}

/* Burger Button – standardmäßig versteckt, nur Mobile */
.kenako-nav__burger {
  display: none;              /* Desktop: nie sichtbar */
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  cursor: pointer;
  padding: 8px;
  flex-shrink: 0;
  transition: background .2s;
}
.kenako-nav__burger:hover {
  background: rgba(255,255,255,.14);
}

.kenako-nav__burger span {
  display: block;
  width: 24px;
  height: 2px;
  background: rgba(255,255,255,.85);
  border-radius: 2px;
  transition: transform .3s, opacity .3s;
}

.kenako-nav__burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.kenako-nav__burger.is-open span:nth-child(2) { opacity: 0; }
.kenako-nav__burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── Mobile Drawer ── */

/* Overlay */
.kenako-nav__overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.6);
  z-index: 9998;
  backdrop-filter: blur(3px);
  opacity: 0;
  transition: opacity .3s ease;
  pointer-events: none;
}
.kenako-nav__overlay.is-visible {
  display: block;
  opacity: 1;
  pointer-events: auto;
}

/* Drawer – nur auf Mobile sichtbar */
.kenako-nav__mobile {
  /* Versteckt auf Desktop */
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  width: min(320px, 85vw);
  max-width: 100vw;          /* nie breiter als der Viewport */
  height: 100dvh;
  height: 100vh;             /* Fallback für ältere Browser */
  background: var(--dark);
  z-index: 9999;
  transform: translateX(100%);
  transition: transform .35s cubic-bezier(.4,0,.2,1);
  flex-direction: column;
  overflow: hidden;
  box-shadow: -4px 0 32px rgba(0,0,0,.4);
}

/* Nur auf Mobile anzeigen */
@media (max-width: 900px) {
  .kenako-nav__mobile {
    display: flex;
  }
}

.kenako-nav__mobile.is-open {
  transform: translateX(0);
}

/* Inner scrollable area */
.kenako-nav__mobile-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow-y: auto;
  overscroll-behavior: contain;
}

/* Close button */
.kenako-nav__mobile-close {
  align-self: flex-end;
  margin: 1.25rem 1.25rem .5rem;
  width: 36px; height: 36px;
  background: rgba(255,255,255,.08);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  transition: background .2s;
}
.kenako-nav__mobile-close:hover { background: rgba(255,255,255,.15); }
.kenako-nav__mobile-close span {
  display: block;
  position: absolute;
  width: 16px; height: 2px;
  background: #fff;
  border-radius: 2px;
  top: 50%; left: 50%;
}
.kenako-nav__mobile-close span:nth-child(1) { transform: translate(-50%, -50%) rotate(45deg); }
.kenako-nav__mobile-close span:nth-child(2) { transform: translate(-50%, -50%) rotate(-45deg); }

/* Nav list */
.kenako-nav__mobile-list {
  list-style: none;
  padding: .5rem 0;
  flex: 1;
}

.kenako-nav__mobile-list li a {
  display: flex;
  align-items: center;
  padding: 1rem 1.75rem;
  color: rgba(255,255,255,.82);
  text-decoration: none;
  font-family: var(--font-ui);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-bottom: 1px solid rgba(255,255,255,.05);
  transition: color .2s, background .2s;
}

.kenako-nav__mobile-list li a:hover,
.kenako-nav__mobile-list li.current-menu-item > a {
  color: var(--na-gold);
  background: rgba(255,255,255,.04);
}

.kenako-nav__mobile-list .sub-menu {
  background: rgba(0,0,0,.2);
  list-style: none;
}
.kenako-nav__mobile-list .sub-menu li a {
  padding-left: 2.75rem;
  font-size: .85rem;
  opacity: .8;
}

/* Drawer Footer */
.kenako-nav__mobile-footer {
  padding: 1.5rem 1.75rem;
  border-top: 1px solid rgba(255,255,255,.07);
  margin-top: auto;
}

.kenako-nav__mobile-tricolor {
  display: flex;
  height: 3px;
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 1rem;
}
.kenako-nav__mobile-tricolor span:nth-child(1) { flex:1; background: var(--ke-red); }
.kenako-nav__mobile-tricolor span:nth-child(2) { flex:1; background: var(--na-gold); }
.kenako-nav__mobile-tricolor span:nth-child(3) { flex:1; background: var(--ko-green); }

.kenako-nav__mobile-copy {
  font-family: var(--font-ui);
  font-size: .65rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.25);
}

/* ==========================================================
   FOOTER (Fallback)
   ========================================================== */

.kenako-footer {
  background: var(--dark);
}

.kenako-footer__inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 3rem 2rem;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 3rem;
  flex-wrap: wrap;
}

.kenako-footer__brand img,
.kenako-footer__brand .custom-logo { height: 54px; width: auto; margin-bottom: 1rem; }

.kenako-footer__brand p {
  font-size: .82rem;
  color: rgba(255,255,255,.45);
  max-width: 280px;
  line-height: 1.6;
}

.kenako-footer__nav-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

.kenako-footer__nav-list a {
  color: rgba(255,255,255,.6);
  text-decoration: none;
  font-family: var(--font-ui);
  font-size: .78rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  transition: color .2s;
}

.kenako-footer__nav-list a:hover { color: var(--na-gold); }

.kenako-footer__bottom {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 1.25rem 2rem;
  border-top: 1px solid rgba(255,255,255,.07);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}

.kenako-footer__bottom span {
  font-family: var(--font-ui);
  font-size: .7rem;
  letter-spacing: .06em;
  color: rgba(255,255,255,.35);
  text-transform: uppercase;
}

.kenako-footer__links {
  display: flex;
  gap: 1.5rem;
}

.kenako-footer__links a {
  font-family: var(--font-ui);
  font-size: .7rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255,255,255,.35);
  text-decoration: none;
  transition: color .2s;
}

.kenako-footer__links a:hover { color: var(--na-gold); }

/* ==========================================================
   ELEMENTOR OVERRIDES & GLOBAL STYLES
   ========================================================== */

/* Elementor: volle Breite ohne Padding-Overflow */
.elementor-section.elementor-section-full_width { padding-left: 0 !important; padding-right: 0 !important; }

/* Elementor Heading-Widget – Farben */
.e-color-red    { color: var(--ke-red)   !important; }
.e-color-gold   { color: var(--na-gold)  !important; }
.e-color-green  { color: var(--ko-green) !important; }

/* ==========================================================
   GLOBALE KOMPONENTEN
   ========================================================== */

/* Buttons */
.kenako-btn,
.elementor-button {
  font-family: var(--font-ui) !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
}

.kenako-btn-primary {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .85rem 2.25rem;
  background: var(--ke-red); color: #fff;
  font-family: var(--font-ui); font-size: .82rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase; text-decoration: none;
  border-radius: var(--radius-pill);
  transition: background .2s, transform .15s;
  box-shadow: 0 4px 16px rgba(204,34,41,.35);
  border: none; cursor: pointer;
}
.kenako-btn-primary:hover { background: var(--ke-red-dk); transform: translateY(-2px); color: #fff; }

.kenako-btn-gold {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .85rem 2.25rem;
  background: var(--na-gold); color: var(--dark);
  font-family: var(--font-ui); font-size: .82rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase; text-decoration: none;
  border-radius: var(--radius-pill);
  transition: background .2s, transform .15s;
  border: none; cursor: pointer;
}
.kenako-btn-gold:hover { background: var(--na-gold-dk); transform: translateY(-2px); }

.kenako-btn-outline {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .8rem 2rem;
  background: transparent; color: var(--ke-red);
  font-family: var(--font-ui); font-size: .82rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase; text-decoration: none;
  border: 2px solid var(--ke-red); border-radius: var(--radius-pill);
  transition: background .2s, color .2s, transform .15s;
  cursor: pointer;
}
.kenako-btn-outline:hover { background: var(--ke-red); color: #fff; transform: translateY(-1px); }

.kenako-btn-ghost {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .8rem 2rem;
  background: transparent; color: rgba(255,255,255,.85);
  font-family: var(--font-ui); font-size: .82rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase; text-decoration: none;
  border: 2px solid rgba(255,255,255,.3); border-radius: var(--radius-pill);
  transition: border-color .2s, color .2s, transform .15s;
  cursor: pointer;
}
.kenako-btn-ghost:hover { border-color: #fff; color: #fff; transform: translateY(-1px); }

/* Tricolor Divider */
.kenako-tricolor {
  display: flex;
  height: 4px;
  width: 80px;
  border-radius: 4px;
  overflow: hidden;
  margin: 1.25rem auto;
}
.kenako-tricolor span:nth-child(1) { flex: 1; background: var(--ke-red); }
.kenako-tricolor span:nth-child(2) { flex: 1; background: var(--na-gold); }
.kenako-tricolor span:nth-child(3) { flex: 1; background: var(--ko-green); }

/* Section Label */
.kenako-section-label {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--na-gold);
  margin-bottom: .75rem;
}

/* Page Title Section */
.kenako-page-title {
  background: var(--dark);
  padding: 3.5rem 2rem 3rem;
  text-align: center;
}

.kenako-page-title h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 700;
  color: #fff;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.1;
  margin-bottom: .5rem;
}

.kenako-page-title .kenako-tricolor { margin: 1rem auto 0; }

/* Breadcrumb */
.kenako-breadcrumb {
  font-family: var(--font-ui);
  font-size: .7rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  margin-top: 1rem;
}
.kenako-breadcrumb a { color: rgba(255,255,255,.6); text-decoration: none; }
.kenako-breadcrumb a:hover { color: var(--na-gold); }
.kenako-breadcrumb span { margin: 0 .35rem; opacity: .4; }

/* ==========================================================
   TYPOGRAFIE
   ========================================================== */

.kenako-main h1,
.kenako-main h2,
.kenako-main h3 {
  font-family: var(--font-display);
  line-height: 1.2;
}

.kenako-main p { margin-bottom: 1rem; }

.kenako-main a { color: var(--ke-red); text-decoration: underline; }
.kenako-main a:hover { color: var(--ke-red-dk); }

/* ==========================================================
   IMPRESSUM / DATENSCHUTZ
   ========================================================== */

.kenako-legal {
  max-width: 760px;
  margin: 0 auto;
  padding: 3rem 2rem 5rem;
}

.kenako-legal h2 {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ke-red);
  margin: 2rem 0 .5rem;
}

.kenako-legal h3 {
  font-family: var(--font-display);
  font-size: .9rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 1.25rem 0 .4rem;
}

.kenako-legal p,
.kenako-legal ul { font-size: .95rem; color: var(--text); line-height: 1.8; margin-bottom: .75rem; }

.kenako-legal strong { color: var(--dark); font-weight: 600; }

.kenako-legal a { color: var(--ke-red); }

/* ==========================================================
   RESPONSIVE
   ========================================================== */

@media (max-width: 900px) {
  /* Desktop-Nav ausblenden */
  .kenako-nav { display: none !important; }

  /* Burger einblenden */
  .kenako-nav__burger { display: flex; }

  /* Overlay und Drawer freischalten */
  .kenako-nav__overlay { display: none; } /* wird per JS gesteuert */

  /* Header: Logo links, Burger rechts */
  .kenako-header__inner {
    justify-content: space-between;
  }
  .kenako-header__logo { order: 1; }
  .kenako-nav__burger  { order: 2; margin-left: 0; }
}

/* Ab 901px: Drawer komplett sperren, auch wenn is-open gesetzt */
@media (min-width: 901px) {
  .kenako-nav__mobile {
    display: none !important;
    transform: translateX(100%) !important;
    pointer-events: none !important;
  }
  .kenako-nav__overlay {
    display: none !important;
    pointer-events: none !important;
  }
  .kenako-nav__burger {
    display: none !important;
  }
}

@media (max-width: 600px) {
  :root { --header-h: 60px; }
  .kenako-header__inner { padding: .6rem 1.25rem; }
  .kenako-footer__inner { flex-direction: column; gap: 2rem; }
  .kenako-footer__bottom { flex-direction: column; text-align: center; }
  .kenako-footer__links { justify-content: center; }
  .kenako-container { padding: 0 1.25rem; }
}

/* ==========================================================
   FOOTER – Sponsors (im dunklen Bereich)
   ========================================================== */

/* Sponsors-Block im Dark-Footer */
.kenako-footer__inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 3rem 2rem 2rem;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 3rem;
  flex-wrap: wrap;
  box-sizing: border-box;
  width: 100%;
}

.kenako-footer__bottom {
  max-width: var(--max-w);
  margin: 0 auto;
  box-sizing: border-box;
  width: 100%;
}

.kenako-footer__sponsors-block {
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

.kenako-footer__sponsors-label {
  font-family: var(--font-ui);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
}

.kenako-footer__sponsors-logos {
  display: flex;
  align-items: center;
  gap: 2rem;
  flex-wrap: wrap;
}

.kenako-footer__sponsors-logos img {
  height: 44px;
  width: auto;
  opacity: .5;
  filter: grayscale(30%) brightness(1.4);
  transition: opacity .2s, filter .2s;
}

.kenako-footer__sponsors-logos img:hover {
  opacity: 1;
  filter: none;
}

/* ==========================================================
   SLIDESHOW (Swiper-basiert)
   ========================================================== */

.kenako-slideshow {
  position: relative;
  overflow: hidden;
  background: var(--dark);
}

.kenako-slideshow .swiper { width: 100%; }

.kenako-slideshow .swiper-slide img {
  width: 100%;
  height: 520px;
  object-fit: cover;
  object-position: center;
  display: block;
  opacity: .85;
}

.kenako-slideshow .swiper-button-next,
.kenako-slideshow .swiper-button-prev {
  color: #fff;
  background: rgba(0,0,0,.35);
  width: 44px; height: 44px;
  border-radius: 50%;
  backdrop-filter: blur(4px);
}

.kenako-slideshow .swiper-button-next::after,
.kenako-slideshow .swiper-button-prev::after { font-size: 14px; font-weight: 700; }

.kenako-slideshow .swiper-pagination-bullet { background: #fff; opacity: .6; }
.kenako-slideshow .swiper-pagination-bullet-active { opacity: 1; background: var(--na-gold); }

/* ==========================================================
   VIDEO SEKTION
   ========================================================== */

.kenako-video-section {
  background: var(--dark);
  padding: 5rem 2rem;
  text-align: center;
}

.kenako-video-section__label {
  font-family: var(--font-ui);
  font-size: .72rem; font-weight: 700;
  letter-spacing: .3em; text-transform: uppercase;
  color: var(--na-gold); margin-bottom: .75rem; display: block;
}

.kenako-video-section h2 {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 700; color: #fff;
  letter-spacing: .04em; text-transform: uppercase;
  margin-bottom: 2.5rem;
}

.kenako-video-wrap {
  max-width: 860px;
  margin: 0 auto;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
  aspect-ratio: 16/9;
  position: relative;
}

/* Hochformat (Instagram 9:16) */
.kenako-video-wrap.is-portrait {
  max-width: 380px;
  aspect-ratio: 9/16;
}

.kenako-video-wrap iframe,
.kenako-video-wrap video {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  border: none;
}

@media (max-width: 600px) {
  .kenako-slideshow .swiper-slide img { height: 240px; }
}

/* Footer credit link */
.kenako-footer__credit {
  color: rgba(255,255,255,.4);
  text-decoration: none;
  transition: color .2s;
}
.kenako-footer__credit:hover { color: var(--na-gold); }

/* ==========================================================
   SIDEBAR LAYOUT
   ========================================================== */

.kenako-page-wrap {
  display: flex;
  align-items: flex-start;
  gap: 2.5rem;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 2rem;
}

.kenako-page-wrap .kenako-main { flex: 1; min-width: 0; }

.kenako-sidebar {
  flex: 0 0 280px;
  width: 280px;
}

/* Widget-Styles */
.kenako-widget { margin-bottom: 2rem; }

.kenako-widget__title {
  font-family: var(--font-display);
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ke-red);
  margin-bottom: 1rem;
  padding-bottom: .5rem;
  border-bottom: 2px solid var(--ke-red);
}

@media (max-width: 768px) {
  .kenako-page-wrap { flex-direction: column; }
  .kenako-sidebar { flex: unset; width: 100%; }
}

/* ==========================================================
   HEADER VARIANTEN
   ========================================================== */

/* Hell */
.kenako-header--light .kenako-nav__link { color: rgba(28,26,23,.8); }
.kenako-header--light .kenako-nav__link:hover,
.kenako-header--light .kenako-nav__link.is-active { color: var(--ke-red); }
.kenako-header--light .kenako-nav__burger span { background: #1c1a17; }

/* Transparent */
.kenako-header--transparent {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: transparent !important;
}
.kenako-header--transparent.is-scrolled {
  background: rgba(28,26,23,.95) !important;
  backdrop-filter: blur(10px);
}

/* ==========================================================
   PAGE TITLE VARIANTEN
   ========================================================== */

.kenako-page-title {
  transition: padding .3s;
}

.kenako-page-title .kenako-breadcrumb {
  font-size: .72rem;
  margin-bottom: .75rem;
  opacity: .75;
}

/* Transparent Header → Seitentitel hat mehr Padding oben */
.kenako-header--transparent ~ .kenako-page-title {
  padding-top: calc(var(--header-h) + 40px);
}

/* Elementor footer link classes (ersetzt inline JS) */
.kenako-footer-link {
  font-family: 'Oswald', sans-serif;
  font-size: .68rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255,255,255,.3);
  text-decoration: none;
  transition: color .2s;
}
.kenako-footer-link:hover { color: #f7a800; }

.kenako-footer-credit {
  color: rgba(255,255,255,.3);
  text-decoration: none;
  transition: color .2s;
}
.kenako-footer-credit:hover { color: #f7a800; }

/* WordPress custom-logo wrapper */
.kenako-header__logo .custom-logo-link {
  display: flex;
  align-items: center;
}
.kenako-header__logo .custom-logo-link img {
  max-height: 70px;
  width: auto;
  height: auto;
}

/* Footer sponsors boxed */
.kenako-footer__sponsors-inner,
.kenako-footer__sponsors-block {
  max-width: var(--max-w);
  margin: 0 auto;
  box-sizing: border-box;
  width: 100%;
}

/* Footer bottom boxed */
.kenako-footer__bottom {
  max-width: var(--max-w);
  margin-left: auto;
  margin-right: auto;
  padding-left: 2rem;
  padding-right: 2rem;
  box-sizing: border-box;
  width: 100%;
}

/* ==========================================================
   SOCIAL MEDIA ICONS
   ========================================================== */

.kenako-social {
  display: flex;
  align-items: center;
  gap: .6rem;
  flex-wrap: wrap;
}

.kenako-social__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.65);
  text-decoration: none;
  transition: background .2s, color .2s, border-color .2s, transform .15s;
  flex-shrink: 0;
}

.kenako-social__link:hover {
  background: var(--ke-red);
  border-color: var(--ke-red);
  color: #fff;
  transform: translateY(-2px);
}

/* Platform-spezifische Hover-Farben */
.kenako-social__link--facebook:hover  { background: #1877f2; border-color: #1877f2; }
.kenako-social__link--instagram:hover { background: linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); border-color: #dc2743; }
.kenako-social__link--youtube:hover   { background: #ff0000; border-color: #ff0000; }
.kenako-social__link--twitter:hover   { background: #000000; border-color: #000000; }
.kenako-social__link--tiktok:hover    { background: #010101; border-color: #69c9d0; }

.kenako-social__link svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* YouTube und TikTok sind filled icons */
.kenako-social__link--youtube svg,
.kenako-social__link--tiktok svg {
  fill: currentColor;
  stroke: none;
}

/* ── Footer-Variante ── */
.kenako-social--footer {
  margin-bottom: 1rem;
}

/* ── Drawer-Variante ── */
.kenako-social--drawer {
  justify-content: center;
  margin-bottom: 1rem;
  padding: .75rem 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
}

.kenako-social--drawer .kenako-social__link {
  width: 40px;
  height: 40px;
}

.kenako-social--drawer .kenako-social__link svg {
  width: 18px;
  height: 18px;
}
