/*
Theme Name: Brauerei Schwelm
Theme URI: https://brauereischwelm.de
Description: Dark Theme für die Brauerei Schwelm – Child Theme von Hello Elementor. Kultur braucht einen Ort.
Author: Brauerei Schwelm e.V.
Author URI: https://brauereischwelm.de
Template: hello-elementor
Version: 1.0.0
Text Domain: brauerei-schwelm
*/

/* ===== TOKENS ===== */
:root {
    --dark: #0A0A0A;
    --dark-2: #111111;
    --dark-3: #181818;
    --dark-border: rgba(255,255,255,0.06);
    --white: #F5F5F5;
    --white-80: rgba(245,245,245,0.8);
    --white-60: rgba(245,245,245,0.6);
    --white-40: rgba(245,245,245,0.35);
    --white-20: rgba(245,245,245,0.15);
    --white-10: rgba(245,245,245,0.08);
    --white-05: rgba(245,245,245,0.04);
    --orange: #E8701A;
    --orange-hover: #D45F0F;
    --orange-glow: rgba(232,112,26,0.35);
    --orange-soft: rgba(232,112,26,0.1);
    --blue: #1B3A5C;
    --green: #34D399;
    --ease: cubic-bezier(0.16, 1, 0.3, 1);
    --font: 'Inter', -apple-system, sans-serif;
    --display: 'Space Grotesk', sans-serif;
    --r: 14px;
    --r-lg: 20px;
}

/* ===== RESET & BASE ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--font);
    background: var(--dark);
    color: var(--white);
    font-size: 17px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}
a { text-decoration: none; color: inherit; }
img { display: block; max-width: 100%; }
button { font-family: var(--font); cursor: pointer; }

.w { max-width: 1200px; margin: 0 auto; padding: 0 28px; }
section { padding: 140px 0; }

/* Override Hello Elementor defaults */
.site-header, .site-footer { display: none !important; }
.site-main { padding: 0 !important; margin: 0 !important; }
.page-content, .entry-content { margin: 0; padding: 0; }
.elementor-page .site-main .entry-content { margin: 0; }

/* ===== ANIMATIONS ===== */
@keyframes fadeUp { from { opacity:0; transform:translateY(50px); } to { opacity:1; transform:translateY(0); } }
@keyframes pulse { 0%,100%{box-shadow:0 0 0 0 var(--orange-glow);} 70%{box-shadow:0 0 0 14px rgba(232,112,26,0);} }
@keyframes marquee { from{transform:translateX(0);} to{transform:translateX(-50%);} }
@keyframes float { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-10px);} }

.reveal {
    opacity: 0; transform: translateY(40px);
    transition: opacity 0.8s var(--ease), transform 0.8s var(--ease);
}
.reveal.v { opacity:1; transform:none; }
.d1 { transition-delay:.1s; }
.d2 { transition-delay:.2s; }
.d3 { transition-delay:.25s; }

/* ===== NAV ===== */
.bs-nav {
    position: fixed; top:0; left:0; right:0; z-index:1000;
    padding: 18px 0;
    transition: all .4s var(--ease);
}
.bs-nav.scrolled {
    background: rgba(10,10,10,0.88);
    backdrop-filter: blur(24px) saturate(160%);
    -webkit-backdrop-filter: blur(24px) saturate(160%);
    padding: 10px 0;
    border-bottom: 1px solid var(--dark-border);
}
.bs-nav .w { display:flex; align-items:center; justify-content:space-between; }
.bs-nav-logo {
    display: flex; align-items: center; gap: 12px;
}
.bs-nav-logo img {
    height: 69px; width: auto;
    background: #fff; padding: 4px 8px; border-radius: 6px;
}
.bs-nav-menu { display:flex; align-items:center; gap:32px; list-style:none; }
.bs-nav-menu a {
    font-size: 0.9rem; font-weight: 500;
    color: var(--white-40);
    transition: color .3s;
}
.bs-nav-menu a:hover,
.bs-nav-menu .current-menu-item a,
.bs-nav-menu .current_page_item a { color: var(--white); }
.bs-nav-cta {
    background: var(--white); color: var(--dark) !important;
    padding: 9px 22px; border-radius: 999px;
    font-weight: 700 !important; font-size: 0.85rem !important;
    transition: all .3s var(--ease);
}
.bs-nav-cta:hover { background: var(--orange); color: #fff !important; transform: scale(1.05); }
.bs-hamburger { display:none; background:none; border:none; padding:8px; }
.bs-hamburger span { display:block; width:22px; height:2px; background:var(--white); margin:5px 0; border-radius:2px; transition: all .3s var(--ease); }

/* Mobile Menu */
.bs-mobile-menu {
    display:none; position:fixed; top:0; left:0; right:0; bottom:0;
    background:rgba(10,10,10,0.96); backdrop-filter:blur(24px);
    z-index:999; padding:120px 28px 40px;
    flex-direction:column; gap:8px;
}
.bs-mobile-menu.open { display:flex; }
.bs-mobile-menu a {
    font-family:var(--display); font-size:1.8rem; font-weight:700;
    color:var(--white-40); padding:12px 0;
    transition:color .3s; border-bottom:1px solid var(--dark-border);
}
.bs-mobile-menu a:hover { color:var(--orange); }

/* ===== BUTTONS ===== */
.btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 15px 34px; border-radius: 999px;
    font-weight: 700; font-size: 0.95rem;
    border: none; transition: all .35s var(--ease);
    letter-spacing: -0.01em; cursor: pointer;
}
.btn-o { background: var(--orange); color: #fff; }
.btn-o:hover { background: var(--orange-hover); transform: translateY(-3px); box-shadow: 0 12px 40px var(--orange-glow); color: #fff; }
.btn-g { background: var(--white-10); color: var(--white); border: 1px solid var(--white-20); }
.btn-g:hover { background: var(--white-20); transform: translateY(-3px); }
.btn-w { background: var(--white); color: var(--dark); }
.btn-w:hover { transform: translateY(-3px); box-shadow: 0 12px 40px rgba(245,245,245,0.12); }
.btn-ol { background: transparent; color: var(--orange); border: 2px solid var(--orange); }
.btn-ol:hover { background: var(--orange); color: #fff; transform: translateY(-3px); }

/* ===== SECTION HELPERS ===== */
.s-tag {
    font-size: 0.75rem; font-weight: 700;
    letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--orange); margin-bottom: 14px;
}
.s-head h2 {
    font-family: var(--display);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700; letter-spacing: -0.03em; line-height: 1.1;
}
.s-head p { margin-top: 14px; font-size: 1.05rem; color: var(--white-40); max-width: 460px; }
.s-top {
    display: flex; justify-content: space-between;
    align-items: flex-end; flex-wrap: wrap; gap: 24px;
    margin-bottom: 56px;
}

/* ===== HERO ===== */
.bs-hero {
    min-height: 100vh;
    display: flex; align-items: flex-end;
    position: relative; overflow: hidden;
    padding: 0;
}
/* Hero Slider */
.bs-hero-slider {
    position: absolute; inset: 0;
}
.bs-hero-slider::after {
    content: '';
    position: absolute; inset: 0; z-index: 1;
    background: linear-gradient(180deg,
        rgba(10,10,10,0.3) 0%,
        rgba(10,10,10,0) 25%,
        rgba(10,10,10,0.5) 60%,
        var(--dark) 100%
    );
    pointer-events: none;
}
.bs-hero-slide {
    position: absolute; inset: 0;
    opacity: 0;
    transition: opacity 1.2s var(--ease);
}
.bs-hero-slide.bs-active { opacity: 1; }
.bs-hero-slide video {
    width: 100%; height: 100%;
    object-fit: cover;
    opacity: 0.45;
    filter: saturate(0.3) contrast(1.1);
}
/* Hero Content Slides */
.bs-hero-content {
    display: none;
}
.bs-hero-content.bs-active {
    display: block;
    animation: fadeUp .6s var(--ease) both;
}
/* Hero Dots */
.bs-hero-dots {
    position: absolute; right: 40px; top: 50%; transform: translateY(-50%);
    z-index: 10;
    display: flex; flex-direction: column; gap: 14px;
}
.bs-hero-dot {
    width: 36px; height: 36px;
    background: none; border: none; cursor: pointer;
    padding: 0; position: relative;
}
.bs-hero-dot::before {
    content: '';
    position: absolute; top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--white-40);
    transition: background .3s var(--ease), transform .3s var(--ease);
}
.bs-hero-dot.bs-active::before,
.bs-hero-dot:hover::before {
    background: var(--orange);
    transform: translate(-50%, -50%) scale(1.2);
}
.bs-dot-ring {
    fill: none; stroke: var(--white-20); stroke-width: 2;
    stroke-dasharray: 100.5; stroke-dashoffset: 100.5;
    transform: rotate(-90deg); transform-origin: center;
    transition: stroke .3s;
}
.bs-hero-dot.bs-active .bs-dot-ring {
    stroke: var(--orange);
    stroke-dashoffset: 0;
    transition: stroke-dashoffset 8s linear, stroke .3s;
}
.bs-hero .w {
    position: relative; z-index: 2;
    padding-top: 200px;
    padding-bottom: 80px;
    width: 100%;
}
.bs-hero-tag {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 0.8rem; font-weight: 600;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--orange);
    margin-bottom: 24px;
    animation: fadeUp .8s var(--ease) both;
}
.bs-hero-tag .dot {
    width: 8px; height: 8px;
    background: var(--orange); border-radius: 50%;
    animation: pulse 2s infinite;
}
.bs-hero h1 {
    font-family: var(--display);
    font-size: clamp(3.2rem, 8vw, 7rem);
    font-weight: 700;
    line-height: 0.95;
    letter-spacing: -0.04em;
    margin-bottom: 28px;
    max-width: 800px;
    animation: fadeUp .8s .15s var(--ease) both;
}
.bs-hero h1 em, .bs-hero .bs-hero-h1 em { font-style: normal; color: var(--orange); }
.bs-hero .bs-hero-h1 {
    font-family: var(--display);
    font-size: clamp(3.2rem, 8vw, 7rem);
    font-weight: 700;
    line-height: 0.95;
    letter-spacing: -0.04em;
    margin-bottom: 28px;
    max-width: 800px;
    animation: fadeUp .8s .15s var(--ease) both;
}
.bs-hero-sub {
    font-size: 1.15rem; color: var(--white-60);
    max-width: 480px; line-height: 1.7;
    margin-bottom: 40px;
    animation: fadeUp .8s .3s var(--ease) both;
}
.bs-hero-actions {
    display: flex; gap: 14px; flex-wrap: wrap;
    animation: fadeUp .8s .45s var(--ease) both;
}

/* Hero Event Bar */
.bs-hero-bar {
    margin-top: 72px;
    background: var(--white-05);
    border: 1px solid var(--dark-border);
    border-radius: var(--r);
    padding: 24px 32px;
    display: flex; align-items: center;
    justify-content: space-between;
    gap: 28px;
    backdrop-filter: blur(16px);
    animation: fadeUp .8s .6s var(--ease) both;
}
.bs-hero-bar-left { display: flex; align-items: center; gap: 24px; }
.bs-hero-bar-date { text-align: center; min-width: 52px; }
.bs-hero-bar-date .day {
    font-family: var(--display);
    font-size: 1.8rem; font-weight: 700; line-height: 1;
    color: var(--orange);
}
.bs-hero-bar-date .mo {
    font-size: 0.72rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--white-40);
}
.bs-hero-bar-sep { width: 1px; height: 44px; background: var(--white-20); }
.bs-hero-bar-info h3 {
    font-family: var(--display);
    font-size: 1.05rem; font-weight: 700; margin-bottom: 3px;
}
.bs-hero-bar-info p { font-size: 0.85rem; color: var(--white-40); }

/* ===== TICKER ===== */
.bs-ticker {
    border-top: 1px solid var(--dark-border);
    border-bottom: 1px solid var(--dark-border);
    padding: 16px 0; overflow: hidden; white-space: nowrap;
}
.bs-ticker-track { display: flex; animation: marquee 35s linear infinite; }
.bs-ticker-item {
    display: inline-flex; align-items: center; gap: 14px;
    padding: 0 44px;
    font-family: var(--display);
    font-size: 0.92rem; font-weight: 600;
    color: var(--white-40); letter-spacing: -0.01em;
}
.bs-ticker-item .dot { width:5px; height:5px; background:var(--orange); border-radius:50%; }

/* ===== EVENT CARDS ===== */
.pills { display: flex; gap: 8px; flex-wrap: wrap; }
.pill {
    padding: 9px 20px; border-radius: 999px;
    border: 1px solid var(--white-10); background: transparent;
    color: var(--white-40); font-size: 0.85rem; font-weight: 600;
    transition: all .3s var(--ease);
}
.pill:hover, .pill.on { background: var(--white); color: var(--dark); border-color: var(--white); }

.e-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }

.ec {
    background: var(--dark-2);
    border: 1px solid var(--dark-border);
    border-radius: var(--r-lg);
    overflow: hidden;
    transition: all .4s var(--ease);
}
.ec:hover { transform: translateY(-6px); border-color: var(--white-20); box-shadow: 0 24px 64px rgba(0,0,0,0.5); }
.ec-img { height: 210px; overflow: hidden; position: relative; }
.ec-img img { width:100%; height:100%; object-fit:cover; object-position:center center; transition: transform .6s var(--ease); filter: saturate(0.7); }
.ec:hover .ec-img img { transform: scale(1.06); filter: saturate(1); }
.ec-badge {
    position: absolute; top:14px; left:14px;
    background: var(--orange); color: #fff;
    padding: 5px 12px; border-radius: 8px;
    font-size: 0.72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.06em; z-index:2;
}
.ec-date {
    position: absolute; top:14px; right:14px;
    background: rgba(10,10,10,0.7); backdrop-filter: blur(10px);
    padding: 8px 12px; border-radius: 8px;
    text-align: center; z-index:2;
}
.ec-date .d { display:block; font-family:var(--display); font-size:1.4rem; font-weight:700; line-height:1; }
.ec-date .m { display:block; font-size:0.65rem; font-weight:600; text-transform:uppercase; letter-spacing:0.08em; color:var(--orange); margin-top:2px; }
.ec-body { padding: 22px 24px; }
.ec-meta { display:flex; gap:14px; font-size:0.8rem; color:var(--white-40); margin-bottom:12px; }
.ec h3 { font-family:var(--display); font-size:1.12rem; font-weight:700; letter-spacing:-0.02em; margin-bottom:8px; line-height:1.3; }
.ec p { font-size:0.9rem; color:var(--white-40); line-height:1.55; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.ec-foot {
    display:flex; align-items:center; justify-content:space-between;
    margin-top:18px; padding-top:14px; border-top:1px solid var(--dark-border);
}
.ec-price { font-weight:700; font-size:0.92rem; }
.ec-link { color:var(--orange); font-weight:700; font-size:0.85rem; display:inline-flex; align-items:center; gap:5px; transition:gap .3s var(--ease); }
.ec-link:hover { gap:10px; }
.e-more { text-align:center; margin-top:52px; }

/* ===== IMAGE STRIP ===== */
.bs-imgstrip {
    display: grid; grid-template-columns: repeat(5,1fr); gap: 4px;
    height: 280px; overflow: hidden;
}
.bs-imgstrip img {
    width:100%; height:100%; object-fit:cover;
    filter: saturate(0.5);
    transition: all .6s var(--ease);
}
.bs-imgstrip img:hover { filter: saturate(1); transform: scale(1.05); }

/* ===== ORT ===== */
.bs-ort { background: var(--dark-2); border-top: 1px solid var(--dark-border); }
.bs-ort-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.bs-ort-img { position: relative; }
.bs-ort-img img { border-radius: var(--r-lg); width:100%; height:500px; object-fit:cover; }
.bs-ort-nrw {
    position: absolute; bottom:-20px; right:-20px;
    background: var(--orange); padding:18px 24px; border-radius:var(--r);
    font-family:var(--display); font-weight:700; font-size:0.9rem; line-height:1.4;
    box-shadow: 0 12px 40px var(--orange-glow);
    animation: float 5s ease-in-out infinite;
}

/* Places grid */
.places { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:36px; }
.place {
    background:var(--white-05); border:1px solid var(--dark-border);
    border-radius:var(--r); padding:18px; text-align:center;
    transition: all .3s var(--ease);
}
.place:hover { border-color:var(--white-20); }
.place.hi { background:var(--orange); border-color:var(--orange); }
.place-ico { font-size:1.5rem; margin-bottom:6px; }
.place-name { font-weight:700; font-size:0.85rem; }
.place-sub { font-size:0.75rem; color:var(--white-40); margin-top:2px; }
.place.hi .place-sub { color:rgba(255,255,255,0.7); }

/* Features */
.feats { list-style:none; display:grid; gap:12px; margin-bottom:32px; }
.feats li { display:flex; align-items:center; gap:12px; font-size:0.95rem; color:var(--white-60); }
.feats .ic {
    width:30px; height:30px; min-width:30px;
    background:var(--orange-soft); border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:0.8rem;
}

/* ===== JOIN ===== */
.bs-join { background:var(--dark); border-top:1px solid var(--dark-border); }
.bs-join-grid { display:grid; grid-template-columns:1.2fr 1fr; gap:72px; align-items:center; }
.benefits { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:36px; }
.bf {
    background:var(--white-05); border:1px solid var(--dark-border);
    border-radius:var(--r); padding:24px;
    transition: all .3s var(--ease);
}
.bf:hover { border-color:var(--orange); transform:translateY(-3px); }
.bf-ico { font-size:1.4rem; margin-bottom:12px; }
.bf h4 { font-weight:700; font-size:0.95rem; margin-bottom:4px; }
.bf p { font-size:0.85rem; color:var(--white-40); line-height:1.5; }

.bs-join-cta {
    background:var(--dark-2); border:1px solid var(--dark-border);
    border-radius:var(--r-lg); padding:52px 44px; text-align:center;
    position:relative; overflow:hidden;
}
.bs-join-cta::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--orange),var(--blue)); }
.bs-join-cta .price { font-family:var(--display); font-size:3.8rem; font-weight:700; color:var(--orange); line-height:1; }
.bs-join-cta .price-label { font-size:0.9rem; color:var(--white-40); margin-bottom:28px; }
.bs-join-cta h3 { font-family:var(--display); font-size:1.5rem; font-weight:700; margin-bottom:10px; }
.bs-join-cta p { color:var(--white-40); font-size:0.92rem; margin-bottom:32px; max-width:280px; margin-left:auto; margin-right:auto; }

/* ===== FÖRDERER ===== */
.bs-foerderer { background:var(--dark-2); border-top:1px solid var(--dark-border); }
.logos { display:flex; flex-wrap:wrap; justify-content:center; gap:12px; margin-bottom:44px; }
.lp {
    background:var(--white-05); border:1px solid var(--dark-border);
    border-radius:999px; padding:12px 28px;
    font-weight:700; font-size:0.85rem; color:var(--white-40); letter-spacing:0.02em;
    transition: all .3s var(--ease);
}
.lp:hover { border-color:var(--orange); color:var(--white); transform:translateY(-2px); }

.f-cats { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:44px; }
.fc {
    background:var(--white-05); border:1px solid var(--dark-border);
    border-radius:var(--r); padding:32px; text-align:center;
    transition: all .3s var(--ease);
}
.fc:hover { border-color:var(--orange); transform:translateY(-4px); }
.fc-ico { font-size:1.8rem; margin-bottom:14px; }
.fc h4 { font-family:var(--display); font-weight:700; font-size:1rem; margin-bottom:6px; }
.fc p { font-size:0.85rem; color:var(--white-40); }

/* ===== NEWSLETTER ===== */
.bs-nl { background:var(--dark); border-top:1px solid var(--dark-border); }
.bs-nl-box { max-width:600px; margin:0 auto; text-align:center; }
.bs-nl-form { display:flex; gap:10px; margin-bottom:12px; }
.bs-nl-form input {
    flex:1; padding:15px 22px;
    border:1px solid var(--white-20); border-radius:999px;
    background:var(--white-05); color:var(--white);
    font-family:var(--font); font-size:0.95rem; outline:none;
    transition: border-color .3s;
}
.bs-nl-form input::placeholder { color:var(--white-40); }
.bs-nl-form input:focus { border-color:var(--orange); }

/* ===== VIDEO CARD ===== */
.bs-video-card {
    position:relative; border-radius:var(--r-lg); overflow:hidden;
    background:var(--dark-2); border:1px solid var(--dark-border);
    aspect-ratio:16/9;
}
.bs-video-card video { width:100%; height:100%; object-fit:cover; }
.bs-video-card .play-btn {
    position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
    width:80px; height:80px; border-radius:50%;
    background:rgba(232,112,26,0.9); border:none;
    display:flex; align-items:center; justify-content:center;
    cursor:pointer; transition:all .3s var(--ease);
    box-shadow:0 8px 32px var(--orange-glow);
}
.bs-video-card .play-btn:hover { transform:translate(-50%,-50%) scale(1.1); }
.bs-video-card .play-btn svg { width:28px; height:28px; fill:#fff; margin-left:4px; }
.bs-video-card.playing .play-btn { opacity:0; pointer-events:none; }

/* ===== STATS ===== */
.bs-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.bs-stat {
    background:var(--white-05); border:1px solid var(--dark-border);
    border-radius:var(--r); padding:32px; text-align:center;
    transition:all .3s var(--ease);
}
.bs-stat:hover { border-color:var(--orange); transform:translateY(-3px); }
.bs-stat-num { font-family:var(--display); font-size:2.4rem; font-weight:700; color:var(--orange); line-height:1; }
.bs-stat-label { font-size:0.85rem; color:var(--white-40); margin-top:6px; }

/* ===== TEAM ===== */
.bs-team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.bs-team-card {
    background:var(--dark-2); border:1px solid var(--dark-border);
    border-radius:var(--r-lg); padding:36px; text-align:center;
    transition:all .4s var(--ease);
}
.bs-team-card:hover { border-color:var(--white-20); transform:translateY(-4px); }
.bs-team-avatar {
    width:80px; height:80px; border-radius:50%;
    background:var(--orange-soft); margin:0 auto 18px;
    display:flex; align-items:center; justify-content:center;
    font-size:2rem;
}
.bs-team-card h4 { font-family:var(--display); font-weight:700; font-size:1.05rem; margin-bottom:4px; }
.bs-team-role { font-size:0.85rem; color:var(--orange); font-weight:600; margin-bottom:10px; }
.bs-team-card p { font-size:0.85rem; color:var(--white-40); line-height:1.5; }

/* ===== TIMELINE ===== */
.bs-timeline { position:relative; padding-left:40px; }
.bs-timeline::before {
    content:''; position:absolute; left:14px; top:0; bottom:0;
    width:2px; background:var(--white-10);
}
.bs-tl-item { position:relative; margin-bottom:48px; }
.bs-tl-item::before {
    content:''; position:absolute; left:-30px; top:6px;
    width:12px; height:12px; border-radius:50%;
    background:var(--dark); border:2px solid var(--orange);
}
.bs-tl-item.active::before { background:var(--orange); box-shadow:0 0 12px var(--orange-glow); }
.bs-tl-date { font-size:0.78rem; font-weight:700; color:var(--orange); letter-spacing:0.08em; text-transform:uppercase; margin-bottom:6px; }
.bs-tl-item h3 { font-family:var(--display); font-size:1.2rem; font-weight:700; margin-bottom:8px; letter-spacing:-0.02em; }
.bs-tl-item p { font-size:0.92rem; color:var(--white-40); line-height:1.6; max-width:500px; }

/* ===== CTA BANNER ===== */
.bs-cta-banner {
    background:linear-gradient(135deg, var(--orange) 0%, #c44d00 100%);
    border-radius:var(--r-lg); padding:72px 52px; text-align:center;
    position:relative; overflow:hidden;
}
.bs-cta-banner::before {
    content:''; position:absolute; top:-50%; right:-20%;
    width:400px; height:400px; border-radius:50%;
    background:rgba(255,255,255,0.08);
}
.bs-cta-banner h2 {
    font-family:var(--display); font-size:clamp(1.8rem,4vw,2.8rem);
    font-weight:700; letter-spacing:-0.03em; margin-bottom:16px; position:relative;
}
.bs-cta-banner p { font-size:1.05rem; color:rgba(255,255,255,0.8); margin-bottom:32px; max-width:500px; margin-left:auto; margin-right:auto; position:relative; }

/* ===== PAGE HERO (Subpages) ===== */
.bs-page-hero {
    padding: 180px 0 80px;
    position: relative; overflow: hidden;
    background: var(--dark) url('img/drohne-gebaeude.jpg') center/cover no-repeat;
}
.bs-page-hero::before {
    content:''; position:absolute; inset:0;
    background:linear-gradient(180deg, rgba(10,10,10,0.82) 0%, rgba(10,10,10,0.92) 100%);
    z-index:0;
}
.bs-page-hero .w { position:relative; z-index:1; }
.bs-page-hero h1 {
    font-family: var(--display);
    font-size: clamp(2.8rem, 6vw, 5rem);
    font-weight: 700; line-height: 0.95;
    letter-spacing: -0.04em; margin-bottom: 20px;
}
.bs-page-hero h1 em { font-style:normal; color:var(--orange); }

/* ===== FOOTER ===== */
.bs-footer { border-top:1px solid var(--dark-border); padding:80px 0 0; background:var(--dark-2); }
.bs-foot-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:44px; padding-bottom:60px; }
.bs-foot-brand p { font-size:0.9rem; color:var(--white-40); margin-top:14px; line-height:1.6; }
.bs-foot-socials { display:flex; gap:8px; margin-top:18px; }
.bs-foot-social {
    width:40px; height:40px; border-radius:50%;
    background:var(--white-05); border:1px solid var(--dark-border);
    display:flex; align-items:center; justify-content:center;
    transition: all .3s var(--ease);
}
.bs-foot-social:hover { background:var(--orange); border-color:var(--orange); transform:translateY(-3px); }
.bs-foot-social svg { width:18px; height:18px; fill:var(--white-60); transition:fill .3s; }
.bs-foot-social:hover svg { fill:#fff; }
.bs-footer h4 { font-family:var(--display); font-size:0.92rem; font-weight:700; margin-bottom:18px; }
.bs-fl { list-style:none; }
.bs-fl li { margin-bottom:10px; }
.bs-fl a { font-size:0.9rem; color:var(--white-40); transition:color .3s; }
.bs-fl a:hover { color:var(--orange); }
.bs-foot-logos {
    display:flex; flex-direction:column; align-items:center; gap:16px;
    padding:32px 0; border-top:1px solid var(--dark-border);
}
.bs-foot-logo-label {
    font-size:0.75rem; font-weight:600; color:var(--white-20);
    letter-spacing:0.06em; text-transform:uppercase;
}
.bs-foot-logo-row {
    display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:20px;
}
.bs-foot-logo-row img {
    height:54px; width:auto; object-fit:contain; background:#fff; border-radius:10px; padding:10px 18px;
}
.bs-foot-bottom {
    display:flex; justify-content:space-between; padding:18px 0;
    border-top:1px solid var(--dark-border);
    font-size:0.8rem; color:var(--white-20);
}
.bs-foot-bottom-links { display:flex; gap:20px; }
.bs-foot-bottom-links a { color:var(--white-20); transition:color .3s; }
.bs-foot-bottom-links a:hover { color:var(--orange); }

/* ===== SPONSOR GRID ===== */
.bs-sponsor-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.bs-sponsor-card {
    background:var(--white-05); border:1px solid var(--dark-border);
    border-radius:var(--r); padding:24px 28px;
    transition: all .3s var(--ease);
}
.bs-sponsor-card:hover { border-color:var(--orange); transform:translateY(-3px); }
a.bs-sponsor-card { display:block; }
.bs-sponsor-card h4 { font-family:var(--display); font-weight:700; font-size:0.95rem; margin-bottom:4px; }
.bs-sponsor-card p { font-size:0.82rem; color:var(--white-40); }

/* ===== LEGAL PAGES ===== */
.bs-legal { color:var(--white-60); font-size:0.95rem; line-height:1.8; }
.bs-legal-block { margin-bottom:40px; }
.bs-legal-block h2 { font-family:var(--display); font-weight:700; font-size:1.2rem; color:var(--white); margin-bottom:12px; }
.bs-legal-block h3 { font-family:var(--display); font-weight:700; font-size:1rem; color:var(--white-80); margin:20px 0 8px; }
.bs-legal-block p { margin-bottom:12px; }
.bs-legal-block a { color:var(--orange); text-decoration:none; }
.bs-legal-block a:hover { text-decoration:underline; }
.bs-legal-block ul { list-style:disc; padding-left:24px; margin-bottom:16px; }
.bs-legal-block li { margin-bottom:6px; }

/* ===== NEWS CARDS ===== */
.bs-news-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.bs-news-card {
    background:var(--dark-2); border:1px solid var(--dark-border);
    border-radius:var(--r-lg); overflow:hidden;
    transition:all .4s var(--ease); display:flex; flex-direction:column;
}
.bs-news-card:hover { transform:translateY(-6px); border-color:var(--white-20); box-shadow:0 24px 64px rgba(0,0,0,0.5); }
.bs-news-img { height:200px; overflow:hidden; }
.bs-news-img img { width:100%; height:100%; object-fit:cover; object-position:center center; transition:transform .6s var(--ease); filter:saturate(0.7); }
.bs-news-card:hover .bs-news-img img { transform:scale(1.06); filter:saturate(1); }
.bs-news-img-empty { background:var(--white-05); }
.bs-news-body { padding:22px 24px; flex:1; display:flex; flex-direction:column; }
.bs-news-date { font-size:0.78rem; font-weight:600; color:var(--orange); letter-spacing:0.06em; text-transform:uppercase; margin-bottom:10px; }
.bs-news-card h3 { font-family:var(--display); font-size:1.12rem; font-weight:700; letter-spacing:-0.02em; margin-bottom:8px; line-height:1.3; }
.bs-news-card p { font-size:0.9rem; color:var(--white-40); line-height:1.55; flex:1; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.bs-news-card .ec-link { margin-top:16px; }

/* Pagination */
.page-numbers { list-style:none; display:flex; justify-content:center; gap:8px; }
.page-numbers li a, .page-numbers li span {
    display:inline-flex; align-items:center; justify-content:center;
    min-width:42px; height:42px; padding:0 14px; border-radius:var(--r);
    font-weight:700; font-size:0.9rem; transition:all .3s var(--ease);
    border:1px solid var(--dark-border); background:var(--white-05); color:var(--white-40);
}
.page-numbers li a:hover { border-color:var(--orange); color:var(--white); }
.page-numbers li .current { background:var(--orange); border-color:var(--orange); color:#fff; }

/* ===== EVENT FORM ===== */
.bs-event-form { display:grid; gap:20px; }
.bs-field { display:flex; flex-direction:column; gap:6px; }
.bs-field label { font-family:var(--display); font-weight:600; font-size:0.85rem; color:var(--white-60); letter-spacing:0.02em; }
.bs-field input[type="text"],
.bs-field input[type="date"],
.bs-field input[type="time"],
.bs-field input[type="url"],
.bs-field textarea,
.bs-field select {
    background:var(--dark-3); border:1px solid var(--dark-border); border-radius:var(--r);
    padding:14px 16px; color:var(--white); font-size:0.95rem; font-family:var(--body);
    transition:border-color .3s var(--ease); outline:none; width:100%; box-sizing:border-box;
}
.bs-field input:focus, .bs-field textarea:focus, .bs-field select:focus { border-color:var(--orange); }
.bs-field input::placeholder, .bs-field textarea::placeholder { color:var(--white-20); }
.bs-field select { cursor:pointer; -webkit-appearance:none; appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(245,245,245,0.35)' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat:no-repeat; background-position:right 16px center; padding-right:40px;
}
.bs-field-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.bs-file-upload { position:relative; }
.bs-file-upload input[type="file"] { position:absolute; inset:0; opacity:0; cursor:pointer; z-index:2; }
.bs-file-label {
    display:flex; align-items:center; gap:12px; padding:20px;
    background:var(--dark-3); border:2px dashed var(--dark-border); border-radius:var(--r);
    color:var(--white-40); font-size:0.9rem; transition:border-color .3s var(--ease);
}
.bs-file-upload:hover .bs-file-label { border-color:var(--orange); color:var(--white-60); }
.bs-form-msg {
    padding:20px 24px; border-radius:var(--r); margin-bottom:28px;
    font-size:0.95rem; line-height:1.6;
}
.bs-form-ok { background:rgba(52,211,153,0.1); border:1px solid rgba(52,211,153,0.3); color:var(--green); }
.bs-form-err { background:rgba(239,68,68,0.1); border:1px solid rgba(239,68,68,0.3); color:#ef4444; }

/* ===== VISION TILES (Dritter Ort) ===== */
.bs-vtile {
    background:var(--white-05); border:1px solid var(--dark-border);
    border-radius:var(--r); padding:28px; text-align:center;
    transition:all .5s var(--ease);
}
.bs-vtile-active {
    background:var(--orange); border-color:var(--orange);
    transform:scale(1.05);
    box-shadow:0 8px 32px var(--orange-glow);
}

/* ===== RESPONSIVE ===== */
@media (max-width:1024px) {
    section { padding:100px 0; }
    .e-grid { grid-template-columns:repeat(2,1fr); }
    .bs-ort-grid, .bs-join-grid { grid-template-columns:1fr; gap:48px; }
    .bs-foot-grid { grid-template-columns:1fr 1fr; }
    .f-cats { grid-template-columns:1fr; }
    .bs-hero-bar { flex-direction:column; align-items:flex-start; }
    .bs-imgstrip { grid-template-columns:repeat(3,1fr); height:220px; }
    .bs-imgstrip img:nth-child(n+4) { display:none; }
    .bs-stats { grid-template-columns:repeat(2,1fr); }
    .bs-team-grid { grid-template-columns:repeat(2,1fr) !important; }
    .bs-sponsor-grid { grid-template-columns:repeat(2,1fr); }
    .bs-news-grid { grid-template-columns:repeat(2,1fr); }
    .bs-vision-grid { grid-template-columns:repeat(3,1fr) !important; }
    .bs-g2 { grid-template-columns:1fr !important; gap:48px !important; }
    .bs-g3 { grid-template-columns:repeat(2,1fr) !important; }
}
@media (max-width:768px) {
    section { padding:72px 0; }
    .w { padding:0 18px; }
    .bs-nav-menu { display:none; }
    .bs-hamburger { display:block; }
    .e-grid { grid-template-columns:1fr; }
    .benefits { grid-template-columns:1fr; }
    .bs-foot-grid { grid-template-columns:1fr; }
    .bs-foot-bottom { flex-direction:column; gap:10px; text-align:center; }
    .bs-nl-form { flex-direction:column; }
    .bs-hero-bar-left { flex-direction:column; align-items:flex-start; gap:10px; }
    .bs-hero-bar-sep { width:100%; height:1px; }
    .bs-ticker { display:none; }
    .bs-imgstrip { grid-template-columns:1fr 1fr; height:180px; }
    .bs-imgstrip img:nth-child(n+3) { display:none; }
    .bs-page-hero { padding:140px 0 60px; }
    .bs-stats { grid-template-columns:1fr 1fr; }
    .bs-team-grid { grid-template-columns:1fr !important; }
    .bs-sponsor-grid { grid-template-columns:1fr; }
    .bs-news-grid { grid-template-columns:1fr; }
    .bs-field-row { grid-template-columns:1fr; }
    .bs-vision-grid { grid-template-columns:repeat(2,1fr) !important; }
    .bs-g2 { grid-template-columns:1fr !important; gap:36px !important; }
    .bs-g3 { grid-template-columns:1fr !important; }
    .bs-hero h1 { font-size:clamp(2.4rem,10vw,4rem); }
    .bs-hero-sub { font-size:1rem; }
    .bs-hero-actions { flex-direction:column; }
    .bs-hero-actions .btn { width:100%; justify-content:center; }
    .bs-hero-dots {
        position:absolute; right:auto; left:50%; top:auto; bottom:24px;
        transform:translateX(-50%); flex-direction:row;
    }
    .bs-post-thumb { max-width:100% !important; }
}
