/* ============================================
   NEXT DESTINY ESPORTS — Homepage Styles
   Based on nde-website-v2 design system
   ============================================ */
:root{--bg:#0e0e0e;--bg2:#141414;--bg3:#1a1a1a;--card:rgba(255,255,255,0.025);--card2:rgba(255,255,255,0.04);--border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.12);--accent:#f93d00;--accent2:#ff7447;--accent3:#ff9b75;--magenta:#ff7447;--cyan:#f93d00;--cyan2:#ff7447;--pink:#ff7447;--green:#10b981;--orange:#f59e0b;--red:#ef4444;--glow:rgba(249,61,0,.35);--text:#e4e4ec;--text2:#8585a0;--text3:#52526a;--font:'Inter',system-ui,-apple-system,sans-serif;--font2:'Inter',system-ui,-apple-system,sans-serif;--grad:linear-gradient(135deg,#f93d00,#ff7447);--grad-h:linear-gradient(to right,#f93d00,#ff7447);--clip-btn:none;--clip-tag:none;--r:12px;--r2:16px;--r3:20px;--ease:cubic-bezier(.4,0,.2,1);--nav-h:80px;--glass:rgba(255,255,255,0.04);--glass-border:rgba(255,255,255,0.07);--glass-border-hover:rgba(255,255,255,0.12);--transition:0.25s cubic-bezier(.4,0,.2,1);--nav-bg:rgba(14,14,14,.9);--menu-bg:rgba(20,20,20,.97)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;background:var(--bg);overscroll-behavior-y:none}
body{background-color:var(--bg);color:var(--text);font-family:var(--font);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.6}
a{color:inherit;text-decoration:none}button{font-family:var(--font);cursor:pointer;border:none;background:none;color:inherit}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}
#nav{position:fixed;top:0;left:0;right:0;z-index:500;height:var(--nav-h);padding:16px 0;transition:var(--transition)}
#nav.scrolled{background:var(--nav-bg);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:10px 0}
.nav-inner{padding:0 32px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;position:relative}
.nav-logo{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.nav-logo-img{width:56px;height:56px;object-fit:contain;flex-shrink:0;border-radius:8px}
.nav-name{font-size:1.1rem;font-weight:800;letter-spacing:-0.02em;white-space:nowrap}
/* Phoenix-Flammen-Effekt fürs Marken-Wortzeichen (per CMS-Toggle brand_flame). Animierter
   Feuer-Gradient als Text-Clip, der nach oben "leckt", plus Flacker-Glow. */
.nav-name-flame{background:linear-gradient(0deg,#c41200 0%,#ff2d00 30%,#ff5e00 62%,#ff7a1a 86%,#ff9b4d 100%);background-size:100% 220%;-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;animation:ndFlameRise 2.6s linear infinite,ndFlameFlicker 1.9s ease-in-out infinite;will-change:filter,background-position}
@keyframes ndFlameRise{0%{background-position:50% 100%}100%{background-position:50% -120%}}
@keyframes ndFlameFlicker{0%,100%{filter:drop-shadow(0 0 4px rgba(255,70,0,.6)) brightness(1)}20%{filter:drop-shadow(0 0 9px rgba(255,90,0,.85)) brightness(1.14)}45%{filter:drop-shadow(0 0 3px rgba(255,50,0,.5)) brightness(.95)}70%{filter:drop-shadow(0 0 11px rgba(255,110,0,.95)) brightness(1.18)}85%{filter:drop-shadow(0 0 6px rgba(255,80,0,.7)) brightness(1.05)}}
@media (prefers-reduced-motion:reduce){.nav-name-flame{animation:none;filter:drop-shadow(0 0 6px rgba(255,90,0,.6))}}
.nav-center{position:absolute;left:50%;transform:translateX(-50%);display:flex;gap:2px;align-items:center}.nav-link{color:var(--text2);padding:8px 14px;font-size:.875rem;font-weight:500;border-radius:8px;transition:var(--transition);white-space:nowrap}
.nav-link:hover{color:var(--text);background:var(--glass)}.nav-link.active{color:var(--accent)}
.nav-link-ext,.nav-subitem-ext,.nav-subitem-parent{display:inline-flex;align-items:center;gap:.35rem}
.nav-item-icons{display:inline-flex;align-items:center;gap:.28rem;margin-left:.25rem}
.nav-external-icon{width:.78rem;height:.78rem;opacity:.72;flex:0 0 auto}
.nav-dropdown-icon{width:.72rem;height:.72rem;opacity:.68;flex:0 0 auto;transition:transform .18s ease,opacity .18s ease}
.nav-right{display:flex;align-items:center;gap:.6rem}
.btn-login{background:var(--grad);color:#fff;padding:8px 20px;font-size:.82rem;font-weight:600;border-radius:50px;transition:var(--transition);text-decoration:none;box-shadow:0 2px 16px var(--glow)}.btn-login:hover{filter:brightness(1.15);transform:translateY(-1px)}
.btn-discord{background:rgba(88,101,242,.1);border:1px solid rgba(88,101,242,.3);color:#a5b4fc;padding:8px 20px;font-size:.82rem;font-weight:600;border-radius:50px;transition:var(--transition);text-decoration:none}.btn-discord:hover{background:rgba(88,101,242,.22)}
.btn-admin{background:var(--grad);color:#fff;padding:8px 20px;font-size:.82rem;font-weight:600;border-radius:50px;transition:var(--transition)}.btn-admin:hover{filter:brightness(1.1)}
.nav-burger{display:none;flex-direction:column;gap:5px;width:28px;padding:4px 0;cursor:pointer;background:none;border:none}
.nav-burger span{display:block;height:2px;background:var(--text);transition:var(--transition);border-radius:2px}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-mobile{display:none;flex-direction:column;background:var(--nav-bg);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:.3rem .9rem 1rem;max-height:calc(100dvh - 58px);overflow-y:auto;overscroll-behavior:contain}
.nav-mobile.open{display:flex}
/* Mobile-Nav-Einträge: volle Tap-Breite, klare Trenner, kollabierbare Gruppen. */
.nav-m-link{display:flex;align-items:center;gap:.45rem;width:100%;text-align:left;padding:.85rem .35rem;font:inherit;font-size:1rem;font-weight:600;color:var(--text);background:none;border:0;border-bottom:1px solid var(--border);border-radius:0;cursor:pointer;white-space:normal}
.nav-m-link:hover{color:var(--accent)}
.nav-m-link.active{color:var(--accent)}
.nav-m-group{border-bottom:1px solid var(--border)}
.nav-m-parent{border-bottom:0}
.nav-m-chev{margin-left:auto;display:inline-flex;align-items:center;padding-left:.5rem}
.nav-m-chev .nav-dropdown-icon{width:.85rem;height:.85rem;opacity:.8;transition:transform .2s ease}
.nav-m-group.is-open>.nav-m-parent .nav-dropdown-icon{transform:rotate(180deg)}
.nav-m-sub{display:none;flex-direction:column;margin:0 0 .35rem .35rem;padding-left:.7rem;border-left:2px solid var(--border)}
.nav-m-group.is-open>.nav-m-sub{display:flex}
.nav-m-sub .nav-m-link{font-size:.92rem;font-weight:500;color:var(--text2)}
.nav-m-sub .nav-m-link:last-child{border-bottom:0}
.nav-m-self{font-weight:600;color:var(--text)}
.nav-mobile .btn-discord,.nav-mobile .btn-login{display:flex;width:100%;margin-top:.7rem;text-align:center;justify-content:center}
/* Navbar-Rechts-Controls (Theme/Sprache/Burger) bleiben in EINER Topbar-Zeile rechts.
   Überschreibt die generische .nav-controls{width:100%}-Regel, die sie sonst unter das
   Logo umbricht. Höhere Spezifität (.nav-right.nav-controls) -> greift auch im Media-Query. */
.nav-right.nav-controls{width:auto;justify-content:flex-end}
/* Hover-Submenu (Desktop) */
.nav-dropdown{position:relative;display:inline-flex;align-items:center}
.nav-dropdown .nav-link{display:inline-flex;align-items:center;gap:.35rem}
.nav-submenu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(-6px);min-width:240px;background:var(--menu-bg);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:12px;padding:.5rem;display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,transform .18s ease,visibility 0s linear .22s;z-index:100;box-shadow:0 12px 32px rgba(0,0,0,.4)}
/* Kein overflow auf dem Submenü: overflow-y:auto erzwingt overflow-x:auto und damit
   (zusammen mit der ::before-Hoverbrücke) einen Scrollbalken (B-Issue #65). Das Menü
   ist kurz; es braucht kein Scrollen. top:100% schließt die Lücke zum Item (#66). */
.nav-dropdown-root > .nav-submenu-root{bottom:auto;overflow:visible;transform-origin:top center}
.nav-dropdown:hover > .nav-link .nav-dropdown-icon,.nav-dropdown:focus-within > .nav-link .nav-dropdown-icon{transform:rotate(180deg);opacity:1}
.nav-dropdown:hover > .nav-submenu,.nav-dropdown:focus-within > .nav-submenu{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0);transition:opacity .18s ease,transform .18s ease,visibility 0s linear 0s}
.nav-submenu::before{content:"";position:absolute;left:-16px;right:-16px;top:-10px;height:12px}
.nav-subitem{appearance:none;border:none;background:none;color:var(--text2);text-align:left;padding:.55rem .85rem;font-size:.86rem;font-weight:500;border-radius:8px;cursor:pointer;transition:background .15s ease,color .15s ease;white-space:nowrap;width:100%}
.nav-subitem:hover{background:var(--glass);color:var(--text)}
.nav-subitem.active{color:var(--accent)}
.nav-dropdown-nested{position:relative;display:block;width:100%}
.nav-dropdown-nested > .nav-subitem{justify-content:space-between}
.nav-dropdown-nested > .nav-subitem .nav-dropdown-icon{transform:rotate(-90deg)}
.nav-dropdown-nested:hover > .nav-subitem .nav-dropdown-icon,.nav-dropdown-nested:focus-within > .nav-subitem .nav-dropdown-icon{transform:rotate(0deg);opacity:1}
/* Dropdown-im-Dropdown (verschachtelt) öffnet zur SEITE (Flyout) — #67. Haupt-Dropdowns
   gehen nach unten, verschachtelte zur Seite. Dank overflow:visible am Root-Submenü (#65)
   wird das Flyout nicht mehr abgeschnitten. top/left überschreiben die geerbten Werte. */
.nav-submenu-nested{top:-.5rem;left:calc(100% + .45rem);transform:translateX(-6px);z-index:101}
.nav-dropdown-nested:hover > .nav-submenu-nested,.nav-dropdown-nested:focus-within > .nav-submenu-nested{transform:translateX(0)}
.nav-submenu-nested::before{left:-10px;right:auto;top:0;bottom:0;width:12px;height:auto}
@media(max-width:900px){.nav-dropdown{display:none}.nav-caret{display:none}.nav-submenu{display:none}}
.nav-desktop-only{display:inline-flex}
@media(max-width:900px){.nav-center{display:none}.nav-burger{display:flex}.nav-desktop-only{display:none}}
#app{display:flex;flex-direction:column;min-height:100vh}
#root{padding-top:var(--nav-h);flex:1}
.page{position:relative;z-index:1;animation:fadeUp .4s ease forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
/* ── CMS content page (Markdown body) ── */
.cms-page{max-width:880px;margin:0 auto;padding:2rem 0}
.cms-page-title{font-size:clamp(2rem,4vw,3rem);font-weight:900;letter-spacing:-0.02em;margin:0 0 1.6rem}
.cms-page-body{line-height:1.65;color:var(--text)}
.cms-page-body h1{font-size:2rem;font-weight:800;margin:1.6rem 0 .8rem}
.cms-page-body h2{font-size:1.5rem;font-weight:700;margin:1.3rem 0 .6rem}
.cms-page-body h3{font-size:1.2rem;font-weight:700;margin:1.1rem 0 .5rem}

/* ── Rich content (Editor-HTML / Legacy-Markdown aus dem Portal) ── */
.rich-content{line-height:1.65}
.rich-content p{margin:.45rem 0}
.rich-content p:empty{margin:0;height:.9em}
.rich-content h1{font-size:1.7rem;font-weight:800;margin:1.4rem 0 .6rem}
.rich-content h2{font-size:1.35rem;font-weight:700;margin:1.2rem 0 .5rem}
.rich-content h3{font-size:1.1rem;font-weight:700;margin:1rem 0 .4rem}
.rich-content h4,.rich-content h5,.rich-content h6{font-size:1rem;font-weight:700;margin:.9rem 0 .35rem}
.rich-content ul,.rich-content ol{margin:.45rem 0 .45rem 1.4rem;padding:0}
.rich-content ul{list-style:disc}
.rich-content ol{list-style:decimal}
.rich-content li{margin:.2rem 0}
.rich-content strong{font-weight:700}
.cms-builder-sec{padding-top:4rem;padding-bottom:4rem}
.cms-builder-container{margin:0 auto;display:grid;gap:1.4rem}
.cms-container-narrow{max-width:820px}.cms-container-wide{max-width:1180px}.cms-container-full{max-width:none}
.cms-container-muted{border:1px solid var(--border);border-radius:var(--r2);background:var(--bg2);padding:2rem}
.cms-container-accent{border:1px solid rgba(249,61,0,.28);border-radius:var(--r2);background:linear-gradient(135deg,rgba(249,61,0,.1),rgba(255,116,71,.05));padding:2rem}
.cms-builder-heading{max-width:860px;margin:0 auto;text-align:left}
.cms-builder-paragraph{max-width:860px;margin:0 auto;color:var(--text2);font-size:1rem;line-height:1.8}
.cms-builder-image{max-width:1040px;margin:0 auto}
.cms-builder-image img{width:100%;max-height:620px;border-radius:var(--r2);border:1px solid var(--border);background:var(--bg2)}
.cms-builder-image figcaption{margin-top:.6rem;color:var(--text3);font-size:.82rem;text-align:center}
.cms-builder-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}
.cms-builder-cardgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;max-width:1180px;margin:0 auto}
.cms-builder-stats{max-width:980px;margin:0 auto}
.rich-content em{font-style:italic;opacity:.95}
.rich-content u{text-decoration:underline}
.rich-content s,.rich-content del{text-decoration:line-through;opacity:.8}
.rich-content a{color:var(--accent);text-decoration:underline}
.rich-content a:hover{opacity:.85}
.rich-content code{background:var(--glass);border:1px solid var(--glass-border);border-radius:4px;padding:.1rem .35rem;font-family:ui-monospace,monospace;font-size:.92em}
.rich-content pre{background:rgba(0,0,0,.35);border:1px solid var(--glass-border);border-radius:8px;padding:.8rem 1rem;overflow-x:auto;margin:.6rem 0}
.rich-content pre code{background:none;border:none;padding:0}
.rich-content blockquote{border-left:2px solid var(--glass-border);margin:.6rem 0;padding-left:1em;color:var(--text2)}
.rich-content img{max-width:100%;border-radius:8px;margin:.6rem 0}
.rich-content hr{border:none;border-top:1px solid var(--glass-border);margin:1rem 0}
.rich-content table{border-collapse:collapse;margin:.6rem 0;width:100%}
.rich-content th,.rich-content td{border:1px solid var(--glass-border);padding:.35rem .6rem;text-align:left;vertical-align:top}
.rich-content th{font-weight:700;background:var(--glass)}
.ann-card-body.rich-content p{margin:.15rem 0}

/* ── Section image bands (CMS-managed) ── */
.section-band{position:relative;width:100%;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;margin:0}
/* Statisches Band: Bild in eigener Ebene (kein Zoom mehr) */
.section-band-bg{position:absolute;inset:0;z-index:1;background-position:center;background-repeat:no-repeat}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none!important}}
/* Sponsoren-Laufband */
.section-band-marquee{flex-direction:column;gap:.9rem;background:linear-gradient(180deg,var(--bg2),var(--bg));padding:1.4rem 0}
.section-band-marquee .section-band-inner{padding-bottom:.2rem}
.marquee{position:relative;z-index:2;width:100%;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;align-items:center;width:max-content;animation:marquee 38s linear infinite;will-change:transform}
.marquee-group{display:flex;align-items:center;gap:3.5rem;padding-right:3.5rem}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{display:flex;align-items:center;justify-content:center;height:60px;opacity:.78;filter:grayscale(.25);transition:opacity .25s ease,filter .25s ease,transform .25s ease}
.marquee-item:hover{opacity:1;filter:grayscale(0);transform:translateY(-2px)}
.marquee-logo{max-height:60px;max-width:160px;width:auto;height:auto}
.marquee-logo-text{font-weight:800;font-size:1.1rem;letter-spacing:.02em;color:var(--text)}
.section-band-short{min-height:140px}
.section-band-medium{min-height:220px}
.section-band-tall{min-height:320px}
.section-band-inner{position:relative;z-index:2;max-width:920px;padding:1.5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.75rem}
.section-band-title{font-size:clamp(1.4rem,3vw,2.4rem);font-weight:800;line-height:1.1;letter-spacing:-0.01em;text-shadow:0 4px 24px rgba(0,0,0,.4);margin:0}
.section-band-sub{font-size:clamp(.95rem,1.4vw,1.15rem);font-weight:500;line-height:1.5;max-width:60ch;opacity:.95;text-shadow:0 2px 12px rgba(0,0,0,.5);margin:0}
.section-band-cta{appearance:none;border:none;border-radius:8px;padding:.7rem 1.5rem;font-size:.95rem;font-weight:700;cursor:pointer;letter-spacing:.02em;transition:transform .2s ease, box-shadow .2s ease;box-shadow:0 6px 20px rgba(0,0,0,.3)}
.section-band-cta:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.4)}
/* Rotierende Slogans: alle Items überlagern sich (Grid-Stack), nur das aktive ist sichtbar. */
.slogan-rotator{display:inline-grid;text-align:center}
.slogan-rotator .slogan-item{grid-area:1/1;opacity:0;transition:opacity .6s ease;pointer-events:none}
.slogan-rotator .slogan-item.is-active{opacity:1;pointer-events:auto}
.section-band-slogans{flex-direction:column;background:linear-gradient(180deg,var(--bg2),var(--bg))}
.section-band-slogan{font-size:clamp(1.4rem,3vw,2.4rem);font-weight:800;line-height:1.15;letter-spacing:-0.01em;text-shadow:0 4px 24px rgba(0,0,0,.4)}
.section-band-slogan .slogan-item{color:var(--accent,#f93d00)}
@media (prefers-reduced-motion: reduce){.slogan-rotator .slogan-item{transition:none}}
@media (max-width: 768px){
  .section-band-inner{padding:1rem 1.25rem}
}

/* ── Hero-Slider (CMS-managed) — Crossfade ── */
.hero-slider{position:relative;width:100%;min-height:calc(100vh - var(--nav-h));overflow:hidden;background:#000}
.hero-slider-track{position:relative;width:100%;height:calc(100vh - var(--nav-h));min-height:520px}
/* Slide = reines Opacity-Crossfade (GPU-freundlich, kein Hard-Cut, kein Transform-Konflikt) */
.hero-slide{position:absolute;inset:0;opacity:0;z-index:1;pointer-events:none;display:flex;align-items:center;justify-content:flex-start;transition:opacity .9s ease;will-change:opacity}
.hero-slide.is-active{opacity:1;z-index:2;pointer-events:auto}
/* Bild als eigene Ebene (statisch, kein Zoom — sauberes Crossfade ohne Scale-Sprung) */
.hero-slide-bg{position:absolute;inset:0;z-index:1;background-position:center;background-repeat:no-repeat}
/* Text: gestaffeltes Fade-up mit weichem Easing */
.hero-slide.is-active .hero-slide-title{animation:heroTextIn .85s cubic-bezier(.22,.61,.36,1) both}
.hero-slide.is-active .hero-slide-sub{animation:heroTextIn .85s cubic-bezier(.22,.61,.36,1) .12s both}
.hero-slide.is-active .hero-slide-cta{animation:heroTextIn .85s cubic-bezier(.22,.61,.36,1) .24s both}
@keyframes heroTextIn{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
.hero-slide-inner{position:relative;z-index:2;max-width:1280px;width:100%;margin:0 auto;padding:0 6rem;display:flex;flex-direction:column;align-items:flex-start;gap:1.35rem}
.hero-slide-title{font-size:clamp(2.4rem,6vw,5rem);font-weight:900;line-height:1.05;letter-spacing:-0.02em;max-width:18ch;text-shadow:0 4px 32px rgba(0,0,0,.45)}
.hero-slide-sub{font-size:clamp(1.05rem,1.6vw,1.4rem);font-weight:500;line-height:1.5;max-width:48ch;opacity:.95;text-shadow:0 2px 16px rgba(0,0,0,.5)}
.hero-slide-cta{appearance:none;border:none;border-radius:10px;padding:1rem 2.1rem;font-size:1rem;font-weight:700;cursor:pointer;letter-spacing:.02em;display:inline-flex;align-items:center;gap:.6rem;box-shadow:0 8px 28px rgba(0,0,0,.4);transition:transform .25s var(--ease),box-shadow .25s var(--ease),gap .25s var(--ease)}
.hero-slide-cta:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(0,0,0,.5);gap:.85rem}
.hero-cta-arrow{transition:transform .25s var(--ease)}
.hero-slide-cta:hover .hero-cta-arrow{transform:translateX(3px)}
/* Pfeile: dezent, erst beim Hover über dem Slider sichtbar */
.hero-slider-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:52px;height:52px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.28);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);opacity:0;transition:background .25s var(--ease),transform .25s var(--ease),opacity .35s var(--ease),border-color .25s var(--ease)}
.hero-slider:hover .hero-slider-arrow{opacity:1}
.hero-slider-arrow:hover{background:rgba(0,0,0,.55);border-color:rgba(255,255,255,.55)}
.hero-slider-arrow:focus-visible{opacity:1;outline:2px solid #fff;outline-offset:2px}
.hero-slider-prev{left:1.6rem}
.hero-slider-prev:hover{transform:translateY(-50%) translateX(-2px)}
.hero-slider-next{right:1.6rem}
.hero-slider-next:hover{transform:translateY(-50%) translateX(2px)}
/* Dots mit Autoplay-Fortschrittsbalken */
.hero-slider-dots{position:absolute;bottom:2.1rem;left:50%;transform:translateX(-50%);z-index:4;display:flex;gap:.55rem}
.hero-slider-dot{appearance:none;border:none;position:relative;width:40px;height:5px;border-radius:3px;background:rgba(255,255,255,.28);cursor:pointer;padding:0;overflow:hidden;transition:width .35s var(--ease),background .25s var(--ease)}
.hero-slider-dot:hover{background:rgba(255,255,255,.5)}
.hero-slider-dot.is-active{width:66px;background:rgba(255,255,255,.3)}
.hero-dot-fill{position:absolute;left:0;top:0;bottom:0;width:0;background:#fff;border-radius:3px}
@media (max-width: 768px){
  .hero-slide-inner{padding:0 1.6rem;gap:1rem}
  .hero-slider-arrow{opacity:1;width:42px;height:42px}
  .hero-slider-prev{left:.7rem}
  .hero-slider-next{right:.7rem}
  .hero-slider-dots{bottom:1.4rem}
}
@media (prefers-reduced-motion: reduce){
  .hero-slide{transition:opacity .25s ease}
  .hero-slide.is-active .hero-slide-title,.hero-slide.is-active .hero-slide-sub,.hero-slide.is-active .hero-slide-cta{animation:none}
}

.hero{min-height:calc(100vh - var(--nav-h));display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:6rem 2rem;position:relative;overflow:hidden}
.hero-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse at 50% 40%,black 20%,transparent 70%);pointer-events:none}
.hero-glow{position:absolute;top:-15%;left:50%;transform:translateX(-50%);width:700px;height:700px;background:radial-gradient(circle,rgba(249,61,0,.12) 0%,transparent 70%);pointer-events:none;filter:blur(80px)}
.hero-glow2{position:absolute;bottom:10%;right:10%;width:400px;height:300px;background:radial-gradient(ellipse,rgba(249,61,0,.06) 0%,transparent 70%);pointer-events:none}
.hero-content{position:relative;z-index:2;max-width:920px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--glass);border:1px solid var(--glass-border);border-radius:50px;padding:8px 18px;font-size:.8rem;font-weight:600;color:var(--accent);margin-bottom:2rem}
.dot-live{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 2s infinite;display:inline-block}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hero-logo-wrap{margin-bottom:1.8rem}.hero-logo{width:180px;height:180px;object-fit:contain;filter:drop-shadow(0 0 80px rgba(249,61,0,.35));opacity:.85}
.hero h1{font-size:clamp(2.4rem,6vw,4rem);font-weight:900;line-height:1.1;letter-spacing:-0.03em;margin-bottom:1.2rem}
.hero h1 .line1{display:inline-block;color:var(--text)}
.hero h1 .hero-slogan{display:inline-block;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-size:clamp(1.6rem,4vw,2.6rem);font-weight:700;letter-spacing:-0.02em}
/* Als Rotator: Grid-Stack statt inline-block; Verlauf wandert auf die einzelnen Items. */
.hero h1 .hero-slogan.slogan-rotator{display:inline-grid;background:none;-webkit-text-fill-color:initial}
.hero h1 .hero-slogan .slogan-item{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-sub{font-size:1.05rem;color:var(--text2);max-width:560px;margin:0 auto 2.5rem;line-height:1.8}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}
.btn-glow{background:var(--grad);color:#fff;padding:12px 28px;border-radius:50px;font-size:.88rem;font-weight:600;transition:var(--transition);box-shadow:0 4px 24px var(--glow);cursor:pointer;border:none;display:inline-flex;align-items:center;gap:8px}.btn-glow:hover{transform:translateY(-2px);filter:brightness(1.15);box-shadow:0 8px 32px var(--glow)}
.btn-ghost{background:var(--glass);color:var(--text2);border:1px solid var(--glass-border);padding:12px 28px;border-radius:50px;font-size:.88rem;font-weight:600;transition:var(--transition);cursor:pointer;display:inline-flex;align-items:center;gap:8px}.btn-ghost:hover{color:var(--accent);border-color:var(--accent)}
.hero-scroll{display:inline-flex;align-items:center;gap:.5rem;color:var(--text3);font-size:.72rem;letter-spacing:2px;text-transform:uppercase}
.stats-bar{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:2.5rem 2rem}
.stats-inner{display:flex;flex-wrap:nowrap;overflow-x:auto;justify-content:space-evenly;gap:0;text-align:center;padding:0 32px}
.stat-box{position:relative;flex:1;min-width:110px;padding:0 1.2rem}.stat-box+.stat-box::before{content:'';position:absolute;left:0;top:15%;bottom:15%;width:1px;background:var(--border)}
.stat-num{font-size:2.8rem;font-weight:900;line-height:1;letter-spacing:-0.02em}
.stat-num.purple{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-num.cyan{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-num.pink{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-num.orange{background:linear-gradient(135deg,var(--orange),#fcd34d);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-num.green{background:linear-gradient(135deg,var(--green),#34d399);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.stat-label{color:var(--text2);font-size:.78rem;text-transform:uppercase;letter-spacing:1.5px;margin-top:.5rem;font-weight:600}
.sec{padding:80px 2rem;max-width:1440px;margin:0 auto}
.strip-bg{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.sec-tag{display:inline-flex;align-items:center;gap:8px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--accent);margin-bottom:14px}.sec-tag::before{content:'';width:20px;height:2px;background:var(--accent);border-radius:2px}
.sec-title{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;line-height:1.15;letter-spacing:-0.02em;margin-bottom:14px}
.sec-sub{color:var(--text2);font-size:1rem;line-height:1.8;max-width:560px}.sec-hdr{margin-bottom:3rem}.sec-hdr-row{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem}
.teams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem}
.tcard{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:var(--transition)}
.tcard:hover{background:var(--card2);border-color:var(--border2);transform:translateY(-3px)}
.tcard-banner{height:130px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;width:100%;padding:0;border:0 none;cursor:pointer;text-align:center}
.tcard-banner::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 20%,var(--bg) 100%)}
.tcard-game{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.35);color:#fff;border-radius:50px;padding:3px 12px;font-size:.68rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;z-index:2}
.tcard-icon{width:68px;height:68px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.7rem;font-weight:900;letter-spacing:1px;background:var(--card2);border:1px solid var(--border2);position:relative;z-index:1;transition:transform .3s;box-shadow:0 2px 14px rgba(0,0,0,.3)}.tcard:hover .tcard-icon{transform:scale(1.06)}
.tcard-body{padding:1.4rem 1.5rem 1.5rem}
.tcard-name{font-size:1.15rem;font-weight:800;letter-spacing:-0.01em;margin-bottom:.4rem}
.tcard-desc{color:var(--text2);font-size:.875rem;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:1rem}
.tcard-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}
.tcard-foot{display:flex;justify-content:space-between;align-items:center;padding-top:.9rem;border-top:1px solid var(--border)}
.pip-row{display:flex}.pip{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;border:2px solid var(--bg);margin-right:-6px;color:#fff}
.pip-more{width:28px;height:28px;border-radius:50%;background:var(--bg3);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.62rem;color:var(--text2)}
.arrow-btn{color:var(--accent);font-size:1.1rem;transition:transform .2s}.tcard:hover .arrow-btn{transform:translateX(4px)}
.about-strip{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.about-inner{max-width:1440px;margin:0 auto;padding:6rem 2rem;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
@media(max-width:900px){.about-inner{grid-template-columns:1fr;gap:3rem}}
.about-features{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2rem}
.feat-box{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.3rem;transition:var(--transition)}.feat-box:hover{border-color:var(--border2);transform:translateY(-2px)}
.feat-icon{font-size:1.5rem;margin-bottom:.6rem}.feat-title{font-weight:700;font-size:.85rem;margin-bottom:.3rem;letter-spacing:-0.01em}.feat-sub{color:var(--text2);font-size:.8rem;line-height:1.5}
.about-stats-grid{display:grid;grid-template-columns:1fr;gap:1rem}.acard{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.8rem;text-align:center;transition:var(--transition)}.acard:hover{border-color:var(--border2);transform:translateY(-2px)}
@media(max-width:900px){.about-stats-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}
.acard-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;color:var(--text3);margin-bottom:.4rem}
.acard-val{font-size:2rem;font-weight:900;letter-spacing:-0.02em}.acard-val.p{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.acard-val.c{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.acard-val.o{background:linear-gradient(135deg,var(--orange),#fcd34d);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.acard-val.pk{background:linear-gradient(135deg,#ec4899,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.acard-val.g{background:linear-gradient(135deg,var(--green),#34d399);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.news-filters{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.news-filter-tabs{display:flex;flex-wrap:wrap;gap:.5rem}
.news-filter-tab{background:transparent;border:1px solid var(--border);color:var(--text2);border-radius:50px;padding:.5rem 1rem;font-size:.82rem;font-weight:600;letter-spacing:.3px;cursor:pointer;transition:var(--transition)}
.news-filter-tab:hover{border-color:var(--border2);color:var(--text)}
.news-filter-tab.is-active{background:rgba(249,61,0,.12);border-color:var(--accent);color:var(--accent)}
.news-filter-year{display:flex;align-items:center;gap:.6rem}
.news-filter-year-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text3)}
.news-filter-year-select{background:var(--card);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:.45rem .8rem;font-size:.85rem;cursor:pointer;color-scheme:dark}
.news-filter-year-select:focus{outline:none;border-color:var(--accent)}
.news-filter-year-select option{background:var(--bg2);color:var(--text)}
.news-filter-reset{background:transparent;border:1px solid var(--border);color:var(--text3);border-radius:8px;padding:.45rem .8rem;font-size:.78rem;cursor:pointer;transition:var(--transition)}
.news-filter-reset:hover{color:var(--text);border-color:var(--border2)}
.news-no-results{padding:3rem 1rem;text-align:center;color:var(--text3);font-size:.95rem;border:1px dashed var(--border);border-radius:var(--r)}
@media(max-width:640px){.news-filters{flex-direction:column;align-items:flex-start}.news-filter-year{width:100%;justify-content:space-between}}
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.2rem}
.ncard{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:var(--transition)}.ncard:hover{background:var(--card2);border-color:var(--border2);transform:translateY(-3px)}
.ncard-thumb{height:130px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;position:relative;overflow:hidden}.ncard-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,var(--bg) 100%)}
.ncard-body{padding:1.3rem 1.5rem 1.4rem}.ncard-meta{display:flex;align-items:center;gap:.7rem;margin-bottom:.7rem}
.ncat{font-size:.73rem;font-weight:700;text-transform:uppercase;color:var(--accent);background:rgba(249,61,0,.12);border-radius:50px;padding:4px 13px;letter-spacing:.5px}
.ncat.match{background:rgba(249,61,0,.12);color:var(--accent)}.ncat.announce{background:rgba(245,158,11,.1);color:var(--orange)}
.ndate{color:var(--text3);font-size:.76rem;letter-spacing:.5px}
.ncard-title{font-size:.97rem;font-weight:700;line-height:1.45;margin-bottom:.55rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;letter-spacing:-0.01em}
.ncard-exc{color:var(--text2);font-size:.875rem;line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.ncard-footer{padding:.9rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.ncard-author{color:var(--text3);font-size:.75rem;letter-spacing:.3px}.ncard-read{color:var(--accent);font-size:.75rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.feat-news{background:var(--card2);border:1px solid var(--border);border-radius:var(--r2);padding:2.5rem;margin-bottom:2rem;cursor:pointer;transition:var(--transition);display:grid;grid-template-columns:1fr auto;gap:2.5rem;align-items:center}.feat-news:hover{border-color:var(--border2);transform:translateY(-2px)}
.feat-news-tag{display:inline-flex;background:var(--grad);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;border-radius:50px;padding:4px 14px;margin-bottom:1rem}
.feat-news-title{font-size:1.7rem;font-weight:800;line-height:1.12;margin-bottom:.75rem;letter-spacing:-0.02em}
.feat-news-exc{color:var(--text2);font-size:.93rem;line-height:1.7}
.feat-news-icon{width:110px;height:110px;display:flex;align-items:center;justify-content:center;font-size:2rem;background:var(--grad);border-radius:var(--r2);flex-shrink:0}
.events-list{display:flex;flex-direction:column;gap:1rem}
.ecard{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--r);padding:1.5rem 1.8rem;display:grid;grid-template-columns:auto 1fr auto;gap:1.5rem;align-items:center;transition:var(--transition)}.ecard:hover{border-color:var(--border2);transform:translateX(3px)}
.ecard-date{text-align:center;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:.7rem 1.1rem;min-width:65px}
.ecard-day{font-size:1.9rem;font-weight:900;line-height:1;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.ecard-month{font-size:.73rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text2);margin-top:.15rem}
.ecard-title{font-weight:700;font-size:.95rem;margin-bottom:.4rem;letter-spacing:-0.01em}
.ecard-meta{display:flex;gap:.8rem;flex-wrap:wrap}.emeta-chip{display:flex;align-items:center;gap:.3rem;font-size:.78rem;color:var(--text2)}
.ecard-badge{padding:4px 12px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:50px}
.ebadge-upcoming{background:rgba(16,185,129,.1);color:var(--green);border:1px solid rgba(16,185,129,.25)}.ebadge-past{background:rgba(148,163,184,.06);color:var(--text3);border:1px solid var(--border)}.ebadge-live{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.25)}
.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}
.achcard{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--orange);border-radius:var(--r);padding:1.2rem 1.4rem;display:flex;gap:1rem;align-items:center;transition:var(--transition)}.achcard:hover{border-color:rgba(245,158,11,.5);transform:translateX(3px)}
.ach-trophy{width:52px;height:52px;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.2);border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:1.6rem;flex-shrink:0}
.ach-placement{font-size:1rem;font-weight:900;color:var(--orange);letter-spacing:-0.01em;margin-bottom:.15rem}.ach-tournament{font-size:.9rem;font-weight:700;margin-bottom:.25rem;line-height:1.4}.ach-team{font-size:.8rem;color:var(--accent);margin-bottom:.1rem}.ach-date{font-size:.75rem;color:var(--text3);margin-top:.2rem}
.players-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1.1rem}
/* Roster-Karten: Vollbild-Portrait mit Hover-Banner, das von unten in der Team-Akzentfarbe einsliedt. */
.pcard{position:relative;display:block;width:100%;aspect-ratio:3/4;border-radius:var(--r);overflow:hidden;border:1px solid var(--border);background:var(--card);padding:0;font:inherit;color:inherit;cursor:pointer;transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease}
.pcard:hover{transform:translateY(-4px);border-color:var(--tc,var(--border2));box-shadow:0 16px 42px -14px color-mix(in srgb,var(--tc,#000) 60%,transparent)}
.pcard:focus-visible{outline:2px solid var(--tc,var(--accent));outline-offset:2px}
.pcard-media{position:absolute;inset:0}
.pcard-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:0!important;border-radius:0;margin:0;transition:transform .5s ease}
.pcard:hover .pcard-photo{transform:scale(1.07)}
.pcard-photo.ppic-fallback{font-size:3rem;font-weight:900}
.ppic-fallback{display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#fff;border:none}
.pcard-shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.25) 42%,rgba(0,0,0,0) 70%);transition:opacity .35s ease}
.pcard:hover .pcard-shade{opacity:.4}
.pcard-foot{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:.9rem .95rem;text-align:left;transition:transform .35s ease,opacity .25s ease}
.pcard:hover .pcard-foot{transform:translateY(10px);opacity:0}
.pcard-foot .pign{margin:0;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.6)}
.pcard-banner{position:absolute;left:0;right:0;bottom:0;z-index:3;padding:1rem .95rem 1.05rem;text-align:left;display:flex;flex-direction:column;gap:.42rem;background:var(--tc,#f93d00);background:linear-gradient(to top,color-mix(in srgb,var(--tc,#f93d00) 94%,#000) 0%,color-mix(in srgb,var(--tc,#f93d00) 80%,#000) 58%,transparent 100%);border-top:2px solid var(--tc,#f93d00);transform:translateY(101%);transition:transform .42s cubic-bezier(.22,1,.36,1)}
.pcard:hover .pcard-banner,.pcard:focus-visible .pcard-banner{transform:translateY(0)}
.pcard-logo-mini{position:absolute;top:.7rem;right:.75rem;width:38px;height:38px;border-radius:8px;background:rgba(0,0,0,.18);padding:3px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.35));opacity:0;transform:translateY(-4px);transition:opacity .3s ease .08s,transform .3s ease .08s}
.pcard:hover .pcard-logo-mini,.pcard:focus-visible .pcard-logo-mini{opacity:1;transform:translateY(0)}
.pcard-banner .pign-lg{font-size:1.12rem;font-weight:900;letter-spacing:-0.01em;color:#fff;line-height:1.12;padding-right:46px}
.pcard-banner .prealname{color:rgba(255,255,255,.85);font-size:.8rem;margin:0}
.pcard-banner .proles{display:flex;flex-wrap:wrap;gap:.3rem;margin:.05rem 0;justify-content:flex-start}
.pcard-banner .pbio{color:rgba(255,255,255,.92);font-size:.8rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:0}
.pcard-banner .chip2{background:rgba(0,0,0,.28);color:#fff;border-color:rgba(255,255,255,.3)}
.pcard-socials{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:.05rem}
.pcard-socials a{color:#fff;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;opacity:.92;text-decoration:none}
.pcard-socials a:hover{opacity:1;text-decoration:underline}
.pcard-cta{color:#fff;font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;margin-top:.1rem}
@media (prefers-reduced-motion:reduce){.pcard,.pcard-photo,.pcard-banner,.pcard-foot{transition:none}.pcard-banner{transform:translateY(0)}.pcard-foot{opacity:0}}
.pcard-body{display:flex;flex-direction:column;align-items:center;gap:.15rem}
.pavatar{width:72px;height:72px;border-radius:50%;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800;color:#fff;position:relative}
.p-cap{position:absolute;bottom:-2px;right:-2px;width:22px;height:22px;border-radius:50%;background:var(--orange);border:2px solid var(--bg);display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;color:#000}
.pign{font-size:1rem;font-weight:800;margin-bottom:.2rem;letter-spacing:-0.01em}
.pflag{margin-right:.4rem;font-size:1.05em;vertical-align:-1px}
.pgender{display:inline-flex;align-items:center;margin-right:.4rem;opacity:.85}
.pgender svg{width:.92em;height:.92em;vertical-align:-.12em}
/* Farbe je Geschlecht (SVG erbt via currentColor). */
.pgender-m{color:#5b9bd5}
.pgender-w{color:#e87fb0}
.pgender-d{color:#b98cff}
/* Im Profil: mit Abstand RECHTS vom Namen. */
.pgender-after{margin-right:0;margin-left:.55rem}
.pp-hero-name .pgender-after svg{width:.78em;height:.78em}
/* Auf der Karte: kleines, eingefärbtes Badge unten rechts in der Ecke. */
.pgender-corner{position:absolute;right:.7rem;bottom:.7rem;z-index:2;margin:0;width:26px;height:26px;justify-content:center;border-radius:50%;background:rgba(0,0,0,.5);box-shadow:0 2px 8px rgba(0,0,0,.35);opacity:1;transition:opacity .25s ease}
.pgender-corner svg{width:15px;height:15px}
.pcard:hover .pgender-corner,.pcard:focus-visible .pgender-corner{opacity:0}

/* Destiny League page */
.dl-list{display:flex;flex-direction:column;gap:1.6rem}
.dl-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;border-left:4px solid var(--accent)}
.dl-banner{height:200px;overflow:hidden;position:relative}
.dl-banner img{width:100%;height:100%;object-fit:cover}
.dl-banner::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.6) 100%)}
.dl-body{padding:1.6rem 1.8rem 1.8rem}
.dl-meta{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:.6rem}
.dl-season{background:var(--accent);color:#fff;font-size:.75rem;font-weight:800;padding:.3rem .8rem;border-radius:50px;letter-spacing:.5px}
.dl-game,.dl-date{background:var(--bg2);color:var(--text2);font-size:.75rem;padding:.3rem .8rem;border-radius:50px;border:1px solid var(--border)}
.dl-title{font-size:1.4rem;font-weight:800;letter-spacing:-0.01em;margin-bottom:.5rem}
.dl-desc{color:var(--text2);line-height:1.6;margin-bottom:1.2rem}
.dl-winner{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:var(--r);background:var(--card);border:1px solid var(--border);margin-bottom:1.2rem}
.dl-winner-logo{width:54px;height:54px;border-radius:50%;object-fit:cover;border:2px solid var(--accent)}
.dl-winner-trophy{font-size:2rem}
.dl-winner-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--text3)}
.dl-winner-name{font-size:1.1rem;font-weight:800;color:var(--accent)}
.dl-winner-note{font-size:.85rem;color:var(--text2);margin-top:.2rem}
.video-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:var(--r);background:#000}
.video-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}

/* Shop page */
.shop-slider{position:relative;border-radius:var(--r);overflow:hidden;background:var(--card);border:1px solid var(--border);margin-bottom:2rem;min-height:280px}
.shop-slider-track{position:relative;width:100%;height:100%}
.shop-promo{position:absolute;inset:0;opacity:0;pointer-events:none;display:flex;align-items:center;gap:2rem;padding:2rem 3rem;transition:opacity .5s ease}
.shop-promo.is-active{opacity:1;pointer-events:auto}
.shop-promo-img{width:240px;height:240px;object-fit:contain;border-radius:var(--r)}
.shop-promo-text{flex:1;min-width:0}
.shop-promo-shop{display:inline-block;background:var(--accent);color:#fff;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;padding:.3rem .8rem;border-radius:50px;margin-bottom:.7rem}
.shop-promo-text h3{font-size:1.7rem;font-weight:800;letter-spacing:-0.02em;margin-bottom:.5rem}
.shop-promo-text p{color:var(--text2);font-size:1rem;line-height:1.5;margin-bottom:1.2rem}
.shop-promo-cta{display:inline-block;background:var(--accent);color:#fff;padding:.7rem 1.4rem;border-radius:50px;font-weight:700;letter-spacing:.3px;text-decoration:none;transition:transform .2s}
.shop-promo-cta:hover{transform:translateY(-2px)}
.shop-slider-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.6);border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.4rem;cursor:pointer;z-index:2;transition:background .2s}
.shop-slider-arrow:hover{background:rgba(0,0,0,.85)}
.shop-slider-prev{left:1rem}
.shop-slider-next{right:1rem}
.shop-slider-dots{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);display:flex;gap:.5rem;z-index:2}
.shop-slider-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);border:none;cursor:pointer;padding:0;transition:all .2s}
.shop-slider-dot.is-active{background:#fff;width:24px;border-radius:4px}
@media(max-width:720px){.shop-promo{flex-direction:column;text-align:center;padding:2rem 1.5rem}.shop-promo-img{width:160px;height:160px}}

.prealname{color:var(--text2);font-size:.8rem;margin-bottom:.55rem}
.prole{display:inline-block;background:rgba(249,61,0,.12);border:1px solid rgba(249,61,0,.25);color:var(--accent);border-radius:50px;padding:4px 14px;font-size:.72rem;font-weight:700;margin-bottom:.7rem;letter-spacing:.3px}
.pcountry{color:var(--text3);font-size:.78rem;margin-bottom:.5rem}.pbio{color:var(--text2);font-size:.83rem;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:.8rem}
.psocials{display:flex;gap:.4rem;justify-content:center;flex-wrap:wrap}.psoc{background:var(--bg3);border:1px solid var(--border);border-radius:50px;padding:4px 14px;font-size:.72rem;color:var(--text2)}
.sponsors-sec{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.sponsor-tier{margin-bottom:2.5rem}.tier-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text3);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.tier-label::after{content:'';flex:1;height:1px;background:var(--border)}
.sponsors-row{display:flex;gap:1rem;flex-wrap:wrap}.spcard{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.2rem 2rem;display:flex;align-items:center;gap:1rem;transition:var(--transition);cursor:pointer}.spcard:hover{border-color:var(--border2);transform:translateY(-2px)}.spcard.title-tier{border-color:rgba(245,158,11,.25)}
.sp-logo{width:48px;height:48px;border-radius:var(--r);background:var(--grad);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;color:#fff;flex-shrink:0}.sp-name{font-weight:700;font-size:.92rem;letter-spacing:-0.01em}.sp-tier{font-size:.72rem;color:var(--text3);text-transform:uppercase;margin-top:.1rem}
.sp-desc{margin-top:.4rem;color:var(--text2);font-size:.82rem;line-height:1.6;max-width:320px}
.sp-code{margin-top:.4rem;font-size:.8rem;color:var(--accent);background:rgba(249,61,0,.1);border:1px solid rgba(249,61,0,.25);border-radius:6px;padding:.2rem .5rem;display:inline-block}
.join-strip{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:6rem 2rem;text-align:center;position:relative;overflow:hidden}
.join-strip::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(249,61,0,.07),rgba(255,116,71,.04));pointer-events:none}
.join-inner{max-width:720px;margin:0 auto;position:relative;z-index:1}
.join-strip h2{font-size:clamp(2rem,4vw,3rem);font-weight:900;letter-spacing:-0.02em;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:1.2rem}
.join-strip p{color:var(--text2);font-size:1.05rem;margin-bottom:2.2rem;line-height:1.8}
.btn-white{background:#fff;color:var(--accent);padding:12px 28px;border-radius:50px;font-size:.88rem;font-weight:700;transition:var(--transition);cursor:pointer;border:none;display:inline-block}.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.25)}
footer{background:var(--bg2);border-top:1px solid var(--border);padding:60px 2rem 28px}
.footer-inner{max-width:1440px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
@media(max-width:900px){.footer-top{grid-template-columns:1fr 1fr}}@media(max-width:600px){.footer-top{grid-template-columns:1fr}}
.footer-brand-name{font-size:1.3rem;font-weight:800;letter-spacing:-0.02em;margin-bottom:.5rem}
.footer-brand-sub{color:var(--text2);font-size:.88rem;line-height:1.75;max-width:290px;margin-bottom:1.5rem}
.footer-socials{display:flex;gap:8px}.fsoc{width:38px;height:38px;border-radius:8px;background:var(--glass);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;color:var(--text2);font-size:.75rem;font-weight:700;letter-spacing:.5px;transition:var(--transition)}.fsoc:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-2px)}
.footer-col h4{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text3);margin-bottom:16px}.footer-col a{display:block;color:var(--text2);font-size:.88rem;padding:6px 0;transition:var(--transition);cursor:pointer}.footer-col a:hover{color:var(--accent)}
.footer-bottom{border-top:1px solid var(--border);padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;font-size:.78rem;color:var(--text3)}
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(10px);z-index:800;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.modal-ov.open{opacity:1;visibility:visible}
.modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);max-width:720px;width:100%;max-height:88vh;overflow-y:auto;padding:2.2rem;position:relative;transform:scale(.9) translateY(20px);transition:transform .3s}.modal-ov.open .modal-box{transform:scale(1) translateY(0)}
.modal-cls{position:absolute;top:1.1rem;right:1.1rem;background:var(--bg3);border:1px solid var(--border);color:var(--text2);width:32px;height:32px;border-radius:50%;font-size:.85rem;transition:var(--transition);display:flex;align-items:center;justify-content:center}.modal-cls:hover{background:var(--red);border-color:var(--red);color:#fff}
#toastZone{position:fixed;bottom:2rem;right:2rem;z-index:9999;display:flex;flex-direction:column;gap:.6rem;pointer-events:none}
.toast{background:var(--bg2);border:1px solid var(--border);border-left:3px solid var(--green);border-radius:var(--r);padding:.85rem 1.3rem;min-width:260px;font-size:.85rem;animation:toastIn .35s var(--ease) forwards}.toast.err{border-left-color:var(--red)}
@keyframes toastIn{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}
.chip2{display:inline-flex;align-items:center;gap:.3rem;background:var(--bg3);border:1px solid var(--border);border-radius:50px;padding:.22rem .9rem;font-size:.7rem;color:var(--text2);letter-spacing:.5px}
.proles{display:flex;flex-wrap:wrap;gap:.35rem;justify-content:center;margin:.2rem 0}
.chip2-lead{background:rgba(245,158,11,.15);border-color:rgba(245,158,11,.4);color:var(--orange)}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}
.empty-state{text-align:center;padding:5rem 2rem;color:var(--text2)}.empty-state h3{color:var(--text);font-size:1.1rem;margin-bottom:.4rem}
.team-detail-hero{padding:4rem 2rem;background:var(--bg2);border-bottom:1px solid var(--border)}.tdh-inner{max-width:1440px;margin:0 auto;display:flex;align-items:center;gap:2rem;flex-wrap:wrap}
.breadcrumb{width:100%;font-size:.78rem;margin-bottom:.5rem;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.breadcrumb a{color:var(--text3);cursor:pointer;transition:var(--transition)}.breadcrumb a:hover{color:var(--accent)}.bc-sep{color:var(--text3);opacity:.5}.bc-current{color:var(--text2)}
.tdh-social a{display:inline-flex;align-items:center;gap:.4rem;background:var(--bg3);border:1px solid var(--border);border-radius:50px;padding:.35rem .9rem;font-size:.72rem;color:var(--text2);transition:var(--transition);margin-right:.4rem;margin-top:.4rem}.tdh-social a:hover{color:var(--accent);border-color:var(--accent)}
.matches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.2rem;max-width:1440px;margin:0 auto}
.match-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:var(--transition)}.match-card:hover{transform:translateY(-3px);border-color:var(--border2)}
.match-card.match-live{border-color:rgba(239,68,68,.25);box-shadow:0 0 24px rgba(239,68,68,.07)}.match-card.match-upcoming{border-color:rgba(16,185,129,.2)}
.match-header{padding:.9rem 1.4rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}
.match-game{font-size:.75rem;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:1.5px}
.match-status-badge{font-size:.72rem;font-weight:700;text-transform:uppercase;padding:4px 12px;border-radius:50px;display:flex;align-items:center;gap:.4rem;letter-spacing:.5px}
.match-status-badge.match-live{background:rgba(239,68,68,.12);color:var(--red)}.match-status-badge.match-upcoming{background:rgba(16,185,129,.1);color:var(--green)}.match-status-badge.match-finished{background:rgba(148,163,184,.05);color:var(--text3)}
.match-teams{display:flex;align-items:center;justify-content:space-between;padding:1.8rem 1.4rem;gap:1rem}
.match-team{display:flex;flex-direction:column;align-items:center;gap:.6rem;flex:1}
.match-team-logo{width:56px;height:56px;border-radius:var(--r);border:none;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:800}
.match-team-logo-img{width:56px;height:56px;border-radius:var(--r);object-fit:cover;border:2px solid}
.match-team-name{font-size:.9rem;font-weight:700;text-align:center;letter-spacing:-0.01em}
.match-score{display:flex;align-items:center;gap:.5rem}.match-score-num{font-size:2.6rem;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.match-score-sep{font-size:1.6rem;color:var(--text3)}
.match-footer{padding:.9rem 1.4rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.match-tournament{font-size:.78rem;color:var(--text2)}
.match-watch{font-size:.75rem;font-weight:700;color:var(--red);letter-spacing:.5px;text-transform:uppercase;transition:var(--transition)}.match-watch:hover{color:#f87171}
.dot-live-match{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--red);animation:livePulse 1.5s ease-in-out infinite}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.3}}
/* Announcements */
.announcements-sec{padding:1rem 2rem;max-width:1440px;margin:0 auto}
.announcements-inner{display:flex;flex-direction:column;gap:.8rem}
.ann-card{display:flex;align-items:center;gap:1.2rem;padding:1.2rem 1.8rem;background:var(--card);border:1px solid var(--border);border-radius:var(--r);position:relative;overflow:hidden;transition:var(--transition)}.ann-card:hover{transform:translateX(3px)}
.ann-card-accent{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:4px 0 0 4px}
.ann-card.ann-critical{border-color:rgba(239,68,68,.25);box-shadow:0 0 30px rgba(239,68,68,.06)}.ann-card.ann-critical .ann-card-accent{background:var(--red)}
.ann-card.ann-important{border-color:rgba(245,158,11,.2)}.ann-card.ann-important .ann-card-accent{background:var(--orange)}
.ann-card.ann-normal .ann-card-accent{background:var(--accent)}
.ann-card-icon{font-size:1.6rem;flex-shrink:0;width:46px;height:46px;display:flex;align-items:center;justify-content:center;background:var(--bg3);border:1px solid var(--border);border-radius:12px}
.ann-card-content{flex:1}.ann-card-title{font-weight:700;font-size:.95rem;letter-spacing:-0.01em}.ann-card-body{color:var(--text2);font-size:.875rem;margin-top:.3rem;line-height:1.65}
.ann-card-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;padding:.35rem .9rem;border-radius:50px;background:rgba(239,68,68,.12);color:var(--red);border:1px solid rgba(239,68,68,.2);flex-shrink:0;animation:annPulse 2s infinite}
.ann-card-badge.imp{background:rgba(245,158,11,.1);color:var(--orange);border-color:rgba(245,158,11,.2);animation:none}
@keyframes annPulse{0%,100%{opacity:1}50%{opacity:.6}}
.legal-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:2.5rem}.legal-card h3{font-size:1.05rem;font-weight:800;margin:2rem 0 .8rem;letter-spacing:-0.01em;color:var(--accent)}.legal-card h3:first-child{margin-top:0}.legal-card p{color:var(--text2);font-size:.9rem;line-height:1.8}
/* Team detail page */
/* Weicher Hero statt flachem grauen Block mit harter Kante: vertikaler Verlauf
   (bg2 → bg, ohne Border-Kante) + ein breiter, diffuser Team-Glow, der zur Seite
   ausfadet statt als hartes Quadrat rechts zu sitzen. */
.td-hero-full{padding:4rem 2rem 3.25rem;background:linear-gradient(180deg,var(--bg2) 0%,var(--bg) 100%);border-bottom:0;position:relative;overflow:hidden}
.td-hero-full::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 65% 90% at 78% 25%,color-mix(in srgb,var(--tc) 11%,transparent) 0%,transparent 68%);pointer-events:none}
.td-hero-inner{max-width:1440px;margin:0 auto;position:relative;z-index:1}
.td-hero-top{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;margin-bottom:1rem}
.td-hero-icon{width:100px;height:100px;border-radius:var(--r2);display:flex;align-items:center;justify-content:center;font-size:2.2rem;font-weight:900;border:2px solid;flex-shrink:0}
.td-hero-logo{width:100px;height:100px;border-radius:var(--r2);object-fit:cover;flex-shrink:0;border:2px solid var(--border)}
.td-hero-name{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:900;letter-spacing:-0.02em}
.td-hero-chips{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.5rem}
.td-hero-desc{color:var(--text2);font-size:.92rem;line-height:1.8;max-width:700px;white-space:pre-line}
/* Player avatar image */
.pavatar-img{width:68px;height:68px;border-radius:50%;object-fit:cover;display:block;margin:0 auto .9rem;border:2px solid}
.tcard-logo-img{width:80px;height:80px;border-radius:16px;object-fit:cover;position:relative;z-index:1;box-shadow:0 4px 24px rgba(0,0,0,.45)}
/* Mitmachen / Apply */
.apply-intro{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:2.5rem;margin-bottom:2rem}
.apply-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem}
.apply-type-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.8rem;cursor:pointer;transition:var(--transition);position:relative}.apply-type-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 8px 28px rgba(249,61,0,.08)}
.atc-icon{font-size:2rem;margin-bottom:.8rem}.atc-title{font-size:1rem;font-weight:700;letter-spacing:-0.01em;margin-bottom:.5rem}.atc-desc{color:var(--text2);font-size:.84rem;line-height:1.6}
.atc-arrow{position:absolute;top:1.5rem;right:1.5rem;font-size:1.2rem;color:var(--accent);opacity:.4;transition:var(--transition)}.apply-type-card:hover .atc-arrow{opacity:1}
/* Team Overview */
.team-overview-grid{display:grid;gap:1.2rem}
.team-ov-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;transition:var(--transition)}.team-ov-card:hover{border-color:var(--border2)}
.team-ov-header{display:flex;align-items:center;gap:1rem;padding-left:1rem}
.team-ov-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;flex-shrink:0}
.team-ov-name{font-size:1.15rem;font-weight:700;letter-spacing:-0.01em}
.team-ov-desc{color:var(--text2);font-size:.84rem;line-height:1.7;margin-top:1rem}
.md-overview .md-p{color:var(--text2);font-size:.84rem;line-height:1.7;margin:.15rem 0}
.md-overview .md-list{margin:.3rem 0}
.md-field{margin:.75rem 0}
.md-label{color:var(--text3);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;margin-bottom:.25rem;opacity:.8}
.md-list{list-style:none;padding:0;margin:.2rem 0;display:flex;flex-direction:column;gap:.15rem}
.md-list li{padding-left:.9rem;position:relative;color:var(--text2);font-size:.8rem;line-height:1.55}
.md-list li::before{content:'–';position:absolute;left:0;color:var(--accent);font-weight:700}
.md-p{color:var(--text2);font-size:.8rem;line-height:1.6;margin:.15rem 0}
.team-ov-actions{margin-top:1rem;display:flex;gap:.8rem;flex-wrap:wrap}
/* Apply form */
.apply-form-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:2rem}
.apply-form-wrap .fld{margin-bottom:1rem}.apply-form-wrap .fld label:not(.apply-check){display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-size:.75rem;font-weight:600;color:var(--text2);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.8px}
.apply-form-wrap .fld input,.apply-form-wrap .fld select,.apply-form-wrap .fld textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:.7rem 1rem;color:var(--text);font-size:.88rem;font-family:var(--font);transition:var(--transition)}.apply-form-wrap .fld input:focus,.apply-form-wrap .fld textarea:focus,.apply-form-wrap .fld select:focus{outline:none;border-color:var(--accent)}
.apply-form-wrap .fld textarea{resize:vertical;min-height:100px}.apply-form-wrap .fld select{cursor:pointer;-webkit-appearance:none;appearance:none}
.apply-form-wrap .fld-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.apply-form-wrap .fld select optgroup{color:var(--text2);font-weight:700;font-size:.8rem;background:var(--bg2)}
.apply-form-wrap .fld select option{color:var(--text);font-weight:400;background:var(--bg3)}
.apply-check{display:flex;align-items:flex-start;gap:.5rem;font-size:.84rem;color:var(--text2);cursor:pointer;line-height:1.5}.apply-check input[type="checkbox"]{margin-top:3px;accent-color:var(--accent)}
.fld-label-text{display:inline-flex;align-items:center;gap:.4rem}
.fld-meta{font-size:.7rem;letter-spacing:0;text-transform:none}
.fld-meta-required{color:var(--accent);font-size:1rem;line-height:1}
.fld-meta-optional{color:var(--text3)}
.status-pill{display:inline-flex;align-items:center;justify-content:center;padding:.3rem .9rem;border-radius:999px;border:1px solid var(--border);font-size:.72rem;font-weight:700;letter-spacing:.3px;text-transform:uppercase}
.status-pill.is-open{background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.2);color:var(--green)}
.status-pill.is-closed{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.2);color:var(--red)}
.status-pill.is-limited{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.2);color:var(--orange)}
.status-pill.is-neutral{background:var(--bg3);color:var(--text2)}
.team-status-note{border:1px solid rgba(245,158,11,.16);background:rgba(245,158,11,.06);color:var(--orange);border-radius:var(--r);padding:.85rem 1rem;font-size:.84rem;line-height:1.55}
.team-form-fields{display:flex;flex-direction:column;gap:1rem;padding:1rem;border:1px solid var(--border);border-radius:var(--r);background:var(--card)}
.team-status-panel{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border)}
.team-status-panel-title{font-size:.9rem;font-weight:800;letter-spacing:-0.01em;margin-bottom:.85rem}
.team-status-list{display:flex;flex-direction:column;gap:.75rem}
.team-status-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;border:1px solid var(--border);border-radius:var(--r);background:var(--card)}
.team-status-name{font-weight:700}
.team-status-meta{color:var(--text3);font-size:.76rem;margin-top:.15rem}
/* Team full notice */
/* Legal card lists */
.legal-card ul{list-style:disc}.legal-card li{margin-bottom:.3rem;font-size:.9rem;line-height:1.7}
/* Games page */
.games-page-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.2rem}
.game-page-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:2rem;transition:var(--transition)}.game-page-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.game-page-header{display:flex;align-items:center;gap:1rem}
.game-page-icon{font-size:2rem;width:56px;height:56px;background:var(--bg3);border:1px solid var(--border);border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.game-page-name{font-size:1.3rem;font-weight:800;letter-spacing:-0.01em}
.game-teams-list{display:flex;flex-direction:column;gap:.6rem}
.game-team-row{display:flex;align-items:center;gap:.8rem;padding:.6rem .8rem;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);transition:var(--transition)}.game-team-row:hover{border-color:var(--accent);transform:translateX(3px)}
@media(max-width:640px){.hero h1{font-size:2.6rem}.hero h1 .hero-slogan{font-size:1.55rem}.teams-grid,.news-grid,.ach-grid,.matches-grid,.apply-type-grid,.games-page-grid{grid-template-columns:1fr}.players-grid{grid-template-columns:repeat(2,1fr)}.stats-inner{flex-wrap:wrap;justify-content:center}.stat-box{min-width:calc(50% - 2.4rem)}.stat-num{font-size:2.2rem}.stat-box+.stat-box::before{display:none}.ecard{grid-template-columns:1fr;gap:.8rem}.feat-news{grid-template-columns:1fr}.feat-news-icon{display:none}.ann-card{padding:.9rem 1rem;gap:.8rem}.ann-card-icon{width:38px;height:38px;font-size:1.3rem}.footer-top{grid-template-columns:1fr 1fr}.td-hero-name{font-size:1.8rem}.td-hero-top{gap:1rem}.td-hero-icon,.td-hero-logo{width:72px;height:72px}}
/* Hero float animation */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.hero-logo{animation:float 8s ease-in-out infinite}
/* Glow box around hero title line1 */
.hero h1 .line1{position:relative;display:block;width:fit-content;margin:0 auto;padding:.1em .45em;border:1.5px solid rgba(249,61,0,.3);border-radius:var(--r);box-shadow:0 0 16px rgba(249,61,0,.18),0 0 40px rgba(249,61,0,.08);text-shadow:none;background:rgba(249,61,0,.04)}
/* Glitch chars */
.glitch-char{display:inline-block;transition:none}
/* Nav logo */
.nav-banner-img{height:100px;object-fit:contain;display:block;margin:0 auto}
@media(max-width:640px){.nav-banner-img{height:80px}}
/* Player detail page */
.pd-hero-layout{display:flex;align-items:center;gap:2rem;flex-wrap:wrap;margin-bottom:1rem}
.pd-avatar{width:140px;height:140px;border-radius:var(--r2);object-fit:cover;border:3px solid;flex-shrink:0}
.pd-avatar-placeholder{width:140px;height:140px;border-radius:var(--r2);display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:900;color:#fff;flex-shrink:0}
.pd-info-box{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:.8rem 1.2rem;min-width:120px}
.pd-info-label{font-size:.72rem;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:.3rem}
.pd-info-val{font-weight:700;font-size:.9rem}
.nav-shell{padding-inline:24px}
.nav-logo-btn{background:none;border:none}
.nav-wrap{flex-wrap:nowrap;overflow:visible}
.nav-controls{gap:.5rem;flex-wrap:nowrap;justify-content:flex-end;align-items:center}
.lang-globe{position:relative}
.lang-globe-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--glass);border:1px solid var(--glass-border);color:var(--text2);cursor:pointer;transition:var(--transition)}
.lang-globe-btn:hover{color:var(--text);border-color:var(--glass-border-hover);background:var(--card2)}
.lang-globe-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:150px;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r);padding:.4rem 0;opacity:0;visibility:hidden;transform:translateY(4px);transition:opacity .2s,visibility .2s,transform .2s;z-index:510;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.lang-globe.open .lang-globe-menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang-option{display:block;width:100%;text-align:left;padding:.5rem 1rem;font-size:.8rem;color:var(--text2);background:none;border:none;cursor:pointer;transition:var(--transition);font-family:var(--font)}
.lang-option:hover{color:var(--text);background:var(--glass)}
.lang-option.active{color:var(--accent)}
.btn-compact{padding:9px 18px;font-size:.78rem}
.stack-actions{display:flex;flex-direction:column;gap:.75rem;align-items:flex-end}
.copy-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;padding:0;margin:.5rem 0 0}
.copy-list li{position:relative;padding-left:1rem;color:var(--text2);line-height:1.65}
.copy-list li::before{content:'•';position:absolute;left:0;color:var(--accent)}
.copy-paragraph{color:var(--text2);line-height:1.75;margin-top:.6rem}
.about-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem}
.copy-stack{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;color:var(--text2)}
.stats-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.sp-logo-img{width:48px;height:48px;border-radius:var(--r);object-fit:cover;flex-shrink:0}
.article-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:2rem}
.article-body{margin-top:1rem}
.split-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem}
.split-grid-single{grid-template-columns:minmax(0,920px);justify-content:center}
.form-stack{display:flex;flex-direction:column;gap:1rem;margin-top:1.25rem}
.footer-col button{display:block;color:var(--text2);font-size:.85rem;padding:5px 0;transition:var(--transition);cursor:pointer;text-align:left}
.footer-col button:hover{color:var(--accent)}
.compact-footer{grid-template-columns:2fr 1fr 1fr}
@media(max-width:980px){.nav-controls{width:100%;justify-content:flex-start}.about-layout,.split-grid{grid-template-columns:1fr}.compact-footer{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.lang-pill{width:100%;justify-content:space-between}.nav-controls{width:100%}.compact-footer{grid-template-columns:1fr}.stats-mini-grid{grid-template-columns:1fr 1fr}.team-status-row{flex-direction:column;align-items:flex-start}.apply-form-wrap .fld label:not(.apply-check){flex-direction:column;align-items:flex-start}}
/* Error Page */
.error-page{min-height:calc(100vh - var(--nav-h));display:flex;align-items:center;justify-content:center;position:relative}
.error-lang-pos{position:absolute;top:1rem;right:1rem}
.error-state{text-align:center;max-width:520px;padding:3rem 2rem}
.error-icon-wobble{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background:var(--grad);color:#fff;font-size:2.5rem;font-weight:900;margin-bottom:1.5rem;animation:wobble 2s ease-in-out infinite}
@keyframes wobble{0%,100%{transform:rotate(0)}15%{transform:rotate(12deg)}30%{transform:rotate(-10deg)}45%{transform:rotate(8deg)}60%{transform:rotate(-6deg)}75%{transform:rotate(3deg)}}
.error-title{font-size:1.6rem;font-weight:800;color:var(--text);margin-bottom:.75rem}
.error-text{color:var(--text2);font-size:1rem;line-height:1.7;margin-bottom:1.25rem}
.error-detail{display:inline-block;background:var(--glass);border:1px solid var(--border);border-radius:var(--r);padding:.5rem 1.4rem;font-size:.85rem;color:var(--accent);font-weight:600;margin-bottom:1.25rem}
.error-contact{color:var(--text3);font-size:.85rem}
.error-mail{color:var(--accent);text-decoration:underline;font-weight:600}
.live-ticker-sec{padding-top:0}
.live-ticker-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}
.live-ticker-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.1rem 1.2rem;transition:var(--transition)}
.live-ticker-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.live-ticker-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.7rem}
.live-ticker-status{display:inline-flex;align-items:center;justify-content:center;padding:.28rem .8rem;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.3px;text-transform:uppercase}
.live-ticker-status.live{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.25)}
.live-ticker-status.upcoming{background:rgba(16,185,129,.1);color:var(--green);border:1px solid rgba(16,185,129,.25)}
.live-ticker-status.finished{background:rgba(148,163,184,.08);color:var(--text2);border:1px solid var(--border)}
.live-ticker-game{font-size:.75rem;color:var(--text3);text-transform:uppercase;letter-spacing:.8px}
.live-ticker-title{font-size:1rem;font-weight:800;letter-spacing:-.01em;margin-bottom:.5rem}
.live-ticker-meta{display:flex;flex-wrap:wrap;gap:.5rem;color:var(--text2);font-size:.8rem;margin-bottom:.75rem}
.live-ticker-score{font-size:1.5rem;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
@media(max-width:640px){.live-ticker-list{grid-template-columns:1fr}}
/* ── Page & Scroll Animations ─────────────────────────────────── */
@keyframes rootIn{from{opacity:0}to{opacity:1}}
#root{animation:rootIn .25s ease both}
@keyframes cardIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes heroIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.nd-reveal{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease}
.nd-visible{opacity:1!important;transform:translateY(0)!important}
.nd-stagger.nd-visible>:nth-child(1){animation:cardIn .42s ease both}
.nd-stagger.nd-visible>:nth-child(2){animation:cardIn .42s ease both .07s}
.nd-stagger.nd-visible>:nth-child(3){animation:cardIn .42s ease both .14s}
.nd-stagger.nd-visible>:nth-child(4){animation:cardIn .42s ease both .21s}
.nd-stagger.nd-visible>:nth-child(n+5){animation:cardIn .42s ease both .26s}
.hero-badge{animation:heroIn .5s ease both .05s}
.hero-logo-wrap{animation:heroIn .5s ease both .12s}
.hero h1{animation:heroIn .6s ease both .2s}
.hero-sub{animation:heroIn .5s ease both .34s}
.hero-cta{animation:heroIn .5s ease both .46s}
.hero-scroll{animation:heroIn .4s ease both .58s}
/* ── Privacy / Datenschutz Page ──────────────────────────────── */
.privacy-table-wrap{overflow-x:auto;margin:.8rem 0}
.privacy-table{width:100%;border-collapse:collapse;font-size:.85rem}
.privacy-table th,.privacy-table td{text-align:left;padding:.6rem .8rem;border-bottom:1px solid var(--border)}
.privacy-table th{color:var(--text);font-weight:600;background:var(--glass)}
.privacy-table td{color:var(--text2)}
/* ── Teams overview (grouped by game, expandable) ───────────────── */
.teams-overview{display:flex;flex-direction:column;gap:2.4rem}
.game-group-title{font-size:1.25rem;font-weight:800;letter-spacing:-.01em;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);text-transform:uppercase}
.team-accordion{display:flex;flex-direction:column;gap:.75rem}
.team-acc{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:var(--transition)}
.team-acc.is-open{border-color:var(--tc,var(--border2))}
.team-acc-head{display:flex;align-items:center;gap:1rem;width:100%;padding:1rem 1.2rem;background:none;border:none;color:inherit;font:inherit;cursor:pointer;text-align:left;transition:var(--transition)}
.team-acc-head:hover{background:var(--glass)}
.tacc-logo-wrap{width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.tacc-logo{width:44px;height:44px;border-radius:10px}
.tacc-icon{font-size:1.4rem;font-weight:900}
.tacc-main{flex:1;min-width:0}
.tacc-name{font-size:1.02rem;font-weight:800;letter-spacing:-.01em}
.tacc-tag{font-size:.72rem;font-weight:700;color:var(--text3);margin-left:.4rem}
.tacc-meta{display:flex;align-items:center;gap:.4rem;flex-shrink:0}
.tacc-count{font-size:.78rem;color:var(--text3);white-space:nowrap}
.tacc-caret{font-size:.9rem;color:var(--text3);transition:transform .25s var(--ease)}
.team-acc.is-open .tacc-caret{transform:rotate(180deg)}
.team-acc-panel{padding:0 1.2rem 1.4rem;border-top:1px solid var(--border)}
.team-acc-loading{padding:1.4rem;text-align:center;color:var(--text3);font-size:.88rem}
.team-panel-desc{color:var(--text2);line-height:1.7;margin:1rem 0}
.team-panel-rows{display:flex;flex-direction:column;gap:.55rem;margin:1rem 0 1.4rem}
.tpr{display:flex;gap:.8rem;align-items:baseline;flex-wrap:wrap}
.tpr-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);min-width:120px;font-weight:700}
.tpr-value{color:var(--text);font-size:.9rem}
.tpr-social{display:inline-flex;flex-wrap:wrap;gap:.8rem}
.tpr-social a{color:var(--accent);font-size:.85rem;font-weight:600}.tpr-social a:hover{text-decoration:underline}
.team-panel-roster-title{font-size:.95rem;font-weight:800;text-transform:uppercase;letter-spacing:.6px;margin:.5rem 0 1rem;color:var(--text2)}
.team-panel-foot{display:flex;justify-content:flex-end;margin-top:1.2rem}
/* ── Player detail modal ────────────────────────────────────────── */
.pmodal-backdrop{position:fixed;inset:0;z-index:9600;background:rgba(0,0,0,.66);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;padding:1.2rem;opacity:0;transition:opacity .22s var(--ease)}
.pmodal-backdrop.is-open{opacity:1}
.pmodal{position:relative;background:var(--bg2);border:1px solid var(--border2);border-top:3px solid var(--tc,var(--accent));border-radius:var(--r2);max-width:480px;width:100%;max-height:88vh;overflow-y:auto;padding:2rem;box-shadow:0 12px 70px rgba(0,0,0,.6);transform:translateY(10px) scale(.98);transition:transform .25s var(--ease)}
.pmodal-backdrop.is-open .pmodal{transform:translateY(0) scale(1)}
.pmodal-close{position:absolute;top:.9rem;right:1rem;font-size:1.3rem;line-height:1;color:var(--text3);background:none;border:none;cursor:pointer;transition:var(--transition)}.pmodal-close:hover{color:var(--text)}
.pmodal-hero{display:flex;align-items:center;gap:1.3rem;margin-bottom:1.2rem}
.pmodal-photo{width:104px;height:104px;border-radius:var(--r2);object-fit:cover;border:2px solid var(--tc,var(--border2));flex-shrink:0}
.pmodal-id{min-width:0}
.pmodal-ign{font-size:1.4rem;font-weight:900;letter-spacing:-.02em}
.pmodal-name{color:var(--text2);font-size:.9rem;margin-top:.1rem}
.pmodal-id .proles{justify-content:flex-start;margin-top:.6rem}
.pmodal-bio{color:var(--text2);line-height:1.75;font-size:.92rem;margin-bottom:1rem}
.pmodal-meta{display:flex;flex-wrap:wrap;gap:1rem;color:var(--text3);font-size:.82rem;margin-bottom:1rem}
.pmodal-social{display:flex;flex-wrap:wrap;gap:1rem;padding-top:1rem;border-top:1px solid var(--border)}
.pmodal-social a{color:var(--accent);font-weight:600;font-size:.88rem}.pmodal-social a:hover{text-decoration:underline}
@media(max-width:640px){.tpr-label{min-width:0}.pmodal-hero{flex-direction:column;text-align:center}.pmodal-id .proles{justify-content:center}.team-acc-head{gap:.7rem;padding:.9rem 1rem}}
/* ── Maintenance page (portal updating / unavailable) ──────────── */
.maintenance-page{min-height:calc(100vh - var(--nav-h));display:flex;align-items:center;justify-content:center;position:relative}
.maintenance-state{text-align:center;max-width:540px;padding:3rem 2rem}
.maint-logo-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;margin-bottom:1.8rem}
.maint-logo{width:96px;height:96px;object-fit:contain;animation:float 7s ease-in-out infinite;position:relative;z-index:2}
.maint-pulse{position:absolute;width:96px;height:96px;border-radius:50%;background:radial-gradient(circle,var(--glow),transparent 70%);animation:maintPulse 2.4s ease-in-out infinite}
@keyframes maintPulse{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.5);opacity:0}}
.maint-title{font-size:1.7rem;font-weight:800;color:var(--text);margin-bottom:.75rem;letter-spacing:-.01em}
.maint-text{color:var(--text2);font-size:1rem;line-height:1.7;margin-bottom:1.5rem}
.maint-dots{display:flex;gap:.5rem;justify-content:center;margin-bottom:1.5rem}
.maint-dots span{width:10px;height:10px;border-radius:50%;background:var(--accent);animation:maintBounce 1.4s ease-in-out infinite}
.maint-dots span:nth-child(2){animation-delay:.2s}
.maint-dots span:nth-child(3){animation-delay:.4s}
@keyframes maintBounce{0%,80%,100%{transform:translateY(0);opacity:.4}40%{transform:translateY(-10px);opacity:1}}
@media(prefers-reduced-motion:reduce){.maint-logo,.maint-pulse,.maint-dots span{animation:none}}

/* ── Spieler-Profilseite (B-80) ─────────────────────────────────── */
.pp-hero-top{display:flex;align-items:center;gap:1.6rem;flex-wrap:wrap;margin-top:1.4rem}
/* Spieler-LOGO im Hero: keine harte Kante/Border — weicher, ausfadender Farb-Glow
   im Hintergrund + sanfter Schatten. Logo wird komplett gezeigt (contain). */
.pp-hero-photo{width:136px;height:136px;object-fit:contain;flex-shrink:0;border:1.5px solid color-mix(in srgb,var(--tc,var(--accent)) 60%,transparent);border-radius:var(--r2);padding:10px;background:radial-gradient(circle at 50% 42%,color-mix(in srgb,var(--tc,var(--accent)) 22%,transparent) 0%,transparent 70%);filter:drop-shadow(0 8px 22px color-mix(in srgb,var(--tc,var(--accent)) 30%,transparent))}
.pp-hero-photo.ppic-fallback{display:flex;align-items:center;justify-content:center;font-size:2.4rem;font-weight:900;color:#fff;text-transform:uppercase;border-radius:var(--r2);background:color-mix(in srgb,var(--tc,var(--accent)) 88%,#000);padding:0;filter:none}
/* Anklickbares Profilbild → Lightbox. */
.pp-hero-photo.is-zoomable{cursor:zoom-in;transition:transform .2s ease,filter .2s ease}
.pp-hero-photo.is-zoomable:hover{transform:scale(1.03)}
.pp-hero-id{display:flex;flex-direction:column;gap:.5rem;min-width:0}
.pp-hero-name{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:900;line-height:1.1;letter-spacing:-.02em;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.pp-hero-real{color:var(--text2);font-size:1rem}
.pp-hero-chips{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.2rem}
.pp-hero-chips .chip2{cursor:default}
.pp-hero-chips button.chip2{cursor:pointer;transition:var(--transition)}
.pp-hero-chips button.chip2:hover{border-color:var(--tc,var(--accent));color:var(--text)}
.pp-hero-social{margin-top:.4rem}
.pp-sec{padding-top:0}
.pp-sec-title{font-size:clamp(1.4rem,2.4vw,2rem);font-weight:800;margin-bottom:1.4rem}
.pp-favorite{font-size:1.3rem;font-weight:800;color:var(--tc,var(--accent))}
.pp-meta-label{color:var(--text3)}
.pp-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}
.pp-stat{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.4rem 1.2rem;text-align:center}
.pp-stat-value{font-size:1.9rem;font-weight:900;letter-spacing:-.02em;color:var(--text)}
.pp-stat-label{color:var(--text2);font-size:.82rem;text-transform:uppercase;letter-spacing:1px;margin-top:.3rem}
.pp-chart{display:flex;flex-direction:column;gap:1rem;max-width:680px}
.pp-bar-row{display:grid;grid-template-columns:140px 1fr 38px;align-items:center;gap:1rem}
.pp-bar-label{color:var(--text2);font-size:.88rem;font-weight:600}
.pp-bar-track{height:12px;background:var(--bg3);border-radius:50px;overflow:hidden}
.pp-bar-fill{display:block;height:100%;border-radius:50px;background:linear-gradient(90deg,var(--tc,var(--accent)),color-mix(in srgb,var(--tc,var(--accent)) 55%,#fff));transition:width .6s var(--ease)}
.pp-bar-val{color:var(--text);font-weight:800;font-size:.88rem;text-align:right}
.pp-clips{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.1rem}
.pp-clip{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:var(--transition)}
.pp-clip:hover{border-color:var(--tc,var(--accent));transform:translateY(-3px)}
.pp-clip-thumb{position:relative;display:flex;align-items:center;justify-content:center;aspect-ratio:16/9;background:var(--bg3)}
.pp-clip-thumb img{width:100%;height:100%;object-fit:cover}
.pp-clip-play{position:absolute;width:46px;height:46px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;padding-left:3px;border:2px solid var(--tc,var(--accent))}
.pp-clip-title{padding:.8rem 1rem;font-size:.9rem;font-weight:600;color:var(--text)}
@media(max-width:560px){.pp-bar-row{grid-template-columns:96px 1fr 30px;gap:.6rem}.pp-hero-photo{width:96px;height:96px}}

/* ── Theme: Light-Mode-Defaults (B-81) ───────────────────────────
   Dark ist der Standard (:root oben). Diese Werte greifen, sobald
   <html data-theme="light"> gesetzt ist. Die CMS-Anker (bg/surface/
   text/textMuted/accent) werden zur Laufzeit per inline-Style auf
   :root überschrieben; translucente Tokens bleiben hier modusabhängig. */
:root[data-theme="light"]{
  --bg:#f4f5f8;--bg2:#ffffff;--bg3:#eef0f4;
  --card:rgba(0,0,0,0.025);--card2:rgba(0,0,0,0.045);
  --border:rgba(0,0,0,0.10);--border2:rgba(0,0,0,0.16);
  --text:#16161d;--text2:#55556a;--text3:#8a8aa0;
  --glass:rgba(0,0,0,0.04);--glass-border:rgba(0,0,0,0.10);--glass-border-hover:rgba(0,0,0,0.18);
  --glow:rgba(249,61,0,.28);
  --nav-bg:rgba(255,255,255,.85);--menu-bg:#ffffff;
}
:root[data-theme="light"] #nav.scrolled{border-bottom:1px solid var(--border)}

/* Theme-Umschalter in der Nav (Sonne im Dark-, Mond im Light-Modus). */
.theme-toggle{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--glass);border:1px solid var(--glass-border);color:var(--text2);cursor:pointer;transition:var(--transition)}
.theme-toggle:hover{color:var(--text);border-color:var(--glass-border-hover);background:var(--card2)}
.theme-toggle .icon-moon{display:none}
.theme-toggle .icon-sun{display:block}
:root[data-theme="light"] .theme-toggle .icon-sun{display:none}
:root[data-theme="light"] .theme-toggle .icon-moon{display:block}

/* ── Section-Band-Slider (mehrere Bilder → Crossfade + Pfeile + Dots) ── */
.section-band-slides{position:absolute;inset:0;z-index:1}
.section-band-slide{position:absolute;inset:0;opacity:0;background-position:center;background-repeat:no-repeat;transition:opacity .8s ease;will-change:opacity}
.section-band-slide.is-active{opacity:1}
.section-band-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.3);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px);opacity:0;transition:background .25s var(--ease),opacity .35s var(--ease),border-color .25s var(--ease),transform .25s var(--ease)}
.section-band-slider:hover .section-band-arrow{opacity:1}
.section-band-arrow:hover{background:rgba(0,0,0,.55);border-color:rgba(255,255,255,.55)}
.section-band-arrow:focus-visible{opacity:1;outline:2px solid #fff;outline-offset:2px}
.section-band-arrow svg{width:18px;height:18px}
.section-band-prev{left:1rem}
.section-band-prev:hover{transform:translateY(-50%) translateX(-2px)}
.section-band-next{right:1rem}
.section-band-next:hover{transform:translateY(-50%) translateX(2px)}
.section-band-dots{position:absolute;bottom:.9rem;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:.45rem}
.section-band-dot{appearance:none;border:none;position:relative;width:28px;height:4px;border-radius:3px;background:rgba(255,255,255,.3);cursor:pointer;padding:0;overflow:hidden;transition:width .35s var(--ease),background .25s var(--ease)}
.section-band-dot:hover{background:rgba(255,255,255,.55)}
.section-band-dot.is-active{width:44px;background:rgba(255,255,255,.32)}
.section-band-dot-fill{position:absolute;left:0;top:0;bottom:0;width:0;background:#fff;border-radius:3px}
@media (max-width:768px){
  .section-band-arrow{opacity:1;width:34px;height:34px}
  .section-band-prev{left:.5rem}
  .section-band-next{right:.5rem}
}
@media (prefers-reduced-motion: reduce){
  .section-band-slide{transition:opacity .2s ease}
}

/* ── Tournament platform pages (TP-H01..03) ───────────────────────── */
.tourn-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; }
.tourn-card { display: block; padding: 18px; border-radius: 14px; background: var(--bg-card, #0d0d2a); border: 1px solid var(--border, #1c1c48); text-decoration: none; color: inherit; transition: transform .15s, border-color .15s; }
.tourn-card:hover { transform: translateY(-3px); border-color: #a855f7; }
.tourn-card-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 8px; }
.tourn-name { font-weight: 700; font-size: 17px; }
.tourn-meta { color: #9090c8; font-size: 13px; }
.tourn-badge { padding: 2px 10px; border-radius: 999px; font-size: 12px; font-weight: 600; white-space: nowrap; }
.tourn-back { display: inline-block; margin-bottom: 12px; color: #a855f7; text-decoration: none; font-size: 14px; }
.tourn-stage { margin-top: 22px; }
.tourn-stage h3 small { color: #9090c8; font-weight: 400; font-size: 13px; }
.brk-rounds { display: flex; gap: 26px; align-items: flex-start; overflow-x: auto; padding: 10px 0; }
.brk-col { display: flex; flex-direction: column; gap: 12px; min-width: 200px; }
.brk-col h4 { color: #9090c8; font-size: 12px; text-transform: uppercase; letter-spacing: 1px; }
.brk-match { border: 1px solid var(--border, #1c1c48); border-radius: 8px; overflow: hidden; }
.brk-slot { display: flex; justify-content: space-between; padding: 7px 11px; font-size: 14px; }
.brk-slot + .brk-slot { border-top: 1px solid var(--border, #1c1c48); }
.brk-slot.win { background: rgba(34,197,94,.16); color: #4ade80; font-weight: 700; }
.tourn-table-wrap { overflow-x: auto; margin-top: 14px; }
.tourn-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.tourn-table th, .tourn-table td { padding: 8px 12px; text-align: left; border-bottom: 1px solid var(--border, #1c1c48); }
.tourn-table th { color: #9090c8; font-weight: 600; }

/* Tournament live ticker (TP-H06/07/08) */
.tourn-live { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; padding: 10px 14px; background: var(--bg-card, #0d0d2a); border: 1px solid var(--border, #1c1c48); border-radius: 10px; }
.tourn-live-label { font-weight: 700; color: #ef4444; white-space: nowrap; }
.tlt-track { display: flex; gap: 22px; overflow-x: auto; }
.tlt-item { display: flex; align-items: center; gap: 8px; white-space: nowrap; font-size: 14px; }
.tlt-vs { color: #a855f7; font-weight: 700; }
.tlt-live { color: #ef4444; font-weight: 700; font-size: 12px; }
.tourn-vs { color: #9090c8; text-align: center; }

/* Tournament participants + tip widget (TP-H04/H15) */
.tpart-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 8px; }
.tpart-card { display: flex; flex-direction: column; padding: 8px 12px; border: 1px solid var(--border, #1c1c48); border-radius: 8px; background: var(--bg-card, #0d0d2a); }
.tpart-name { font-weight: 600; }
.tpart-meta { font-size: 12px; color: #9090c8; }
.tip-widget { display: flex; gap: 14px; align-items: center; margin-top: 22px; padding: 16px 18px; border: 1px solid #a855f7; border-radius: 12px; background: rgba(168,85,247,.08); }
.tip-widget-emoji { font-size: 28px; }
.tip-widget p { color: #9090c8; margin: 2px 0 0; font-size: 14px; }
.tip-widget code { background: #05051a; padding: 1px 6px; border-radius: 5px; color: #a855f7; }

/* ── In-App-Lightbox (anklickbare Bilder, z. B. Spieler-Profilbild) ── */
.nd-lightbox{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:clamp(1rem,5vw,3rem);background:rgba(0,0,0,.78);backdrop-filter:blur(6px);opacity:0;transition:opacity .18s ease;cursor:zoom-out}
.nd-lightbox.is-open{opacity:1}
.nd-lightbox-img{max-width:min(92vw,720px);max-height:88vh;object-fit:contain;border-radius:14px;box-shadow:0 24px 70px rgba(0,0,0,.6);transform:scale(.96);transition:transform .2s cubic-bezier(.22,1,.36,1);cursor:default}
.nd-lightbox.is-open .nd-lightbox-img{transform:scale(1)}
.nd-lightbox-close{position:absolute;top:max(1rem,env(safe-area-inset-top));right:max(1rem,env(safe-area-inset-right));width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.7rem;line-height:1;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:50%;cursor:pointer;transition:background .15s ease}
.nd-lightbox-close:hover{background:rgba(255,255,255,.24)}
@media (prefers-reduced-motion:reduce){.nd-lightbox,.nd-lightbox-img{transition:none}}
