/* ── Design System: Shared Variables, Reset & Components ── */

:root {
    --bg:#0a0a0f; --card:#13131a; --card-border:#1e1e2a;
    --text:#e8e8ed; --text-muted:#8b8b9b; --muted:#8b8b9b;
    --accent:#22c55e; --accent-dim:rgba(34,197,94,0.15); --accent-glow:rgba(34,197,94,0.3);
    --loss:#ef4444; --loss-dim:rgba(239,68,68,0.15);
    --gold:#f59e0b; --gold-dim:rgba(245,158,11,0.15);
    --silver:#94a3b8; --bronze:#cd7c2f;
    --link:#5b8af5; --radius:14px; --radius-sm:10px;
    --men:#5b8af5; --women:#f472b6; --udvalgte:#eab308;
    --toggle-active:#22c55e; --toggle-inactive:#1e1e2a;
}

/* ── Reset ── */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{touch-action:manipulation;scrollbar-gutter:stable;}
body{
    background:var(--bg);color:var(--text);
    font-family:'DM Sans',-apple-system,sans-serif;
    min-height:100vh;-webkit-font-smoothing:antialiased;
}

/* ── Top Nav ── */
.nav{display:flex;justify-content:space-between;align-items:center;padding:8px 0 16px;font-size:13px;color:var(--text-muted);}
.nav a{color:var(--link);text-decoration:none;font-weight:500;}
.nav-home{display:inline-flex;vertical-align:-3px;margin-right:4px;color:var(--text-muted);transition:color 0.2s;}.nav-home:hover{color:var(--accent);}

/* ── Floating Bottom Nav ── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:1000;display:flex;justify-content:center;padding:0 16px 16px;pointer-events:none;}
.bottom-nav-inner{display:flex;align-items:stretch;background:rgba(16,16,24,0.82);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border:1px solid rgba(255,255,255,0.1);border-radius:22px;padding:6px 4px 8px;gap:0;width:100%;max-width:520px;pointer-events:auto;box-shadow:0 4px 30px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.05);}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 4px 4px;background:none;border:none;color:var(--text-muted);font-family:'DM Sans',sans-serif;font-size:10px;font-weight:600;letter-spacing:0.02em;cursor:pointer;transition:all 0.2s ease;position:relative;-webkit-tap-highlight-color:transparent;text-decoration:none;}
.nav-item svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:all 0.2s ease;}
.nav-item:hover{color:var(--text);}
.nav-item.active{color:var(--accent);}
.nav-item.active svg{stroke-width:2.2;}
.nav-item.active::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:24px;height:3px;border-radius:0 0 3px 3px;background:var(--accent);animation:navDot 0.3s ease both;}
@keyframes navDot{from{width:0;opacity:0}to{width:24px;opacity:1}}

/* ── Nav Submenu (Rangliste dropdown) ── */
.nav-item-wrap{flex:1;position:relative;display:flex;flex-direction:column;align-items:center;}
.nav-item-wrap .nav-item{width:100%;}
.nav-submenu{display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:rgba(16,16,24,0.92);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border:1px solid rgba(255,255,255,0.12);border-radius:14px;padding:6px;gap:4px;flex-direction:column;min-width:140px;box-shadow:0 4px 24px rgba(0,0,0,0.5);z-index:1001;animation:submenuIn 0.2s ease both;}
.nav-submenu.open{display:flex;}
@keyframes submenuIn{from{opacity:0;transform:translateX(-50%) translateY(6px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.nav-submenu-item{display:flex;align-items:center;gap:8px;padding:10px 14px;background:none;border:none;color:var(--text-muted);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;border-radius:10px;transition:all 0.15s ease;white-space:nowrap;}
.nav-submenu-item svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.nav-submenu-item:hover{background:rgba(255,255,255,0.06);color:var(--text);}
.nav-submenu-item.active{color:var(--accent);background:var(--accent-dim);}
.nav-submenu::after{content:'';position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);width:12px;height:6px;background:rgba(16,16,24,0.92);clip-path:polygon(0 0,100% 0,50% 100%);}

/* ── Toast ── */
#shareToast{position:fixed;top:24px;left:50%;transform:translateX(-50%) translateY(-12px);background:#1e1e2a;border:1px solid var(--card-border);color:var(--accent);font-size:13px;font-weight:600;padding:10px 20px;border-radius:30px;box-shadow:0 4px 20px rgba(0,0,0,0.5);opacity:0;pointer-events:none;transition:opacity 0.2s ease,transform 0.2s ease;z-index:9999;white-space:nowrap;}
#shareToast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ── Shared Animations ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes modalIn{from{opacity:0;transform:scale(0.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}

/* ── Flag badges (unified cross-browser) ── */
.flag{border-radius:3px;vertical-align:middle;flex-shrink:0;display:inline-block;}
.flag--sm{width:18px;height:auto;}
.flag--md{width:24px;height:auto;}
.flag--lg{width:32px;height:auto;}

/* ── Cross-page view transitions (draw pages) ── */
::view-transition-old(root){animation:fadeIn 0.2s ease reverse}
::view-transition-new(root){animation:fadeIn 0.2s ease}
