/**
 * SpeedShot Frontend v3 – Component-System Styles
 * Brand: #6B8F23
 */

/* ═══ Foundation ═══════════════════════════════════════════════ */
:root {
    --g:#6B8F23; --gh:#5A7A1D; --gl:#E8F0D4; --gd:#3A5010;
    --tx:#1C1C1C; --tx2:#6B7280; --tx3:#9CA3AF;
    --bd:#E5E7EB; --bg:#fff; --bg2:#F5F6F4;
    --r:8px; --r2:12px; --r3:16px;
    --sh:0 2px 8px rgba(0,0,0,.06); --sh2:0 8px 24px rgba(0,0,0,.1); --sh3:0 16px 48px rgba(0,0,0,.14);
    --ez:cubic-bezier(.4,0,.2,1);
}
.ssf-home,.ssf-page-events { color:var(--tx); line-height:1.6; -webkit-font-smoothing:antialiased; }
.ssf-home [x-cloak],.ssf-page-events [x-cloak],.ssf-header [x-cloak],.ssf-demo [x-cloak],.ssf-cfg [x-cloak] { display:none !important; }
.ssf-home *,.ssf-home *::before,.ssf-home *::after,
.ssf-page-events *,.ssf-page-events *::before,.ssf-page-events *::after { box-sizing:border-box; }
.ssf-container { max-width:1200px; margin:0 auto; padding:0 1.25rem; }

/* ═══════════════════════════════════════════════════════════════
   HEADER / NAV
   ═══════════════════════════════════════════════════════════════ */
.ssf-header {
    background:#fff; border-bottom:1px solid var(--bd);
    position:sticky; top:0; z-index:100;
}
.ssf-header-inner {
    display:flex; align-items:center; gap:1rem;
    height:3.5rem;
}
.ssf-header-logo {
    display:flex; align-items:center; gap:.5rem;
    text-decoration:none; color:var(--tx); flex-shrink:0;
}
.ssf-header-logo-icon { display:flex; }
.ssf-header-logo-text {
    font-size:.9375rem; font-weight:400; letter-spacing:.04em;
    color:var(--tx2);
}
.ssf-header-logo-text strong { color:var(--tx); font-weight:800; }

.ssf-header-nav {
    display:flex; align-items:center; gap:.125rem;
    margin-left:2rem;
}
.ssf-header-link {
    padding:.375rem .75rem; font-size:.8125rem; font-weight:500;
    color:var(--tx2); text-decoration:none; border-radius:var(--r);
    transition:all .15s;
}
.ssf-header-link:hover { color:var(--tx); background:var(--bg2); }

.ssf-header-auth {
    display:flex; align-items:center; gap:.5rem;
    margin-left:auto;
}
.ssf-header-login {
    padding:.375rem .875rem; font-size:.8125rem; font-weight:600;
    color:var(--tx); text-decoration:none; border-radius:var(--r);
    transition:all .15s;
}
.ssf-header-login:hover { background:var(--bg2); }
.ssf-header-register {
    padding:.375rem .875rem; font-size:.8125rem; font-weight:600;
    color:#fff; background:var(--g); text-decoration:none;
    border-radius:var(--r); transition:all .15s;
}
.ssf-header-register:hover { background:var(--gh); }

/* Hamburger */
.ssf-header-burger {
    display:none; flex-direction:column; gap:4px;
    padding:6px; margin-left:auto; background:none; border:none; cursor:pointer;
}
.ssf-header-burger span {
    width:20px; height:2px; background:var(--tx); border-radius:2px;
    transition:all .2s;
}
.ssf-header-burger.is-open span:nth-child(1) { transform:rotate(45deg) translate(4px,4px); }
.ssf-header-burger.is-open span:nth-child(2) { opacity:0; }
.ssf-header-burger.is-open span:nth-child(3) { transform:rotate(-45deg) translate(4px,-4px); }

/* Mobile Menu */
.ssf-header-mobile {
    display:flex; flex-direction:column; padding:1rem 0;
    border-top:1px solid var(--bd);
}
.ssf-header-mobile-nav {
    display:flex; flex-direction:column; gap:.25rem;
}
.ssf-header-mobile-nav a {
    padding:.625rem .5rem; font-size:.9375rem; font-weight:500;
    color:var(--tx); text-decoration:none; border-radius:var(--r);
}
.ssf-header-mobile-nav a:hover { background:var(--bg2); }
.ssf-header-mobile-auth {
    display:flex; gap:.5rem; margin-top:.75rem; padding-top:.75rem;
    border-top:1px solid var(--bd);
}
.ssf-header-mobile-auth .ssf-header-login,
.ssf-header-mobile-auth .ssf-header-register {
    flex:1; text-align:center; padding:.625rem;
}

/* ═══════════════════════════════════════════════════════════════
   HERO V4 – Screenshot Design
   ═══════════════════════════════════════════════════════════════ */
.ssf-hero-v4 {
    position:relative; overflow:hidden;
    padding:3rem 0 2.5rem;
    background:#f0f1ec;
}
.ssf-hero-v4-bg {
    position:absolute; inset:0;
    background:linear-gradient(135deg, rgba(240,241,236,.95) 40%, rgba(200,210,180,.3) 100%);
    z-index:0;
}
.ssf-hero-v4-grid {
    position:relative; z-index:1;
    display:grid; grid-template-columns:1fr 1fr; gap:2rem;
    align-items:center; min-height:380px;
}
.ssf-hero-v4-left { padding:1rem 0; }
.ssf-hero-v4-title {
    font-size:3.5rem; font-weight:900; line-height:1.05;
    color:var(--tx); margin:0 0 .75rem;
    letter-spacing:-.02em;
}
.ssf-hero-v4-sub {
    font-size:1.0625rem; color:var(--tx2); margin:0 0 1.75rem;
    font-weight:400;
}
.ssf-hero-v4-btn { font-size:.875rem; }

.ssf-hero-v4-right { position:relative; }
.ssf-hero-v4-img {
    width:100%; aspect-ratio:4/3; border-radius:var(--r2);
    overflow:hidden; background:var(--bg2);
}
.ssf-hero-v4-img img { width:100%; height:100%; object-fit:cover; }
.ssf-hero-v4-placeholder {
    width:100%; height:100%;
    display:flex; align-items:center; justify-content:center;
    background:linear-gradient(135deg, #d4dcc4 0%, #e8edd8 100%);
    color:var(--tx3);
}

/* ═══ Buttons ══════════════════════════════════════════════════ */
.ssf-btn-green { display:inline-flex; align-items:center; gap:.4rem; padding:.7rem 1.5rem; font-size:.875rem; font-weight:700; background:var(--g); color:#fff; border:none; border-radius:var(--r); cursor:pointer; text-decoration:none; transition:all .2s var(--ez); }
.ssf-btn-green:hover { background:var(--gh); box-shadow:0 4px 16px rgba(107,143,35,.35); transform:translateY(-1px); }
.ssf-btn-green span { transition:transform .2s; }
.ssf-btn-green:hover span { transform:translateX(3px); }
.ssf-btn-green-sm { padding:.55rem 1.2rem; font-size:.8125rem; }
.ssf-btn-green-full { width:100%; justify-content:center; }

.ssf-btn-ghost { display:inline-flex; align-items:center; gap:.4rem; padding:.7rem 1.5rem; font-size:.875rem; font-weight:600; background:transparent; color:rgba(255,255,255,.8); border:2px solid rgba(255,255,255,.3); border-radius:var(--r); cursor:pointer; text-decoration:none; transition:all .2s var(--ez); }
.ssf-btn-ghost:hover { border-color:#fff; color:#fff; background:rgba(255,255,255,.08); }

.ssf-btn-white { display:inline-flex; align-items:center; gap:.4rem; padding:.7rem 1.75rem; font-size:.875rem; font-weight:700; background:#fff; color:var(--gd); border:none; border-radius:var(--r); cursor:pointer; text-decoration:none; transition:all .2s var(--ez); }
.ssf-btn-white:hover { box-shadow:var(--sh2); transform:translateY(-1px); }
.ssf-btn-white-outline { display:inline-flex; align-items:center; gap:.4rem; padding:.7rem 1.75rem; font-size:.875rem; font-weight:600; background:transparent; color:#fff; border:2px solid rgba(255,255,255,.5); border-radius:var(--r); cursor:pointer; text-decoration:none; transition:all .2s var(--ez); }
.ssf-btn-white-outline:hover { border-color:#fff; background:rgba(255,255,255,.1); }

.ssf-btn-outline-sm { display:inline-flex; align-items:center; gap:.4rem; padding:.5rem 1rem; font-size:.8125rem; font-weight:600; background:var(--bg); color:var(--tx2); border:1px solid var(--bd); border-radius:var(--r); cursor:pointer; text-decoration:none; transition:all .15s; }
.ssf-btn-outline-sm:hover { border-color:var(--g); color:var(--g); }

/* ═══ Helpers ══════════════════════════════════════════════════ */
.ssf-loading { display:flex; justify-content:center; padding:3rem; }
.ssf-spinner { width:2rem; height:2rem; border:3px solid var(--bd); border-top-color:var(--g); border-radius:50%; animation:ssf-spin .6s linear infinite; }
@keyframes ssf-spin { to{transform:rotate(360deg)} }
.ssf-empty-msg { text-align:center; padding:3rem; color:var(--tx3); }
.ssf-notice { padding:1rem; background:var(--bg2); border:1px solid var(--bd); border-radius:var(--r); color:var(--tx2); text-align:center; }

/* Shared stats row */
.ssf-hstat { text-align:center; }
.ssf-hstat-n { display:block; font-size:1.375rem; font-weight:800; color:#fff; }
.ssf-hstat-l { font-size:.6875rem; text-transform:uppercase; letter-spacing:.08em; color:rgba(255,255,255,.45); font-weight:600; }
.ssf-hstat-sep { width:1px; height:2rem; background:rgba(255,255,255,.12); }


/* ═══════════════════════════════════════════════════════════════
   HERO V1 – Centered, Badge, Stats Bar
   ═══════════════════════════════════════════════════════════════ */
.ssf-hero-v1 {
    position:relative; min-height:520px; display:flex; flex-direction:column;
    justify-content:center; align-items:center; text-align:center;
    padding:4rem 2rem 2rem; overflow:hidden;
}
.ssf-hero-v1-bg { position:absolute; inset:0; background:var(--bg2) center/cover no-repeat; }
.ssf-hero-v1-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(15,26,10,.88),rgba(26,43,10,.7) 50%,rgba(107,143,35,.25) 100%); }
.ssf-hero-v1-content {
    position:relative; z-index:2; max-width:720px;
    opacity:0; transform:translateY(20px); transition:opacity .6s var(--ez),transform .6s var(--ez);
}
.ssf-hero-v1-content.is-visible { opacity:1; transform:translateY(0); }
.ssf-hero-v1-badge { display:inline-block; padding:.375rem 1rem; margin-bottom:1.5rem; font-size:.8rem; font-weight:600; letter-spacing:.03em; background:rgba(107,143,35,.25); color:var(--gl); border:1px solid rgba(107,143,35,.4); border-radius:99px; backdrop-filter:blur(8px); }
.ssf-hero-v1-content h1 { font-size:clamp(2.25rem,5vw,3.75rem); font-weight:900; color:#fff; line-height:1.05; letter-spacing:-.02em; margin:0 0 .75rem; }
.ssf-hero-v1-content h1 span { color:var(--gl); }
.ssf-hero-v1-sub { font-size:clamp(1rem,2vw,1.25rem); color:rgba(255,255,255,.75); font-weight:300; margin:0 0 2rem; }
.ssf-hero-v1-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.ssf-hero-v1-stats { position:relative; z-index:2; display:flex; align-items:center; gap:2rem; flex-wrap:wrap; justify-content:center; margin-top:3rem; padding-top:2rem; border-top:1px solid rgba(255,255,255,.12); }


/* ═══════════════════════════════════════════════════════════════
   HERO V2 – Left-aligned, Photo Right
   ═══════════════════════════════════════════════════════════════ */
.ssf-hero-v2 { position:relative; min-height:480px; display:flex; flex-direction:column; justify-content:center; overflow:hidden; }
.ssf-hero-v2-bg { position:absolute; inset:0; background:linear-gradient(135deg,#0d1a06 0%,#1a2b0a 40%,transparent 100%) center/cover no-repeat; }
.ssf-hero-v2-overlay { position:absolute; inset:0; background:linear-gradient(90deg,rgba(13,26,6,.92),rgba(13,26,6,.6) 50%,rgba(13,26,6,.15) 100%); }
.ssf-hero-v2-content { position:relative; z-index:2; max-width:1200px; margin:0 auto; padding:4rem 2rem 5rem; width:100%; }
.ssf-hero-v2-text { max-width:520px; }
.ssf-hero-v2-text h1 { font-size:clamp(2rem,5vw,3.25rem); font-weight:900; color:#fff; line-height:1.05; letter-spacing:-.02em; margin:0 0 .75rem; }
.ssf-hero-v2-text h1 span { color:var(--gl); }
.ssf-hero-v2-text p { font-size:1.0625rem; color:rgba(255,255,255,.7); margin:0 0 1.75rem; font-weight:300; }
.ssf-hero-v2-stats { position:relative; z-index:2; display:flex; align-items:center; justify-content:center; gap:2rem; flex-wrap:wrap; background:rgba(255,255,255,.06); backdrop-filter:blur(12px); border-top:1px solid rgba(255,255,255,.1); padding:1.25rem 2rem; }


/* ═══════════════════════════════════════════════════════════════
   HERO V3 – Split Editorial
   ═══════════════════════════════════════════════════════════════ */
.ssf-hero-v3 { background:var(--bg); padding:4rem 0; }
.ssf-hero-v3-grid { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center; }
.ssf-hero-v3-tag { font-size:.7rem; font-weight:800; letter-spacing:.1em; color:var(--g); text-transform:uppercase; }
.ssf-hero-v3-left h1 { font-size:clamp(2rem,4vw,3.5rem); font-weight:300; color:var(--tx); line-height:1.1; margin:.5rem 0 1rem; }
.ssf-hero-v3-left h1 span { font-weight:900; color:var(--g); display:block; }
.ssf-hero-v3-left p { color:var(--tx2); font-size:1rem; margin:0 0 1.5rem; line-height:1.6; }
.ssf-hero-v3-btns { display:flex; gap:.75rem; flex-wrap:wrap; margin-bottom:2rem; }
.ssf-hero-v3-nums { display:flex; gap:2rem; font-size:.8125rem; color:var(--tx2); }
.ssf-hero-v3-nums strong { display:block; font-size:1.5rem; font-weight:800; color:var(--tx); }

.ssf-hero-v3-right { position:relative; }
.ssf-hero-v3-img { aspect-ratio:4/3; border-radius:var(--r3); background:var(--bg2) center/cover no-repeat; object-fit:cover; width:100%; display:block; }
.ssf-hero-v3-card { position:absolute; bottom:-1rem; left:-1rem; background:var(--bg); border:1px solid var(--bd); border-radius:var(--r2); padding:1rem 1.25rem; box-shadow:var(--sh2); display:flex; align-items:center; gap:.75rem; }
.ssf-hero-v3-card-icon { font-size:1.5rem; }
.ssf-hero-v3-card strong { font-size:.9375rem; color:var(--tx); display:block; }
.ssf-hero-v3-card span { font-size:.75rem; color:var(--tx3); }


/* ═══════════════════════════════════════════════════════════════
   QUICK-FILTER V1 – Floating Card
   ═══════════════════════════════════════════════════════════════ */
.ssf-qf-v1 { max-width:1000px; margin:-2.5rem auto 0; position:relative; z-index:20; padding:0 1.25rem; }
.ssf-qf-v1-card { display:flex; gap:.75rem; align-items:flex-end; flex-wrap:wrap; background:var(--bg); padding:1.25rem 1.5rem; border-radius:var(--r3); box-shadow:var(--sh3); border:1px solid var(--bd); }
.ssf-qf-v1-col { flex:1; min-width:140px; }
.ssf-qf-v1-col label { display:block; font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--tx2); margin-bottom:.25rem; }
.ssf-qf-v1-col-btn { flex:0 0 auto; }
.ssf-qf-select { width:100%; padding:.55rem .75rem; font-size:.8125rem; border:1px solid var(--bd); border-radius:var(--r); background:var(--bg); color:var(--tx); outline:none; transition:border-color .2s; }
.ssf-qf-select:focus { border-color:var(--g); }


/* ═══════════════════════════════════════════════════════════════
   QUICK-FILTER V2 – Flat Bar
   ═══════════════════════════════════════════════════════════════ */
.ssf-qf-v2 { background:var(--bg); border-bottom:1px solid var(--bd); box-shadow:var(--sh); position:relative; z-index:20; }
.ssf-qf-v2-row { display:flex; align-items:flex-end; gap:.75rem; flex-wrap:wrap; padding:1rem 0; }
.ssf-qf-v2-col { flex:1; min-width:140px; }
.ssf-qf-v2-col label { display:block; font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--tx2); margin-bottom:.25rem; }
.ssf-qf-v2-col-search { flex:1.5; position:relative; }
.ssf-qf-v2-col-btn { flex:0 0 auto; }
.ssf-qf-input { width:100%; padding:.55rem .75rem; font-size:.8125rem; border:1px solid var(--bd); border-radius:var(--r); background:var(--bg); color:var(--tx); outline:none; transition:border-color .2s; }
.ssf-qf-input:focus { border-color:var(--g); }
.ssf-qf-dropdown { position:absolute; top:100%; left:0; right:0; margin-top:2px; background:var(--bg); border:1px solid var(--bd); border-radius:var(--r); box-shadow:var(--sh2); z-index:50; max-height:16rem; overflow-y:auto; }
.ssf-qf-dropdown-item { display:block; padding:.6rem .75rem; font-size:.8125rem; text-decoration:none; color:var(--tx); border-bottom:1px solid var(--bd); transition:background .15s; }
.ssf-qf-dropdown-item:last-child { border-bottom:none; }
.ssf-qf-dropdown-item:hover { background:var(--bg2); }

/* ── quickfilter-v3 ──────────────────────────────────────────────────── */
.ssf-qf-v3 { background:var(--bg); border-bottom:1px solid var(--bd); box-shadow:var(--sh); position:relative; z-index:20; }
.ssf-qf-v3-row { display:flex; align-items:flex-end; gap:.75rem; flex-wrap:wrap; padding:1rem 0; }
.ssf-qf-v3-col { flex:1; min-width:140px; }
.ssf-qf-v3-col label { display:block; font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--tx2); margin-bottom:.25rem; }
.ssf-qf-v3-col-search { flex:2; position:relative; }
.ssf-qf-v3-col-btn { flex:0 0 auto; }
.ssf-qf-v3-search-wrap { position:relative; }
.ssf-qf-v3-search-wrap .ssf-qf-input { padding-right:2rem; }
.ssf-qf-v3-search-icon { position:absolute; right:.6rem; top:50%; transform:translateY(-50%); color:var(--tx2); pointer-events:none; display:flex; }

/* Dropdown v3 – zwei Sektionen */
.ssf-qf-v3-dropdown { position:absolute; top:calc(100% + 4px); left:0; right:0; background:var(--bg); border:1px solid var(--bd); border-radius:var(--r); box-shadow:var(--sh2); z-index:50; max-height:22rem; overflow-y:auto; }
.ssf-qf-v3-section-label { padding:.35rem .75rem .25rem; font-size:.6rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--tx2); background:var(--bg2); border-bottom:1px solid var(--bd); }
.ssf-qf-v3-divider { height:1px; background:var(--bd); margin:0; }

/* Event-Treffer */
.ssf-qf-v3-item-event { display:flex; flex-direction:column; gap:.1rem; padding:.55rem .75rem; }
.ssf-qf-v3-item-event:hover { background:var(--bg2); }
.ssf-qf-v3-item-title { font-size:.8125rem; color:var(--tx); font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ssf-qf-v3-item-meta { font-size:.7rem; color:var(--tx2); }

/* Galerie-Treffer */
.ssf-qf-v3-item-gallery { display:flex; align-items:center; gap:.5rem; padding:.55rem .75rem; text-decoration:none; color:var(--tx); border-bottom:1px solid var(--bd); transition:background .15s; }
.ssf-qf-v3-item-gallery:last-child { border-bottom:none; }
.ssf-qf-v3-item-gallery:hover { background:var(--bg2); }
.ssf-qf-v3-item-gallery .ssf-qf-v3-item-title { flex:1; font-size:.8125rem; font-weight:500; }
.ssf-qf-v3-item-count { font-size:.7rem; color:var(--tx2); white-space:nowrap; }
.ssf-qf-v3-item-icon { flex-shrink:0; color:var(--tx2); }

/* "Alle Fotos"-Zeile */
.ssf-qf-v3-item-gallery-all { display:flex; align-items:center; gap:.5rem; padding:.55rem .75rem; text-decoration:none; color:var(--g); font-size:.8125rem; font-weight:600; transition:background .15s; border-top:1px solid var(--bd); }
.ssf-qf-v3-item-gallery-all:hover { background:var(--bg2); }
.ssf-qf-v3-item-gallery-all strong { color:var(--g); }
.ssf-qf-v3-arrow { margin-left:auto; font-size:.9rem; }

/* Transition */
.ssf-qf-dropdown-enter { transition:opacity .15s ease, transform .15s ease; }
.ssf-qf-dropdown-enter-start { opacity:0; transform:translateY(-4px); }
.ssf-qf-dropdown-enter-end { opacity:1; transform:translateY(0); }

/* ═══════════════════════════════════════════════════════════════
   SECTIONS
   ═══════════════════════════════════════════════════════════════ */
.ssf-section { padding:3rem 0; }
.ssf-section-alt { background:var(--bg2); }
.ssf-section-head { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:1.75rem; flex-wrap:wrap; gap:.5rem; }
.ssf-section-head h2 { font-size:1.5rem; font-weight:400; color:var(--tx); margin:0; }
.ssf-section-head h2 strong { font-weight:800; }
.ssf-link { font-size:.8125rem; font-weight:600; color:var(--tx2); text-decoration:none; transition:color .2s; }
.ssf-link:hover { color:var(--g); }
.ssf-section-title-line { font-size:1.375rem; font-weight:400; color:var(--tx); padding-bottom:.75rem; margin:0 0 1.5rem; border-bottom:2px solid var(--bd); }


/* ═══════════════════════════════════════════════════════════════
   EVENTS LAYOUT – Sidebar + Swipe/Grid
   ═══════════════════════════════════════════════════════════════ */
#ssf-events-anchor { scroll-margin-top:1rem; }

.ssf-events-layout { display:grid; grid-template-columns:240px 1fr; gap:1.5rem; }

/* Sidebar */
.ssf-sidebar { background:var(--bg); border:1px solid var(--bd); border-radius:var(--r2); padding:1.25rem; align-self:start; position:sticky; top:1rem; }
.ssf-sidebar-title-desktop { display:flex; align-items:center; gap:.5rem; font-size:.8125rem; font-weight:800; letter-spacing:.04em; color:var(--tx); margin-bottom:1.25rem; text-transform:uppercase; }
.ssf-sidebar-toggle { display:none; }
.ssf-sidebar-body { display:block; }
.ssf-sidebar-icon { width:1.125rem; height:1.125rem; color:var(--g); flex-shrink:0; }
.ssf-sidebar-field { margin-bottom:1rem; }
.ssf-sidebar-field label { display:block; font-size:.75rem; font-weight:700; color:var(--tx); margin-bottom:.25rem; }
.ssf-sidebar-select, .ssf-sidebar-input { width:100%; padding:.5rem .625rem; font-size:.8125rem; border:1px solid var(--bd); border-radius:var(--r); background:var(--bg); color:var(--tx); outline:none; transition:border-color .2s; }
.ssf-sidebar-select:focus, .ssf-sidebar-input:focus { border-color:var(--g); }

/* Events Main */
.ssf-events-main { min-width:0; }
.ssf-events-swipe-wrap { position:relative; }

/* Desktop: normal Grid */
.ssf-events-swipe { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
.ssf-events-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
.ssf-events-grid-3 { grid-template-columns:repeat(3,1fr); }
.ssf-events-swipe-3 { grid-template-columns:repeat(3,1fr); }

/* Dynamic column classes */
.ssf-events-cols-2 { grid-template-columns:repeat(2,1fr); }
.ssf-events-cols-3 { grid-template-columns:repeat(3,1fr); }
.ssf-events-cols-4 { grid-template-columns:repeat(4,1fr); }

/* Swipe Hint – nur mobile */
.ssf-swipe-hint { display:none; }

/* Loading more (infinite swipe) */
.ssf-swipe-loading {
    display:none; align-items:center; justify-content:center; gap:.5rem;
    padding:.75rem 0; font-size:.8rem; color:var(--tx3);
}
.ssf-spinner-sm {
    width:1rem; height:1rem; border:2px solid var(--bd);
    border-top-color:var(--g); border-radius:50%;
    animation:ssf-spin .6s linear infinite;
}

/* All loaded (mobile end) */
.ssf-swipe-end {
    display:none; text-align:center; padding:.75rem 0;
    font-size:.75rem; color:var(--tx3); letter-spacing:.02em;
}

/* Sidebar Chevron */
.ssf-sidebar-chevron { width:1.25rem; height:1.25rem; margin-left:auto; transition:transform .2s; color:var(--tx3); }
.ssf-sidebar-chevron.is-open { transform:rotate(180deg); }


/* ═══════════════════════════════════════════════════════════════
   EVENT CARD
   ═══════════════════════════════════════════════════════════════ */
.ssf-ecard { display:block; background:var(--bg); border:1px solid var(--bd); border-radius:var(--r2); overflow:hidden; text-decoration:none; color:inherit; transition:box-shadow .25s var(--ez),transform .25s var(--ez); }
.ssf-ecard:hover { box-shadow:var(--sh2); transform:translateY(-2px); }
.ssf-ecard-img { position:relative; aspect-ratio:16/10; overflow:hidden; background:var(--bg2); }
.ssf-ecard-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s var(--ez); }
.ssf-ecard:hover .ssf-ecard-img img { transform:scale(1.05); }
.ssf-ecard-noimg { width:100%; height:100%; display:flex; align-items:center; justify-content:center; color:var(--tx3); font-size:.875rem; }
.ssf-ecard-badge { position:absolute; top:.625rem; right:.625rem; padding:.2rem .65rem; font-size:.6875rem; font-weight:700; background:var(--g); color:#fff; border-radius:5px; }
.ssf-ecard-body { padding:.875rem 1rem; }
.ssf-ecard-body h3 { font-size:.9375rem; font-weight:800; color:#1C1C1C; margin:0 0 .25rem; line-height:1.3; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.ssf-ecard-city { font-size:.75rem; color:#6B7280; }
.ssf-ecard-meta { font-size:.75rem; color:#6B7280; margin-bottom:.375rem; }
.ssf-ecard-foot { display:flex; justify-content:space-between; align-items:center; font-size:.7rem; margin-top:.375rem; }
.ssf-ecard-count { font-weight:700; color:var(--g); }
.ssf-ecard-liga { color:var(--tx3); }

/* Swipe Card sizing for mobile */
.ssf-ecard-swipe { min-width:0; }


/* ═══════════════════════════════════════════════════════════════
   PAGINATION
   ═══════════════════════════════════════════════════════════════ */
.ssf-pag { display:flex; align-items:center; gap:.25rem; margin-top:1.5rem; flex-wrap:wrap; }
.ssf-pag-btn { width:2rem; height:2rem; display:flex; align-items:center; justify-content:center; font-size:.8125rem; font-weight:600; color:var(--tx2); background:var(--bg); border:1px solid var(--bd); border-radius:var(--r); cursor:pointer; transition:all .15s; }
.ssf-pag-btn:hover { border-color:var(--g); color:var(--g); }
.ssf-pag-btn.is-active { background:var(--g); color:#fff; border-color:var(--g); }
.ssf-pag-btn:disabled { opacity:.4; cursor:not-allowed; }
.ssf-pag-info { font-size:.75rem; color:var(--tx3); margin-left:.75rem; }


/* ═══════════════════════════════════════════════════════════════
   ABOUT V1 – Image + Text
   ═══════════════════════════════════════════════════════════════ */
.ssf-about-row { display:grid; grid-template-columns:300px 1fr; gap:2.5rem; align-items:start; }
.ssf-about-img { aspect-ratio:3/4; border-radius:var(--r2); overflow:hidden; background:var(--bg2) center/cover no-repeat; object-fit:cover; width:100%; display:block; }
.ssf-about-text h3 { font-size:1.375rem; font-weight:400; color:var(--tx); margin:0 0 .75rem; }
.ssf-about-text h3 strong { font-weight:800; }
.ssf-about-text p { color:var(--tx2); font-size:.9rem; margin:0 0 1rem; line-height:1.7; }


/* ═══════════════════════════════════════════════════════════════
   ABOUT V2 – Full-Width Banner
   ═══════════════════════════════════════════════════════════════ */
.ssf-about-v2 { position:relative; padding:4rem 0; overflow:hidden; }
.ssf-about-v2-bg { position:absolute; inset:0; background:var(--bg2) center/cover no-repeat; }
.ssf-about-v2-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(13,26,6,.9),rgba(26,43,10,.85)); }
.ssf-about-v2-inner { position:relative; z-index:2; display:grid; grid-template-columns:1fr auto; gap:3rem; align-items:center; }
.ssf-about-v2-tag { font-size:.7rem; font-weight:800; letter-spacing:.1em; color:var(--gl); text-transform:uppercase; margin-bottom:.5rem; display:block; }
.ssf-about-v2-text h2 { font-size:1.75rem; font-weight:400; color:#fff; margin:0 0 .75rem; }
.ssf-about-v2-text h2 strong { font-weight:800; }
.ssf-about-v2-text p { color:rgba(255,255,255,.65); font-size:.9375rem; margin:0 0 1.5rem; max-width:600px; line-height:1.7; }
.ssf-about-v2-stats { display:flex; gap:2rem; }
.ssf-about-v2-stat { text-align:center; background:rgba(255,255,255,.08); backdrop-filter:blur(8px); padding:1.25rem 1.5rem; border-radius:var(--r2); border:1px solid rgba(255,255,255,.1); }
.ssf-about-v2-stat span { display:block; font-size:1.75rem; font-weight:800; color:#fff; }
.ssf-about-v2-stat label { font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; color:rgba(255,255,255,.5); }


/* ═══════════════════════════════════════════════════════════════
   DUO V1 – Two Cards
   ═══════════════════════════════════════════════════════════════ */
.ssf-duo-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; }
.ssf-duo-card h3 { font-size:1.125rem; font-weight:400; color:var(--tx); margin:1rem 0 .5rem; }
.ssf-duo-card h3 strong { font-weight:800; }
.ssf-duo-card p { font-size:.875rem; color:var(--tx2); margin:0 0 1rem; line-height:1.6; }
.ssf-duo-img { display:block; aspect-ratio:16/9; border-radius:var(--r2); overflow:hidden; position:relative; background-size:cover; background-position:center; transition:transform .3s var(--ez); }
.ssf-duo-img:hover { transform:scale(1.01); }
.ssf-duo-img-gallery { background-color:var(--bg2); }
.ssf-duo-img-blog { background-color:var(--bg2); }
.ssf-duo-img-overlay { position:absolute; inset:0; background:linear-gradient(transparent 40%,rgba(0,0,0,.4)); }


/* ═══════════════════════════════════════════════════════════════
   DUO V2 – Feature Cards
   ═══════════════════════════════════════════════════════════════ */
.ssf-feature-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.ssf-feature-card { display:block; padding:2rem 1.5rem; background:var(--bg); border:1px solid var(--bd); border-radius:var(--r2); text-decoration:none; color:inherit; transition:all .25s var(--ez); }
.ssf-feature-card:hover { border-color:var(--g); box-shadow:var(--sh2); transform:translateY(-3px); }
.ssf-feature-icon { font-size:2rem; margin-bottom:.75rem; }
.ssf-feature-card h3 { font-size:1.125rem; font-weight:700; color:var(--tx); margin:0 0 .5rem; }
.ssf-feature-card p { font-size:.8125rem; color:var(--tx2); margin:0 0 1rem; line-height:1.6; }
.ssf-feature-link { font-size:.8125rem; font-weight:700; color:var(--g); }


/* ═══════════════════════════════════════════════════════════════
   CTA V1 – Full-Width Bar
   ═══════════════════════════════════════════════════════════════ */
.ssf-cta-footer { background:linear-gradient(135deg,#0d1a06,#1a3a0a,#2d5a10); padding:3rem 0; }
.ssf-cta-footer-inner { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1.5rem; }
.ssf-cta-footer h2 { font-size:1.5rem; font-weight:400; color:#fff; margin:0; }
.ssf-cta-footer h2 strong { font-weight:800; }
.ssf-cta-footer p { color:rgba(255,255,255,.6); margin:.25rem 0 0; font-size:.9rem; }
.ssf-cta-footer-btns { display:flex; gap:.75rem; flex-wrap:wrap; }


/* ═══════════════════════════════════════════════════════════════
   CTA V2 – Centered Card
   ═══════════════════════════════════════════════════════════════ */
.ssf-cta-card { text-align:center; max-width:640px; margin:0 auto; padding:3rem 2.5rem; background:var(--bg); border:2px solid var(--g); border-radius:var(--r3); }
.ssf-cta-card-icon { font-size:2.5rem; margin-bottom:.75rem; display:block; }
.ssf-cta-card h2 { font-size:1.375rem; font-weight:400; color:var(--tx); margin:0 0 .75rem; }
.ssf-cta-card h2 strong { font-weight:800; }
.ssf-cta-card p { color:var(--tx2); font-size:.9rem; margin:0 0 1.5rem; line-height:1.6; }
.ssf-cta-card-btns { display:flex; gap:.75rem; justify-content:center; flex-wrap:wrap; }


/* ═══════════════════════════════════════════════════════════════
   EVENTS PAGE (/events/)
   ═══════════════════════════════════════════════════════════════ */
.ssf-page-events { padding:2rem 0 3rem; }
.ssf-page-head { margin-bottom:2rem; }
.ssf-page-title { font-size:1.75rem; font-weight:800; color:var(--tx); margin:0; }
.ssf-page-sub { font-size:.875rem; color:var(--tx2); margin:.25rem 0 0; }

/* Events Page Grid: 3→2→1 columns responsive */
.ssf-events-page-grid { grid-template-columns:repeat(3,1fr); }

/* Full-width outline button */
.ssf-btn-outline-full { width:100%; text-align:center; }


/* ═══════════════════════════════════════════════════════════════
   EXISTING SHORTCODES (Standalone)
   ═══════════════════════════════════════════════════════════════ */
.ssf-event-card { display:block; background:var(--bg); border:1px solid var(--bd); border-radius:var(--r2); overflow:hidden; transition:box-shadow .25s var(--ez),transform .25s var(--ez); text-decoration:none; color:inherit; }
.ssf-event-card:hover { box-shadow:var(--sh2); transform:translateY(-2px); }
.ssf-event-card-image { position:relative; width:100%; aspect-ratio:16/10; overflow:hidden; background:var(--bg2); }
.ssf-event-card-badge { position:absolute; top:.625rem; right:.625rem; background:var(--g); color:#fff; padding:.2rem .65rem; border-radius:5px; font-size:.6875rem; font-weight:700; }
.ssf-event-card-body { padding:1rem; }
.ssf-event-card-title { font-size:1rem; font-weight:700; color:var(--tx); margin-bottom:.25rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ssf-event-card-meta { font-size:.8125rem; color:var(--tx2); margin-bottom:.5rem; }
.ssf-event-card-footer { display:flex; justify-content:space-between; align-items:center; font-size:.75rem; }
.ssf-event-card-count { font-weight:700; color:var(--g); }
.ssf-event-card-liga { color:var(--tx3); }
.ssf-event-card-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; background:var(--bg2); }

/* Gallery */
.ssf-gallery-item { aspect-ratio:1; overflow:hidden; border-radius:var(--r); background:var(--bg2); }
.ssf-gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .3s var(--ez); }
.ssf-gallery-item:hover img { transform:scale(1.05); }

/* Lightbox */
.ssf-lightbox { position:fixed; inset:0; z-index:99999; background:rgba(0,0,0,.94); display:flex; align-items:center; justify-content:center; padding:2rem; }
.ssf-lightbox-image { max-width:90vw; max-height:85vh; object-fit:contain; border-radius:var(--r); }
.ssf-lightbox-close { position:absolute; top:1rem; right:1.5rem; color:#fff; font-size:2rem; background:none; border:none; cursor:pointer; z-index:10; opacity:.7; transition:opacity .2s; }
.ssf-lightbox-close:hover { opacity:1; }
.ssf-lightbox-nav { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.12); color:#fff; border:none; padding:.75rem 1rem; font-size:1.25rem; border-radius:var(--r); cursor:pointer; backdrop-filter:blur(4px); transition:background .2s; z-index:10; }
.ssf-lightbox-nav:hover { background:rgba(255,255,255,.22); }
.ssf-lightbox-prev { left:1rem; }
.ssf-lightbox-next { right:1rem; }
.ssf-lightbox-caption { position:absolute; bottom:0; left:0; right:0; padding:1.5rem 2rem; background:linear-gradient(transparent,rgba(0,0,0,.7)); color:#fff; font-size:.875rem; }

/* Hero standalone */
.ssf-hero { position:relative; padding:4rem 2rem; text-align:center; background:linear-gradient(135deg,#0d1a06,#1a3a0a,#2d5a10); color:#fff; border-radius:var(--r3); overflow:hidden; }
.ssf-hero-content { max-width:800px; margin:0 auto; }
.ssf-hero-title { font-size:2.5rem; font-weight:900; margin-bottom:.5rem; }
.ssf-hero-subtitle { font-size:1.25rem; opacity:.85; font-weight:300; }

/* Stats */
.ssf-stat-item { text-align:center; padding:1.5rem; }
.ssf-stat-number { display:block; font-size:2rem; font-weight:800; color:var(--tx); }
.ssf-stat-label { display:block; font-size:.8125rem; color:var(--tx2); text-transform:uppercase; margin-top:.25rem; }

/* Search */
.ssf-search-dropdown { position:absolute; top:100%; left:0; right:0; margin-top:.25rem; background:var(--bg); border:1px solid var(--bd); border-radius:var(--r); box-shadow:var(--sh2); z-index:50; max-height:20rem; overflow-y:auto; }
.ssf-search-result { display:block; padding:.75rem 1rem; border-bottom:1px solid var(--bd); text-decoration:none; color:var(--tx); transition:background .15s; }
.ssf-search-result:last-child { border-bottom:none; }
.ssf-search-result:hover { background:var(--bg2); }

/* Sport tiles */
.ssf-sport-tile { display:flex; flex-direction:column; align-items:center; padding:1.25rem .75rem; background:var(--bg); border:1px solid var(--bd); border-radius:var(--r2); text-align:center; text-decoration:none; color:inherit; transition:all .25s var(--ez); }
.ssf-sport-tile:hover { border-color:var(--g); box-shadow:var(--sh); transform:translateY(-2px); }
.ssf-sport-tile-icon { font-size:1.5rem; width:2.75rem; height:2.75rem; display:flex; align-items:center; justify-content:center; background:var(--gl); border-radius:50%; margin-bottom:.5rem; }
.ssf-sport-tile-name { font-size:.8125rem; font-weight:700; color:var(--tx); }
.ssf-sport-tile-count { font-size:.6875rem; color:var(--tx3); }

/* Slider / Latest */
.ssf-slider { position:relative; overflow:hidden; }
.ssf-slider-track { display:flex; gap:1rem; transition:transform .3s ease; }
.ssf-slider-card { flex:0 0 300px; background:var(--bg); border:1px solid var(--bd); border-radius:var(--r2); overflow:hidden; text-decoration:none; color:inherit; }
.ssf-slider-card-image { width:100%; aspect-ratio:16/10; overflow:hidden; background:var(--bg2); }
.ssf-latest-list-item { display:flex; align-items:center; gap:1rem; padding:.75rem; border:1px solid var(--bd); border-radius:var(--r); text-decoration:none; color:inherit; transition:all .2s; }
.ssf-latest-list-item:hover { background:var(--bg2); border-color:var(--g); }
.ssf-latest-list-image { width:5rem; height:3.5rem; border-radius:var(--r); overflow:hidden; flex-shrink:0; background:var(--bg2); }

/* Photographer Cards */
.ssf-photographer-card { display:flex; flex-direction:column; align-items:center; padding:1.5rem 1rem; background:var(--bg); border:1px solid var(--bd); border-radius:var(--r2); text-align:center; }
.ssf-photographer-avatar { width:4rem; height:4rem; border-radius:50%; overflow:hidden; background:var(--gl); margin-bottom:.75rem; display:flex; align-items:center; justify-content:center; }
.ssf-photographer-avatar img { width:100%; height:100%; object-fit:cover; }
.ssf-photographer-initials { font-size:1.125rem; font-weight:700; color:var(--g); }
.ssf-photographer-name { font-size:.875rem; font-weight:700; color:var(--tx); }
.ssf-photographer-city { font-size:.75rem; color:var(--tx3); }
.ssf-photographer-stats { display:flex; gap:.75rem; margin-top:.5rem; font-size:.7rem; color:var(--tx2); font-weight:600; }

/* Badges / Filters */
.ssf-badge { display:inline-flex; align-items:center; padding:.125rem .625rem; font-size:.75rem; font-weight:700; border-radius:6px; background:var(--gl); color:var(--gd); }
.ssf-filters { background:var(--bg); padding:1rem 1.25rem; border:1px solid var(--bd); border-radius:var(--r2); }


/* ═══════════════════════════════════════════════════════════════
   UPCOMING EVENTS (ohne Bilder)
   ═══════════════════════════════════════════════════════════════ */
.ssf-upcoming-grid { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; }
.ssf-upcoming-card {
    display:flex; align-items:center; gap:1rem; padding:1rem 1.25rem;
    background:var(--bg); border:1px solid var(--bd); border-radius:var(--r2);
    text-decoration:none; color:inherit; transition:all .2s var(--ez);
    min-width:0; overflow:hidden;
}
.ssf-upcoming-card:hover { border-color:var(--g); box-shadow:var(--sh); transform:translateY(-1px); }
.ssf-upcoming-icon {
    flex-shrink:0; width:2.75rem; height:2.75rem; display:flex; align-items:center; justify-content:center;
    background:var(--bg2); border-radius:var(--r); color:var(--tx3);
}
.ssf-upcoming-info { flex:1; min-width:0; overflow:hidden; }
.ssf-upcoming-info h4 { font-size:.875rem; font-weight:700; color:var(--tx); margin:0 0 .15rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ssf-upcoming-meta { font-size:.75rem; color:var(--tx2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ssf-upcoming-sport { color:var(--g); font-weight:600; }
.ssf-upcoming-status {
    flex-shrink:0; font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em;
    padding:.25rem .625rem; background:#FEF3C7; color:#92400E; border-radius:5px;
}


/* ═══════════════════════════════════════════════════════════════
   FEATURED (Redaktion empfiehlt)
   ═══════════════════════════════════════════════════════════════ */
.ssf-featured { padding:2.5rem 0; }
.ssf-featured-head {
    display:flex; align-items:center; gap:1.5rem; margin-bottom:1.5rem;
    flex-wrap:wrap;
}
.ssf-featured-head h2 { margin:0; font-size:1.5rem; font-weight:800; color:var(--tx); white-space:nowrap; }
.ssf-featured-tabs {
    display:flex; gap:.25rem; overflow-x:auto; scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
}
.ssf-featured-tabs::-webkit-scrollbar { display:none; }
.ssf-ftab {
    padding:.375rem .875rem; font-size:.75rem; font-weight:600;
    background:transparent; border:1px solid transparent;
    border-radius:var(--r); color:var(--tx2); cursor:pointer;
    white-space:nowrap; transition:all .2s;
}
.ssf-ftab:hover { color:var(--tx); background:var(--bg); }
.ssf-ftab.is-active { color:var(--tx); border-bottom:2px solid var(--g); font-weight:700; }

.ssf-featured-scroll-wrap { position:relative; }
.ssf-featured-scroll {
    display:flex; gap:1rem; overflow-x:auto; scroll-snap-type:x mandatory;
    scroll-behavior:smooth; -webkit-overflow-scrolling:touch;
    scrollbar-width:none; padding:0 0 .5rem;
}
.ssf-featured-scroll::-webkit-scrollbar { display:none; }

.ssf-featured-arrow {
    position:absolute; top:50%; transform:translateY(-50%); z-index:2;
    width:2.25rem; height:2.25rem; border-radius:50%;
    background:rgba(255,255,255,.95); border:1px solid var(--bd);
    display:flex; align-items:center; justify-content:center;
    font-size:1.25rem; color:var(--tx2); cursor:pointer;
    box-shadow:0 2px 8px rgba(0,0,0,.1); transition:all .2s;
}
.ssf-featured-arrow:hover { background:#fff; color:var(--g); border-color:var(--g); }
.ssf-featured-arrow-l { left:-.75rem; }
.ssf-featured-arrow-r { right:-.75rem; }

/* Featured Card */
.ssf-fcard {
    flex:0 0 260px; scroll-snap-align:start;
    border-radius:var(--r2); overflow:hidden;
    background:var(--bg); border:1px solid var(--bd);
    text-decoration:none; color:var(--tx);
    transition:transform .2s, box-shadow .2s;
    display:flex; flex-direction:column;
}
.ssf-fcard:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.1); }
.ssf-fcard-hero { flex:0 0 320px; }

.ssf-fcard-img {
    position:relative; height:180px; overflow:hidden;
    background:var(--bg2);
}
.ssf-fcard-hero .ssf-fcard-img { height:240px; }
.ssf-fcard-img img { width:100%; height:100%; object-fit:cover; }
.ssf-fcard-noimg {
    width:100%; height:100%; display:flex; align-items:center;
    justify-content:center; background:var(--bg2); color:var(--tx3);
}
.ssf-fcard-badge {
    position:absolute; top:.5rem; right:.5rem;
    background:var(--g); color:#fff; font-size:.625rem; font-weight:700;
    padding:.2rem .5rem; border-radius:3px; text-transform:uppercase;
    letter-spacing:.03em;
}

.ssf-fcard-info { padding:.875rem; flex:1; display:flex; flex-direction:column; }
.ssf-fcard-info h3 {
    font-size:.875rem; font-weight:800; color:#1C1C1C; margin:0 0 .375rem;
    line-height:1.3;
    display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
    overflow:hidden;
}
.ssf-fcard-hero .ssf-fcard-info h3 { font-size:1.0625rem; }
.ssf-fcard-meta { font-size:.75rem; color:#6B7280; font-weight:500; margin-bottom:.25rem; }
.ssf-fcard-sub { font-size:.6875rem; color:var(--tx3); margin-bottom:.5rem; }
.ssf-fcard-count { margin-left:.5rem; }
.ssf-fcard-cta {
    display:inline-block; margin-top:auto;
    font-size:.6875rem; font-weight:700; color:#fff;
    background:var(--g); padding:.3rem .75rem; border-radius:4px;
    align-self:flex-start;
}

/* ═══════════════════════════════════════════════════════════════
   FEATURED V2 (Redaktion empfiehlt – Grid-Layout)
   ═══════════════════════════════════════════════════════════════ */
.ssf-featured2 { padding:2rem 0; }
.ssf-featured2-head {
    display:flex; align-items:center; gap:1.5rem; margin-bottom:1.25rem;
    flex-wrap:wrap;
}
.ssf-featured2-head h2 { margin:0; font-size:1.375rem; font-weight:800; color:var(--tx); white-space:nowrap; }
.ssf-featured2-tabs {
    display:flex; gap:.125rem; overflow-x:auto; scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
}
.ssf-featured2-tabs::-webkit-scrollbar { display:none; }
.ssf-f2tab {
    padding:.375rem .75rem; font-size:.75rem; font-weight:500;
    background:transparent; border:none; border-bottom:2px solid transparent;
    color:var(--tx2); cursor:pointer; white-space:nowrap; transition:all .2s;
}
.ssf-f2tab:hover { color:var(--tx); }
.ssf-f2tab.is-active { color:var(--tx); border-bottom-color:var(--tx); font-weight:700; }

/* Mobile sport dropdown (hidden on desktop) */
.ssf-f2tabs-mobile { display:none; }
.ssf-f2-select {
    width:100%; padding:.625rem .875rem; font-size:.875rem; font-weight:600;
    border:1px solid var(--bd); border-radius:var(--r); background:var(--bg); color:var(--tx);
    appearance:none; -webkit-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='%236B7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat:no-repeat; background-position:right .75rem center;
    cursor:pointer; outline:none; transition:border-color .2s;
}
.ssf-f2-select:focus { border-color:var(--g); }

/* Main Grid: single grid, 4 columns, 2 rows */
.ssf-f2-grid {
    display:grid;
    grid-template-columns:1.3fr 1fr 1fr 1fr;
    grid-template-rows:1fr 1fr;
    grid-template-areas:
        "hero c1 c2 c3"
        "hero t1 t2 t3";
    gap:.875rem;
    height:520px;
}

/* Hero card: image fills space, info at bottom */
.ssf-f2-hero {
    grid-area:hero;
    border-radius:var(--r2); overflow:hidden;
    background:var(--bg); border:1px solid var(--bd);
    text-decoration:none; color:var(--tx);
    display:flex; flex-direction:column;
    transition:transform .2s, box-shadow .2s;
}
.ssf-f2-hero:hover { transform:translateY(-2px); box-shadow:var(--sh2); }
.ssf-f2-hero-img {
    position:relative; flex:1; overflow:hidden;
    background:var(--bg2); min-height:0;
}
.ssf-f2-hero-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ssf-f2-hero-noimg { width:100%; height:100%; background:linear-gradient(135deg,#1a2a10,#2d4a14); }
.ssf-f2-hero .ssf-f2-card-info { padding:1rem; flex-shrink:0; height:6.5rem; overflow:hidden; }
.ssf-f2-hero .ssf-f2-card-info h4 {
    font-size:1.0625rem; font-weight:800; color:#1C1C1C;
    -webkit-line-clamp:2;
}
.ssf-f2-hero-foot { font-size:.6875rem; color:#9CA3AF; margin-top:.25rem; }
.ssf-f2-hero-foot span + span { margin-left:.75rem; }

/* Right-side cards (row 1) */
.ssf-f2-card {
    border-radius:var(--r2); overflow:hidden;
    background:var(--bg); border:1px solid var(--bd);
    text-decoration:none; color:var(--tx);
    display:flex; flex-direction:column;
    transition:transform .2s, box-shadow .2s;
}
.ssf-f2-card:hover { transform:translateY(-2px); box-shadow:var(--sh2); }
.ssf-f2-card-img {
    position:relative; flex:1; overflow:hidden;
    background:var(--bg2); min-height:0;
}
.ssf-f2-card-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ssf-f2-card-noimg { width:100%; height:100%; background:var(--bg2); }
.ssf-f2-badge {
    position:absolute; top:.5rem; right:.5rem;
    background:var(--g); color:#fff; font-size:.5625rem; font-weight:700;
    padding:.15rem .4rem; border-radius:3px; text-transform:uppercase;
}
.ssf-f2-card-info { padding:.75rem; flex-shrink:0; height:5.5rem; overflow:hidden; }
.ssf-f2-card-info h4 {
    font-size:.875rem; font-weight:800; margin:0 0 .25rem; color:#1C1C1C;
    line-height:1.3;
    display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.ssf-f2-card-meta { font-size:.75rem; color:#6B7280; font-weight:500; }

/* Thumbnails (row 2, right side) */
.ssf-f2-thumb {
    position:relative; border-radius:var(--r); overflow:hidden;
    text-decoration:none;
    transition:transform .2s;
}
.ssf-f2-thumb:hover { transform:translateY(-2px); }
.ssf-f2-thumb-img { position:absolute; inset:0; background:var(--bg2); overflow:hidden; }
.ssf-f2-thumb-img img { width:100%; height:100%; object-fit:cover; }
.ssf-f2-thumb-noimg { width:100%; height:100%; background:var(--bg2); }
.ssf-f2-thumb-overlay {
    position:absolute; bottom:0; left:0; right:0;
    padding:.625rem .75rem; display:flex; align-items:center; justify-content:space-between;
    background:linear-gradient(to top, rgba(0,0,0,.8) 0%, rgba(0,0,0,.3) 60%, transparent 100%);
    color:#fff;
}
.ssf-f2-thumb-sport { font-size:.6875rem; font-weight:600; }
.ssf-f2-thumb-cta {
    font-size:.5625rem; font-weight:700; color:#fff;
    background:var(--g); padding:.2rem .5rem; border-radius:3px;
}

/* ═══════════════════════════════════════════════════════════════
   CATEGORIES (Live / Trending / Neu)
   ═══════════════════════════════════════════════════════════════ */
.ssf-categories { padding:0 0 1rem; }
.ssf-cat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }

.ssf-cat-box {
    display:flex; align-items:center; gap:1rem;
    padding:1.25rem 1.5rem; border-radius:var(--r2);
    background:var(--bg); border:1px solid var(--bd);
    text-decoration:none; color:var(--tx);
    transition:all .2s;
}
.ssf-cat-box:hover { border-color:var(--g); box-shadow:0 4px 12px rgba(0,0,0,.06); }

.ssf-cat-icon {
    position:relative; width:2.75rem; height:2.75rem; flex-shrink:0;
    display:flex; align-items:center; justify-content:center;
    border-radius:50%; background:var(--bg2); color:var(--g);
}
.ssf-cat-dot-pulse {
    position:absolute; top:0; right:0;
    width:.5rem; height:.5rem; border-radius:50%;
    background:#EF4444;
    animation:ssf-pulse 2s ease-in-out infinite;
}
@keyframes ssf-pulse { 0%,100%{ opacity:1; transform:scale(1); } 50%{ opacity:.5; transform:scale(1.3); } }

.ssf-cat-text { flex:1; min-width:0; }
.ssf-cat-text h3 { font-size:.9375rem; font-weight:700; margin:0; }
.ssf-cat-text h3 span { font-weight:400; color:var(--tx3); font-size:.8125rem; }
.ssf-cat-text p { font-size:.75rem; color:var(--tx3); margin:.125rem 0 0; line-height:1.3; }
.ssf-cat-arrow { flex-shrink:0; color:var(--tx3); transition:color .2s; }
.ssf-cat-box:hover .ssf-cat-arrow { color:var(--g); }

/* ═══════════════════════════════════════════════════════════════
   SPORT SHOWCASE (Top Shots by Sportart)
   ═══════════════════════════════════════════════════════════════ */
.ssf-showcase { padding:2.5rem 0; }

.ssf-showcase-wrap { position:relative; }
.ssf-showcase-scroll {
    display:flex; gap:1.25rem; overflow-x:auto; scroll-snap-type:x mandatory;
    scroll-behavior:smooth; -webkit-overflow-scrolling:touch;
    scrollbar-width:none; padding:0 0 .5rem;
}
.ssf-showcase-scroll::-webkit-scrollbar { display:none; }

.ssf-showcase-arrow {
    position:absolute; top:50%; transform:translateY(-50%); z-index:2;
    width:2.5rem; height:2.5rem; border-radius:50%;
    background:rgba(255,255,255,.95); border:1px solid var(--bd);
    display:flex; align-items:center; justify-content:center;
    font-size:1.375rem; color:var(--tx2); cursor:pointer;
    box-shadow:0 2px 8px rgba(0,0,0,.1); transition:all .2s;
}
.ssf-showcase-arrow:hover { color:var(--g); border-color:var(--g); }
.ssf-showcase-arrow-l { left:-.75rem; }
.ssf-showcase-arrow-r { right:-.75rem; }

.ssf-showcase-card {
    flex:0 0 280px; scroll-snap-align:start;
    text-decoration:none; color:#fff;
    border-radius:var(--r2); overflow:hidden;
    transition:transform .2s;
}
.ssf-showcase-card:hover { transform:translateY(-3px); }

.ssf-showcase-img {
    position:relative; height:200px; overflow:hidden;
    background:var(--bg2); border-radius:var(--r2);
}
.ssf-showcase-img img { width:100%; height:100%; object-fit:cover; }
.ssf-showcase-placeholder { width:100%; height:100%; background:linear-gradient(135deg,#1a1a2e,#16213e); }

.ssf-showcase-overlay {
    position:absolute; bottom:0; left:0; right:0;
    padding:1rem 1.25rem; display:flex; align-items:center; justify-content:space-between;
    background:linear-gradient(to top, rgba(0,0,0,.9) 0%, rgba(0,0,0,.55) 55%, transparent 100%);
}
.ssf-showcase-overlay h3 {
    font-size:.8125rem; font-weight:700; margin:0;
    background:rgba(0,0,0,.7); color:#fff;
    padding:.3rem .75rem; border-radius:5px;
    backdrop-filter:blur(4px);
    text-shadow:none;
}
.ssf-showcase-cta {
    font-size:.6875rem; font-weight:700; color:#fff;
    background:var(--g); padding:.3rem .625rem; border-radius:4px;
    white-space:nowrap;
}
.ssf-showcase-count {
    position:absolute; top:.625rem; right:.625rem;
    font-size:.6875rem; font-weight:700; color:#fff;
    background:var(--g); padding:.2rem .6rem; border-radius:4px;
}

/* ═══════════════════════════════════════════════════════════════
   NEWSLETTER
   ═══════════════════════════════════════════════════════════════ */
.ssf-newsletter { padding:0; }
.ssf-newsletter-inner {
    background:linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    border-radius:var(--r2); padding:2.5rem 3rem;
    color:#fff; text-align:center;
}
.ssf-newsletter-text h2 { font-size:1.5rem; font-weight:800; margin:0 0 .5rem; color:#fff; }
.ssf-newsletter-text h2 strong { color:var(--g); }
.ssf-newsletter-text p { font-size:.875rem; color:rgba(255,255,255,.7); margin:0 0 1.5rem; max-width:500px; margin-left:auto; margin-right:auto; }

.ssf-newsletter-form {
    display:flex; gap:.5rem; max-width:440px; margin:0 auto;
}
.ssf-newsletter-input {
    flex:1; padding:.75rem 1rem; border-radius:var(--r);
    border:1px solid rgba(255,255,255,.2); background:rgba(255,255,255,.1);
    color:#fff; font-size:.875rem; outline:none;
}
.ssf-newsletter-input::placeholder { color:rgba(255,255,255,.4); }
.ssf-newsletter-input:focus { border-color:var(--g); }

.ssf-newsletter-success {
    display:flex; align-items:center; justify-content:center;
    gap:.5rem; font-size:.875rem; color:var(--g);
}
.ssf-newsletter-hint {
    font-size:.6875rem; color:rgba(255,255,255,.4);
    margin:.75rem 0 0;
}


/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:1024px) {
    .ssf-events-layout { grid-template-columns:200px 1fr; gap:1rem; }
    .ssf-about-row { grid-template-columns:220px 1fr; gap:2rem; }
    .ssf-events-page-grid { grid-template-columns:repeat(2,1fr); }
    .ssf-f2tabs-desktop { display:none; }
    .ssf-f2tabs-mobile { display:block; max-width:280px; }
}

/* ── Tablet + Mobile ── */
@media (max-width:768px) {
    /* Header */
    .ssf-header-nav, .ssf-header-auth { display:none; }
    .ssf-header-burger { display:flex; }

    /* Hero v4 */
    .ssf-hero-v4 { padding:2rem 0 1.5rem; }
    .ssf-hero-v4-grid { grid-template-columns:1fr; gap:1.5rem; min-height:auto; }
    .ssf-hero-v4-title { font-size:2.25rem; }
    .ssf-hero-v4-right { order:-1; }

    .ssf-hero-v1 { min-height:420px; padding:3rem 1.25rem 1.5rem; }
    .ssf-hero-v1-stats { gap:1.25rem; }
    .ssf-hero-v1-content h1 { font-size:2rem; }

    .ssf-hero-v2 { min-height:380px; }
    .ssf-hero-v2-content { padding:3rem 1.25rem 4rem; }
    .ssf-hero-v2-stats { gap:1.25rem; padding:1rem; }
    .ssf-hstat-sep { display:none; }

    .ssf-hero-v3-grid { grid-template-columns:1fr; }
    .ssf-hero-v3-right { order:-1; }
    .ssf-hero-v3-card { bottom:auto; top:-.75rem; left:auto; right:-.5rem; }

    .ssf-qf-v1-card { flex-direction:column; }
    .ssf-qf-v1-col { min-width:100%; }
    .ssf-qf-v2-row { flex-direction:column; gap:.5rem; }
    .ssf-qf-v2-col { min-width:100%; }
    .ssf-qf-v3-row { flex-direction:column; gap:.5rem; }
    .ssf-qf-v3-col { min-width:100%; }

    /* Events: full width, sidebar collapsible */
    .ssf-events-layout { grid-template-columns:1fr; }

    .ssf-sidebar {
        position:static; padding:0;
        border:1px solid var(--bd); border-radius:var(--r2);
        overflow:hidden;
    }
    .ssf-sidebar-title-desktop { display:none; }
    .ssf-sidebar-toggle {
        display:flex; align-items:center; gap:.5rem; width:100%;
        padding:1rem 1.25rem; background:var(--bg); border:none;
        font-size:.8125rem; font-weight:800; letter-spacing:.04em;
        color:var(--tx); text-transform:uppercase; cursor:pointer;
    }
    .ssf-sidebar-body {
        display:none; padding:0 1.25rem 1.25rem;
    }
    .ssf-sidebar-body.is-open { display:block; }

    /* SWIPE CAROUSEL */
    .ssf-events-swipe,
    .ssf-events-swipe.ssf-events-cols-2,
    .ssf-events-swipe.ssf-events-cols-3,
    .ssf-events-swipe.ssf-events-cols-4,
    .ssf-events-swipe.ssf-events-swipe-3 {
        display:flex; gap:1rem;
        grid-template-columns:none;
        overflow-x:auto; overflow-y:hidden;
        scroll-snap-type:x mandatory;
        scroll-behavior:smooth;
        -webkit-overflow-scrolling:touch;
        scrollbar-width:none;
        padding-bottom:.5rem;
    }
    .ssf-events-swipe::-webkit-scrollbar { display:none; }

    .ssf-ecard-swipe {
        flex:0 0 80vw; max-width:320px;
        scroll-snap-align:start;
    }

    .ssf-swipe-hint {
        display:flex; justify-content:center; padding:.625rem 0 0;
        font-size:.7rem; color:var(--tx3); letter-spacing:.02em;
    }
    .ssf-swipe-loading { display:flex; }
    .ssf-swipe-end { display:block; }

    .ssf-about-row { grid-template-columns:1fr; }
    .ssf-about-img { max-height:280px; aspect-ratio:16/9; }
    .ssf-about-v2-inner { grid-template-columns:1fr; }
    .ssf-about-v2-stats { justify-content:center; }

    .ssf-duo-grid { grid-template-columns:1fr; gap:2rem; }
    .ssf-feature-grid { grid-template-columns:1fr; gap:1rem; }
    .ssf-upcoming-grid { grid-template-columns:1fr; }

    .ssf-cta-footer-inner { flex-direction:column; text-align:center; }
    .ssf-cta-footer-btns { justify-content:center; }

    .ssf-section { padding:2rem 0; }

    /* Featured v2 */
    .ssf-f2-grid {
        grid-template-columns:1fr;
        grid-template-rows:auto;
        grid-template-areas:
            "hero"
            "c1" "c2" "c3"
            "t1" "t2" "t3";
        height:auto;
    }
    .ssf-f2-hero { min-height:250px; }
    .ssf-f2-card { min-height:180px; }
    .ssf-featured2-head { flex-direction:column; align-items:flex-start; gap:.75rem; }
    .ssf-f2tabs-desktop { display:none; }
    .ssf-f2tabs-mobile { display:block; width:100%; }

    /* Featured v1 */
    .ssf-featured-head { flex-direction:column; align-items:flex-start; gap:.75rem; }
    .ssf-featured-arrow { display:none; }
    .ssf-fcard { flex:0 0 75vw; max-width:280px; }
    .ssf-fcard-hero { flex:0 0 80vw; max-width:300px; }

    /* Categories */
    .ssf-cat-grid { grid-template-columns:1fr; gap:.75rem; }
    .ssf-cat-box { padding:1rem 1.25rem; }

    /* Showcase */
    .ssf-showcase-arrow { display:none; }
    .ssf-showcase-card { flex:0 0 75vw; max-width:280px; }

    /* Newsletter */
    .ssf-newsletter-inner { padding:2rem 1.5rem; }
    .ssf-newsletter-form { flex-direction:column; }

    /* Events Page mobile */
    .ssf-page-events { padding:1rem 0 2rem; }
    .ssf-page-head { margin-bottom:1.25rem; }
    .ssf-page-title { font-size:1.25rem; }
    .ssf-events-page-grid { grid-template-columns:1fr; }

    /* Pagination: kompakter auf mobile */
    .ssf-pag { justify-content:center; flex-wrap:nowrap; overflow-x:auto; }
    .ssf-pag-info { display:none; }
    .ssf-pag-arrow { width:2.5rem; height:2.5rem; font-size:1rem; }
}

/* ── Small Mobile ── */
@media (max-width:480px) {
    .ssf-hero-v1 { min-height:360px; }
    .ssf-hero-v1-content h1 { font-size:1.75rem; }
    .ssf-hero-v2-text h1 { font-size:1.75rem; }
    .ssf-hero-v3-left h1 { font-size:1.75rem; }

    .ssf-ecard-swipe { flex:0 0 85vw; max-width:300px; }
    .ssf-fcard { flex:0 0 85vw; max-width:300px; }
    .ssf-fcard-hero { flex:0 0 85vw; max-width:300px; }
    .ssf-showcase-card { flex:0 0 85vw; max-width:280px; }

    .ssf-qf-v1 { margin-top:-1.5rem; }
    .ssf-upcoming-status { display:none; }

    .ssf-lightbox { padding:.5rem; }
    .ssf-lightbox-nav { padding:.5rem .625rem; font-size:1rem; }
}

/* ═══════════════════════════════════════════════════════════════
   LARGE SCREENS
   ═══════════════════════════════════════════════════════════════ */

/* ── Large Desktop (1440px+) ── */
@media (min-width:1440px) {
    .ssf-container { max-width:1360px; }

    /* Featured v2 */
    .ssf-f2-grid { height:580px; }
    .ssf-f2-hero .ssf-f2-card-info h4 { font-size:1.1875rem; }
    .ssf-f2-card-info h4 { font-size:.9375rem; }

    /* Events: with sidebar = 3 cols, page = 4 cols */
    .ssf-events-swipe { grid-template-columns:repeat(3,1fr); }
    .ssf-events-grid { grid-template-columns:repeat(3,1fr); }
    .ssf-events-page-grid { grid-template-columns:repeat(4,1fr); }

    /* Showcase */
    .ssf-showcase-card { flex:0 0 320px; }
    .ssf-showcase-img { height:230px; }

    /* Hero */
    .ssf-hero-v1 { min-height:560px; }
    .ssf-hero-v1-content h1 { font-size:3.5rem; }
    .ssf-hero-v4-title { font-size:3.5rem; }

    /* Categories */
    .ssf-cat-grid { grid-template-columns:repeat(4,1fr); }
}

/* ── Full HD / QHD (1920px+) ── */
@media (min-width:1920px) {
    .ssf-container { max-width:1680px; }

    /* Featured v2 */
    .ssf-f2-grid {
        height:660px;
        grid-template-columns:1.4fr 1fr 1fr 1fr;
        gap:1.125rem;
    }
    .ssf-f2-hero .ssf-f2-card-info h4 { font-size:1.375rem; }
    .ssf-f2-card-info h4 { font-size:1.0625rem; }
    .ssf-f2-card-info { height:6rem; padding:1rem; }
    .ssf-f2-card-meta { font-size:.8125rem; }
    .ssf-f2-hero .ssf-f2-card-info { height:7rem; }
    .ssf-featured2-head h2 { font-size:1.625rem; }
    .ssf-f2tab { font-size:.875rem; padding:.5rem 1rem; }
    .ssf-f2-badge { font-size:.625rem; padding:.25rem .625rem; }

    /* Events: with sidebar = 3 cols, page = 4 cols */
    .ssf-events-swipe { grid-template-columns:repeat(3,1fr); }
    .ssf-events-grid { grid-template-columns:repeat(3,1fr); }
    .ssf-events-page-grid { grid-template-columns:repeat(4,1fr); }
    .ssf-ecard-body h3 { font-size:1rem; }
    .ssf-ecard-body { padding:.875rem 1rem; }
    .ssf-events-layout { grid-template-columns:280px 1fr; }

    /* Section headings */
    .ssf-section-head h2 { font-size:1.625rem; }

    /* Showcase */
    .ssf-showcase-card { flex:0 0 380px; }
    .ssf-showcase-img { height:260px; }
    .ssf-showcase h2 { font-size:1.5rem; }

    /* Hero */
    .ssf-hero-v1 { min-height:640px; }
    .ssf-hero-v1-content h1 { font-size:4rem; }
    .ssf-hero-v1-sub { font-size:1.25rem; }
    .ssf-hero-v4-title { font-size:4rem; }

    /* Categories */
    .ssf-cat-grid { grid-template-columns:repeat(4,1fr); }
    .ssf-cat-box { padding:1.125rem 1.25rem; }

    /* About */
    .ssf-about-row { grid-template-columns:300px 1fr; }

    /* Sidebar */
    .ssf-sidebar-title-desktop { font-size:.875rem; }
    .ssf-sidebar-field label { font-size:.8125rem; }
    .ssf-sidebar-select, .ssf-sidebar-input { font-size:.875rem; padding:.5625rem .75rem; }

    /* Section spacing */
    .ssf-section { padding:3rem 0; }
    .ssf-featured2 { padding:2.5rem 0; }
}

/* ── Ultrawide / 4K (2560px+) – DISABLED, uncomment to activate ──
@media (min-width:2560px) {
    .ssf-container { max-width:2200px; }
    .ssf-f2-grid {
        height:780px;
        grid-template-columns:1.5fr 1fr 1fr 1fr;
        gap:1.5rem;
    }
    .ssf-f2-hero .ssf-f2-card-info h4 { font-size:1.5rem; }
    .ssf-f2-card-info h4 { font-size:1.1875rem; }
    .ssf-f2-card-info { height:7rem; padding:1.125rem; }
    .ssf-f2-hero .ssf-f2-card-info { height:8rem; }
    .ssf-f2-card-meta { font-size:.9375rem; }
    .ssf-f2-badge { font-size:.75rem; padding:.3rem .75rem; }
    .ssf-featured2-head h2 { font-size:2rem; }
    .ssf-f2tab { font-size:1rem; padding:.5rem 1.25rem; }
    .ssf-events-swipe { grid-template-columns:repeat(4,1fr); }
    .ssf-events-grid { grid-template-columns:repeat(4,1fr); }
    .ssf-events-page-grid { grid-template-columns:repeat(5,1fr); }
    .ssf-ecard-body h3 { font-size:1.125rem; }
    .ssf-ecard-body { padding:1rem 1.25rem; }
    .ssf-events-layout { grid-template-columns:320px 1fr; gap:2rem; }
    .ssf-ecard-badge { font-size:.6875rem; }
    .ssf-section-head h2 { font-size:1.875rem; }
    .ssf-showcase-card { flex:0 0 440px; }
    .ssf-showcase-img { height:300px; }
    .ssf-showcase h2 { font-size:1.75rem; }
    .ssf-showcase-overlay h3 { font-size:.9375rem; }
    .ssf-showcase-cta { font-size:.8125rem; padding:.375rem .75rem; }
    .ssf-showcase-count { font-size:.8125rem; padding:.25rem .625rem; }
    .ssf-hero-v1 { min-height:740px; }
    .ssf-hero-v1-content h1 { font-size:4.5rem; }
    .ssf-hero-v1-sub { font-size:1.375rem; }
    .ssf-hero-v4-title { font-size:4.5rem; }
    .ssf-hero-v4-grid { gap:3rem; }
    .ssf-cat-grid { grid-template-columns:repeat(5,1fr); gap:1.5rem; }
    .ssf-cat-box { padding:1.25rem 1.5rem; }
    .ssf-cat-text h3 { font-size:1.125rem; }
    .ssf-cat-text p { font-size:.875rem; }
    .ssf-about-row { grid-template-columns:380px 1fr; gap:3rem; }
    .ssf-sidebar { padding:1.5rem; }
    .ssf-sidebar-title-desktop { font-size:1rem; }
    .ssf-sidebar-field label { font-size:.875rem; }
    .ssf-sidebar-select, .ssf-sidebar-input { font-size:.9375rem; padding:.625rem .875rem; }
    .ssf-section { padding:4rem 0; }
    .ssf-featured2 { padding:3rem 0; }
}


/* ═══════════════════════════════════════════════════════════════
   DESCRIPTION V1 – SpeedShot Plattform-Beschreibung
   ═══════════════════════════════════════════════════════════════ */

/* Kopfbereich */
.ssf-desc-v1-head {
    text-align:center; max-width:680px; margin:0 auto 3rem;
}
.ssf-desc-v1-tag {
    display:inline-block; font-size:.6875rem; font-weight:800;
    letter-spacing:.12em; text-transform:uppercase;
    color:var(--g); margin-bottom:.75rem;
}
.ssf-desc-v1-head h2 {
    font-size:clamp(1.75rem,3.5vw,2.5rem); font-weight:400;
    color:var(--tx); line-height:1.15; margin:0 0 1rem;
}
.ssf-desc-v1-head h2 strong { font-weight:900; }
.ssf-desc-v1-lead {
    font-size:1.0625rem; color:var(--tx2); line-height:1.7; margin:0;
}

/* Feature-Kacheln */
.ssf-desc-v1-features {
    display:grid; grid-template-columns:repeat(2,1fr); gap:1.25rem;
    margin-bottom:3rem;
}
.ssf-desc-v1-feature {
    background:var(--bg); border:1px solid var(--bd); border-radius:var(--r2);
    padding:1.75rem 1.5rem; transition:box-shadow .2s var(--ez),transform .2s var(--ez);
}
.ssf-desc-v1-feature:hover {
    box-shadow:var(--sh2); transform:translateY(-2px);
}
.ssf-desc-v1-icon {
    width:2.5rem; height:2.5rem; border-radius:var(--r);
    background:var(--gl); color:var(--g);
    display:flex; align-items:center; justify-content:center;
    margin-bottom:1rem; flex-shrink:0;
}
.ssf-desc-v1-icon svg { width:1.125rem; height:1.125rem; }
.ssf-desc-v1-feature h3 {
    font-size:1rem; font-weight:700; color:var(--tx); margin:0 0 .5rem;
}
.ssf-desc-v1-feature p {
    font-size:.875rem; color:var(--tx2); line-height:1.65; margin:0;
}

/* Workflow */
.ssf-desc-v1-workflow {
    background:var(--bg2); border:1px solid var(--bd); border-radius:var(--r2);
    padding:2rem 2rem 2.25rem; margin-bottom:2.5rem;
}
.ssf-desc-v1-workflow-title {
    font-size:1rem; font-weight:800; color:var(--tx);
    text-transform:uppercase; letter-spacing:.05em;
    margin:0 0 1.75rem; text-align:center;
}
.ssf-desc-v1-steps {
    display:flex; align-items:center; gap:1rem; flex-wrap:wrap; justify-content:center;
}
.ssf-desc-v1-step {
    flex:1; min-width:160px; max-width:240px; text-align:center;
}
.ssf-desc-v1-step-num {
    display:inline-flex; align-items:center; justify-content:center;
    width:2rem; height:2rem; border-radius:50%;
    background:var(--g); color:#fff;
    font-size:.875rem; font-weight:800; margin-bottom:.75rem;
}
.ssf-desc-v1-step h4 {
    font-size:.9375rem; font-weight:700; color:var(--tx); margin:0 0 .375rem;
}
.ssf-desc-v1-step p {
    font-size:.8125rem; color:var(--tx2); line-height:1.55; margin:0;
}
.ssf-desc-v1-step-arrow {
    color:var(--tx3); flex-shrink:0; display:flex; align-items:center;
}

/* CTA-Zeile */
.ssf-desc-v1-cta {
    display:flex; align-items:center; justify-content:center;
    gap:1rem; flex-wrap:wrap;
}

/* Responsive */
@media (max-width:767px) {
    .ssf-desc-v1-features { grid-template-columns:1fr; }
    .ssf-desc-v1-steps { flex-direction:column; gap:.75rem; }
    .ssf-desc-v1-step-arrow { transform:rotate(90deg); }
    .ssf-desc-v1-step { max-width:100%; }
    .ssf-desc-v1-workflow { padding:1.5rem 1.25rem; }
}
@media (min-width:1024px) {
    .ssf-desc-v1-features { grid-template-columns:repeat(4,1fr); }
}

/* ── description-v2 ─────────────────────────────────────────────── */
.ssf-desc-v2-grid {
    display:grid; grid-template-columns:1fr; gap:3rem; align-items:center;
}
.ssf-desc-v2-tag {
    display:inline-block; font-size:.6875rem; font-weight:800;
    letter-spacing:.12em; text-transform:uppercase;
    color:var(--g); margin-bottom:.75rem;
}
.ssf-desc-v2-text h2 {
    font-size:clamp(1.625rem,3vw,2.25rem); font-weight:400;
    color:var(--tx); line-height:1.2; margin:0 0 1.25rem;
}
.ssf-desc-v2-text h2 strong { font-weight:900; }
.ssf-desc-v2-text > p {
    font-size:.9375rem; color:var(--tx2); line-height:1.75; margin:0 0 1rem;
}
.ssf-desc-v2-list {
    list-style:none; margin:.25rem 0 1.25rem; padding:0;
    display:flex; flex-direction:column; gap:.75rem;
}
.ssf-desc-v2-list li {
    display:flex; gap:.75rem; align-items:flex-start;
    font-size:.9rem; color:var(--tx2); line-height:1.6;
}
.ssf-desc-v2-list li svg {
    flex-shrink:0; margin-top:.2rem; color:var(--g);
}
.ssf-desc-v2-list li strong { color:var(--tx); }
.ssf-desc-v2-closing {
    font-size:.9rem; color:var(--tx2); line-height:1.75;
    border-left:3px solid var(--g); padding-left:1rem;
    margin:1.25rem 0 1.75rem !important;
}
.ssf-desc-v2-cta { display:flex; gap:.75rem; flex-wrap:wrap; align-items:center; }

/* Bild */
.ssf-desc-v2-media { position:relative; }
.ssf-desc-v2-img {
    width:100%; aspect-ratio:4/5; border-radius:var(--r2); overflow:hidden;
    object-fit:cover; display:block; background:var(--bg2);
}
.ssf-desc-v2-badge {
    position:absolute; bottom:1.5rem; left:-1rem;
    background:var(--dark); color:#fff; border-radius:var(--r2);
    padding:.875rem 1.125rem; display:flex; align-items:center; gap:.75rem;
    box-shadow:var(--sh2);
}
.ssf-desc-v2-badge svg { flex-shrink:0; color:var(--g-light); }
.ssf-desc-v2-badge strong { display:block; font-size:.9375rem; font-weight:800; color:#fff; }
.ssf-desc-v2-badge span { display:block; font-size:.75rem; color:rgba(255,255,255,.65); margin-top:.1rem; }

/* Responsive */
@media (max-width:767px) {
    .ssf-desc-v2-badge { left:.75rem; right:.75rem; }
    .ssf-desc-v2-img { aspect-ratio:16/9; }
}
@media (min-width:768px) {
    .ssf-desc-v2-grid { grid-template-columns:1fr 400px; }
}
@media (min-width:1024px) {
    .ssf-desc-v2-grid { grid-template-columns:1fr 460px; gap:4rem; }
}
@media (min-width:1280px) {
    .ssf-desc-v2-grid { grid-template-columns:1fr 500px; }
}

/* ── hero-v5 ─────────────────────────────────────────────────────── */
.ssf-hero-v5 {
    background:var(--bg); position:relative; overflow:hidden;
    padding:4.5rem 0 3.5rem;
}

/* Hintergrund-Blob (helles Grün oben rechts) */
.ssf-hero-v5-blob {
    position:absolute; top:-120px; right:-80px;
    width:560px; height:560px; border-radius:50%;
    background:radial-gradient(circle, rgba(107,143,35,.08) 0%, transparent 70%);
    pointer-events:none;
}

/* Grid */
.ssf-hero-v5-grid {
    display:grid; grid-template-columns:1fr; gap:2.5rem; align-items:center;
}

/* ── Linke Spalte ── */
.ssf-hero-v5-left {
    opacity:0; transform:translateY(18px);
    transition:opacity .55s var(--ez), transform .55s var(--ez);
}
.ssf-hero-v5-left.is-visible { opacity:1; transform:none; }

.ssf-hero-v5-tag {
    display:inline-flex; align-items:center; gap:.5rem;
    font-size:.7rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
    color:var(--g); margin-bottom:1.25rem;
}
.ssf-hero-v5-dot {
    width:8px; height:8px; border-radius:50%; background:var(--g);
    animation:ssf-v5-pulse 1.8s ease-in-out infinite;
}
@keyframes ssf-v5-pulse {
    0%,100% { opacity:1; transform:scale(1); }
    50%      { opacity:.5; transform:scale(1.3); }
}

.ssf-hero-v5-headline {
    font-size:clamp(2rem,4.5vw,3.5rem); font-weight:300; line-height:1.1;
    color:var(--tx); margin:0 0 1.25rem; letter-spacing:-.01em;
}
.ssf-hero-v5-headline strong { font-weight:900; color:var(--tx); }

.ssf-hero-v5-sub {
    font-size:.9375rem; color:var(--tx2); line-height:1.75;
    max-width:480px; margin:0 0 1.75rem;
}

.ssf-hero-v5-btns { display:flex; gap:.75rem; flex-wrap:wrap; align-items:center; margin-bottom:2rem; }

/* Stats */
.ssf-hero-v5-stats {
    display:flex; align-items:center; gap:1rem; flex-wrap:wrap;
}
.ssf-hero-v5-stat { display:flex; flex-direction:column; }
.ssf-hero-v5-stat strong { font-size:1.25rem; font-weight:800; color:var(--tx); line-height:1; }
.ssf-hero-v5-stat span { font-size:.75rem; color:var(--tx3); margin-top:.15rem; }
.ssf-hero-v5-sep {
    width:1px; height:2rem; background:var(--bd);
}

/* ── Rechte Spalte ── */
.ssf-hero-v5-right { position:relative; }

/* Grüne Deko-Box hinter dem Bild */
.ssf-hero-v5-deco {
    position:absolute; bottom:-1.5rem; right:-1rem;
    width:70%; height:80%;
    background:var(--gl); border-radius:var(--r3);
    z-index:0;
}

.ssf-hero-v5-img-wrap {
    position:relative; z-index:1;
    border-radius:var(--r3); overflow:visible;
}

.ssf-hero-v5-img {
    width:100%; aspect-ratio:3/4; object-fit:cover;
    border-radius:var(--r3);
    display:block;
    box-shadow:var(--sh3);
}
.ssf-hero-v5-img-ph {
    width:100%; aspect-ratio:3/4; border-radius:var(--r3);
    background:var(--bg2); display:flex; align-items:center; justify-content:center;
    box-shadow:var(--sh3);
}

/* Speed-Badge */
.ssf-hero-v5-badge {
    position:absolute; bottom:1.75rem; left:-1.25rem;
    background:#fff; border-radius:var(--r2);
    padding:.875rem 1.125rem;
    display:flex; align-items:center; gap:.75rem;
    box-shadow:var(--sh2); border:1px solid var(--bd);
}
.ssf-hero-v5-badge-icon {
    width:2rem; height:2rem; border-radius:var(--r);
    background:var(--g); color:#fff;
    display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.ssf-hero-v5-badge strong {
    display:block; font-size:.9rem; font-weight:800; color:var(--tx); line-height:1.1;
}
.ssf-hero-v5-badge span {
    display:block; font-size:.7rem; color:var(--tx2); margin-top:.15rem;
}

/* Agenturen-Pill */
.ssf-hero-v5-pill {
    position:absolute; top:1.25rem; right:-1rem;
    background:#fff; border:1px solid var(--bd);
    border-radius:99px; padding:.45rem 1rem;
    font-size:.75rem; font-weight:600; color:var(--tx2);
    display:flex; align-items:center; gap:.5rem;
    box-shadow:var(--sh);
}
.ssf-hero-v5-pill-dot {
    width:6px; height:6px; border-radius:50%; background:var(--g); flex-shrink:0;
}

/* Responsive */
@media (max-width:767px) {
    .ssf-hero-v5 { padding:3rem 0 2.5rem; }
    .ssf-hero-v5-deco { display:none; }
    .ssf-hero-v5-badge { left:.75rem; bottom:1rem; }
    .ssf-hero-v5-pill { right:.75rem; top:.75rem; }
    .ssf-hero-v5-img { aspect-ratio:4/3; }
    .ssf-hero-v5-img-ph { aspect-ratio:4/3; }
}
@media (min-width:768px) {
    .ssf-hero-v5-grid { grid-template-columns:1fr 420px; gap:3rem; }
}
@media (min-width:1024px) {
    .ssf-hero-v5 { padding:5.5rem 0 4rem; }
    .ssf-hero-v5-grid { grid-template-columns:1fr 460px; gap:4rem; }
}
@media (min-width:1280px) {
    .ssf-hero-v5-grid { grid-template-columns:1fr 500px; gap:5rem; }
}

/* ── Hero-v4 Events-Slider ─────────────────────────────────────────────────── */

/* Custom-BG Variante */
.ssf-hero-v4--custom-bg .ssf-hero-v4-bg {
    background-size: cover;
    background-position: center;
}

/* Slider-Container */
.ssf-hero-v4-slider {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    border-radius: .75rem;
}

/* Einzelner Slide */
.ssf-hero-v4-slide {
    position: absolute;
    inset: 0;
    display: block;
    opacity: 0;
    pointer-events: none;
    transition: opacity .5s ease;
    text-decoration: none;
    color: inherit;
}

.ssf-hero-v4-slide.is-active {
    opacity: 1;
    pointer-events: auto;
    z-index: 2;
}

.ssf-hero-v4-slide.is-prev {
    opacity: 0;
    z-index: 1;
}

/* Bild-Bereich */
.ssf-hero-v4-slide-img {
    position: absolute;
    inset: 0;
}

.ssf-hero-v4-slide-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.ssf-hero-v4-slide-noimg {
    width: 100%;
    height: 100%;
    background: #1a1a2e;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Info-Overlay */
.ssf-hero-v4-slide-info {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 2rem 1.25rem 1.25rem;
    background: linear-gradient(to top, rgba(0,0,0,.82) 0%, rgba(0,0,0,0) 100%);
    color: #fff;
    z-index: 3;
}

.ssf-hero-v4-slide-badges {
    display: flex;
    gap: .375rem;
    flex-wrap: wrap;
    margin-bottom: .375rem;
}

.ssf-hero-v4-badge-sport,
.ssf-hero-v4-badge-liga {
    font-size: .65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    padding: .125rem .45rem;
    border-radius: 3px;
    line-height: 1.5;
}

.ssf-hero-v4-badge-sport {
    background: var(--ssf-green, #00c853);
    color: #000;
}

.ssf-hero-v4-badge-liga {
    background: rgba(255,255,255,.18);
    color: #fff;
}

.ssf-hero-v4-slide-title {
    font-size: .9rem;
    font-weight: 700;
    margin: 0 0 .25rem;
    line-height: 1.3;
    color: #fff;
}

.ssf-hero-v4-slide-meta {
    font-size: .72rem;
    color: rgba(255,255,255,.7);
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .25rem;
}

.ssf-hero-v4-slide-count {
    margin-left: auto;
    font-size: .7rem;
    color: rgba(255,255,255,.6);
}

/* Dots */
.ssf-hero-v4-dots {
    position: absolute;
    bottom: .6rem;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: .3rem;
    z-index: 10;
}

.ssf-hero-v4-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(255,255,255,.4);
    border: none;
    cursor: pointer;
    padding: 0;
    transition: background .25s, transform .25s;
}

.ssf-hero-v4-dot.is-active {
    background: #fff;
    transform: scale(1.3);
}

/* Prev/Next */
.ssf-hero-v4-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    background: rgba(0,0,0,.45);
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 32px;
    height: 32px;
    font-size: 1.3rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .2s;
    padding: 0;
}

.ssf-hero-v4-slider:hover .ssf-hero-v4-nav {
    opacity: 1;
}

.ssf-hero-v4-nav--prev { left: .5rem; }
.ssf-hero-v4-nav--next { right: .5rem; }

.ssf-hero-v4-nav:hover {
    background: rgba(0,0,0,.7);
}
