/**
 * 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] { 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; }

/* ═══ 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:url('https://images.unsplash.com/photo-1517466787929-bc90951d0974?w=1600&q=80') 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%),url('https://images.unsplash.com/photo-1574629810360-7efbbe195018?w=1600&q=80') right 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:url('https://images.unsplash.com/photo-1574629810360-7efbbe195018?w=800&q=80') center/cover no-repeat; }
.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); }


/* ═══════════════════════════════════════════════════════════════
   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:.875rem; font-weight:700; color:var(--tx); margin:0 0 .2rem; line-height:1.35; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.ssf-ecard-city { font-size:.75rem; color:var(--tx2); }
.ssf-ecard-meta { font-size:.75rem; color:var(--tx2); 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:url('https://images.unsplash.com/photo-1552674605-db6ffd4facb5?w=600&q=80') center/cover no-repeat; }
.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:url('https://images.unsplash.com/photo-1461896836934-bd45ba7e4cac?w=1600&q=80') 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-image:url('https://images.unsplash.com/photo-1461896836934-bd45ba7e4cac?w=800&q=80'); }
.ssf-duo-img-blog { background-image:url('https://images.unsplash.com/photo-1579952363873-27f3bade9f55?w=800&q=80'); }
.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;
}


/* ═══════════════════════════════════════════════════════════════
   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); }
}

/* ── Tablet + Mobile ── */
@media (max-width:768px) {
    .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%; }

    /* 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; }

    /* 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-qf-v1 { margin-top:-1.5rem; }
    .ssf-upcoming-status { display:none; }

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