:root,
[data-theme="dark"] {
    --color-white: #fff;
    --ln-logo-color: var(--color-white);
    --color-text-primary: var(--color-white);
    --color-text-accent: #e62e37;

    --color-background-body: #222;
    --color-background-primary: #050505;
    --color-background-secondary: #090909;
    --color-background-tertiary: #0d0d0d;
    --color-background-footer: rgba(0, 0, 0, .16);

    --color-navi-link: #fff;

    --color-surface-primary: #181818;
    --color-surface-secondary: #191818;
    --color-surface-tertiary: #232323;
    --color-surface-quaternary: #2a2c31;
    --color-surface-quinary: #373636;
    --color-surface-muted: #141414;
    --color-surface-divider: #3f3f3f;

    --color-border-primary: #242424;
    --color-border-secondary: #272727;
    --color-border-muted: #2e2e2e;

    --color-brand-primary: #e62e37;
    --color-brand-primary-dark: #a62727;
    --color-brand-secondary: #f31b23;
    --color-brand-hero-start: #4f2323;
    --color-brand-hero-middle: #1e0707;

    --color-overlay-dark: rgba(0,0,0,.9);
    --color-overlay-medium: rgba(0,0,0,.8);
    --color-overlay-soft: rgba(0,0,0,.5);
    --color-overlay-light: rgba(0,0,0,.45);
    --color-overlay-lighter: rgba(0,0,0,.35);
    --color-overlay-minimal: rgba(0,0,0,.3);
    --color-overlay-subtle: rgba(0,0,0,.15);

    --color-shadow-brand: rgb(103 0 0 / 30%);

    --color-border-light: rgba(255,255,255,.06);
    --color-border-light-hover: rgba(255,255,255,.08);
    --color-border-highlight: rgba(255,255,255,.2);

    --color-border-dark: rgba(0,0,0,.55);

    --color-glow-primary: rgba(255,60,40,.55);
    --color-glow-secondary: rgba(255,60,40,.15);


    --hero-surface-stop-1: #5d5d5d;
    --hero-surface-stop-2: #3a3a3a;
    --hero-surface-stop-3: #181818;
    --hero-surface-stop-4: #333;

    --hero-ambient-stop-1: #4a0000;
    --hero-ambient-stop-2: #120000;
    --hero-ambient-stop-3: #250000;

    --hero-line-primary: #ff1a12;
    --hero-line-secondary: #ff4a38;
    --hero-line-hotspot: #ffd9cc;

}

[data-theme="light"] {
    --ln-logo-color: #000;
    --color-text-primary: #1a1a1a;
    --color-text-accent: #c8202a;

    --color-background-body: #f4f4f4;
    --color-background-primary: #ffffff;
    --color-background-secondary: #f7f7f7;
    --color-background-tertiary: #eeeeee;
    --color-background-footer: rgba(255, 255, 255, .75);

    --color-navi-link: #1a1a1a;

    --color-surface-primary: #ffffff;
    --color-surface-secondary: #fafafa;
    --color-surface-tertiary: #f1f1f1;
    --color-surface-quaternary: #ffffff;
    --color-surface-quinary: #f6f6f6;
    --color-surface-muted: #e9e9e9;
    --color-surface-divider: #d0d0d0;

    --color-border-primary: #d8d8d8;
    --color-border-secondary: #cccccc;
    --color-border-muted: #dddddd;

    --color-brand-primary: #e62e37;
    --color-brand-primary-dark: #b9232b;
    --color-brand-secondary: #f31b23;
    --color-brand-hero-start: #fff;
    --color-brand-hero-middle: #ff9e9e;

    --color-overlay-dark: rgba(0,0,0,.35);
    --color-overlay-medium: rgba(0,0,0,.25);
    --color-overlay-soft: rgba(0,0,0,.14);
    --color-overlay-light: rgba(0,0,0,.12);
    --color-overlay-lighter: rgba(0,0,0,.10);
    --color-overlay-minimal: rgba(0,0,0,.08);
    --color-overlay-subtle: rgba(0,0,0,.05);

    --color-shadow-brand: rgb(230 46 55 / 20%);

    --color-border-light: rgba(0,0,0,.08);
    --color-border-light-hover: rgba(0,0,0,.12);
    --color-border-highlight: rgba(255,255,255,.8);

    --color-border-dark: rgba(0,0,0,.12);

    --color-glow-primary: rgba(230,46,55,.35);
    --color-glow-secondary: rgba(230,46,55,.12);

    --hero-surface-stop-1: #ffffff;
    --hero-surface-stop-2: #f0f0f0;
    --hero-surface-stop-3: #dddddd;
    --hero-surface-stop-4: #eeeeee;

    --hero-ambient-stop-1: #ffd6d6;
    --hero-ambient-stop-2: #ffffff;
    --hero-ambient-stop-3: #ffe6e6;

    --hero-line-primary: #e62e37;
    --hero-line-secondary: #c8202a;
    --hero-line-hotspot: #ffffff;
}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html,
body {
    min-height: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    padding: 0;
    color: var(--color-text-primary);
    background: var(--color-background-body);
    font-family: "Titillium Web", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 16px;
}

.slogan {
    padding: 8px 10px;
    font-size: clamp(0.8rem, calc(0.8em + 1.1vw), 1.5rem);
    box-shadow: 0px 6px 11px 5px var(--color-shadow-brand);
    border-bottom: 1px solid var(--color-surface-primary);
}

.logoColor {
    fill: var(--ln-logo-color);
}

.theme-toggle {
    position: absolute;
    top: 15px;
    left: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;

    height: 34px;
    padding: 0 12px;

    border: 1px solid var(--color-border-primary);
    border-radius: 999px;

    background: var(--color-background-secondary);
    color: var(--color-text-primary);

    cursor: pointer;
    z-index: 50;

    transition:
        background .2s ease,
        border-color .2s ease,
        color .2s ease,
        transform .15s ease;
}

.theme-toggle:hover {
    background: var(--color-surface-tertiary);
}

.theme-toggle:active {
    transform: scale(.96);
}

.theme-toggle span {
    font-size: 14px;
    line-height: 1;
}

.text-letztenacht {
    color: var(--color-text-accent);
}
.bg-letztenacht {
    background: var(--color-brand-primary);
}

.d-none {
    display: none;
}

.text-center {
    text-align: center;
}

.text-white {
    color: var(--color-white);
}

.mt-10 {
    margin-top: 10px;
}

.mb-10 {
    margin-bottom: 10px;
}

.mb-15 {
    margin-bottom: 15px;
}

.mb-20 {
    margin-bottom: 20px;
}

.mb-25 {
    margin-bottom: 25px;
}

.font-hh {
    font-weight: 400;
    font-family: 'Hemi Head FourTwentySix', sans-serif;
}

.font-14 {
    font-size: 14px;
}

.container{
    flex: 1;
    width: 100%;
    max-width: 75vw;
    margin:auto;
    padding: 0 20px;
}

.footer {
    margin-top: auto;
    padding: 10px 15px;
    background: var(--color-background-footer);
    border-top: 1px solid var(--color-brand-primary);
    color: var(--color-text-primary);
    text-align: center;
    font-size: 13px;
    margin-top: 40px;
}

.footer ul {
    display: flex;
    justify-content: center;
    align-items: center;
    padding-left: 0;
    list-style: none;
}

.footer li {
    font-style: normal;
    font-weight: 400;
    text-shadow:0 1px 4px var(--color-overlay-dark);
}

.footer li + li::before {
    content: "";
    display: inline-block;
    background-color: var(--color-surface-divider);
    margin: 0 12px;
    height: 15px;
    width: 2px;
    vertical-align: middle;
}

.wrap {
    margin-top: 40px;
    max-width: 100%;
    border-radius: 8px;
    background: var(--color-background-primary);
    box-shadow: 0px 0px 12px 0px var(--color-overlay-soft);
}

/* =========================
   STICKY NAV
========================= */

nav {
    position: sticky;
    top: 0;
    z-index: 500;

    border-radius: 0 0 8px 8px;
}

nav::before {
    content: "";
    position: fixed;

    top: 0;
    left: 0;
    width: 100%;
    height: 44px;
    background: var(--color-brand-primary);
    box-shadow: 0 8px 24px var(--color-overlay-light);
    background: linear-gradient(var(--color-brand-primary), var(--color-brand-primary-dark));
    opacity: 0;
    pointer-events: none;
    z-index: -1;
}

nav.is-sticky::before {
    opacity: 1;
}

/* =========================
   NAV CONTAINER
========================= */

.nav {
    position: relative;
    border-top: 1px solid var(--color-border-dark);
    border-right: none;
    height: 44px;
    overflow: hidden;
    background: linear-gradient(var(--color-brand-primary), var(--color-brand-primary-dark));
}

nav.is-sticky .nav {
    border-radius: 0;
    background: transparent;
    box-shadow: 0 8px 20px var(--color-overlay-lighter);
    animation: none;
    border-top: none;
}

nav.is-sticky .nav > svg {
    display: none;
}

/* =========================
   NAV SVG
========================= */

.nav svg {
    position: absolute;
    inset: 0;

    width: 100%;
    height: 100%;
    display: none;
}

/* =========================
   NAV CONTENT
========================= */

.nav-items {
    position: relative;
    z-index: 2;

    display: flex;
    align-items: center;
    font-size: 16px;

    height: 100%;
    color: var(--color-text-primary);
    text-shadow: 0 1px 4px var(--color-overlay-dark);
}

.nav-item {
    display: flex;
    align-items: center;
    height: 100%;
    padding: 0 18px;
    border-right: 1px solid var(--color-border-light);

}

.nav-right {
    margin-left: auto;
    padding-right: 16px;
}

.nav-item a,
.nav-right a {
    color: var(--color-white);
    text-decoration: none;
}

.nav-toggle {
    display: none;
    position: relative;
    z-index: 10;
    width: 44px;
    height: 44px;
    margin-left: auto;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.nav-toggle span {
    display: block;
    width: 24px;
    height: 2px;
    margin: 5px auto;
    background: var(--color-white);
    box-shadow: 0 1px 4px var(--color-overlay-medium);
    transition: .25s ease;
}

@media (max-width: 700px) {
    .nav {
        min-height: 44px;
        height: auto;
    }

    .nav-toggle {
        display: block;
        position: absolute;
        top: 0;
        right: 0;
    }

    .nav-items {
        display: flex;
        flex-wrap: wrap;
        align-items: stretch;
        height: auto;
        padding-right: 44px;
        background: transparent;
    }

    .nav-item,
    .nav-right {
        display: none;
    }

    .nav-item.mobile-visible {
        display: flex;
        height: 44px;
        align-items: center;
        justify-content: center;
        padding: 0 14px;
        border-right: 1px solid var(--color-border-light-hover);
    }

    nav.is-sticky .nav.is-open,
    nav .nav.is-open {
        border-right: 1px solid var(--color-border-light);
        border-bottom: 1px solid var(--color-border-light);
        border-left: 1px solid var(--color-border-light);
    }

    .nav.is-open .nav-items {
        padding-right: 0;
        padding-top: 44px;
        background: transparent;
    }

    .nav.is-open .nav-items a {
        color: var(--color-navi-link);
    }

    .nav.is-open .nav-item,
    .nav.is-open .nav-right {
        display: flex;
        width: 100%;
        height: 44px;
        justify-content: center;
        align-items: center;
        border-right: 0;
        border-top: 1px solid var(--color-border-light);
        background: var(--color-background-secondary);
    }

    .nav.is-open .nav-toggle span:nth-child(1) {
        transform: translateY(7px) rotate(45deg);
    }

    .nav.is-open .nav-toggle span:nth-child(2) {
        opacity: 0;
    }

    .nav.is-open .nav-toggle span:nth-child(3) {
        transform: translateY(-7px) rotate(-45deg);
    }
}

/* HERO */

.hero .logo{
    position: absolute;
    text-align: right;
    right: 20px;
    top: 20px;
    z-index: 50;
}

.hero .logo svg {
    width: 189px;
    max-width: 100%;
    height: auto;
    display: block;
    filter: drop-shadow( 5px 3px 12px rgba(230, 46, 55, 0.3));
}

.hero{
    height:300px;
    position:relative;
    overflow:hidden;
    border-radius:8px 8px 0 0;
    background: var(--color-background-primary);
    background: linear-gradient(119deg, var(--color-brand-hero-start), var(--color-brand-hero-middle), var(--color-background-primary));

}

.hero > svg {
    width: 100%;
    height: 100%;
    display: block;
    filter: drop-shadow( -3px -3px 5px rgba(0, 0, 0, 0.2));
    z-index: 1;
}

@media (max-width: 800px) {
    .hero{
        height:222px;
    }
    .hero .logo {
        right: 30px;
        top: 25px;
        text-align: right;
    }

    .hero .logo svg {
        width: 160px;
        height: auto;
        margin: 0 auto;
    }

    .hero > svg {
        width: auto;
        min-width: 100%;
        height: 100%;
        margin: 0 auto;
    }
}

.hero {
    overflow: hidden;
    border-radius: 8px 8px 0 0;
}

.hero-surface-stop-1 { stop-color: var(--hero-surface-stop-1); }
.hero-surface-stop-2 { stop-color: var(--hero-surface-stop-2); }
.hero-surface-stop-3 { stop-color: var(--hero-surface-stop-3); }
.hero-surface-stop-4 { stop-color: var(--hero-surface-stop-4); }

.hero-ambient-stop-1 { stop-color: var(--hero-ambient-stop-1); }
.hero-ambient-stop-2 { stop-color: var(--hero-ambient-stop-2); }
.hero-ambient-stop-3 { stop-color: var(--hero-ambient-stop-3); }

.hero-line-inner,
.hero-line-wulst,
.hero-line-wide {
    stroke: var(--hero-line-primary);
}

.hero-line-main {
    stroke: var(--hero-line-secondary);
}

.hero-line-hotspot {
    stroke: var(--hero-line-hotspot);
}

.nav {
    border-radius: 0 0 8px 8px;
}

/* CONTENT */

.boxes{
    margin-top: 20px;
    display:grid;
    grid-template-columns:1fr 2.3fr 1fr;
    gap:6px;
    padding:6px;
    background: var(--color-background-tertiary);
}

.box{
    height:56px;
    background: var(--color-surface-primary);
    border:1px solid var(--color-border-primary);
    border-radius:3px;
}

.ln-outer-box hr {
    border-color: var(--color-border-muted);
}

.ln-border-box {
  border-radius: 8px;
  border:1px solid var(--color-border-primary);
  padding: 12px;
}

.ln-outer-box {
    margin-top: 30px;
    padding: 12px;
    border-radius: 8px;
    background: linear-gradient(180deg, var(--color-surface-primary), var(--color-surface-primary));
    box-shadow:
    0 2px 10px var(--color-overlay-soft),
    0 2px 1px var(--color-overlay-subtle)
}

.ln-inner-box {
  border: 1px solid transparent;
  border-radius: 8px;
  background:
  linear-gradient(180deg, var(--color-surface-quaternary), var(--color-surface-quinary)) padding-box,
  linear-gradient(180deg, var(--color-border-muted), var(--color-surface-tertiary)) border-box;
  box-shadow:
  inset 0 2px 0 var(--color-border-highlight),
  inset 0 -2px 6px var(--color-overlay-minimal),
  0 8px 14px var(--color-overlay-subtle);
  overflow: hidden;
}

.ln-box-header {
  padding: 10px 15px;
  font-weight: bold;
  color: var(--color-text-primary);
  background: linear-gradient(180deg, var(--color-surface-tertiary), var(--color-surface-tertiary));
  text-shadow: 0 2px 4px var(--color-overlay-medium);
  border-bottom: 1px solid var(--color-border-secondary);
}

.ln-box-body {
  padding: 15px;
  color: var(--color-text-primary);
  background: linear-gradient(180deg, var(--color-surface-secondary), var(--color-surface-secondary));
}

.ln-register {
  position: absolute;
  left: 5%;
  bottom: 60px;
  z-index: 2;
  color: var(--color-text-primary);
  font-size: 13px;
  line-height: 1;
  transform: rotate(-10deg);
  text-shadow: 0 2px 3px var(--color-background-primary);
  text-align: center;
  font-weight: 300;
  text-decoration: none;
}

.ln-register strong {
  display: block;
  font-weight: 600;
  font-size: 25px;
}

@media(max-width:800px){
    .ln-register {
        left: 30px;
        bottom: 40px;
    }
}

.row{
    display:grid;
    grid-template-columns:repeat(12,minmax(0,1fr));
    gap:20px;
}

.col-1{grid-column:span 1;}
.col-2{grid-column:span 2;}
.col-3{grid-column:span 3;}
.col-4{grid-column:span 4;}
.col-5{grid-column:span 5;}
.col-6{grid-column:span 6;}
.col-7{grid-column:span 7;}
.col-8{grid-column:span 8;}
.col-9{grid-column:span 9;}
.col-10{grid-column:span 10;}
.col-11{grid-column:span 11;}
.col-12{grid-column:span 12;}

@media(max-width:900px){
    .row{ grid-template-columns:1fr; }
    [class*="col-"]{ grid-column:span 1; }
}

/* ── PULSE ANIMATIONS ── */

@keyframes pulseWulst {
    0%   { opacity: 1;    }
    45%  { opacity: 0.55; }
    100% { opacity: 1;    }
}

@keyframes pulseWide {
    0%   { opacity: 1;    }
    50%  { opacity: 0.45; }
    100% { opacity: 1;    }
}

@keyframes pulseLine {
    0%   { opacity: 1;    }
    50%  { opacity: 0.72; }
    100% { opacity: 1;    }
}

@keyframes pulseHot {
    0%   { opacity: 0.8;  }
    40%  { opacity: 0.25; }
    100% { opacity: 0.8;  }
}

@keyframes pulseNav {
    0%   { opacity: 1;    }
    50%  { opacity: 0.65; }
    100% { opacity: 1;    }
}

@keyframes pulseBorder {
    0%   { box-shadow: inset 0 1px 0 var(--color-glow-primary); }
    50%  { box-shadow: inset 0 1px 0 var(--color-glow-secondary); }
    100% { box-shadow: inset 0 1px 0 var(--color-glow-primary); }
}

.glow-wulst {
    animation: pulseWulst 3.2s ease-in-out infinite;
}
.glow-wide {
    animation: pulseWide 3.2s ease-in-out infinite;
    animation-delay: 0.4s;
}
.glow-line {
    animation: pulseLine 3.2s ease-in-out infinite;
    animation-delay: 0.1s;
}
.glow-hot {
    animation: pulseHot 3.2s ease-in-out infinite;
    animation-delay: 0.7s;
}
.glow-nav {
    animation: pulseNav 3.2s ease-in-out infinite;
    animation-delay: 0.2s;
}
.nav {
    animation: pulseBorder 3.2s ease-in-out infinite;
}

@media (max-width: 1600px) {
    .container {
        max-width: 90vw;
    }
}
@media (max-width: 1200px) {
    .container {
        max-width: 100%;
    }
}

@media (max-width: 600px) {
    .container {
        padding: 0 12px;
    }

    .slogan {
        line-height: 1.2;
    }

    .wrap {
        margin-top: 20px;
    }

    .hero {
        height: 220px;
    }

    .hero .logo {
        right: 14px;
        top: 18px;
    }

    .hero .logo svg {
        width: 150px;
    }

    .nav {
        height: auto;
        min-height: 44px;
    }

    .nav svg {
        height: 100%;
    }

    .nav-items {
        flex-wrap: wrap;
        align-items: stretch;
    }

    .nav-item {
        height: 44px;
        flex: auto;
        justify-content: center;
        padding: 0 10px;
        font-size: 15px;
    }

    .nav-right {
        width: 100%;
        margin-left: 0;
        padding: 8px 12px;
        text-align: center;
        font-size: 13px;
    }

    .ln-outer-box {
        margin-top: 20px;
        padding: 10px;
    }

    .ln-border-box,
    .ln-box-body {
        padding: 12px;
    }

    .footer ul {
        flex-wrap: wrap;
        gap: 6px 0;
    }

    .footer li {
        flex: 0 0 auto;
        line-height: 1.6;
    }

    .footer li + li::before {
        margin: 0 8px;
    }
}

@media (max-width: 420px) {
    .footer ul {
        flex-direction: column;
        gap: 4px;
    }

    .footer li + li::before {
        display: none;
    }
}


.ln-header {
  position: relative;
  overflow: hidden;
  background:
  linear-gradient(180deg, transparent 0 40%, var(--color-brand-secondary) 41%, var(--color-surface-divider) 44%, var(--color-surface-muted) 68%);
}