/**
 * Strongman - Main Stylesheet
 *
 * Clean modern design system - light mode, mobile-first.
 * All styles scoped to .strongman-app to prevent WordPress conflicts.
 *
 * @package Strongman
 * @since 4.0.0
 */

/* ==========================================================================
   1. DESIGN TOKENS
   ========================================================================== */

.strongman-app {
    /* Bold Sports Design System */
    /* Primary: Crimson accent */
    --sm-primary: #e94560;
    --sm-primary-hover: #c81e45;
    --sm-primary-light: rgba(233, 69, 96, 0.08);
    --sm-primary-soft: rgba(233, 69, 96, 0.12);

    /* Navy: Dark primary for headers, heroes, footer */
    --sm-navy: #1a1a2e;
    --sm-navy-light: #16213e;
    --sm-electric: #0f3460;
    --sm-electric-light: #1a4a7a;

    /* Accent: Gold */
    --sm-accent: #f5a623;
    --sm-accent-hover: #d4920a;
    --sm-accent-light: rgba(245, 166, 35, 0.08);
    --sm-accent-soft: rgba(245, 166, 35, 0.12);

    /* Green */
    --sm-green: #2ecc71;
    --sm-green-soft: rgba(46, 204, 113, 0.1);
    --sm-green-400: #4ade80;
    --sm-green-500: #2ecc71;
    --sm-green-600: #27ae60;
    --sm-green-700: #1e8449;

    /* Cool gray neutrals */
    --sm-gray-50: #f8f9fb;
    --sm-gray-100: #f0f2f5;
    --sm-gray-200: #e8ecf1;
    --sm-gray-300: #d1d9e0;
    --sm-gray-400: #6b7585;
    --sm-gray-500: #6b7688;
    --sm-gray-600: #5a6577;
    --sm-gray-700: #3d4555;
    --sm-gray-800: #2a2f3d;
    --sm-gray-900: var(--sm-navy);

    /* Semantic aliases */
    --sm-bg: #fff;
    /*var(--sm-gray-50);*/
    --sm-surface: #ffffff;
    --sm-border: var(--sm-gray-200);
    --sm-border-strong: var(--sm-gray-300);
    --sm-text-primary: var(--sm-navy);
    --sm-text-secondary: #5a6577;
    --sm-text-muted: #6b7585;

    /* CTA uses primary crimson */
    --sm-cta: var(--sm-primary);
    --sm-cta-hover: var(--sm-primary-hover);
    --sm-cta-light: var(--sm-primary-light);

    /* Semantic status */
    --sm-success: #2ecc71;
    --sm-success-light: rgba(46, 204, 113, 0.1);
    --sm-warning: #f5a623;
    --sm-warning-light: rgba(245, 166, 35, 0.1);
    --sm-error: #ef4444;
    --sm-error-light: #fee2e2;

    /* Typography: DM Sans */
    --sm-font-heading: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --sm-font-body: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --sm-font-sans: var(--sm-font-body);
    --sm-font-mono: ui-monospace, SFMono-Regular, 'SF Mono', Menlo, monospace;

    /* Spacing */
    --sm-space-1: 0.25rem;
    --sm-space-2: 0.5rem;
    --sm-space-3: 0.75rem;
    --sm-space-4: 1rem;
    --sm-space-5: 1.25rem;
    --sm-space-6: 1.5rem;
    --sm-space-8: 2rem;
    --sm-space-10: 2.5rem;
    --sm-space-12: 3rem;
    --sm-space-16: 4rem;
    --sm-space-20: 5rem;
    --sm-space-24: 6rem;

    /* Font sizes */
    --sm-fs-xs: 0.75rem;
    --sm-fs-sm: 0.875rem;
    --sm-fs-base: 1rem;
    --sm-fs-md: 1.125rem;
    --sm-fs-lg: 1.25rem;
    --sm-fs-xl: 1.5rem;
    --sm-fs-2xl: 1.875rem;
    --sm-fs-3xl: 2.25rem;
    --sm-fs-2xs: 0.6875rem;
    /* 11px */
    --sm-fs-15: 0.9375rem;
    /* 15px */

    /* Bold Sports radii */
    --sm-radius-sm: 6px;
    --sm-radius: 10px;
    --sm-radius-md: 12px;
    --sm-radius-lg: 14px;
    --sm-radius-xl: 18px;
    --sm-radius-2xl: 24px;
    --sm-radius-full: 9999px;

    /* Soft card shadows */
    --sm-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04);
    --sm-shadow: 0 1px 3px rgba(0, 0, 0, 0.04), 0 4px 12px rgba(0, 0, 0, 0.03);
    --sm-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.06);
    --sm-shadow-lg: 0 10px 40px rgba(0, 0, 0, 0.08);

    /* Focus ring */
    --sm-focus-ring-color: var(--sm-primary);
    --sm-focus-ring-width: 2px;
    --sm-focus-ring-offset: 2px;

    /* Transitions */
    --sm-transition-fast: 150ms;
    --sm-transition: 150ms ease;
    --sm-transition-normal: 200ms;
    --sm-transition-slow: 300ms ease;
    --sm-ease-out: cubic-bezier(0.33, 1, 0.68, 1);
    --sm-ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);

    /* Animation stagger */
    --sm-stagger: 60ms;

    /* Font weights */
    --sm-weight-normal: 400;
    --sm-weight-medium: 500;
    --sm-weight-semibold: 600;
    --sm-weight-bold: 700;
    --sm-weight-extrabold: 800;

    /* Level colors (Beginner < Novice < Intermediate < Advanced < Elite) */
    --sm-level-beginner: #8b95a5;
    --sm-level-novice: #2ecc71;
    --sm-level-intermediate: #0f3460;
    --sm-level-advanced: var(--sm-primary);
    --sm-level-elite: #f5a623;

    /* Rank badge colors */
    --sm-gold: #ffd700;
    --sm-gold-end: #f0c800;
    --sm-gold-text: #5c4a00;
    --sm-silver: #c0c0c0;
    --sm-silver-end: #a8a8a8;
    --sm-silver-text: #3d3d3d;
    --sm-bronze: #cd7f32;
    --sm-bronze-end: #b5692a;
    --sm-bronze-text: #fff;

    /* Container */
    --sm-container: 1240px;

    /*
     * Z-Index Scale (not custom properties - used as raw values)
     *   1-2   : Content stacking (positioned elements within cards/headers)
     *   10    : Minor overlay (floating labels, badges)
     *   50    : Dropdown / tooltip / popover
     *   100   : Sticky header / skip-link
     *   1000  : Modal backdrop
     *   10000 : Toast / notification / confetti (topmost layer)
     */
}

/* ==========================================================================
   2. RESET & BASE
   ========================================================================== */

.strongman-app {
    font-family: var(--sm-font-body) !important;
    font-size: 15px !important;
    line-height: 1.5 !important;
    color: var(--sm-text-primary) !important;
    background-color: var(--sm-bg) !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.strongman-app *,
.strongman-app *::before,
.strongman-app *::after {
    box-sizing: border-box;
}

.strongman-app img,
.strongman-app video {
    max-width: 100%;
}

.strongman-app a,
.strongman-app a:hover,
.strongman-app a:focus,
.strongman-app a:visited,
.rbct .strongman-app a,
.entry-content .strongman-app a {
    text-decoration: none !important;
}

.strongman-app a {
    color: var(--sm-primary);
    transition: color var(--sm-transition);
}

.strongman-app a:hover {
    color: var(--sm-primary-hover);
}

/* ==========================================================================
   3. LAYOUT
   ========================================================================== */

.sm-container {
    width: 100%;
    max-width: var(--sm-container);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--sm-space-4);
    padding-right: var(--sm-space-4);
}

@media (min-width: 640px) {
    .sm-container {
        padding-left: var(--sm-space-6);
        padding-right: var(--sm-space-6);
    }
}

.sm-main {
    min-height: calc(100vh - 200px);
    padding-top: var(--sm-space-8);
    padding-bottom: var(--sm-space-16);
}

/* Skip Link */
.sm-skip-link {
    position: absolute;
    top: -9999px;
    left: 16px;
    clip: rect(0, 0, 0, 0);
    overflow: hidden;
    background: var(--sm-gray-800);
    color: white !important;
    padding: var(--sm-space-2) var(--sm-space-4);
    z-index: 100;
    border-radius: var(--sm-radius);
    transition: none;
}

.sm-skip-link:focus {
    top: 16px;
    clip: auto;
    overflow: visible;
}

/* ==========================================================================
   4. TYPOGRAPHY
   ========================================================================== */

.sm-page-title {
    font-family: var(--sm-font-heading);
    font-size: 32px;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
    letter-spacing: -0.03em;
    margin-bottom: var(--sm-space-4);
    line-height: 1.15;
}

.sm-page-subtitle {
    font-size: 15px;
    color: var(--sm-text-secondary);
    margin-bottom: var(--sm-space-8);
    max-width: 500px;
}

.sm-section-heading {
    font-family: var(--sm-font-heading);
    font-size: 20px;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
    letter-spacing: -0.02em;
    margin-bottom: 20px;
}

.sm-seo-heading {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin-bottom: var(--sm-space-4);
}

.sm-seo-content {
    color: var(--sm-text-secondary);
    line-height: 1.7;
}

.sm-seo-content p {
    margin-bottom: var(--sm-space-4);
}

/* ==========================================================================
   5. NAVIGATION
   ========================================================================== */

.sm-nav {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--sm-gray-200);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    transition: all var(--sm-transition);
}

.sm-nav>.sm-container {
    max-width: 100%;
    padding: 0 var(--sm-space-4);
}

.sm-nav-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 6px 0;
}

.strongman-app .sm-nav-logo {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 900;
    font-size: 22px;
    color: var(--sm-text-primary);
    letter-spacing: -0.03em;
    flex-shrink: 0;
    text-decoration: none;
    transition: opacity 0.15s;
}

.strongman-app .sm-nav-logo:hover {
    opacity: 0.8;
    color: var(--sm-text-primary);
}

.sm-nav-logo-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 22px;
    color: var(--sm-primary);
}

.sm-nav-logo-icon svg {
    width: 30px;
    height: 22px;
}

.sm-nav-links {
    display: none;
    align-items: center;
    gap: 2px;
    flex: 1;
    justify-content: center;
}

@media (min-width: 769px) {
    .sm-nav-links {
        display: flex;
    }
}

.sm-nav-link {
    color: var(--sm-text-muted);
    font-weight: 500;
    font-size: 13px;
    padding: 4px 12px;
    border-radius: 6px;
    border: none;
    transition: all 0.15s;
    display: flex;
    align-items: center;
    white-space: nowrap;
}

.sm-nav-link:hover {
    color: var(--sm-text-primary);
    background: var(--sm-gray-50, #f8f9fb);
}

/* Active state only on top-level nav tabs, NOT dropdown items */
.sm-nav-dropdown-item.sm-nav-link-active,
.sm-nav-dropdown-item.sm-nav-link-active:hover {
    background: none;
    border: none;
    border-bottom: none;
    color: var(--sm-primary);
    font-weight: 600;
}

.sm-nav-actions {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3);
    flex-shrink: 0;
}

/* Nav Auth Button (visitors only) */
.strongman-app .sm-nav-auth-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: var(--sm-navy);
    color: #fff;
    border-radius: var(--sm-radius-full);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.15s;
    white-space: nowrap;
}
.strongman-app .sm-nav-auth-btn:hover {
    background: var(--sm-primary);
    color: #fff;
    text-decoration: none;
}
.strongman-app .sm-nav-auth-btn svg {
    opacity: 0.85;
}

/* Mobile auth buttons (visitors only) */
.sm-nav-mobile-auth {
    display: flex;
    gap: 8px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--sm-gray-100);
}

/* Unit Toggle (LBS/KG) — segmented control */
.sm-unit-toggle {
    display: flex;
    align-items: center;
    background: var(--sm-gray-100);
    border-radius: var(--sm-radius-full);
    padding: 3px;
    border: 1px solid var(--sm-gray-200);
}

.sm-unit-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 30px;
    background: transparent;
    border: none;
    border-radius: var(--sm-radius-full);
    font-size: 12px;
    font-weight: 700;
    color: var(--sm-text-muted);
    cursor: pointer;
    transition: all 0.15s;
    font-family: inherit;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    line-height: 1;
}

.sm-unit-btn:hover:not(.sm-unit-btn-active) {
    color: var(--sm-text-primary);
}

.sm-unit-btn-active {
    background: var(--sm-navy);
    color: #fff;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
}

/* Unit toggle inline variant (for calculator forms) */
.sm-unit-toggle-inline {
    display: flex;
    background: var(--sm-gray-100);
    border-radius: var(--sm-radius);
    padding: 3px;
}

.sm-unit-toggle-inline .sm-unit-btn {
    padding: 10px 30px;
    font-size: 13px;
    font-weight: 600;
    border: none;
    background: transparent;
    color: var(--sm-text-muted);
    cursor: pointer;
    border-radius: calc(var(--sm-radius) - 3px);
    transition: all 0.15s;
    font-family: inherit;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.sm-unit-toggle-inline .sm-unit-btn-active {
    background: var(--sm-surface);
    color: var(--sm-primary);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Hamburger */
.sm-nav-hamburger {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    border-radius: var(--sm-radius);
    transition: background var(--sm-transition);
}

.sm-nav-hamburger:hover {
    background: var(--sm-gray-100);
}

.sm-nav-hamburger-icon {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.sm-nav-hamburger-icon span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--sm-gray-700);
    border-radius: 1px;
    transition: all 0.2s ease;
    transform-origin: center;
}

.sm-nav-hamburger[aria-expanded="true"] .sm-nav-hamburger-icon span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.sm-nav-hamburger[aria-expanded="true"] .sm-nav-hamburger-icon span:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
}

.sm-nav-hamburger[aria-expanded="true"] .sm-nav-hamburger-icon span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

/* Mobile Menu */
.sm-nav-mobile {
    background: var(--sm-surface);
    border-bottom: 1px solid var(--sm-gray-200);
    box-shadow: var(--sm-shadow-md);
    overflow: hidden;
}

@media (min-width: 769px) {
    .sm-nav-mobile {
        display: none !important;
    }

    .sm-nav-hamburger {
        display: none !important;
    }
}

@media (max-width: 768px) {
    .sm-nav-hamburger {
        display: flex !important;
    }

    .sm-nav-links {
        display: none !important;
    }

    .sm-nav-auth-btn {
        display: none !important;
    }
}

.sm-nav-mobile-inner {
    padding: var(--sm-space-4);
}

.sm-nav-mobile-links {
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-1);
}

.strongman-app .sm-nav-mobile-link {
    display: block;
    padding: var(--sm-space-3) var(--sm-space-4);
    color: var(--sm-gray-700);
    font-weight: 500;
    font-size: var(--sm-fs-15);
    border-radius: var(--sm-radius);
    transition: background var(--sm-transition);
    text-decoration: none;
}

.strongman-app .sm-nav-mobile-link:hover,
.strongman-app .sm-nav-mobile-link:focus {
    background: var(--sm-gray-50);
    color: var(--sm-gray-900);
}

.strongman-app .sm-nav-mobile-link[aria-current="page"] {
    background: var(--sm-primary-light);
    color: var(--sm-primary);
}

.sm-nav-mobile-group {
    padding: 8px 0;
    border-bottom: 1px solid var(--sm-gray-100);
}

.sm-nav-mobile-group:last-child {
    border-bottom: none;
}

.sm-nav-mobile-group-label {
    padding: 4px 16px;
    font-size: var(--sm-fs-2xs);
    font-weight: 600;
    text-transform: uppercase;
    color: var(--sm-gray-400);
    letter-spacing: 0.05em;
}

/* Nav Dropdowns */
.sm-nav-dropdown {
    position: relative;
    display: flex;
    align-items: center;
}

.sm-nav-dropdown-trigger {
    display: flex;
    align-items: center;
    gap: 3px;
    cursor: pointer;
    background: none;
    border: none;
    border-radius: 6px;
    padding: 4px 6px;
    font-family: inherit;
    font-size: inherit;
    transition: all 0.15s;
    color: inherit;
}

.sm-nav-dropdown-trigger svg {
    width: 12px;
    height: 12px;
    opacity: 0.5;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.sm-nav-dropdown:hover .sm-nav-dropdown-trigger svg,
.sm-nav-dropdown[data-open="true"] .sm-nav-dropdown-trigger svg {
    opacity: 0.8;
}

.sm-nav-dropdown[data-open="true"] .sm-nav-dropdown-trigger svg {
    transform: rotate(180deg);
}

.sm-nav-dropdown-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    min-width: 200px;
    background: var(--sm-surface);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius-lg);
    box-shadow: var(--sm-shadow-lg);
    padding-top: 12px;
    padding-bottom: 8px;
    z-index: 50;
    opacity: 0;
    visibility: hidden;
    transform: translateX(-50%) translateY(-4px);
    transition: all 0.15s ease;
}

/* Invisible hover bridge — prevents menu from closing when mouse crosses the gap */
.sm-nav-dropdown-menu::before {
    content: "";
    position: absolute;
    top: -12px;
    left: 0;
    right: 0;
    height: 12px;
}

.sm-nav-dropdown[data-open="true"] .sm-nav-dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

.strongman-app .sm-nav-dropdown-item {
    display: block;
    padding: 8px 16px;
    font-size: 0.875rem;
    color: var(--sm-gray-700);
    font-weight: 500;
    text-decoration: none;
    transition: background 0.1s ease, color 0.1s ease;
    white-space: nowrap;
}

.strongman-app .sm-nav-dropdown-item:hover {
    background: var(--sm-gray-50);
    color: var(--sm-primary);
}

.sm-nav-dropdown-divider {
    height: 1px;
    background: var(--sm-gray-100);
    margin: 4px 0;
}

/* ==========================================================================
   6. COMPONENTS
   ========================================================================== */

/* --- Cards --- */

.sm-card {
    background: var(--sm-surface);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius-lg);
    padding: var(--sm-space-4);
    box-shadow: var(--sm-shadow);
    transition: border-color var(--sm-transition), box-shadow var(--sm-transition);
}

.sm-card:hover {
    border-color: var(--sm-gray-300);
    box-shadow: var(--sm-shadow-md);
}

.sm-card--link {
    cursor: pointer;
    text-decoration: none;
    display: block;
    color: inherit;
}

.sm-card--link:hover {
    border-color: var(--sm-primary);
}

.sm-card-hover {
    cursor: pointer;
    transition: border-color var(--sm-transition);
}

.sm-card-hover:hover {
    border-color: var(--sm-primary);
    box-shadow: var(--sm-shadow-md);
}

.sm-card-header {
    padding: var(--sm-space-6);
    border-bottom: 1px solid var(--sm-gray-100);
}

.sm-card-body {
    padding: var(--sm-space-6);
}

.sm-card-footer {
    padding: var(--sm-space-4) var(--sm-space-6);
    background: var(--sm-gray-50);
    border-top: 1px solid var(--sm-gray-100);
    border-radius: 0 0 var(--sm-radius-lg) var(--sm-radius-lg);
}

.sm-card-interactive {
    transition: box-shadow 0.2s ease;
    cursor: pointer;
}

.sm-card-interactive:hover {
    box-shadow: var(--sm-shadow-md);
}

.sm-card-interactive:focus-visible {
    outline: 2px solid var(--sm-primary);
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    .sm-card-interactive {
        transition: none;
    }
}

/* Calculator/data/featured cards */
.sm-calculator-card {
    transition: border-color var(--sm-transition), box-shadow var(--sm-transition);
}

.sm-calculator-card:hover {
    border-color: var(--sm-primary);
    box-shadow: var(--sm-shadow-md);
}

.sm-data-card,
.sm-ai-card {
    transition: border-color var(--sm-transition);
}

.sm-data-card:hover,
.sm-ai-card:hover {
    border-color: var(--sm-primary);
}

.sm-featured-card {
    transition: box-shadow var(--sm-transition-slow);
}

.sm-featured-card:hover {
    box-shadow: var(--sm-shadow-lg);
}

/* Cursor pointer for interactive elements */
.sm-calc-card,
.sm-related-card,
.sm-data-card,
.sm-topic-btn,
.sm-bento-card,
.sm-featured-card,
[role="button"],
button:not(:disabled) {
    cursor: pointer;
}

/* --- Tables --- */

/* Table card wrapper — matches mockup .table-card */
.sm-table-card {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04), 0 4px 12px rgba(0, 0, 0, 0.03);
}

/* Override Foxiz theme global thead dark background — triple specificity to beat any theme rule */
.strongman-app thead,
div.strongman-app thead,
body .strongman-app thead,
body .strongman-app table thead {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    color: inherit !important;
}

.strongman-app th,
.strongman-app td,
body .strongman-app th,
body .strongman-app td {
    border: none !important;
    border-color: transparent !important;
}

/* Re-apply mockup-approved table styles */
.strongman-app .sm-table th,
.strongman-app .sm-results-table th,
.strongman-app thead th,
body .strongman-app thead th {
    padding: 12px 18px;
    font-size: 11px;
    font-weight: 700;
    color: var(--sm-text-muted) !important;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border-bottom: 2px solid var(--sm-border) !important;
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
    background: transparent !important;
    background-color: transparent !important;
}

.strongman-app tbody td {
    padding: 14px 18px;
    border-bottom: 1px solid var(--sm-border) !important;
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
    color: var(--sm-text-secondary);
}

.strongman-app tbody tr:last-child td {
    border-bottom: none !important;
}

.strongman-app tbody tr:hover {
    background: var(--sm-primary-light);
}

.sm-table-wrapper {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04), 0 4px 12px rgba(0, 0, 0, 0.03);
}

.strongman-app .sm-table-scroll-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.sm-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}

.sm-table th {
    text-align: left;
    padding: 12px 18px;
    font-size: 11px;
    font-weight: 700;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border-bottom: 2px solid var(--sm-border);
    white-space: nowrap;
    cursor: pointer;
    user-select: none;
}

.sm-table td {
    padding: 14px 18px;
    border-bottom: 1px solid var(--sm-border);
    color: var(--sm-text-secondary);
}

.sm-table tbody tr:last-child td {
    border-bottom: none;
}

.sm-table tbody tr:hover {
    background: var(--sm-primary-light);
}

/* Table athlete avatar initials */
.sm-td-athlete-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--sm-electric) 0%, var(--sm-navy) 100%);
    color: white;
    font-size: 13px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

/* Table athlete name */
.sm-td-athlete-name {
    font-weight: 700;
    color: var(--sm-navy);
}

.sm-td-athlete-name a {
    color: var(--sm-navy);
}

.sm-td-athlete-name a:hover {
    color: var(--sm-primary);
}

.sm-table-weight-class {
    font-weight: 500;
    color: var(--sm-gray-800);
}

.sm-results-table-wrapper {
    overflow-x: auto;
}

.sm-results-table {
    width: 100%;
    border-collapse: collapse;
}

.sm-results-table th,
.sm-results-table td {
    text-align: left;
}

.sm-results-table th {
    padding: 12px 18px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--sm-text-muted);
    border-bottom: 2px solid var(--sm-border);
}

.sm-results-table td {
    padding: 14px 18px;
    font-size: 14px;
    color: var(--sm-text-secondary);
    border-bottom: 1px solid var(--sm-border);
}

.sm-results-table tbody tr:last-child td {
    border-bottom: none;
}

.sm-results-table tbody tr:hover {
    background: var(--sm-primary-light);
}

.sm-results-table tr.sm-highlight {
    background: var(--sm-gray-50);
}

/* Responsive table - card transform on mobile */
@media (max-width: 768px) {
    .strongman-app .sm-table--responsive {
        display: block;
    }

    .strongman-app .sm-table--responsive thead {
        display: none;
    }

    .strongman-app .sm-table--responsive tbody {
        display: block;
    }

    .strongman-app .sm-table--responsive tbody tr {
        display: block;
        background: var(--sm-surface);
        border: 1px solid var(--sm-gray-200);
        border-radius: var(--sm-radius-md);
        padding: 0.75rem 1rem;
        margin-bottom: 0.5rem;
    }

    .strongman-app .sm-table--responsive td {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 0.25rem 0;
        border: none;
        font-size: 0.9rem;
    }

    .strongman-app .sm-table--responsive td::before {
        content: attr(data-label);
        font-weight: 600;
        color: var(--sm-text-secondary);
        font-size: 0.8rem;
        text-transform: uppercase;
        letter-spacing: 0.03em;
        flex-shrink: 0;
        margin-right: 1rem;
    }

    .strongman-app .sm-table--responsive td:first-child {
        font-weight: 700;
        font-size: 1rem;
        padding-bottom: 0.5rem;
        margin-bottom: 0.25rem;
        border-bottom: 1px solid var(--sm-border);
    }

    /* Card name cells - displayed inline as prominent card header */
    .strongman-app .sm-table--responsive td.sm-card-name {
        display: inline;
        font-size: 1.05rem;
        font-weight: 700;
        color: var(--sm-text-primary);
        padding: 0;
        border: none;
        margin: 0;
    }

    .strongman-app .sm-table--responsive td.sm-card-name::before {
        display: none;
    }

    /* Comma + space between last name and first name inline */
    .strongman-app .sm-table--responsive td.sm-card-name:first-child::after {
        content: ",\00a0";
        font-weight: 400;
    }

    .strongman-app .sm-table--responsive td.sm-card-name .sm-athlete-link {
        color: var(--sm-text-primary);
        text-decoration: none;
    }

    .strongman-app .sm-table--responsive td.sm-card-name .sm-athlete-link:hover {
        color: var(--sm-primary);
    }

    /* Separator border after the last inline name cell, before data rows */
    .strongman-app .sm-table--responsive td.sm-card-name+td:not(.sm-card-name) {
        margin-top: 0.5rem;
        padding-top: 0.5rem;
        border-top: 1px solid var(--sm-border);
    }

    /* Override first-child defaults when it is a card-name */
    .strongman-app .sm-table--responsive td.sm-card-name:first-child {
        padding-bottom: 0;
        margin-bottom: 0;
        border-bottom: none;
        font-size: 1.05rem;
    }

    /* Country cell - keep flag + code inline */
    .strongman-app .sm-table--responsive td .sm-country-cell {
        display: inline-flex;
        align-items: center;
        gap: 0.35rem;
    }

    /* WSM winner badge stays visible */
    .strongman-app .sm-table--responsive td .sm-wsm-winner {
        color: var(--sm-primary);
        font-weight: 700;
    }

    /* Scroll wrapper should not clip cards on mobile */
    .strongman-app .sm-table-scroll-wrapper {
        overflow-x: visible;
    }
}

/* --- Badges --- */

.sm-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    font-size: 11px;
    font-weight: 700;
    border-radius: 6px;
    letter-spacing: 0.02em;
}

.sm-badge--default {
    background: var(--sm-gray-100);
    color: var(--sm-gray-600);
}

.sm-badge--primary {
    background: var(--sm-primary-light);
    color: var(--sm-primary);
}

.sm-badge--success {
    background: var(--sm-success-light);
    color: var(--sm-success);
}

.sm-badge--warning {
    background: rgba(245, 166, 35, 0.12);
    color: #d4920a;
}

.sm-badge-success {
    background: rgba(46, 204, 113, 0.1);
    color: #27ae60;
}

.sm-badge-neutral {
    background: var(--sm-gray-100);
    color: var(--sm-gray-600);
}

/* Status badges: elite (gold), active (green), retired (crimson) */
.sm-badge--elite {
    background: rgba(245, 166, 35, 0.12);
    color: #d4920a;
}

.sm-badge--active {
    background: rgba(46, 204, 113, 0.1);
    color: #27ae60;
}

.sm-badge--retired {
    background: rgba(233, 69, 96, 0.08);
    color: var(--sm-primary);
}

.sm-place-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    padding: 3px 10px;
    font-size: 12px;
    font-weight: 700;
    border-radius: 6px;
    background: var(--sm-gray-100);
    color: var(--sm-gray-600);
}

.sm-place-1 {
    background: linear-gradient(135deg, #fef3c7, #fde68a);
    color: #92400e;
}

.sm-place-2 {
    background: #f1f5f9;
    color: #475569;
}

.sm-place-3 {
    background: #fff7ed;
    color: #9a3412;
}

.sm-tag {
    font-size: 0.625rem;
    font-weight: 600;
    padding: var(--sm-space-1) var(--sm-space-2);
    background: var(--sm-gray-100);
    color: var(--sm-gray-600);
    border-radius: var(--sm-radius-sm);
    text-transform: uppercase;
}

.sm-tag-success {
    background: var(--sm-success-light);
    color: #16a34a;
}

.sm-tag-info {
    background: rgba(233, 69, 96, 0.12);
    color: var(--sm-primary);
}

/* Level badges */
.sm-level-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    border-radius: var(--sm-radius-full);
    font-weight: 600;
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.sm-level-beginner {
    background: rgba(139, 149, 165, 0.1);
    color: var(--sm-level-beginner);
}

.sm-level-novice {
    background: rgba(46, 204, 113, 0.1);
    color: var(--sm-level-novice);
}

.sm-level-intermediate {
    background: rgba(15, 52, 96, 0.1);
    color: var(--sm-level-intermediate);
}

.sm-level-advanced {
    background: rgba(233, 69, 96, 0.1);
    color: var(--sm-level-advanced);
}

.sm-level-elite {
    background: rgba(245, 158, 11, 0.1);
    color: var(--sm-level-elite);
}

.sm-level-elite::before {
    content: '\2605';
    font-size: 0.875rem;
}

.sm-level-badge.novice {
    background: rgba(46, 204, 113, 0.1);
    color: var(--sm-level-novice);
}

.sm-level-badge.beginner {
    background: rgba(139, 149, 165, 0.1);
    color: var(--sm-level-beginner);
}

.sm-level-badge.intermediate {
    background: rgba(15, 52, 96, 0.1);
    color: var(--sm-level-intermediate);
}

.sm-level-badge.advanced {
    background: rgba(233, 69, 96, 0.1);
    color: var(--sm-level-advanced);
}

.sm-level-badge.elite {
    background: rgba(245, 158, 11, 0.1);
    color: var(--sm-level-elite);
}

/* Feed type badges */
.sm-badge-lift {
    background: var(--sm-accent-light);
    color: var(--sm-accent-hover);
}

.sm-badge-challenge {
    background: rgba(233, 69, 96, 0.12);
    color: #c81e45;
}

.sm-badge-achievement {
    background: var(--sm-success-light);
    color: #15803d;
}

/* --- Buttons --- */

.sm-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 20px;
    font-family: var(--sm-font-sans);
    font-size: 14px;
    font-weight: 600;
    line-height: 1;
    border-radius: var(--sm-radius);
    border: none;
    cursor: pointer;
    transition: all 0.15s;
    min-height: 44px;
}

.sm-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Primary = Crimson */
.sm-btn-primary {
    background: var(--sm-primary);
    color: white !important;
    box-shadow: 0 1px 3px rgba(233, 69, 96, 0.3);
}

.sm-btn-primary:hover:not(:disabled) {
    background: var(--sm-primary-hover);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(233, 69, 96, 0.25);
}

.sm-btn-primary:active:not(:disabled) {
    box-shadow: 0 1px 2px rgba(233, 69, 96, 0.3);
}

/* CTA = Orange accent */
.sm-btn-cta {
    background: var(--sm-cta);
    color: white !important;
    box-shadow: 0 1px 3px rgba(245, 166, 35, 0.3);
}

.sm-btn-cta:hover:not(:disabled) {
    background: var(--sm-cta-hover);
    box-shadow: 0 4px 12px rgba(245, 166, 35, 0.3);
}

.sm-btn-cta:active:not(:disabled) {
    box-shadow: 0 1px 2px rgba(245, 166, 35, 0.3);
}

/* Secondary */
.sm-btn-secondary {
    background: var(--sm-surface);
    color: var(--sm-text-primary) !important;
    border: 2px solid var(--sm-border);
    box-shadow: var(--sm-shadow-sm);
}

.sm-btn-secondary:hover:not(:disabled) {
    background: var(--sm-gray-50);
    border-color: var(--sm-border-strong);
}

/* Outline */
.sm-btn-outline {
    background: var(--sm-surface);
    color: var(--sm-text-primary) !important;
    border: 2px solid var(--sm-border);
}

.sm-btn-outline:hover:not(:disabled) {
    background: var(--sm-gray-50);
    border-color: var(--sm-border-strong);
}

/* Ghost */
.sm-btn--ghost {
    background: transparent;
    color: var(--sm-primary);
    border-color: transparent;
}

.sm-btn--ghost:hover:not(:disabled) {
    background: var(--sm-primary-light);
    color: var(--sm-primary-hover);
}

/* Arrow slide */
.sm-arrow-slide svg {
    transition: transform var(--sm-transition);
}

.sm-arrow-slide:hover svg {
    transform: translateX(4px);
}

/* Button sizes */
.sm-btn-lg {
    padding: var(--sm-space-4) var(--sm-space-8);
    font-size: 1.0625rem;
    min-height: 52px;
}

.sm-btn-sm {
    padding: var(--sm-space-2) var(--sm-space-3);
    font-size: 0.8125rem;
    min-height: 36px;
}

.sm-w-full {
    width: 100%;
}

/* Button loading */
.sm-btn-loading {
    position: relative;
    color: transparent !important;
    pointer-events: none;
}

.sm-btn-loading::after {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    top: 50%;
    left: 50%;
    margin-left: -10px;
    margin-top: -10px;
    border: 2px solid transparent;
    border-top-color: currentColor;
    border-radius: 50%;
    animation: sm-spin 0.8s linear infinite;
}

.sm-btn-primary.sm-btn-loading::after {
    border-top-color: white;
}

.sm-btn-loading-spinner {
    position: relative;
    color: transparent !important;
    pointer-events: none;
}

.sm-btn-loading-spinner::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 -10px;
    border: 2px solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    animation: sm-spin 0.6s linear infinite;
}

.sm-btn-icon {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sm-gray-100);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius);
    color: var(--sm-gray-500);
    cursor: pointer;
    transition: all var(--sm-transition);
}

.sm-btn-icon:hover:not(:disabled) {
    background: var(--sm-error-light);
    border-color: var(--sm-error);
    color: var(--sm-error);
}

.sm-btn-icon:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

@keyframes sm-spin {
    to {
        transform: rotate(360deg);
    }
}

/* --- Forms --- */

.sm-form-group {
    margin-bottom: var(--sm-space-6);
    position: relative;
}

.sm-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--sm-gray-700);
    margin-bottom: var(--sm-space-2);
    letter-spacing: -0.01em;
}

.sm-input,
.sm-select,
.sm-filter-input,
.sm-filter-select,
.sm-search-input {
    display: block;
    width: 100%;
    padding: 10px 14px;
    font-family: inherit;
    font-size: 14px;
    color: var(--sm-gray-800);
    background: var(--sm-surface);
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius);
    outline: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    min-height: 44px;
}

.sm-select,
.sm-filter-select {
    font-weight: 500;
    padding-right: 36px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238b95a5' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 12px;
}

.sm-input:hover:not(:focus):not(:disabled),
.sm-select:hover:not(:focus):not(:disabled),
.sm-filter-input:hover:not(:focus):not(:disabled),
.sm-filter-select:hover:not(:focus):not(:disabled),
.sm-search-input:hover:not(:focus):not(:disabled) {
    border-color: var(--sm-border-strong);
}

.sm-input:focus,
.sm-select:focus,
.sm-filter-input:focus,
.sm-filter-select:focus,
.sm-search-input:focus {
    outline: none;
    border-color: var(--sm-primary);
    box-shadow: 0 0 0 3px var(--sm-primary-light);
    background-color: var(--sm-surface);
}

.sm-input:disabled,
.sm-select:disabled,
.sm-filter-input:disabled,
.sm-filter-select:disabled,
.sm-search-input:disabled {
    background-color: var(--sm-gray-100);
    color: var(--sm-gray-400);
    cursor: not-allowed;
    border-color: var(--sm-gray-200);
}

.sm-input::placeholder,
.sm-filter-input::placeholder,
.sm-search-input::placeholder {
    color: var(--sm-gray-400);
}

.sm-input-error {
    border-color: var(--sm-error);
}

.sm-input-error:focus {
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.12);
}

.sm-input-success {
    border-color: var(--sm-green-500);
}

.sm-input-success:focus {
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.12);
}

.sm-error-text {
    display: flex;
    align-items: center;
    gap: var(--sm-space-1);
    font-size: 0.8125rem;
    color: var(--sm-error);
    margin-top: var(--sm-space-2);
}

.sm-help-text {
    font-size: 0.8125rem;
    color: var(--sm-gray-500);
    margin-top: var(--sm-space-2);
}

.sm-input-wrapper {
    position: relative;
}

.sm-input-suffix {
    position: absolute;
    right: var(--sm-space-4);
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.875rem;
    color: var(--sm-gray-500);
    pointer-events: none;
}

.sm-input-wrapper .sm-input {
    padding-right: 60px;
}

.sm-input-icon-wrapper {
    position: relative;
}

.sm-input-icon-wrapper .sm-input {
    padding-left: 48px;
}

.sm-input-icon {
    position: absolute;
    left: var(--sm-space-4);
    top: 50%;
    transform: translateY(-50%);
    color: var(--sm-gray-400);
    pointer-events: none;
    transition: color var(--sm-transition);
}

.sm-input-icon svg {
    width: 20px;
    height: 20px;
}

.sm-input-icon-wrapper .sm-input:focus~.sm-input-icon {
    color: var(--sm-primary);
}

/* Floating Label */
.sm-form-group-float {
    position: relative;
}

.sm-form-group-float .sm-input {
    padding-top: var(--sm-space-6);
    padding-bottom: var(--sm-space-3);
}

.sm-form-group-float .sm-label {
    position: absolute;
    top: 50%;
    left: var(--sm-space-4);
    transform: translateY(-50%);
    background: var(--sm-surface);
    padding: 0 var(--sm-space-1);
    margin: 0;
    font-weight: 400;
    color: var(--sm-gray-400);
    pointer-events: none;
    transition: all var(--sm-transition);
}

.sm-form-group-float .sm-input:focus+.sm-label,
.sm-form-group-float .sm-input:not(:placeholder-shown)+.sm-label {
    top: 0;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--sm-primary);
    transform: translateY(-50%);
}

.sm-textarea {
    display: block;
    width: 100%;
    padding: 10px 14px;
    font-family: inherit;
    font-size: 14px;
    color: var(--sm-gray-800);
    background: var(--sm-surface);
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius);
    outline: none;
    resize: vertical;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.sm-textarea:focus {
    outline: none;
    border-color: var(--sm-primary);
    box-shadow: 0 0 0 3px var(--sm-primary-light);
}

.sm-radio-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sm-space-4);
}

.sm-radio-label,
.sm-checkbox-label {
    display: flex;
    align-items: center;
    gap: var(--sm-space-2);
    font-size: 0.875rem;
    color: var(--sm-gray-600);
    cursor: pointer;
}

.sm-radio-label input,
.sm-checkbox-label input {
    width: 18px;
    height: 18px;
    accent-color: var(--sm-primary);
}

.sm-checkbox-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sm-space-2);
}

@media (min-width: 640px) {
    .sm-checkbox-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.sm-form-section {
    margin-bottom: var(--sm-space-8);
    padding-bottom: var(--sm-space-6);
    border-bottom: 1px solid var(--sm-gray-200);
}

.sm-form-section-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--sm-gray-800);
    margin-bottom: var(--sm-space-2);
}

.sm-filter-label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--sm-gray-600);
    margin-bottom: var(--sm-space-3);
}

.sm-select-sm,
.sm-input-sm {
    padding: 8px 12px;
    font-size: 13px;
    min-height: 36px;
}

.sm-form-hint {
    display: block;
    margin-top: var(--sm-space-1);
    font-size: var(--sm-fs-xs);
    color: var(--sm-gray-400);
}

/* Input animated */
.sm-input-animated {
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.sm-input-animated:focus {
    border-color: var(--sm-primary);
    box-shadow: 0 0 0 3px var(--sm-primary-light);
}

/* Floating label effect */
.sm-input-floating {
    position: relative;
}

.sm-input-floating label {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    transition: all 0.2s ease;
    pointer-events: none;
    color: var(--sm-gray-500);
    background: var(--sm-surface);
    padding: 0 4px;
}

.sm-input-floating input:focus+label,
.sm-input-floating input:not(:placeholder-shown)+label {
    top: 0;
    font-size: 0.75rem;
    color: var(--sm-primary);
}

/* --- Tabs --- */

.sm-tabs {
    display: flex;
    gap: 2px;
    margin-bottom: 20px;
    border-bottom: 2px solid var(--sm-border);
}

.sm-tab {
    padding: 10px 18px;
    font-size: 14px;
    font-weight: 600;
    color: var(--sm-text-muted);
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    cursor: pointer;
    transition: all 0.15s;
    font-family: inherit;
    white-space: nowrap;
}

.sm-tab:hover {
    color: var(--sm-text-primary);
}

.sm-tab.active {
    color: var(--sm-primary);
    border-bottom-color: var(--sm-primary);
}

.sm-tab:focus-visible {
    outline: 2px solid var(--sm-focus-ring-color);
    outline-offset: 2px;
}

.sm-tab-content {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    border: 1px solid var(--sm-gray-200);
    padding: var(--sm-space-6);
}

.sm-tab-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    margin-left: var(--sm-space-2);
    font-size: 0.75rem;
    font-weight: 600;
    background: var(--sm-gray-200);
    color: var(--sm-gray-600);
    border-radius: 10px;
}

.sm-tab.active .sm-tab-count {
    background: var(--sm-primary-soft);
    color: var(--sm-primary);
}

/* Tab panels use Alpine x-show for visibility — no display:none needed */

/* --- Pagination / Load More --- */

.sm-load-more {
    text-align: center;
    margin-top: var(--sm-space-8);
}

.sm-load-more-btn {
    min-width: 160px;
}

/* --- Loading --- */

.sm-loading {
    display: inline-flex;
    align-items: center;
    gap: var(--sm-space-2);
}

.sm-loading::before {
    content: '';
    width: 16px;
    height: 16px;
    border: 2px solid currentColor;
    border-top-color: transparent;
    border-radius: 50%;
    animation: sm-spin 0.6s linear infinite;
}

.sm-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2px solid var(--sm-gray-200);
    border-top-color: var(--sm-primary);
    border-radius: 50%;
    animation: sm-spin 0.6s linear infinite;
}

/* --- Empty State --- */

.sm-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--sm-space-12) var(--sm-space-6);
    color: var(--sm-gray-400);
}

.sm-empty-state svg {
    margin-bottom: var(--sm-space-4);
    opacity: 0.5;
}

.sm-empty-state h2 {
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-lg);
    font-weight: 600;
    color: var(--sm-gray-600);
    margin: 0 0 var(--sm-space-2) 0;
}

.sm-empty-state p {
    margin: 0 0 var(--sm-space-6) 0;
    font-size: var(--sm-fs-sm);
}

/* --- Skeleton Loading --- */

.sm-skeleton {
    background: linear-gradient(90deg, var(--sm-gray-100) 25%, var(--sm-gray-200) 50%, var(--sm-gray-100) 75%);
    background-size: 200% 100%;
    animation: sm-shimmer 1.5s infinite;
    border-radius: var(--sm-radius);
}

.sm-skeleton-text {
    height: 1em;
    margin-bottom: 0.5em;
    border-radius: 4px;
}

.sm-skeleton-text:last-child {
    width: 75%;
}

.sm-skeleton-text-sm {
    height: 0.875em;
    width: 60%;
}

.sm-skeleton-title {
    height: 1.5em;
    width: 50%;
    margin-bottom: 0.75em;
}

.sm-skeleton-card {
    height: 200px;
    border-radius: var(--sm-radius-lg);
}

.sm-skeleton-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
}

.sm-skeleton-stat {
    height: 3em;
    width: 120px;
    border-radius: 8px;
}

.sm-skeleton-button {
    height: 44px;
    width: 120px;
    border-radius: var(--sm-radius);
}

.sm-skeleton-image {
    aspect-ratio: 16/9;
    width: 100%;
    border-radius: 8px;
}

.sm-skeleton-row {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 0;
    height: 48px;
    margin-bottom: 4px;
}

.sm-skeleton-circle {
    border-radius: 50%;
}

.sm-skeleton-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--sm-space-4);
}

.sm-skeleton-pulse {
    background: linear-gradient(90deg, var(--sm-gray-100) 25%, var(--sm-gray-200) 50%, var(--sm-gray-100) 75%);
    background-size: 200% 100%;
    animation: sm-shimmer 1.5s ease-in-out infinite;
    border-radius: var(--sm-radius-sm);
}

.sm-skeleton-line {
    height: 14px;
    margin-bottom: 8px;
}

.sm-skeleton-transition {
    transition: opacity 0.3s ease;
}

.sm-skeleton-transition.sm-loading {
    opacity: 0.6;
}

.sm-content-swap {
    position: relative;
}

.sm-content-swap>.sm-skeleton-overlay {
    position: absolute;
    inset: 0;
    transition: opacity 0.3s ease;
    pointer-events: none;
}

.sm-content-swap.sm-loaded>.sm-skeleton-overlay {
    opacity: 0;
}

.sm-loading-skeleton {
    padding: var(--sm-space-8);
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    border: 1px solid var(--sm-gray-200);
}

/* Skeleton height utilities (replaces inline style="height: Xpx") */
.sm-skeleton-h-60 {
    height: 60px;
}

.sm-skeleton-h-80 {
    height: 80px;
}

.sm-skeleton-h-100 {
    height: 100px;
}

.sm-skeleton-h-120 {
    height: 120px;
}

.sm-skeleton-h-160 {
    height: 160px;
}

.sm-skeleton-h-180 {
    height: 180px;
}

.sm-skeleton-h-200 {
    height: 200px;
}

.sm-skeleton-h-300 {
    height: 300px;
}

.sm-skeleton-h-400 {
    height: 400px;
}

.sm-skeleton-h-500 {
    height: 500px;
}

.sm-skeleton-h-600 {
    height: 600px;
}

/* Modal open state (replaces document.body.style.overflow) */
body.sm-modal-open {
    overflow: hidden;
}

@keyframes sm-shimmer {
    0% {
        background-position: -200% 0;
    }

    100% {
        background-position: 200% 0;
    }
}

/* --- Notice / Alerts --- */

.sm-notice {
    padding: var(--sm-space-4);
    border-radius: var(--sm-radius);
    border-left: 4px solid;
}

.sm-notice p {
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.5;
}

.sm-notice-info {
    background: rgba(233, 69, 96, 0.08);
    border-color: var(--sm-primary);
    color: #c81e45;
}

.sm-notice-success {
    background: #f0fdf4;
    border-color: #22c55e;
    color: #166534;
}

.sm-notice-warning {
    background: #fffbeb;
    border-color: #f5a623;
    color: #92400e;
}

.sm-notice-error {
    background: #fef2f2;
    border-color: #ef4444;
    color: #991b1b;
}

.sm-alert {
    padding: var(--sm-space-3) var(--sm-space-4);
    border-radius: var(--sm-radius);
    font-size: var(--sm-fs-sm);
    margin-bottom: var(--sm-space-4);
}

.sm-alert-error {
    background: var(--sm-error-light);
    color: #991b1b;
    border: 1px solid #fecaca;
}

.sm-alert-success {
    background: var(--sm-success-light);
    color: #166534;
    border: 1px solid #bbf7d0;
}

/* --- Link --- */

.sm-link {
    color: inherit;
    font-weight: 500;
    text-decoration: underline;
    text-underline-offset: 2px;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    font-family: inherit;
    font-size: inherit;
    transition: opacity var(--sm-transition);
}

.sm-link:hover {
    opacity: 0.7;
}

/* --- Progress Bars / Gauge --- */

.sm-progress-bar {
    height: 8px;
    background: var(--sm-gray-200);
    border-radius: var(--sm-radius-full);
    overflow: hidden;
}

.sm-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--sm-primary), var(--sm-primary-hover));
    border-radius: var(--sm-radius-full);
    transition: width 0.8s ease-out;
}

.sm-progress-fill.novice {
    background: var(--sm-level-novice);
}

.sm-progress-fill.beginner {
    background: var(--sm-level-beginner);
}

.sm-progress-fill.intermediate {
    background: var(--sm-level-intermediate);
}

.sm-progress-fill.advanced {
    background: var(--sm-level-advanced);
}

.sm-progress-fill.elite {
    background: var(--sm-level-elite);
}

.sm-progress-container {
    width: 100%;
    margin: 1rem 0;
}

.sm-progress-label {
    display: flex;
    justify-content: space-between;
    font-size: 0.75rem;
    color: var(--sm-gray-400);
    margin-bottom: 0.5rem;
}

.sm-gauge {
    position: relative;
    width: 120px;
    height: 120px;
}

.sm-gauge-circle {
    fill: none;
    stroke-width: 8;
    stroke-linecap: round;
    transform: rotate(-90deg);
    transform-origin: 50% 50%;
}

.sm-gauge-bg {
    stroke: var(--sm-gray-200);
}

.sm-gauge-fill {
    stroke: var(--sm-primary);
    stroke-dasharray: 314;
    stroke-dashoffset: 314;
    transition: stroke-dashoffset 1s ease-out;
}

.sm-gauge-center {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

/* Percentile bar */
.sm-percentile-bar {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin: 1rem 0;
}

.sm-percentile-track {
    flex: 1;
    height: 6px;
    background: rgba(0, 0, 0, 0.1);
    border-radius: 3px;
    position: relative;
}

.sm-percentile-fill {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    background: linear-gradient(90deg, var(--sm-primary), var(--sm-level-elite));
    border-radius: 3px;
    transition: width 0.8s ease-out;
}

.sm-percentile-marker {
    position: absolute;
    top: -4px;
    width: 14px;
    height: 14px;
    background: var(--sm-surface);
    border: 3px solid var(--sm-primary);
    border-radius: 50%;
    transform: translateX(-50%);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.sm-percentile-value {
    font-weight: 700;
    font-size: 1rem;
    min-width: 3rem;
    text-align: right;
}

/* Star Rating */
.sm-stars {
    display: inline-flex;
    gap: 2px;
    font-size: 1.25rem;
}

.sm-star {
    color: var(--sm-gray-300);
}

.sm-star.filled {
    color: var(--sm-level-elite);
}

.sm-star.half {
    background: linear-gradient(90deg, var(--sm-level-elite) 50%, var(--sm-gray-300) 50%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Pro comparison */
.sm-pro-comparison {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    background: rgba(0, 0, 0, 0.03);
    border-radius: 8px;
    margin-top: 1rem;
    font-size: 0.875rem;
}

.sm-pro-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--sm-navy), var(--sm-electric));
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 700;
    font-size: 0.75rem;
}

.sm-pro-text {
    flex: 1;
    color: var(--sm-text-secondary);
}

.sm-pro-percent {
    font-weight: 700;
    color: var(--sm-primary);
}

/* Comparison Bars */
.sm-comparison-row {
    display: grid;
    grid-template-columns: 100px 1fr 70px;
    gap: 12px;
    align-items: center;
    padding: 8px 0;
}

.sm-comparison-label {
    font-size: 0.8125rem;
    color: var(--sm-gray-600);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sm-comparison-track {
    height: 24px;
    background: var(--sm-gray-100);
    border-radius: var(--sm-radius-full);
    overflow: hidden;
}

.sm-comparison-fill {
    height: 100%;
    border-radius: var(--sm-radius-full);
    transition: width 0.6s ease-out;
}

.sm-comparison-fill-user {
    background: linear-gradient(90deg, var(--sm-primary), var(--sm-primary-hover));
}

.sm-comparison-fill-pro {
    background: var(--sm-gray-400);
}

.sm-comparison-value {
    font-size: 0.875rem;
    font-weight: 600;
    text-align: right;
    color: var(--sm-gray-900);
}

/* Trust Badges */
.sm-trust-badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 16px;
    margin-top: 24px;
}

.sm-trust-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: var(--sm-surface);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius-full);
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--sm-gray-700);
}

.sm-trust-badge svg {
    width: 16px;
    height: 16px;
    color: var(--sm-primary);
}

/* Transitions */
.sm-fade-enter {
    opacity: 0;
}

.sm-fade-enter-active {
    opacity: 1;
    transition: opacity 0.3s ease;
}

.sm-fade-leave {
    opacity: 1;
}

.sm-fade-leave-active {
    opacity: 0;
    transition: opacity 0.2s ease;
}

.sm-slide-up-enter {
    opacity: 0;
    transform: translateY(10px);
}

.sm-slide-up-enter-active {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.sm-results-section {
    transition: opacity 0.3s ease, transform 0.3s ease, max-height 0.4s ease;
    overflow: hidden;
}

.sm-results-section.hidden {
    opacity: 0;
    max-height: 0;
    transform: translateY(-10px);
}

.sm-results-section.visible {
    opacity: 1;
    max-height: 2000px;
    transform: translateY(0);
}

.sm-collapsible {
    overflow: hidden;
    transition: max-height 0.3s ease-out, opacity 0.3s ease-out;
}

.sm-collapsible.collapsed {
    max-height: 0;
    opacity: 0;
}

.sm-collapsible.expanded {
    max-height: 1000px;
    opacity: 1;
}

.sm-accordion-content {
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transition: max-height 0.35s ease, opacity 0.25s ease;
}

.sm-accordion-content.open {
    max-height: 500px;
    opacity: 1;
}

.sm-form-section.calculating {
    opacity: 0.6;
    pointer-events: none;
}

/* Modals */
.sm-modal-backdrop {
    opacity: 0;
    transition: opacity 0.2s ease;
}

.sm-modal-backdrop.visible {
    opacity: 1;
}

.sm-modal-content {
    opacity: 0;
    transform: scale(0.95) translateY(-20px);
    transition: opacity 0.25s ease, transform 0.25s ease;
}

.sm-modal-content.visible {
    opacity: 1;
    transform: scale(1) translateY(0);
}

/* Tooltip */
.sm-tooltip {
    opacity: 0;
    transform: translateY(4px);
    transition: opacity 0.15s ease, transform 0.15s ease;
    pointer-events: none;
}

.sm-tooltip.visible {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.sm-smooth-scroll {
    scroll-behavior: smooth;
}

/* Count-up */
.sm-count-up {
    display: inline-block;
    font-variant-numeric: tabular-nums;
}

/* Result level borders */
.sm-result-novice {
    border-left: 4px solid var(--sm-level-novice);
}

.sm-result-beginner {
    border-left: 4px solid var(--sm-level-beginner);
}

.sm-result-intermediate {
    border-left: 4px solid var(--sm-level-intermediate);
}

.sm-result-advanced {
    border-left: 4px solid var(--sm-level-advanced);
}

.sm-result-elite {
    border-left: 4px solid var(--sm-level-elite);
    background: linear-gradient(135deg, rgba(245, 166, 35, 0.05), transparent);
}

/* Result reveal */
.sm-result-reveal {
    animation: sm-resultReveal 0.5s ease-out forwards;
}

@keyframes sm-resultReveal {
    0% {
        opacity: 0;
        transform: scale(0.9);
    }

    60% {
        transform: scale(1.02);
    }

    100% {
        opacity: 1;
        transform: scale(1);
    }
}

.sm-elite-glow {
    animation: sm-eliteGlow 2s ease-in-out infinite;
}

@keyframes sm-eliteGlow {

    0%,
    100% {
        box-shadow: 0 0 20px rgba(245, 158, 11, 0.4);
    }

    50% {
        box-shadow: 0 0 40px rgba(245, 158, 11, 0.6);
    }
}

.sm-success-flash {
    animation: sm-successFlash 0.6s ease-out;
}

@keyframes sm-successFlash {
    0% {
        background-color: rgba(34, 197, 94, 0.2);
    }

    100% {
        background-color: transparent;
    }
}

.sm-results-container {
    margin-top: var(--sm-space-6);
}

/* ==========================================================================
   7. CALCULATOR COMPONENTS
   ========================================================================== */

.sm-calculator {
    max-width: 600px;
    margin: 0 auto;
}

.sm-calculator-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    max-width: 700px;
    margin: 0 auto;
    padding: var(--sm-space-6);
}

.sm-calculator-form {
    width: 100%;
    margin-bottom: var(--sm-space-8);
}

.sm-calculator-results {
    width: 100%;
}

.sm-calc-form {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    border: 1px solid var(--sm-gray-200);
    padding: var(--sm-space-6);
    box-shadow: var(--sm-shadow);
}

.sm-calculator-short {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--sm-primary);
    margin-bottom: 4px;
    display: block;
}

/* Results */
.sm-results {
    margin-top: var(--sm-space-6);
    padding: var(--sm-space-6);
    background: var(--sm-gray-800);
    border-radius: var(--sm-radius-lg);
    color: white;
}

.sm-result-grid {
    display: grid;
    gap: var(--sm-space-4);
}

.sm-result-item {
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-1);
}

.sm-result-primary {
    padding: var(--sm-space-4);
    background: rgba(255, 255, 255, 0.1);
    border-radius: var(--sm-radius);
}

.sm-result-label {
    font-size: 0.75rem;
    color: var(--sm-gray-400);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.sm-result-value {
    font-size: 1.5rem;
    font-weight: 700;
}

.sm-result-primary .sm-result-value {
    font-size: 2rem;
    color: var(--sm-primary-soft);
}

.sm-error {
    margin-top: var(--sm-space-4);
    padding: var(--sm-space-4);
    background: var(--sm-error-light);
    border: 1px solid var(--sm-error);
    border-radius: var(--sm-radius);
    color: var(--sm-error);
}

/* Prediction Cards */
.sm-translator-results,
.sm-standards-results {
    display: grid;
    gap: var(--sm-space-4);
}

.sm-prediction-card,
.sm-standard-card {
    background: rgba(255, 255, 255, 0.05);
    border-radius: var(--sm-radius);
    padding: var(--sm-space-4);
}

.sm-prediction-header,
.sm-standard-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--sm-space-2);
}

.sm-prediction-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    color: var(--sm-primary);
}

.sm-prediction-icon svg {
    width: 100%;
    height: 100%;
}

/* Readiness calculator: event label icon + status icon */
.strongman-app .sm-event-type-icon,
.strongman-app .sm-event-result-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

.strongman-app .sm-event-type-icon svg,
.strongman-app .sm-event-result-status svg {
    width: 100%;
    height: 100%;
}

/* Inline icon (clock, clipboard) */
.strongman-app .sm-inline-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    vertical-align: middle;
    flex-shrink: 0;
}

.strongman-app .sm-inline-icon svg {
    width: 100%;
    height: 100%;
}

/* Achievement icons */
.strongman-app .sm-account-ach-icon-unlocked,
.strongman-app .sm-account-achievement-icon,
.strongman-app .sm-account-pub-badge-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    flex-shrink: 0;
    color: var(--sm-primary);
}

.strongman-app .sm-account-ach-icon-unlocked svg,
.strongman-app .sm-account-achievement-icon svg,
.strongman-app .sm-account-pub-badge-icon svg {
    width: 100%;
    height: 100%;
}

.sm-prediction-event,
.sm-standard-event {
    font-weight: 600;
}

.sm-prediction-level,
.sm-standard-level {
    font-size: 0.75rem;
    padding: var(--sm-space-1) var(--sm-space-2);
    border-radius: var(--sm-radius-sm);
    text-transform: uppercase;
    font-weight: 600;
}

.sm-prediction-value,
.sm-standard-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--sm-primary-soft);
}

.sm-prediction-percentile {
    font-size: 0.75rem;
    color: var(--sm-gray-400);
    margin-top: var(--sm-space-1);
}

/* Readiness Score */
.sm-readiness-results {
    text-align: center;
}

.sm-readiness-score {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sm-space-4);
    margin-bottom: var(--sm-space-6);
}

.sm-score-circle {
    width: 150px;
    height: 150px;
    border-radius: 50%;
    background: conic-gradient(var(--sm-primary) calc(var(--score, 0) * 3.6deg), var(--sm-gray-700) 0);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.sm-score-circle::before {
    content: '';
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: var(--sm-gray-800);
    position: absolute;
}

.sm-score-value {
    font-size: 2rem;
    font-weight: 700;
    position: relative;
    z-index: 1;
}

.sm-score-label {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--sm-primary-soft);
}

.sm-readiness-recommendations {
    text-align: left;
    padding: var(--sm-space-4);
    background: rgba(255, 255, 255, 0.05);
    border-radius: var(--sm-radius);
}

.sm-readiness-recommendations h4 {
    font-size: 0.875rem;
    font-weight: 600;
    margin-bottom: var(--sm-space-3);
    color: var(--sm-gray-300);
}

.sm-readiness-recommendations ul {
    margin: 0;
    padding-left: var(--sm-space-5);
}

.sm-readiness-recommendations li {
    margin-bottom: var(--sm-space-2);
    color: var(--sm-gray-400);
}

/* ==========================================================================
   8. FAQ
   ========================================================================== */

.sm-faq-section {
    margin-top: var(--sm-space-12);
}

.sm-faq-list {
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-3);
}

.sm-faq-item {
    background: var(--sm-surface);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius-lg);
    overflow: hidden;
    margin-bottom: var(--sm-space-3);
}

.sm-faq-item:last-child {
    margin-bottom: 0;
}

.sm-faq-question {
    display: flex;
    width: 100%;
    justify-content: space-between;
    align-items: center;
    padding: var(--sm-space-4) var(--sm-space-5);
    background: transparent;
    border: none;
    font-family: var(--sm-font-sans);
    font-size: var(--sm-fs-base);
    font-weight: 600;
    color: var(--sm-gray-800);
    text-align: left;
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.sm-faq-question:hover {
    background: var(--sm-gray-50);
    color: var(--sm-primary-hover);
}

.sm-faq-question[aria-expanded="true"] {
    background: var(--sm-primary);
    color: white;
}

.sm-faq-question svg {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    transition: transform var(--sm-transition);
}

.sm-faq-question[aria-expanded="true"] svg {
    transform: rotate(180deg);
}

.sm-faq-icon {
    flex-shrink: 0;
    color: var(--sm-gray-400);
    transition: transform 0.2s ease;
}

.sm-faq-icon-open {
    transform: rotate(180deg);
}

.sm-faq-answer {
    padding: var(--sm-space-4) var(--sm-space-5);
    color: var(--sm-gray-600);
    line-height: 1.7;
}

.sm-faq-answer p {
    margin: 0;
}

.sm-faq-answer p+p {
    margin-top: var(--sm-space-3);
}

/* ==========================================================================
   9. RELATED CALCULATORS
   ========================================================================== */

.sm-related-section {
    margin-top: var(--sm-space-12);
}

.sm-related-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sm-space-4);
}

@media (min-width: 640px) {
    .sm-related-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1024px) {
    .sm-related-grid {
        grid-template-columns: repeat(5, 1fr);
    }
}

.sm-related-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--sm-space-5);
    background: var(--sm-surface);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius-lg);
    text-align: center;
    transition: border-color var(--sm-transition), box-shadow var(--sm-transition);
}

.sm-related-card:hover {
    border-color: var(--sm-primary);
    box-shadow: var(--sm-shadow-md);
}

.sm-related-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: var(--sm-primary-light);
    border-radius: var(--sm-radius-lg);
    margin-bottom: var(--sm-space-3);
}

.sm-related-icon svg {
    width: 24px;
    height: 24px;
    color: var(--sm-primary);
}

.sm-related-name {
    font-weight: 600;
    color: var(--sm-gray-800);
    margin-bottom: var(--sm-space-1);
}

.sm-related-desc {
    font-size: 0.75rem;
    color: var(--sm-gray-500);
}

.sm-seo-section {
    margin-top: var(--sm-space-12);
    padding: var(--sm-space-8);
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    border: 1px solid var(--sm-gray-200);
}

.sm-standards-section {
    margin-top: var(--sm-space-12);
}

.sm-cross-cta {
    background: linear-gradient(135deg, var(--sm-navy) 0%, var(--sm-electric) 100%);
    border-radius: var(--sm-radius-xl);
    padding: 48px 32px;
    margin: 48px 0;
    text-align: center;
}

.sm-cross-cta-content h3 {
    font-size: 1.5rem;
    font-weight: 700;
    color: white;
    margin-bottom: 12px;
}

.sm-cross-cta-content p {
    font-size: 1rem;
    color: var(--sm-gray-300);
    margin-bottom: 24px;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
}

.sm-cross-cta .sm-btn-primary {
    background: linear-gradient(135deg, var(--sm-primary), var(--sm-primary-hover));
}

@media (max-width: 640px) {
    .sm-cross-cta {
        padding: 32px 20px;
        margin: 32px 0;
    }

    .sm-cross-cta-content h3 {
        font-size: 1.25rem;
    }
}

/* ==========================================================================
   10. FOOTER
   ========================================================================== */

.sm-footer {
    background: var(--sm-navy);
    padding: 16px 0;
    margin-top: 48px;
    font-size: 13px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.sm-footer-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.sm-footer-brand {
    font-weight: var(--sm-weight-extrabold);
    font-size: 15px;
    color: rgba(255, 255, 255, 0.6);
    text-decoration: none;
    letter-spacing: -0.03em;
    transition: color var(--sm-transition);
}

.sm-footer-brand:hover {
    color: rgba(255, 255, 255, 0.9);
}

.sm-footer-links {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}

.sm-footer-links a {
    color: rgba(255, 255, 255, 0.5);
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    transition: color var(--sm-transition);
}

.sm-footer-links a:hover {
    color: rgba(255, 255, 255, 0.9);
}

@media (max-width: 640px) {
    .sm-footer-inner {
        flex-direction: column;
        text-align: center;
        gap: 10px;
    }

    .sm-footer-links {
        justify-content: center;
        gap: 14px;
    }
}

/* Breadcrumbs */
.strongman-app .sm-breadcrumbs {
    background: transparent;
    padding: 0 0 12px;
    font-size: 13px;
    margin-bottom: 4px;
}

.strongman-app .sm-breadcrumb-list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 2px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.strongman-app .sm-breadcrumb-item {
    display: flex;
    align-items: center;
    gap: 4px;
    color: rgba(255, 255, 255, 0.5);
    font-size: 12px;
}

.strongman-app .sm-breadcrumb-item a {
    color: rgba(255, 255, 255, 0.65);
    text-decoration: none;
    transition: color 0.15s;
}

.strongman-app .sm-breadcrumb-item a:hover {
    color: rgba(255, 255, 255, 0.95);
}

.strongman-app .sm-breadcrumb-sep {
    color: rgba(255, 255, 255, 0.3);
    font-size: 14px;
    line-height: 1;
}

.strongman-app .sm-breadcrumb-current span {
    color: rgba(255, 255, 255, 0.85);
    font-weight: 500;
}

.strongman-app .sm-breadcrumb-item:last-child {
    color: rgba(255, 255, 255, 0.85);
}

/* (Footer columns removed — minimal footer, theme handles main footer) */

/* Active nav group */
.strongman-app .sm-nav-group-active {
    color: var(--sm-text-primary);
    font-weight: 600;
    background: rgba(233, 69, 96, 0.07);
    border: none;
    border-radius: 6px;
}

/* Units label (removed - label no longer in markup) */

/* Brand accent */
.sm-brand-accent {
    color: var(--sm-primary);
}

.sm-nav-logo-text {
    font-weight: 900;
    font-size: 1.25rem;
    letter-spacing: 0.06em;
}

/* ==========================================================================
   11. PAGE-SPECIFIC STYLES
   ========================================================================== */

/* --- Compact Page Headers --- */

.strongman-app .sm-page-header {
    padding: var(--sm-space-4) 0;
    margin-bottom: var(--sm-space-4);
    border-bottom: 1px solid var(--sm-gray-200);
}

.strongman-app .sm-page-header-row {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3);
    flex-wrap: wrap;
}

.strongman-app .sm-page-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    max-width: 56px;
    max-height: 56px;
    flex-shrink: 0;
    color: var(--sm-primary);
}

.strongman-app .sm-page-icon svg {
    width: 56px;
    height: 56px;
}

.strongman-app .sm-page-title {
    font-size: var(--sm-fs-2xl);
    font-weight: 700;
    color: var(--sm-gray-900);
    margin: 0;
    line-height: 1.2;
}

.strongman-app .sm-page-subtitle {
    font-size: var(--sm-fs-sm);
    color: var(--sm-gray-500);
    margin: var(--sm-space-1) 0 0;
}

.sm-see-also {
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid var(--sm-gray-200);
}

.sm-see-also-title {
    font-family: var(--sm-font-heading);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--sm-gray-800);
    margin: 0 0 16px;
}

.sm-see-also-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 0 0 16px;

}

.sm-see-also-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: var(--sm-gray-50);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius);
    font-size: 0.875rem;
    color: var(--sm-gray-700);
    text-decoration: none;
    transition: all 0.15s ease;
}

.sm-see-also-link:hover {
    background: var(--sm-primary-light);
    border-color: var(--sm-primary-soft);
    color: var(--sm-primary-hover);
}

@media (max-width: 640px) {
    .strongman-app .sm-page-title {
        font-size: 1.5rem;
    }

    .strongman-app .sm-page-subtitle {
        font-size: 1rem;
    }
}

/* ==========================================================================
   DARK PAGE HEADER — compact hero strip for data pages
   ========================================================================== */

.strongman-app .sm-page-header.sm-page-header-dark {
    background: linear-gradient(135deg, var(--sm-navy) 0%, #1a3a5c 100%);
    border-radius: var(--sm-radius-lg);
    padding: 28px 32px;
    margin-bottom: 24px;
    border-bottom: none;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0 24px;
}

.strongman-app .sm-page-header.sm-page-header-dark::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -10%;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(233, 69, 96, 0.1) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}

/* Text container when .sm-hero-text wrapper is present */
.strongman-app .sm-page-header-dark .sm-hero-text {
    flex: 1;
    min-width: 0;
    position: relative;
    z-index: 1;
}

/* Title and subtitle — works with or without .sm-hero-text wrapper */
.strongman-app .sm-page-header.sm-page-header-dark .sm-page-title {
    color: #ffffff;
    position: relative;
    z-index: 1;
}

.strongman-app .sm-page-header.sm-page-header-dark .sm-page-subtitle {
    color: rgba(255, 255, 255, 0.75);
    position: relative;
    z-index: 1;
}

/* Unwrapped fallback: title/subtitle as direct children take full row
   so they stack vertically even inside flexbox */
.strongman-app .sm-page-header-dark > .sm-page-title {
    width: 100%;
}

.strongman-app .sm-page-header-dark > .sm-page-subtitle {
    width: 100%;
}

/* Hero illustration inside dark page headers (not hub hero) */
.strongman-app .sm-page-header-dark .sm-hero-illustration {
    width: 140px;
    height: 140px;
    flex-shrink: 0;
    opacity: 0.6;
    position: relative;
    z-index: 1;
}

/* Hero icon - AI-generated PNG icons in dark page headers */
.strongman-app .sm-page-header-dark .sm-hero-icon {
    width: 160px;
    height: 160px;
    flex-shrink: 0;
    opacity: 0.85;
    position: relative;
    z-index: 1;
    border-radius: var(--sm-radius-lg, 12px);
    object-fit: contain;
}

@media (max-width: 640px) {
    /* Hide header icon on small screens to save space */
    .strongman-app .sm-page-header-dark .sm-hero-illustration,
    .strongman-app .sm-page-header-dark .sm-hero-icon {
        display: none;
    }
}

/* Content illustration - large AI-generated images in page body */
.strongman-app .sm-content-illustration {
    width: 100%;
    max-width: 800px;
    height: auto;
    border-radius: var(--sm-radius-lg, 12px);
    margin: var(--sm-space-lg, 24px) auto;
    display: block;
}

/* Image-text layout: illustration beside content */
.strongman-app .sm-illustration-row {
    display: flex;
    gap: var(--sm-space-lg, 24px);
    align-items: center;
    margin: var(--sm-space-xl, 32px) 0;
}
.strongman-app .sm-illustration-row .sm-content-illustration {
    width: 45%;
    max-width: 480px;
    flex-shrink: 0;
    margin: 0;
}
.strongman-app .sm-illustration-row .sm-illustration-text {
    flex: 1;
    min-width: 0;
}
@media (max-width: 768px) {
    .strongman-app .sm-illustration-row {
        flex-direction: column;
    }
    .strongman-app .sm-illustration-row .sm-content-illustration {
        width: 100%;
        max-width: 100%;
    }
}


/* --- Toast Notifications --- */

.sm-toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    padding: 12px 20px;
    border-radius: var(--sm-radius-lg);
    font-size: 0.875rem;
    font-weight: 500;
    color: #fff;
    z-index: 10000;
    opacity: 0;
    transform: translateY(12px);
    animation: smToastIn 0.25s ease forwards;
    max-width: 360px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    pointer-events: none;
}

.sm-toast--success {
    background: var(--sm-success);
}

.sm-toast--error {
    background: var(--sm-error);
}

.sm-toast--info {
    background: var(--sm-navy);
}

.sm-toast--out {
    animation: smToastOut 0.2s ease forwards;
}

@keyframes smToastIn {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes smToastOut {
    to {
        opacity: 0;
        transform: translateY(12px);
    }
}

/* --- AI Coach --- */

.sm-ai-coach {
    max-width: 800px;
    margin: 0 auto;
}

.sm-ai-disclaimer {
    display: flex;
    align-items: center;
    gap: var(--sm-space-2);
    padding: var(--sm-space-3) var(--sm-space-4);
    margin-bottom: var(--sm-space-4);
    font-size: 0.8125rem;
    color: var(--sm-gray-600);
    background: var(--sm-warning-light);
    border: 1px solid var(--sm-warning);
    border-radius: var(--sm-radius);
}

.sm-disclaimer-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    color: var(--sm-warning);
}

.sm-chat-container {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    border: 1px solid var(--sm-gray-200);
    overflow: hidden;
    margin-bottom: var(--sm-space-8);
}

.sm-chat-messages {
    height: 400px;
    overflow-y: auto;
    padding: var(--sm-space-4);
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-4);
}

.sm-chat-message {
    display: flex;
    gap: var(--sm-space-3);
}

.sm-message-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--sm-gray-100);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.sm-message-user .sm-message-avatar {
    background: var(--sm-primary-light);
}

.sm-avatar-icon {
    width: 22px;
    height: 22px;
    color: var(--sm-gray-500);
}

.sm-message-user .sm-avatar-icon {
    color: var(--sm-primary);
}

.sm-message-content {
    max-width: 70%;
}

.sm-message-text {
    padding: var(--sm-space-3) var(--sm-space-4);
    border-radius: var(--sm-radius-lg);
    line-height: 1.5;
}

.sm-message-assistant .sm-message-text {
    background: var(--sm-gray-100);
    color: var(--sm-gray-800);
}

.sm-message-user .sm-message-text {
    background: var(--sm-primary);
    color: white;
}

.sm-typing-indicator {
    display: flex;
    gap: 4px;
    padding: var(--sm-space-3) var(--sm-space-4);
    background: var(--sm-gray-100);
    border-radius: var(--sm-radius-lg);
}

.sm-typing-indicator span {
    width: 8px;
    height: 8px;
    background: var(--sm-gray-400);
    border-radius: 50%;
    animation: smTyping 1.4s infinite;
}

.sm-typing-indicator span:nth-child(2) {
    animation-delay: 0.2s;
}

.sm-typing-indicator span:nth-child(3) {
    animation-delay: 0.4s;
}

@keyframes smTyping {

    0%,
    60%,
    100% {
        transform: translateY(0);
    }

    30% {
        transform: translateY(-6px);
    }
}

.sm-chat-input {
    display: flex;
    gap: var(--sm-space-3);
    padding: var(--sm-space-4);
    border-top: 1px solid var(--sm-gray-200);
    background: var(--sm-gray-50);
}

.sm-chat-textarea {
    flex: 1;
    padding: var(--sm-space-3);
    font-family: var(--sm-font-sans);
    font-size: 0.875rem;
    border: 1px solid var(--sm-gray-300);
    border-radius: var(--sm-radius);
    resize: none;
}

.sm-chat-textarea:focus {
    outline: none;
    border-color: var(--sm-primary);
}

.sm-rate-notice {
    text-align: center;
    padding: var(--sm-space-2);
    font-size: 0.75rem;
    color: var(--sm-gray-500);
    background: var(--sm-gray-100);
}

.sm-quick-topics {
    background: var(--sm-surface);
    padding: var(--sm-space-6);
    border-radius: var(--sm-radius-lg);
    border: 1px solid var(--sm-gray-200);
}

.sm-topics-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--sm-gray-800);
    margin-bottom: var(--sm-space-4);
}

.sm-topics-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--sm-space-3);
}

.sm-topic-btn {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3);
    padding: var(--sm-space-3) var(--sm-space-4);
    min-height: 48px;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--sm-gray-700);
    background: var(--sm-gray-50);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius);
    cursor: pointer;
    transition: all var(--sm-transition);
    text-align: left;
}

.sm-topic-btn:hover {
    background: var(--sm-surface);
    border-color: var(--sm-primary);
}

.sm-topic-btn:focus-visible {
    outline: 2px solid var(--sm-focus-ring-color);
    outline-offset: 2px;
}

.sm-topic-icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    color: var(--sm-primary);
}

/* --- Program Generator --- */

.sm-program-generator {
    max-width: 900px;
    margin: 0 auto;
}

.sm-program-result {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    border: 1px solid var(--sm-gray-200);
    padding: var(--sm-space-6);
}

.sm-program-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--sm-space-6);
    padding-bottom: var(--sm-space-4);
    border-bottom: 1px solid var(--sm-gray-200);
}

.sm-program-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--sm-gray-800);
}

.sm-program-actions {
    display: flex;
    gap: var(--sm-space-2);
    flex-wrap: wrap;
}

.sm-program-overview {
    margin-bottom: var(--sm-space-8);
    padding: var(--sm-space-4);
    background: var(--sm-gray-50);
    border-radius: var(--sm-radius);
}

.sm-program-overview h3 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: var(--sm-space-2);
}

.sm-week-block {
    margin-bottom: var(--sm-space-8);
}

.sm-week-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--sm-gray-800);
    margin-bottom: var(--sm-space-4);
    padding-bottom: var(--sm-space-2);
    border-bottom: 2px solid var(--sm-primary);
}

.sm-days-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--sm-space-4);
}

.sm-day-card {
    background: var(--sm-gray-50);
    border-radius: var(--sm-radius);
    padding: var(--sm-space-4);
}

.sm-day-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--sm-primary);
    margin-bottom: var(--sm-space-3);
}

.sm-exercise-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.sm-exercise-item {
    display: flex;
    justify-content: space-between;
    padding: var(--sm-space-2) 0;
    border-bottom: 1px solid var(--sm-gray-200);
    font-size: 0.875rem;
}

.sm-exercise-item:last-child {
    border-bottom: none;
}

.sm-exercise-name {
    font-weight: 500;
    color: var(--sm-gray-800);
}

.sm-exercise-prescription {
    color: var(--sm-gray-600);
}

.sm-day-notes {
    margin-top: var(--sm-space-3);
    padding-top: var(--sm-space-2);
    font-size: 0.75rem;
    color: var(--sm-gray-500);
    font-style: italic;
}

.sm-program-notes {
    margin-top: var(--sm-space-6);
    padding: var(--sm-space-4);
    background: var(--sm-gray-50);
    border-radius: var(--sm-radius);
}

.sm-program-notes h3 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: var(--sm-space-3);
}

/* --- Competition Readiness --- */

.sm-recommendations-title {
    font-size: 0.875rem;
    font-weight: 600;
    margin-bottom: var(--sm-space-3);
}

.sm-recommendations-list {
    margin: 0;
    padding-left: var(--sm-space-5);
}

.sm-recommendations-list li {
    font-size: 0.875rem;
    color: var(--sm-text-secondary);
    margin-bottom: var(--sm-space-2);
}

/* Readiness Calculator */
.sm-readiness-calculator {
    max-width: 800px;
    margin: 0 auto;
}

.sm-readiness-calculator .sm-unit-toggle-inline {
    margin-bottom: var(--sm-space-6);
}

.sm-calc-section {
    margin-bottom: var(--sm-space-6);
}

.sm-calc-section-title {
    font-family: var(--sm-font-heading);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0 0 var(--sm-space-2) 0;
}

.sm-calc-section-subtitle {
    font-size: 0.875rem;
    color: var(--sm-text-secondary);
    margin: 0 0 var(--sm-space-4) 0;
}

/* Input with unit suffix (e.g. weight + "lbs") */
.sm-input-with-unit {
    position: relative;
    display: flex;
    align-items: center;
}

.sm-input-with-unit .sm-input {
    flex: 1;
    padding-right: 50px;
}

.sm-input-unit {
    position: absolute;
    right: 12px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    pointer-events: none;
}

/* Form actions row */
.sm-form-actions {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3);
    margin-top: var(--sm-space-6);
    flex-wrap: wrap;
}

/* Error message */
.sm-error-message {
    padding: var(--sm-space-3) var(--sm-space-4);
    background: rgba(239, 68, 68, 0.08);
    border: 1px solid rgba(239, 68, 68, 0.2);
    border-radius: var(--sm-radius);
    color: #dc2626;
    font-size: 0.875rem;
    margin-bottom: var(--sm-space-4);
}

.sm-event-input-card {
    background: var(--sm-surface);
    box-shadow: var(--sm-shadow);
    border-radius: 12px;
    padding: 1rem;
    margin-bottom: 1rem;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr auto;
    gap: 1rem;
    align-items: end;
}

.sm-event-input-card .sm-form-group {
    margin: 0;
}

.sm-event-remove-btn {
    background: rgba(239, 68, 68, 0.1);
    border: none;
    color: #EF4444;
    width: 40px;
    height: 40px;
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease;
}

.sm-event-remove-btn:hover {
    background: rgba(239, 68, 68, 0.2);
}

.sm-add-event-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 1rem;
    background: var(--sm-gray-50);
    border: 2px dashed var(--sm-gray-300);
    border-radius: 12px;
    color: var(--sm-gray-500);
    cursor: pointer;
    transition: all 0.2s ease;
    margin-bottom: 1.5rem;
}

.sm-add-event-btn:hover {
    background: var(--sm-surface);
    border-color: var(--sm-primary);
    color: var(--sm-gray-800);
}

.sm-athlete-lifts-section {
    background: var(--sm-surface);
    box-shadow: var(--sm-shadow);
    border-radius: 12px;
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}

.sm-athlete-lifts-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--sm-gray-800);
    margin-bottom: 1rem;
}

.sm-athlete-lifts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1rem;
}

.sm-athlete-lift-input {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.sm-athlete-lift-label {
    font-size: 0.875rem;
    color: var(--sm-gray-500);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Overall Score Card */
.sm-overall-score-card {
    background: var(--sm-surface);
    box-shadow: var(--sm-shadow);
    border-radius: 16px;
    padding: 2rem;
    text-align: center;
    margin-bottom: 1.5rem;
    position: relative;
    overflow: hidden;
}

.sm-overall-score-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
}

.sm-overall-score-card.ready::before {
    background: linear-gradient(90deg, #2ecc71, #27ae60);
}

.sm-overall-score-card.close::before {
    background: linear-gradient(90deg, #f5a623, #d4920a);
}

.sm-overall-score-card.train::before {
    background: linear-gradient(90deg, var(--sm-primary), var(--sm-primary-hover));
}

.sm-overall-score-card.not_ready::before {
    background: linear-gradient(90deg, #ef4444, #dc2626);
}

.sm-overall-score-number {
    font-size: 4rem;
    font-weight: var(--sm-weight-extrabold);
    line-height: 1;
    margin-bottom: 0.5rem;
}

.sm-overall-score-card.ready .sm-overall-score-number {
    color: #2ecc71;
}

.sm-overall-score-card.close .sm-overall-score-number {
    color: #f5a623;
}

.sm-overall-score-card.train .sm-overall-score-number {
    color: var(--sm-primary);
}

.sm-overall-score-card.not_ready .sm-overall-score-number {
    color: #ef4444;
}

.sm-overall-score-label {
    font-size: 1rem;
    color: var(--sm-gray-500);
    margin-bottom: 0.5rem;
}

.sm-overall-status-text {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--sm-gray-800);
}

.sm-overall-message {
    font-size: 1rem;
    color: var(--sm-gray-500);
    margin-top: 0.5rem;
}

.sm-weeks-estimate {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 1rem;
    padding: 0.5rem 1rem;
    background: var(--sm-gray-50);
    border-radius: 8px;
    font-size: 0.875rem;
    color: var(--sm-gray-500);
}

/* Event Results Grid */
.sm-event-results-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.sm-event-result-card {
    background: var(--sm-surface);
    box-shadow: var(--sm-shadow);
    border-radius: 12px;
    padding: 1.25rem;
    border-left: 4px solid;
}

.sm-event-result-card:hover {
    box-shadow: var(--sm-shadow-md);
}

.sm-event-result-card.ready {
    border-left-color: #2ecc71;
}

.sm-event-result-card.close {
    border-left-color: #f5a623;
}

.sm-event-result-card.train {
    border-left-color: #ef4444;
}

.sm-event-result-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.75rem;
}

.sm-event-result-name {
    font-weight: 600;
    color: var(--sm-gray-800);
}

.sm-event-result-status {
    font-size: 1.25rem;
}

.sm-event-result-stats {
    display: flex;
    gap: 1.5rem;
    margin-bottom: 0.75rem;
}

.sm-event-stat {
    display: flex;
    flex-direction: column;
}

.sm-event-stat-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--sm-gray-800);
}

.sm-event-stat-label {
    font-size: 0.75rem;
    color: var(--sm-gray-500);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.sm-event-result-bar {
    height: 6px;
    background: var(--sm-gray-200);
    border-radius: 3px;
    overflow: hidden;
    margin-bottom: 0.75rem;
}

.sm-event-result-bar-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.6s ease;
}

.sm-event-result-card.ready .sm-event-result-bar-fill {
    background: #2ecc71;
}

.sm-event-result-card.close .sm-event-result-bar-fill {
    background: #f5a623;
}

.sm-event-result-card.train .sm-event-result-bar-fill {
    background: #ef4444;
}

.sm-event-result-message {
    font-size: 0.875rem;
    color: var(--sm-gray-500);
}

.sm-recommendations {
    background: var(--sm-surface);
    box-shadow: var(--sm-shadow);
    border-radius: 12px;
    padding: 1.5rem;
}

@media (max-width: 640px) {
    .sm-event-input-card {
        grid-template-columns: 1fr;
    }

    .sm-event-input-card .sm-event-remove-btn {
        justify-self: end;
    }

    .sm-overall-score-number {
        font-size: 3rem;
    }

    .sm-event-results-grid {
        grid-template-columns: 1fr;
    }
}

/* --- Share System --- */

.sm-share-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: var(--sm-primary);
    color: white;
    border: none;
    border-radius: var(--sm-radius-full);
    font-size: 13px;
    font-weight: 600;
    line-height: 1.4;
    cursor: pointer;
    transition: all 0.15s ease;
}

.sm-share-btn:hover {
    background: var(--sm-primary-hover);
}

.sm-share-btn svg {
    width: 20px;
    height: 20px;
}

.sm-challenge-target {
    background: rgba(255, 255, 255, 0.15);
    padding: 0.25rem 0.75rem;
    border-radius: 6px;
    font-weight: 700;
}

/* --- Community Features --- */

.sm-feed-filters {
    display: flex;
    gap: var(--sm-space-2);
    padding: var(--sm-space-2);
    background: var(--sm-gray-50);
    border-radius: var(--sm-radius-lg);
    border: 1px solid var(--sm-gray-200);
    margin-bottom: var(--sm-space-6);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.sm-feed-filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: var(--sm-space-2) var(--sm-space-4);
    border: none;
    border-radius: var(--sm-radius);
    background: transparent;
    color: var(--sm-gray-500);
    font-family: var(--sm-font-body);
    font-size: var(--sm-fs-sm);
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
    transition: all var(--sm-transition);
}

.sm-feed-filter-btn:hover {
    background: var(--sm-gray-100);
    color: var(--sm-gray-700);
}

.sm-feed-filter-btn.active {
    background: var(--sm-surface);
    color: var(--sm-primary);
    box-shadow: var(--sm-shadow-sm);
    font-weight: 600;
}

.sm-feed-filter-btn svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

/* Feed Items */
.sm-feed-list {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.sm-feed-item {
    display: flex;
    align-items: flex-start;
    gap: var(--sm-space-3);
    padding: var(--sm-space-4);
    border-bottom: 1px solid var(--sm-gray-100);
    transition: background var(--sm-transition);
}

.sm-feed-item:hover {
    background: var(--sm-gray-50);
}

.sm-feed-item:last-child {
    border-bottom: none;
}

.sm-feed-avatar {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    overflow: hidden;
    background: var(--sm-gray-200);
}

.sm-feed-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.sm-feed-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-1);
}

.sm-feed-header {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: baseline;
}

.sm-feed-username {
    font-weight: 600;
    color: var(--sm-gray-800);
    text-decoration: none;
    font-size: var(--sm-fs-sm);
}

.sm-feed-username:hover {
    color: var(--sm-primary);
}

.sm-feed-action {
    color: var(--sm-gray-500);
    font-size: var(--sm-fs-sm);
}

.sm-feed-detail {
    display: flex;
    gap: var(--sm-space-2);
    align-items: center;
}

.sm-feed-value {
    font-weight: 700;
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-md);
    color: var(--sm-primary);
}

.sm-feed-event {
    color: var(--sm-gray-400);
    font-size: var(--sm-fs-xs);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.sm-feed-meta {
    display: flex;
    gap: var(--sm-space-3);
    align-items: center;
}

.sm-feed-time {
    color: var(--sm-gray-400);
    font-size: var(--sm-fs-xs);
}

.sm-feed-link {
    color: var(--sm-primary);
    font-size: var(--sm-fs-xs);
    font-weight: 500;
    text-decoration: none;
}

.sm-feed-link:hover {
    color: var(--sm-primary-hover);
    text-decoration: underline;
}

.sm-feed-type-badge {
    flex-shrink: 0;
    padding: 2px 8px;
    border-radius: var(--sm-radius-full);
    font-size: var(--sm-fs-2xs);
    font-weight: 600;
    text-transform: capitalize;
    letter-spacing: 0.02em;
}

.sm-feed-item-skeleton {
    pointer-events: none;
}

.sm-feed-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--sm-space-2);
    color: var(--sm-gray-400);
    font-size: var(--sm-fs-sm);
}

.sm-feed-end {
    text-align: center;
    padding: var(--sm-space-6) 0;
    color: var(--sm-gray-400);
    font-size: var(--sm-fs-sm);
}

/* Challenge Cards */
.sm-challenge-list {
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-4);
}

.sm-challenge-card {
    display: block;
    padding: var(--sm-space-5);
    text-decoration: none;
    color: inherit;
}

.sm-challenge-vs {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--sm-space-4);
    margin-bottom: var(--sm-space-4);
}

.sm-challenge-vs-large {
    padding: var(--sm-space-4) 0;
}

.sm-challenge-user {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sm-space-2);
    text-align: center;
    flex: 1;
    min-width: 0;
}

.sm-challenge-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--sm-gray-200);
}

.sm-challenge-avatar-lg {
    width: 72px;
    height: 72px;
    border-width: 3px;
}

.sm-challenge-name {
    font-weight: 600;
    font-size: var(--sm-fs-sm);
    color: var(--sm-gray-800);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}

.sm-challenge-name-lg {
    font-size: var(--sm-fs-md);
    font-family: var(--sm-font-heading);
}

.sm-challenge-role {
    font-size: var(--sm-fs-xs);
    color: var(--sm-gray-400);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.sm-challenge-vs-text {
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-lg);
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-gray-300);
    flex-shrink: 0;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.sm-challenge-vs-text-lg {
    font-size: var(--sm-fs-2xl);
}

.sm-challenge-vs-center {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sm-space-2);
    flex-shrink: 0;
}

.sm-challenge-info {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--sm-space-3);
    padding: var(--sm-space-2) 0;
    border-top: 1px solid var(--sm-gray-100);
}

.sm-challenge-event {
    font-weight: 600;
    font-size: var(--sm-fs-sm);
    color: var(--sm-gray-700);
}

.sm-challenge-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: var(--sm-space-3);
    border-top: 1px solid var(--sm-gray-100);
}

.sm-challenge-expires {
    font-size: var(--sm-fs-xs);
    color: var(--sm-gray-400);
}

/* Challenge Status Badges */
.sm-challenge-status,
.sm-challenge-status-lg {
    display: inline-block;
    padding: 2px 10px;
    border-radius: var(--sm-radius-full);
    font-size: var(--sm-fs-2xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.sm-status-pending {
    background: var(--sm-warning-light);
    color: #92400e;
}

.sm-detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--sm-space-4);
}

.sm-detail-item {
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-1);
}

.sm-detail-label {
    font-size: var(--sm-fs-xs);
    color: var(--sm-gray-400);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 600;
}

.sm-detail-value {
    font-size: var(--sm-fs-base);
    font-weight: 600;
    color: var(--sm-gray-800);
}

.sm-challenge-message {
    padding: var(--sm-space-4);
    background: var(--sm-gray-50);
    border-radius: var(--sm-radius);
    border-left: 3px solid var(--sm-accent);
}

/* Submissions */
.sm-submission-list {
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-3);
}

.sm-submission-item {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3);
    padding: var(--sm-space-3);
    background: var(--sm-gray-50);
    border-radius: var(--sm-radius);
}

.sm-submission-user {
    display: flex;
    align-items: center;
    gap: var(--sm-space-2);
    font-weight: 500;
    font-size: var(--sm-fs-sm);
    flex: 1;
    min-width: 0;
}

.sm-submission-value {
    display: flex;
    align-items: center;
    gap: var(--sm-space-2);
    font-weight: 700;
    color: var(--sm-primary);
    font-family: var(--sm-font-heading);
}

/* Comments */
.sm-comment-thread {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.sm-comment {
    padding: var(--sm-space-4) 0;
    border-bottom: 1px solid var(--sm-gray-100);
}

.sm-comment:last-child {
    border-bottom: none;
}

.sm-comment-header {
    display: flex;
    align-items: center;
    gap: var(--sm-space-2);
    margin-bottom: var(--sm-space-2);
}

.sm-comment-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.sm-comment-author {
    font-weight: 600;
    font-size: var(--sm-fs-sm);
    color: var(--sm-gray-800);
}

.sm-comment-body {
    font-size: var(--sm-fs-sm);
    color: var(--sm-gray-600);
    line-height: 1.6;
    padding-left: calc(32px + var(--sm-space-2));
}

.sm-comment-actions {
    display: flex;
    gap: var(--sm-space-3);
    padding-left: calc(32px + var(--sm-space-2));
    margin-top: var(--sm-space-1);
}

.sm-comment-action-btn {
    background: none;
    border: none;
    font-size: var(--sm-fs-xs);
    color: var(--sm-gray-400);
    cursor: pointer;
    padding: 2px 0;
    font-family: var(--sm-font-body);
    transition: color var(--sm-transition);
}

.sm-comment-action-btn:hover {
    color: var(--sm-primary);
}

.sm-comment-delete:hover {
    color: var(--sm-error);
}

.sm-comment-replies {
    padding-left: calc(32px + var(--sm-space-2));
    margin-top: var(--sm-space-2);
    border-left: 2px solid var(--sm-gray-100);
}

.sm-comment-reply {
    padding: var(--sm-space-3) 0 var(--sm-space-3) var(--sm-space-3);
    border-bottom: none;
}

.sm-comment-reply .sm-comment-avatar {
    width: 28px;
    height: 28px;
}

.sm-comment-reply .sm-comment-body {
    padding-left: calc(28px + var(--sm-space-2));
}

.sm-comment-reply .sm-comment-actions {
    padding-left: calc(28px + var(--sm-space-2));
}

.sm-comment-form {
    margin-bottom: var(--sm-space-6);
    padding-bottom: var(--sm-space-4);
    border-bottom: 1px solid var(--sm-gray-200);
}

.sm-comment-textarea {
    width: 100%;
    resize: vertical;
    min-height: 80px;
    margin-bottom: var(--sm-space-2);
}

.sm-comment-form-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sm-space-2);
}

.sm-reply-indicator {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: var(--sm-fs-xs);
    color: var(--sm-primary);
    font-weight: 500;
}

.sm-cancel-reply {
    background: none;
    border: none;
    color: var(--sm-gray-400);
    cursor: pointer;
    font-size: 1rem;
    padding: 0 4px;
    line-height: 1;
}

.sm-cancel-reply:hover {
    color: var(--sm-error);
}

/* Follow Button */
.sm-follow-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius-full);
    background: var(--sm-surface);
    color: var(--sm-gray-500);
    font-family: var(--sm-font-body);
    font-size: var(--sm-fs-xs);
    font-weight: 600;
    line-height: 1.4;
    cursor: pointer;
    transition: all var(--sm-transition);
}

.sm-follow-btn:hover {
    border-color: var(--sm-primary);
    color: var(--sm-primary);
}

/* Opponent Search */
.sm-opponent-results {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 50;
    background: var(--sm-surface);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius);
    box-shadow: var(--sm-shadow-lg);
    max-height: 240px;
    overflow-y: auto;
    margin-top: 4px;
}

.sm-opponent-option {
    display: block;
    width: 100%;
    padding: var(--sm-space-3) var(--sm-space-4);
    border: none;
    background: transparent;
    text-align: left;
    font-family: var(--sm-font-body);
    font-size: var(--sm-fs-sm);
    color: var(--sm-gray-700);
    cursor: pointer;
    transition: background var(--sm-transition);
}

.sm-opponent-option:hover {
    background: var(--sm-gray-50);
    color: var(--sm-primary);
}

.sm-selected-opponent {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: var(--sm-space-2);
    padding: 4px 10px;
    background: var(--sm-primary-light);
    border: 1px solid var(--sm-primary-soft);
    border-radius: var(--sm-radius-full);
    font-size: var(--sm-fs-sm);
    font-weight: 500;
    color: var(--sm-primary-hover);
}

.sm-remove-opponent {
    background: none;
    border: none;
    color: var(--sm-gray-400);
    cursor: pointer;
    font-size: 1.2rem;
    line-height: 1;
    padding: 0 2px;
}

.sm-remove-opponent:hover {
    color: var(--sm-error);
}

@media (max-width: 640px) {
    .sm-feed-filters {
        gap: var(--sm-space-1);
        padding: var(--sm-space-1);
    }

    .sm-feed-filter-btn {
        padding: var(--sm-space-2) var(--sm-space-3);
        font-size: var(--sm-fs-xs);
    }

    .sm-challenge-vs {
        gap: var(--sm-space-2);
    }

    .sm-challenge-avatar {
        width: 36px;
        height: 36px;
    }

    .sm-challenge-avatar-lg {
        width: 56px;
        height: 56px;
    }

    .sm-challenge-vs-text-lg {
        font-size: var(--sm-fs-xl);
    }

    .sm-detail-grid {
        grid-template-columns: 1fr 1fr;
    }

    .sm-feed-type-badge {
        display: none;
    }
}

/* ==========================================================================
   12. UTILITIES
   ========================================================================== */

/* Inline SVG icon base class */
.strongman-app .sm-icon {
    display: inline-block;
    vertical-align: middle;
    flex-shrink: 0;
}

.strongman-app .sm-rank-medal {
    margin-right: 2px;
}

.sm-text-center {
    text-align: center;
}

.sm-text-left {
    text-align: left;
}

.sm-text-right {
    text-align: right;
}

.sm-capitalize {
    text-transform: capitalize;
}

.sm-uppercase {
    text-transform: uppercase;
}

.sm-font-bold {
    font-weight: 700;
}

.sm-font-semibold {
    font-weight: 600;
}

.sm-font-medium {
    font-weight: 500;
}

.sm-text-xs {
    font-size: 0.75rem;
}

.sm-text-sm {
    font-size: 0.875rem;
}

.sm-text-base {
    font-size: 1rem;
}

.sm-text-lg {
    font-size: 1.125rem;
}

.sm-text-xl {
    font-size: 1.25rem;
}

.sm-text-2xl {
    font-size: 1.5rem;
}

.sm-text-3xl {
    font-size: 1.875rem;
}

.sm-text-slate-400 {
    color: var(--sm-gray-400);
}

.sm-text-slate-500 {
    color: var(--sm-gray-500);
}

.sm-text-slate-600 {
    color: var(--sm-gray-600);
}

.sm-text-slate-800 {
    color: var(--sm-gray-800);
}

.sm-mt-2 {
    margin-top: var(--sm-space-2);
}

.sm-mt-4 {
    margin-top: var(--sm-space-4);
}

.sm-mt-6 {
    margin-top: var(--sm-space-6);
}

.sm-mt-8 {
    margin-top: var(--sm-space-8);
}

.sm-mt-12 {
    margin-top: var(--sm-space-12);
}

.sm-mb-2 {
    margin-bottom: var(--sm-space-2);
}

.sm-mb-3 {
    margin-bottom: var(--sm-space-3);
}

.sm-mb-4 {
    margin-bottom: var(--sm-space-4);
}

.sm-mb-6 {
    margin-bottom: var(--sm-space-6);
}

.sm-mb-8 {
    margin-bottom: var(--sm-space-8);
}

.sm-ml-2 {
    margin-left: var(--sm-space-2);
}

.sm-ml-4 {
    margin-left: var(--sm-space-4);
}

.sm-py-4 {
    padding-top: var(--sm-space-4);
    padding-bottom: var(--sm-space-4);
}

.sm-py-8 {
    padding-top: var(--sm-space-8);
    padding-bottom: var(--sm-space-8);
}

.sm-py-12 {
    padding-top: var(--sm-space-12);
    padding-bottom: var(--sm-space-12);
}

.sm-hidden {
    display: none;
}

.sm-block {
    display: block;
}

.sm-flex {
    display: flex;
}

.sm-grid {
    display: grid;
}

.sm-items-center {
    align-items: center;
}

.sm-justify-center {
    justify-content: center;
}

.sm-justify-between {
    justify-content: space-between;
}

.sm-gap-2 {
    gap: var(--sm-space-2);
}

.sm-gap-4 {
    gap: var(--sm-space-4);
}

.sm-gap-6 {
    gap: var(--sm-space-6);
}

.sm-touch-target {
    min-height: 44px;
    min-width: 44px;
}

.sm-no-select {
    -webkit-user-select: none;
    user-select: none;
}

/* Text color utilities */
.sm-text-secondary {
    color: var(--sm-text-secondary);
}

.sm-text-muted {
    color: var(--sm-text-muted);
}

/* Empty state icon */
.sm-empty-state-icon {
    color: var(--sm-gray-300);
    margin-bottom: var(--sm-space-4);
}

/* Card heading (used inside sm-card-header) */
.sm-card-heading {
    margin: 0;
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-lg);
}

/* Challenge detail helpers */
.sm-challenge-message-text {
    font-style: italic;
    color: var(--sm-text-secondary);
}

.sm-challenge-actions-row {
    display: flex;
    gap: var(--sm-space-4);
    flex-wrap: wrap;
}

.sm-challenge-action-btn {
    flex: 1;
    min-width: 140px;
}

/* Avatar round */
.sm-avatar-round {
    border-radius: 50%;
}

/* Loading centered */
.sm-loading-centered {
    padding: 3rem;
    text-align: center;
}

/* Screen reader only */
.sm-sr-only,
.sm-visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

#sm-live-region,
.sm-live-region {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Alpine.js */
[x-cloak] {
    display: none !important;
}

.transition {
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.ease-out {
    transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}

.ease-in {
    transition-timing-function: cubic-bezier(0.4, 0, 1, 1);
}

.duration-150 {
    transition-duration: 150ms;
}

.duration-200 {
    transition-duration: 200ms;
}

.opacity-0 {
    opacity: 0;
}

.opacity-100 {
    opacity: 1;
}

.-translate-y-2 {
    transform: translateY(-0.5rem);
}

.translate-y-0 {
    transform: translateY(0);
}

/* ==========================================================================
   13. RESPONSIVE
   ========================================================================== */

@media (max-width: 640px) {

    .strongman-app button,
    .strongman-app [role="button"],
    .strongman-app a.sm-btn-primary,
    .strongman-app a.sm-btn-secondary,
    .strongman-app input,
    .strongman-app select {
        min-height: 44px !important;
    }

    .strongman-app input[type="checkbox"],
    .strongman-app input[type="radio"] {
        width: 22px !important;
        height: 22px !important;
    }

    .strongman-app .sm-back-link {
        position: relative;
    }

    .strongman-app .sm-back-link::before {
        content: '';
        position: absolute;
        top: -8px;
        left: -8px;
        right: -8px;
        bottom: -8px;
    }

    .sm-trust-badges {
        gap: 8px;
    }

    .sm-trust-badge {
        padding: 6px 12px;
        font-size: 0.75rem;
    }
}

@media (max-width: 768px) {

    .sm-input,
    .sm-select,
    .sm-filter-input,
    .sm-filter-select,
    .sm-search-input,
    input[type="text"],
    input[type="number"],
    input[type="email"],
    select {
        min-height: 44px;
        font-size: 16px;
        padding: 12px 16px;
    }

    .sm-select,
    .sm-filter-select {
        padding-right: 36px;
    }

    .sm-btn {
        min-height: 48px;
        padding: 12px 24px;
    }

    .sm-form-group {
        margin-bottom: 1.25rem;
    }

    .sm-radio-label,
    .sm-checkbox-label {
        min-height: 44px;
        display: flex;
        align-items: center;
        padding: 8px 0;
    }

    .sm-pagination-btn {
        min-width: 44px;
        min-height: 44px;
    }
}

@media (hover: none) {

    .sm-calculator-card:hover,
    .sm-related-card:hover,
    .sm-data-card:hover,
    .sm-ai-card:hover,
    .sm-featured-card:hover {
        transform: none;
    }
}

@supports (padding: env(safe-area-inset-bottom)) {
    .strongman-app {
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
    }

    .strongman-app .sm-calculator-container {
        padding-bottom: calc(24px + env(safe-area-inset-bottom));
    }
}

/* ==========================================================================
   14. ACCESSIBILITY
   ========================================================================== */

.strongman-app :focus-visible {
    outline: var(--sm-focus-ring-width) solid var(--sm-focus-ring-color);
    outline-offset: var(--sm-focus-ring-offset);
}

.strongman-app :focus:not(:focus-visible) {
    outline: none;
}

.strongman-app .sm-input:focus-visible,
.strongman-app .sm-select:focus-visible,
.strongman-app .sm-filter-input:focus-visible,
.strongman-app .sm-filter-select:focus-visible,
.strongman-app .sm-search-input:focus-visible {
    outline: none;
    border-color: var(--sm-focus-ring-color);
    box-shadow: 0 0 0 3px var(--sm-primary-light);
}

.strongman-app .sm-btn:focus-visible {
    outline: none;
    box-shadow:
        0 0 0 var(--sm-focus-ring-offset) white,
        0 0 0 calc(var(--sm-focus-ring-offset) + var(--sm-focus-ring-width)) var(--sm-focus-ring-color);
}

.strongman-app .sm-calculator-card:focus-visible,
.strongman-app .sm-related-card:focus-visible,
.strongman-app .sm-data-card:focus-visible,
.strongman-app .sm-ai-card:focus-visible,
.strongman-app .sm-featured-card:focus-visible {
    outline: var(--sm-focus-ring-width) solid var(--sm-focus-ring-color);
    outline-offset: 3px;
}

.strongman-app .sm-faq-question:focus-visible {
    outline: none;
    box-shadow: inset 0 0 0 2px var(--sm-focus-ring-color);
    background: var(--sm-gray-50);
}

.strongman-app .sm-unit-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px white, 0 0 0 4px var(--sm-focus-ring-color);
}

.strongman-app .sm-nav-hamburger:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px white, 0 0 0 4px var(--sm-focus-ring-color);
}

.strongman-app .sm-nav-mobile-link:focus-visible {
    outline: none;
    box-shadow: inset 0 0 0 2px var(--sm-focus-ring-color);
}

.strongman-app .sm-nav-link:focus-visible {
    outline: none;
    text-decoration: underline;
    text-underline-offset: 4px;
    text-decoration-thickness: 2px;
    text-decoration-color: var(--sm-focus-ring-color);
}

.strongman-app .sm-helper {
    color: var(--sm-gray-600);
}

@media (forced-colors: active) {
    .strongman-app :focus-visible {
        outline: 3px solid CanvasText !important;
        outline-offset: 2px !important;
    }
}

@media (prefers-reduced-motion: reduce) {

    .strongman-app *,
    .strongman-app *::before,
    .strongman-app *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }

    .sm-skeleton {
        animation: none !important;
        background: var(--sm-gray-200) !important;
    }

    .sm-progress-fill,
    .sm-gauge-fill,
    .sm-comparison-fill {
        transition: none !important;
    }

    .sm-result-reveal,
    .sm-elite-glow,
    .sm-success-flash {
        animation: none;
    }

    .sm-result-reveal {
        opacity: 1;
    }
}

/* ==========================================================================
   15. PRINT
   ========================================================================== */

@media print {

    .sm-program-actions,
    .sm-nav,
    .sm-footer {
        display: none !important;
    }

    .sm-program-result {
        box-shadow: none;
        border: none;
    }

    .strongman-app {
        background: white !important;
    }
}

/* ==========================================================================
   16. HUB & PAGE-SPECIFIC STYLES
   Migrated from strongman-premium.css with Bold Sports design tokens.
   ========================================================================== */

/* --------------------------------------------------------------------------
   16.1 HERO SECTION - Navy/Crimson Gradient
   -------------------------------------------------------------------------- */

.sm-hero {
    background: linear-gradient(135deg, var(--sm-navy) 0%, var(--sm-electric) 100%);
    border-radius: var(--sm-radius-xl);
    padding: 40px 48px;
    margin-bottom: 32px;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
}

/* Animated background pattern */
.sm-hero::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -10%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(233, 69, 96, 0.15) 0%, transparent 70%);
    border-radius: 50%;
    animation: heroFloat 20s ease-in-out infinite;
    pointer-events: none;
}

.sm-hero::after {
    content: '';
    position: absolute;
    bottom: -30%;
    left: -5%;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(46, 204, 113, 0.1) 0%, transparent 70%);
    border-radius: 50%;
    animation: heroFloat 15s ease-in-out infinite reverse;
    pointer-events: none;
}

@keyframes heroFloat {

    0%,
    100% {
        transform: translate(0, 0) scale(1);
    }

    50% {
        transform: translate(30px, -30px) scale(1.1);
    }
}

.sm-hero-content {
    max-width: 600px;
    position: relative;
    z-index: 1;
    flex-shrink: 0;
}

/* Hero Illustration (right side) */
.sm-hero-illustration {
    position: relative;
    z-index: 1;
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
}

.sm-hero-illustration svg {
    width: 100%;
    max-width: 380px;
    height: auto;
    opacity: 0.9;
    filter: drop-shadow(0 8px 32px rgba(233, 69, 96, 0.2));
}

@media (max-width: 960px) {
    .sm-hero {
        flex-direction: column;
    }

    .sm-hero-content {
        max-width: 100%;
    }

    .sm-hero-illustration {
        display: none;
    }
}

/* Trust Badge */
.sm-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--sm-space-2);
    padding: var(--sm-space-2) var(--sm-space-4);
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--sm-radius-full);
    margin-bottom: var(--sm-space-6);
}

.sm-hero-badge-dot {
    width: 8px;
    height: 8px;
    background: var(--sm-primary);
    border-radius: 50%;
    animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {

    0%,
    100% {
        opacity: 1;
        transform: scale(1);
    }

    50% {
        opacity: 0.6;
        transform: scale(0.85);
    }
}

.sm-hero-badge-text {
    font-size: var(--sm-fs-sm);
    font-weight: 600;
    color: white;
}

/* Hero Headlines */
h1.sm-heading-hero {
    font-family: var(--sm-font-heading);
    font-size: clamp(var(--sm-fs-sm), 2.5vw, var(--sm-fs-lg));
    font-weight: 600;
    line-height: 1.3;
    color: var(--sm-text-secondary);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin: 0 0 var(--sm-space-2);
}

.sm-heading-hero {
    font-family: var(--sm-font-heading);
    font-size: clamp(2rem, 6vw, 3rem);
    font-weight: var(--sm-weight-extrabold);
    line-height: 1.15;
    color: white;
    letter-spacing: -0.03em;
    margin: 0 0 var(--sm-space-3);
}

.sm-heading-hero-sub {
    font-family: var(--sm-font-heading);
    font-size: clamp(var(--sm-fs-lg), 4vw, var(--sm-fs-3xl));
    font-weight: 600;
    line-height: 1.2;
    color: var(--sm-primary);
    margin: 0 0 var(--sm-space-6);
}

.sm-hero-description {
    max-width: 550px;
    margin: 0 0 var(--sm-space-8);
    font-size: var(--sm-fs-lg);
    color: rgba(255, 255, 255, 0.8);
    line-height: 1.7;
}

/* CTA Buttons Row */
.sm-cta-row {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3);
    flex-wrap: wrap;
    margin-bottom: var(--sm-space-10);
}

/* Hero-specific primary button */
.sm-hero .sm-btn-primary {
    background: var(--sm-primary);
    color: white !important;
    box-shadow: 0 4px 14px rgba(233, 69, 96, 0.35);
    position: relative;
    overflow: hidden;
}

.sm-hero .sm-btn-primary::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.2) 0%, transparent 50%);
    opacity: 0;
    transition: opacity var(--sm-transition);
}

.sm-hero .sm-btn-primary:hover {
    background: var(--sm-primary-hover);
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(233, 69, 96, 0.45);
}

.sm-hero .sm-btn-primary:hover::before {
    opacity: 1;
}

.sm-hero .sm-btn-primary:active {
    transform: translateY(0) scale(0.98);
    box-shadow: 0 4px 14px rgba(233, 69, 96, 0.35);
}

.sm-hero .sm-btn-primary:hover svg {
    transform: translateX(4px);
}

/* Hero-specific secondary button */
.sm-hero .sm-btn-secondary {
    background: rgba(255, 255, 255, 0.1);
    color: white !important;
    border: 2px solid rgba(255, 255, 255, 0.2);
    box-shadow: none;
}

.sm-hero .sm-btn-secondary:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(255, 255, 255, 0.35);
    transform: translateY(-2px);
}

/* Hero-specific CTA button (green) */
.sm-hero .sm-btn-cta {
    background: linear-gradient(135deg, var(--sm-green) 0%, var(--sm-green-600) 100%);
    color: white !important;
    box-shadow: 0 4px 14px rgba(46, 204, 113, 0.35);
    border: none;
}

.sm-hero .sm-btn-cta:hover {
    background: linear-gradient(135deg, var(--sm-green-600) 0%, var(--sm-green-700) 100%);
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(46, 204, 113, 0.45);
}

.sm-hero .sm-btn-cta:active {
    transform: translateY(0) scale(0.98);
}

/* Hero responsive */
@media (max-width: 768px) {
    .sm-hero {
        padding: 28px;
        border-radius: var(--sm-radius-lg);
    }

    h1.sm-heading-hero {
        font-size: var(--sm-fs-xs);
    }

    .sm-heading-hero {
        font-size: 24px;
    }

    .sm-hero-description {
        font-size: var(--sm-fs-sm);
    }

    .sm-hero::before {
        width: 300px;
        height: 300px;
    }

    .sm-hero::after {
        display: none;
    }
}

/* Stats Row */
.sm-stats-row {
    display: flex;
    align-items: center;
    gap: var(--sm-space-8);
    flex-wrap: wrap;
    padding: 10px;
}

.sm-stat {
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-1);
}

.sm-stat-number {
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-3xl);
    font-weight: 700;
    color: white;
    line-height: 1;
    letter-spacing: -0.02em;
}

.sm-stat-number.highlight {
    color: var(--sm-primary);
}

.sm-stat-label {
    font-size: var(--sm-fs-sm);
    font-weight: 500;
    color: rgba(255, 255, 255, 0.6);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* Hero Stats Row - scoped override to prevent .strongman-app strip styles from breaking hero layout */
.strongman-app .sm-hero .sm-stats-row {
    display: flex;
    align-items: stretch;
    gap: 0;
    background: rgba(255, 255, 255, 0.08);
    border-radius: var(--sm-radius-lg);
    overflow: hidden;
    margin-top: 24px;
    margin-bottom: 0;
    padding: 0;
    border: 1px solid rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(8px);
}

.strongman-app .sm-hero .sm-stat {
    flex: 1;
    background: transparent;
    padding: 16px 20px;
    text-align: center;
    border-right: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 0;
}

.strongman-app .sm-hero .sm-stat:first-child {
    border-radius: 0;
}

.strongman-app .sm-hero .sm-stat:last-child {
    border-right: none;
    border-radius: 0;
}

.strongman-app .sm-hero .sm-stat-number {
    font-size: 1.5rem;
    font-weight: var(--sm-weight-extrabold, 800);
    color: #fff;
    line-height: 1.2;
    letter-spacing: -0.02em;
}

.strongman-app .sm-hero .sm-stat-number.highlight {
    color: var(--sm-primary);
    font-size: 1.25rem;
}

.strongman-app .sm-hero .sm-stat-label {
    font-size: 0.6875rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.55);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-top: 4px;
}

@media (max-width: 640px) {
    .strongman-app .sm-hero .sm-stats-row {
        flex-direction: column;
    }

    .strongman-app .sm-hero .sm-stat {
        border-right: none;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
        padding: 12px 16px;
    }

    .strongman-app .sm-hero .sm-stat:last-child {
        border-bottom: none;
    }
}

/* Stats strip — separate section below hero (1px gap pattern) */
.sm-stats-strip {
    display: flex;
    gap: 1px;
    background: var(--sm-border);
    border-radius: var(--sm-radius-lg);
    overflow: hidden;
    margin-bottom: 28px;
}

.sm-stats-strip .sm-stat-item {
    flex: 1;
    background: var(--sm-surface);
    padding: 20px 24px;
    text-align: center;
}

.sm-stats-strip .sm-stat-item:first-child {
    border-radius: var(--sm-radius-lg) 0 0 var(--sm-radius-lg);
}

.sm-stats-strip .sm-stat-item:last-child {
    border-radius: 0 var(--sm-radius-lg) var(--sm-radius-lg) 0;
}

.sm-stats-strip .sm-stat-number {
    font-size: 30px;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-navy);
    letter-spacing: -0.04em;
    line-height: 1.1;
}

.sm-stats-strip .sm-stat-number .accent {
    color: var(--sm-primary);
}

.sm-stats-strip .sm-stat-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-top: 2px;
}

@media (max-width: 768px) {
    .sm-stats-strip {
        flex-direction: column;
    }

    .sm-stats-strip .sm-stat-item:first-child {
        border-radius: var(--sm-radius-lg) var(--sm-radius-lg) 0 0;
    }

    .sm-stats-strip .sm-stat-item:last-child {
        border-radius: 0 0 var(--sm-radius-lg) var(--sm-radius-lg);
    }
}

.sm-page-header-dark+.sm-stats-strip {
    margin-top: -8px;
}

/* --------------------------------------------------------------------------
   16.2 FEATURED CARD - Crimson Gradient
   -------------------------------------------------------------------------- */

.sm-featured-section {
    margin-top: calc(var(--sm-space-8) * -1);
    padding: 0 0 var(--sm-space-16);
}

.sm-featured-section .sm-featured-card {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: var(--sm-space-6);
    padding: var(--sm-space-8) var(--sm-space-10);
    background: linear-gradient(135deg, var(--sm-primary) 0%, var(--sm-primary-hover) 100%);
    border-radius: var(--sm-radius-2xl);
    box-shadow: var(--sm-shadow-lg), 0 0 0 1px rgba(0, 0, 0, 0.02);
    color: white;
    text-decoration: none;
    transition: all var(--sm-transition-slow);
    position: relative;
    overflow: hidden;
}

.sm-featured-section .sm-featured-card::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 60%;
    height: 200%;
    background: rgba(255, 255, 255, 0.1);
    transform: rotate(-15deg);
    pointer-events: none;
}

.sm-featured-section .sm-featured-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sm-shadow-lg), 0 16px 48px rgba(233, 69, 96, 0.25);
}

.sm-featured-content {
    position: relative;
    z-index: 1;
}

.sm-featured-badge {
    display: inline-block;
    padding: var(--sm-space-1) var(--sm-space-3);
    background: rgba(255, 255, 255, 0.25);
    border-radius: var(--sm-radius-sm);
    font-size: var(--sm-fs-xs);
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: var(--sm-space-3);
    color: white;
}

.sm-featured-title {
    font-family: var(--sm-font-heading);
    font-size: clamp(var(--sm-fs-lg), 3vw, var(--sm-fs-3xl));
    font-weight: 700;
    letter-spacing: -0.02em;
    margin: 0 0 var(--sm-space-2);
    line-height: 1.15;
    color: white;
}

.sm-featured-description {
    font-size: var(--sm-fs-base);
    line-height: 1.6;
    margin: 0 0 var(--sm-space-5);
    max-width: 400px;
    color: rgba(255, 255, 255, 0.9);
}

.sm-featured-cta {
    display: inline-flex;
    align-items: center;
    gap: var(--sm-space-2);
    padding: var(--sm-space-3) var(--sm-space-5);
    background: var(--sm-surface);
    color: var(--sm-primary-hover);
    border-radius: var(--sm-radius-lg);
    font-weight: 600;
    font-size: var(--sm-fs-sm);
    transition: all var(--sm-transition);
}

.sm-featured-section .sm-featured-card:hover .sm-featured-cta {
    background: var(--sm-gray-50);
    gap: var(--sm-space-3);
}

.sm-featured-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 16px;
    transition: transform 250ms cubic-bezier(0.34, 1.56, 0.64, 1);
}

.sm-featured-icon svg {
    width: 32px;
    height: 32px;
    color: white;
    stroke-width: 1.5;
}

.sm-featured-section .sm-featured-card:hover .sm-featured-icon {
    transform: scale(1.1) rotate(-5deg);
}

@media (max-width: 768px) {
    .sm-featured-section .sm-featured-card {
        grid-template-columns: 1fr;
        text-align: center;
        padding: var(--sm-space-6);
    }

    .sm-featured-icon {
        width: 56px;
        height: 56px;
        order: -1;
    }

    .sm-featured-icon svg {
        width: 28px;
        height: 28px;
    }

    .sm-featured-description {
        max-width: none;
    }
}

/* --------------------------------------------------------------------------
   16.3 CALCULATOR CARDS - Clean White Grid
   -------------------------------------------------------------------------- */

.sm-calcs-section {
    padding: var(--sm-space-16) 0;
    background: var(--sm-gray-50);
}

.sm-section-header {
    text-align: center;
    margin-bottom: var(--sm-space-10);
}

.sm-section-label {
    display: inline-block;
    padding: var(--sm-space-1) var(--sm-space-3);
    background: var(--sm-primary-light);
    color: var(--sm-primary-hover);
    border-radius: var(--sm-radius-full);
    font-size: var(--sm-fs-xs);
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: var(--sm-space-3);
}

.sm-heading-section {
    font-family: var(--sm-font-heading);
    font-size: clamp(var(--sm-fs-2xl), 4vw, 2.5rem);
    font-weight: 700;
    line-height: 1.15;
    color: var(--sm-gray-800);
    letter-spacing: -0.02em;
    margin: 0 0 var(--sm-space-3);
}

.sm-section-header p {
    font-size: var(--sm-fs-lg);
    color: var(--sm-gray-400);
    margin: 0;
}

/* Card Grid */
.sm-cards-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sm-space-5);
}

.sm-calc-card {
    display: flex;
    flex-direction: column;
    padding: 28px;
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    text-decoration: none;
    color: inherit;
    transition: all 0.2s ease;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    cursor: pointer;
    position: relative;
    overflow: hidden;
}

/* Colored top border — cycles crimson/gold/green */
.sm-calc-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--sm-primary);
}

.sm-calc-card:nth-child(3n+2)::before {
    background: var(--sm-accent);
}

.sm-calc-card:nth-child(3n+3)::before {
    background: var(--sm-green);
}

.sm-calc-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

/* Card Icon — soft colored bg, cycles with card border */
.sm-calc-icon {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(233, 69, 96, 0.08);
    border-radius: 12px;
    margin-bottom: 16px;
    transition: all 0.2s ease;
}

.sm-calc-card:nth-child(3n+2) .sm-calc-icon {
    background: rgba(245, 166, 35, 0.12);
}

.sm-calc-card:nth-child(3n+3) .sm-calc-icon {
    background: rgba(46, 204, 113, 0.1);
}

.sm-calc-icon svg {
    width: 22px;
    height: 22px;
    color: var(--sm-primary);
    stroke-width: 1.5;
}

.sm-calc-card:nth-child(3n+2) .sm-calc-icon svg {
    color: #d4920a;
}

.sm-calc-card:nth-child(3n+3) .sm-calc-icon svg {
    color: var(--sm-green);
}

/* Card Content */
.sm-calc-title {
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-lg);
    font-weight: 600;
    color: var(--sm-gray-800);
    margin: 0 0 var(--sm-space-1);
    letter-spacing: -0.01em;
}

.sm-calc-tagline {
    font-size: var(--sm-fs-sm);
    font-weight: 500;
    color: var(--sm-primary-hover);
    margin: 0 0 var(--sm-space-3);
}

.sm-calc-description {
    font-size: var(--sm-fs-sm);
    color: var(--sm-gray-400);
    line-height: 1.6;
    margin: 0;
    flex-grow: 1;
}

.sm-calc-link {
    display: inline-flex;
    align-items: center;
    gap: var(--sm-space-2);
    margin-top: var(--sm-space-4);
    font-size: var(--sm-fs-sm);
    font-weight: 600;
    color: var(--sm-primary-hover);
    transition: gap var(--sm-transition);
}

.sm-calc-card:hover .sm-calc-link {
    gap: var(--sm-space-3);
}

/* Responsive Grid */
@media (max-width: 1024px) {
    .sm-cards-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .sm-cards-grid {
        grid-template-columns: 1fr;
        gap: var(--sm-space-4);
    }

    .sm-calc-card {
        padding: var(--sm-space-5);
    }
}

/* --------------------------------------------------------------------------
   16.4 HOW IT WORKS SECTION
   -------------------------------------------------------------------------- */

.sm-howit-section {
    padding: var(--sm-space-20) 0;
    background: var(--sm-surface);
}

.sm-steps-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sm-space-6);
    max-width: 900px;
    margin: 0 auto;
    position: relative;
}

/* Connecting line */
.sm-steps-grid::before {
    content: '';
    position: absolute;
    top: 44px;
    left: 18%;
    right: 18%;
    height: 2px;
    background: linear-gradient(90deg,
            var(--sm-gray-200) 0%,
            var(--sm-primary) 50%,
            var(--sm-gray-200) 100%);
    border-radius: var(--sm-radius-full);
}

.sm-step {
    text-align: center;
    position: relative;
    z-index: 1;
}

.sm-step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 88px;
    height: 88px;
    background: var(--sm-gray-50);
    border: 2px solid var(--sm-primary);
    border-radius: var(--sm-radius-xl);
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-2xl);
    font-weight: 700;
    color: var(--sm-primary-hover);
    margin-bottom: var(--sm-space-5);
    transition: all var(--sm-transition-slow);
}

.sm-step:hover .sm-step-number {
    background: var(--sm-primary);
    color: white;
    transform: scale(1.05);
    box-shadow: 0 8px 20px rgba(233, 69, 96, 0.3);
}

.sm-step-title {
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-lg);
    font-weight: 600;
    color: var(--sm-gray-800);
    margin: 0 0 var(--sm-space-2);
}

.sm-step-description {
    font-size: var(--sm-fs-sm);
    color: var(--sm-gray-400);
    line-height: 1.6;
    margin: 0;
    max-width: 240px;
    margin-left: auto;
    margin-right: auto;
}

@media (max-width: 768px) {
    .sm-steps-grid {
        grid-template-columns: 1fr;
        gap: var(--sm-space-8);
    }

    .sm-steps-grid::before {
        display: none;
    }
}

/* --------------------------------------------------------------------------
   16.5 DATA PLATFORM SECTION
   -------------------------------------------------------------------------- */

.sm-data-section {
    padding: var(--sm-space-20) 0;
    background: var(--sm-gray-50);
}

.sm-data-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--sm-space-4);
}

.sm-data-grid .sm-calc-card {
    background: var(--sm-surface);
    border: 1px solid var(--sm-gray-200);
}

.sm-data-grid .sm-calc-card .sm-calc-icon {
    background: var(--sm-gray-100);
    box-shadow: none;
}

.sm-data-grid .sm-calc-card:hover {
    border-color: var(--sm-primary);
}

.sm-data-grid .sm-calc-card .sm-calc-icon svg {
    color: var(--sm-gray-500);
}

.sm-data-grid .sm-calc-card:hover .sm-calc-icon {
    background: var(--sm-primary);
}

.sm-data-grid .sm-calc-card:hover .sm-calc-icon svg {
    color: white;
}

@media (max-width: 1024px) {
    .sm-data-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .sm-data-grid {
        grid-template-columns: 1fr;
    }
}

/* --------------------------------------------------------------------------
   16.6 FINAL CTA SECTION
   -------------------------------------------------------------------------- */

.sm-final-cta {
    padding: var(--sm-space-20) 0;
    background: var(--sm-navy);
    text-align: center;
    position: relative;
    overflow: hidden;
}

/* Decorative shapes */
.sm-final-cta::before {
    content: '';
    position: absolute;
    top: -100px;
    right: -100px;
    width: 300px;
    height: 300px;
    background: rgba(233, 69, 96, 0.1);
    border-radius: 50%;
}

.sm-final-cta::after {
    content: '';
    position: absolute;
    bottom: -150px;
    left: -150px;
    width: 400px;
    height: 400px;
    background: rgba(233, 69, 96, 0.05);
    border-radius: 50%;
}

.sm-final-cta .sm-container {
    position: relative;
    z-index: 1;
}

.sm-final-cta .sm-heading-section {
    color: white;
    margin-bottom: var(--sm-space-4);
}

.sm-final-cta .sm-text-body {
    color: var(--sm-gray-300);
    font-size: var(--sm-fs-lg);
    margin-bottom: var(--sm-space-8);
    max-width: 450px;
    margin-left: auto;
    margin-right: auto;
}

.sm-final-cta .sm-btn-primary {
    background: var(--sm-primary);
    color: white !important;
    padding: var(--sm-space-4) var(--sm-space-8);
    font-size: var(--sm-fs-lg);
}

.sm-final-cta .sm-btn-primary:hover {
    background: var(--sm-primary-hover);
    box-shadow: 0 12px 32px rgba(233, 69, 96, 0.4);
}

/* Hub sections - reduced mobile padding */
@media (max-width: 768px) {

    .sm-calcs-section,
    .sm-howit-section,
    .sm-data-section,
    .sm-final-cta {
        padding-top: var(--sm-space-10);
        padding-bottom: var(--sm-space-10);
    }
}

/* --------------------------------------------------------------------------
   16.7 FORM ICON HEADER - Calculator Form Top Section
   -------------------------------------------------------------------------- */

.sm-form-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sm-space-4);
    padding: var(--sm-space-6) var(--sm-space-8);
    background: var(--sm-gray-50);
    border-radius: var(--sm-radius-xl) var(--sm-radius-xl) 0 0;
    margin: calc(var(--sm-space-6) * -1);
    margin-bottom: var(--sm-space-6);
    text-align: center;
}

.sm-form-icon {
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sm-primary);
    border-radius: var(--sm-radius-lg);
    font-size: 28px;
    box-shadow: 0 4px 12px rgba(233, 69, 96, 0.25);
}

.sm-form-icon svg {
    width: 32px;
    height: 32px;
    color: white;
}

.sm-form-title {
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-xl);
    font-weight: 600;
    color: var(--sm-gray-800);
    margin: 0;
}

.sm-form-subtitle {
    font-size: var(--sm-fs-sm);
    color: var(--sm-gray-400);
    margin: 0;
}

/* --------------------------------------------------------------------------
   16.8 RESULT CARD - Crimson Accent
   -------------------------------------------------------------------------- */

.sm-result-card {
    background: linear-gradient(135deg, var(--sm-primary-light) 0%, #ffffff 100%);
    border: 2px solid rgba(233, 69, 96, 0.2);
    border-radius: var(--sm-radius-xl);
    padding: var(--sm-space-6);
}

.sm-result-card .sm-result-value {
    font-family: var(--sm-font-heading);
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--sm-primary-hover);
}

.sm-result-card .sm-result-label {
    font-size: var(--sm-fs-xs);
    font-weight: 600;
    color: var(--sm-gray-400);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* --------------------------------------------------------------------------
   16.9 PAGINATION
   -------------------------------------------------------------------------- */

.sm-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 18px;
    border-top: 2px solid var(--sm-border);
    font-size: 13px;
    color: var(--sm-text-muted);
}

.sm-pagination-btn {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    border: none;
    background: none;
    color: var(--sm-text-secondary);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.15s;
}

.sm-pagination-btn:hover {
    background: var(--sm-bg);
}

.sm-pagination-btn.active {
    background: var(--sm-primary);
    color: white;
}

/* --------------------------------------------------------------------------
   16.10 TEXT BODY UTILITY
   -------------------------------------------------------------------------- */

.sm-text-body {
    font-size: var(--sm-fs-lg);
    color: var(--sm-gray-400);
    line-height: 1.7;
}

/* --------------------------------------------------------------------------
   16.11 WELCOME BACK BANNER
   -------------------------------------------------------------------------- */

.sm-welcome-back {
    background: linear-gradient(135deg, var(--sm-primary-light) 0%, rgba(233, 69, 96, 0.06) 100%);
    border: 1px solid rgba(233, 69, 96, 0.15);
    border-radius: var(--sm-radius-lg);
    padding: var(--sm-space-4) var(--sm-space-6);
    margin-bottom: var(--sm-space-6);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sm-space-4);
    animation: slideDown 0.4s ease;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.sm-welcome-back-content {
    flex: 1;
}

.sm-welcome-back-title {
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-lg);
    font-weight: 600;
    color: var(--sm-gray-700);
    margin: 0 0 var(--sm-space-1);
}

.sm-welcome-back-text {
    font-size: var(--sm-fs-sm);
    color: var(--sm-gray-500);
    margin: 0;
}

.sm-welcome-back-actions {
    display: flex;
    gap: var(--sm-space-3);
    flex-shrink: 0;
}

.sm-welcome-back-btn {
    padding: var(--sm-space-2) var(--sm-space-4);
    border-radius: var(--sm-radius);
    font-size: var(--sm-fs-sm);
    font-weight: 500;
    transition: all var(--sm-transition);
    cursor: pointer;
    border: none;
}

.sm-welcome-back-continue {
    background: var(--sm-primary);
    color: white;
}

.sm-welcome-back-continue:hover {
    background: var(--sm-primary-hover);
}

.sm-welcome-back-dismiss {
    background: transparent;
    color: var(--sm-gray-400);
}

.sm-welcome-back-dismiss:hover {
    color: var(--sm-gray-600);
}

@media (max-width: 640px) {
    .sm-welcome-back {
        flex-direction: column;
        text-align: center;
    }

    .sm-welcome-back-actions {
        width: 100%;
        justify-content: center;
    }
}

/* --------------------------------------------------------------------------
   16.12 SHARE SECTION (Extended)
   -------------------------------------------------------------------------- */

.sm-share-section {
    margin-top: var(--sm-space-6);
    padding-top: var(--sm-space-6);
    border-top: 1px solid var(--sm-gray-200);
}

.sm-share-title {
    font-size: var(--sm-fs-sm);
    font-weight: 600;
    color: var(--sm-gray-500);
    margin-bottom: var(--sm-space-3);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.sm-share-buttons {
    display: flex;
    gap: var(--sm-space-3);
    flex-wrap: wrap;
}

.sm-share-btn-twitter {
    background: #000;
    border-color: #000;
    color: white !important;
}

.sm-share-btn-twitter:hover {
    background: var(--sm-navy);
    border-color: var(--sm-navy);
}

.sm-share-btn-challenge {
    background: var(--sm-primary);
    border-color: var(--sm-primary);
    color: white;
}

.sm-share-btn-challenge:hover {
    background: var(--sm-primary-hover);
    border-color: var(--sm-primary-hover);
}

.sm-share-copied {
    color: var(--sm-green-600);
    font-weight: 500;
}

/* Challenge Modal */
.sm-challenge-modal {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1000;
    padding: var(--sm-space-4);
}

.sm-challenge-card {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-xl);
    padding: var(--sm-space-6);
    max-width: 400px;
    width: 100%;
    text-align: center;
}

.sm-challenge-emoji {
    font-size: 48px;
    margin-bottom: var(--sm-space-4);
}

.sm-challenge-title {
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-xl);
    font-weight: 700;
    color: var(--sm-gray-700);
    margin-bottom: var(--sm-space-2);
}

.sm-challenge-link {
    background: var(--sm-gray-100);
    border-radius: var(--sm-radius);
    padding: var(--sm-space-3);
    font-size: var(--sm-fs-sm);
    color: var(--sm-gray-500);
    word-break: break-all;
    margin: var(--sm-space-4) 0;
}

/* --------------------------------------------------------------------------
   16.13 CELEBRATION EFFECTS
   -------------------------------------------------------------------------- */

.sm-confetti-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10000;
    overflow: hidden;
}

.sm-confetti-piece {
    position: absolute;
    top: -10px;
    width: 10px;
    height: 10px;
    border-radius: 2px;
    animation: confettiFall linear forwards;
}

@keyframes confettiFall {
    0% {
        transform: translateY(0) rotate(0deg);
        opacity: 1;
    }

    100% {
        transform: translateY(100vh) rotate(720deg);
        opacity: 0;
    }
}

.sm-celebration-toast {
    position: fixed;
    top: var(--sm-space-6);
    left: 50%;
    transform: translateX(-50%) translateY(-100px);
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    padding: var(--sm-space-4) var(--sm-space-6);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
    z-index: 10000;
    text-align: center;
    opacity: 0;
    transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.sm-celebration-toast.sm-celebration-show {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

.sm-celebration-elite {
    border: 2px solid var(--sm-primary);
    background: linear-gradient(135deg, var(--sm-primary-light) 0%, white 100%);
}

.sm-celebration-advanced {
    border: 2px solid var(--sm-green);
    background: linear-gradient(135deg, var(--sm-green-soft) 0%, white 100%);
}

.sm-celebration-title {
    display: block;
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-xl);
    font-weight: 700;
    color: var(--sm-gray-700);
    margin-bottom: var(--sm-space-1);
}

.sm-celebration-subtitle {
    display: block;
    font-size: var(--sm-fs-sm);
    color: var(--sm-gray-500);
}

/* --------------------------------------------------------------------------
   16.14 FORM VALIDATION FEEDBACK
   -------------------------------------------------------------------------- */

.sm-input-feedback {
    min-height: 20px;
    margin-top: var(--sm-space-1);
    font-size: var(--sm-fs-sm);
    transition: all var(--sm-transition);
}

.sm-feedback-positive {
    color: var(--sm-green-600);
}

.sm-feedback-warning {
    color: var(--sm-primary-hover);
}

.sm-feedback-neutral {
    color: var(--sm-gray-400);
}

.sm-input-valid {
    border-color: var(--sm-green);
}

.sm-input-warning {
    border-color: var(--sm-primary);
}

/* --------------------------------------------------------------------------
   16.15 PROGRESSIVE FORM ENHANCEMENTS
   -------------------------------------------------------------------------- */

.sm-progress-bar-form {
    height: 4px;
    background: var(--sm-gray-200);
    border-radius: 2px;
    margin-bottom: var(--sm-space-6);
    overflow: hidden;
}

.sm-progress-bar-form .sm-progress-fill-form {
    height: 100%;
    background: var(--sm-primary);
    border-radius: 2px;
    transition: width 0.5s ease;
}

.sm-form-step {
    animation: fadeInUp 0.4s ease;
}

.sm-expand-fields-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sm-space-2);
    padding: var(--sm-space-2) var(--sm-space-4);
    font-size: var(--sm-fs-sm);
    color: var(--sm-primary-hover);
    background: transparent;
    border: 1px dashed var(--sm-primary);
    border-radius: var(--sm-radius);
    cursor: pointer;
    transition: all var(--sm-transition);
}

.sm-expand-fields-btn:hover {
    background: var(--sm-primary-light);
    border-color: var(--sm-primary);
}

/* --------------------------------------------------------------------------
   16.16 CHALLENGE BANNER
   -------------------------------------------------------------------------- */

.sm-challenge-banner {
    background: linear-gradient(135deg, var(--sm-navy) 0%, var(--sm-gray-800) 100%);
    color: white;
    padding: var(--sm-space-4) var(--sm-space-6);
    border-radius: var(--sm-radius-lg);
    margin-bottom: var(--sm-space-6);
    display: flex;
    align-items: center;
    gap: var(--sm-space-4);
}

.sm-challenge-banner-emoji {
    font-size: 32px;
}

.sm-challenge-banner-text {
    font-size: var(--sm-fs-base);
    font-weight: 500;
}

.sm-challenge-banner-level {
    color: var(--sm-primary);
    font-weight: 700;
}

/* --------------------------------------------------------------------------
   16.17 RELATED CALCULATORS TRACKING
   -------------------------------------------------------------------------- */

.sm-related-card[data-track-from] {
    cursor: pointer;
}

/* --------------------------------------------------------------------------
   16.18 RESULT CARD ENHANCEMENTS
   -------------------------------------------------------------------------- */

.sm-result-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--sm-space-2);
    padding: var(--sm-space-1) var(--sm-space-3);
    background: var(--sm-primary-light);
    color: var(--sm-primary-hover);
    border-radius: var(--sm-radius-full);
    font-size: var(--sm-fs-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* Optional field label */
.sm-optional {
    font-weight: 400;
    color: var(--sm-gray-400);
    font-size: var(--sm-fs-sm);
}

/* --------------------------------------------------------------------------
   16.19 ANIMATIONS
   -------------------------------------------------------------------------- */

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.sm-animate-in {
    animation: fadeInUp 0.5s ease forwards;
}

/* Screen reader only */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* 16.20 FAQ hub overrides removed - styles consolidated into Section 8 (core FAQ) */

/* --------------------------------------------------------------------------
   16.21 SEO SECTION ENHANCEMENTS (Hub Page)
   -------------------------------------------------------------------------- */

.sm-seo-section h2 {
    font-family: var(--sm-font-heading);
    font-size: var(--sm-fs-xl);
    font-weight: 600;
    color: var(--sm-gray-700);
    margin: 0 0 var(--sm-space-4);
}

.sm-seo-section p {
    color: var(--sm-gray-500);
    line-height: 1.8;
    margin-bottom: var(--sm-space-4);
}

/* ==========================================================================
   17. DATA PAGE COMPONENTS
   Shared styles for SA-clone data pages: competitions, records, events, etc.
   Migrated from inline <style> blocks and sa-clone.css.
   ========================================================================== */

/* --------------------------------------------------------------------------
   17.1 TABS — use canonical .sm-tabs + .sm-tab from section 6 above.
   The .sm-tab-active alias maps to .sm-tab.active for templates using it.
   -------------------------------------------------------------------------- */

.sm-tabs-wrapper {
    margin-bottom: var(--sm-space-4);
}

.sm-tab-active {
    color: var(--sm-primary);
    border-bottom-color: var(--sm-primary);
}

.sm-tab-separator {
    display: flex;
    align-items: center;
    color: var(--sm-text-muted);
    font-size: 14px;
    padding: 0 6px;
    user-select: none;
    opacity: 0.4;
}

.sm-tab-icon {
    display: flex;
    align-items: center;
}

.sm-tab-icon svg {
    width: 18px;
    height: 18px;
}

@media (max-width: 640px) {
    .sm-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .sm-tabs::-webkit-scrollbar {
        display: none;
    }
}


/* --------------------------------------------------------------------------
   17.3 SORT INDICATORS
   -------------------------------------------------------------------------- */

.sm-th-sortable {
    display: inline-flex;
    align-items: center;
    gap: var(--sm-space-2);
    background: none;
    border: none;
    padding: 0;
    font: inherit;
    font-weight: 600;
    color: inherit;
    cursor: pointer;
    transition: color 0.15s ease;
}

.sm-th-sortable:hover {
    color: var(--sm-primary-hover);
}

.sm-sort-icons {
    display: inline-flex;
    flex-direction: column;
    gap: 1px;
    margin-left: 4px;
}

.sm-sort-asc,
.sm-sort-desc {
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    opacity: 0.3;
    transition: opacity 0.15s ease;
}

.sm-sort-asc {
    border-bottom: 5px solid currentColor;
}

.sm-sort-desc {
    border-top: 5px solid currentColor;
}

.sm-sort-asc.sm-sort-active,
.sm-sort-desc.sm-sort-active {
    opacity: 1;
}


.sm-contest-row {
    /* base row */
}

.sm-row-even {
    background: var(--sm-gray-50);
}

.sm-row-even:hover {
    background: var(--sm-primary-light);
}

/* Image column */
.sm-td-image {
    width: 60px;
    padding-right: 0;
}

.sm-contest-logo {
    width: 50px;
    height: 50px;
    border-radius: 10px;
    overflow: hidden;
    background: var(--sm-gray-100);
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--sm-border);
}

.sm-contest-logo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sm-logo-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--sm-gray-200), var(--sm-gray-100));
}

.sm-logo-placeholder svg {
    width: 24px;
    height: 24px;
    color: var(--sm-text-muted);
}

/* Contest name column */
.sm-td-contest {
    min-width: 250px;
}

.sm-contest-link {
    display: block;
    text-decoration: none;
    color: var(--sm-primary);
}

.sm-contest-link:hover {
    color: var(--sm-primary-hover);
    text-decoration: underline;
}

.sm-contest-link:hover .sm-contest-name {
    color: var(--sm-primary-hover);
}

.sm-contest-name {
    font-family: var(--sm-font-heading);
    font-size: 1rem;
    font-weight: 600;
    color: var(--sm-text-primary);
    margin: 0;
    transition: color 0.15s ease;
}

/* Count column */
.sm-td-count {
    text-align: center;
}

.sm-contest-count {
    display: inline-block;
    min-width: 32px;
    padding: 4px 10px;
    background: var(--sm-gray-100);
    border-radius: 4px;
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--sm-text-primary);
}

/* Recent date column */
.sm-td-recent {
    text-align: center;
}

.sm-recent-date {
    font-size: 0.875rem;
    color: var(--sm-text-secondary);
}

@media (max-width: 768px) {

    .sm-th-count,
    .sm-td-count {
        display: none;
    }

    .sm-contest-name {
        font-size: 0.875rem;
    }
}


/* --------------------------------------------------------------------------
   17.6 LOADING, ERROR, EMPTY STATES (Data Pages)
   -------------------------------------------------------------------------- */

.sm-loading--page {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--sm-space-16);
    gap: var(--sm-space-4);
    color: var(--sm-text-secondary);
}

.sm-loading-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid var(--sm-border);
    border-top-color: var(--sm-primary);
    border-radius: 50%;
    animation: sm-spin 0.8s linear infinite;
}

@keyframes sm-spin {
    to {
        transform: rotate(360deg);
    }
}

.sm-error--page {
    text-align: center;
    padding: var(--sm-space-8);
    color: var(--sm-error);
}

.sm-error--page p {
    margin: 0 0 var(--sm-space-4);
}

.sm-empty {
    text-align: center;
    padding: var(--sm-space-16);
    color: var(--sm-text-secondary);
}

.sm-empty p {
    margin: 0 0 var(--sm-space-4);
}

.sm-empty-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto var(--sm-space-4);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sm-gray-100);
    border-radius: 50%;
}

.sm-empty-icon svg {
    width: 32px;
    height: 32px;
    color: var(--sm-text-muted);
}

.sm-empty-row {
    text-align: center;
    color: var(--sm-text-muted);
    font-style: italic;
    padding: 30px;
}

/* Loading skeleton (shared) */
.sm-loading-skeleton {
    padding: 20px;
}

/* Duplicate .sm-skeleton removed - canonical definition is in Section 6 (line ~1950) using @keyframes sm-shimmer */

.sm-skeleton-table {
    min-height: 300px;
}

/* Error card (shared) */
.sm-error-card {
    text-align: center;
    padding: 30px;
    background: var(--sm-error-light);
    color: var(--sm-error);
    border: 1px solid var(--sm-error);
    margin: 20px;
    border-radius: 6px;
}

.sm-error-card p {
    margin: 0 0 15px;
}

.sm-error-heading {
    font-size: var(--sm-fs-lg);
    font-weight: var(--sm-weight-bold);
    margin: 0 0 6px;
}

.sm-error-body {
    font-size: var(--sm-fs-sm);
    color: var(--sm-text-secondary);
    margin: 0 0 15px;
}

/* --------------------------------------------------------------------------
   17.7 CONTEST DETAIL PAGE
   -------------------------------------------------------------------------- */

.sm-contest-detail {
    max-width: 1100px;
    margin: 0 auto;
    padding: var(--sm-space-4);
}

/* Contest header */
.sm-contest-header {
    background: linear-gradient(135deg, #f8f9fb 0%, #e8ecf1 100%);
    border: 1px solid #e8ecf1;
    border-radius: 14px;
    padding: var(--sm-space-6);
    margin-bottom: var(--sm-space-6);
}

.sm-contest-title {
    font-family: var(--sm-font-heading);
    font-size: clamp(1.5rem, 4vw, 2rem);
    font-weight: 700;
    color: var(--sm-navy);
    margin: 0 0 var(--sm-space-4) 0;
    line-height: 1.2;
}

.sm-contest-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sm-space-4) var(--sm-space-6);
}

.sm-contest-meta-item {
    display: flex;
    align-items: center;
    gap: var(--sm-space-2);
    font-size: var(--sm-fs-15);
}

.sm-meta-label {
    font-weight: 600;
    color: var(--sm-text-secondary);
}

.sm-meta-value {
    color: var(--sm-text-primary);
}

.sm-contest-type-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
}

.sm-type-international {
    background: rgba(233, 69, 96, 0.08);
    color: #c81e45;
}

.sm-type-national {
    background: rgba(46, 204, 113, 0.1);
    color: #1e8449;
}

.sm-type-regional {
    background: rgba(245, 166, 35, 0.15);
    color: #d4920a;
}

.sm-type-single-event {
    background: rgba(15, 52, 96, 0.1);
    color: var(--sm-electric);
}

@media (max-width: 768px) {
    .sm-contest-meta {
        flex-direction: column;
        gap: var(--sm-space-2);
    }
}

@media (max-width: 480px) {
    .sm-contest-title {
        font-size: 1.25rem;
    }

    .sm-contest-meta-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 0;
    }
}

/* --------------------------------------------------------------------------
   17.8 WINNER SPOTLIGHT
   -------------------------------------------------------------------------- */

.sm-winner-spotlight {
    background: linear-gradient(135deg, rgba(245, 166, 35, 0.12) 0%, rgba(245, 166, 35, 0.22) 100%);
    border: 2px solid #f5a623;
    border-radius: 14px;
    padding: var(--sm-space-5);
    margin-bottom: var(--sm-space-6);
}

.sm-winner-content {
    display: flex;
    align-items: center;
    gap: var(--sm-space-5);
}

.sm-winner-photo {
    flex-shrink: 0;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    overflow: hidden;
    background: var(--sm-surface);
    border: 3px solid #f5a623;
}

.sm-winner-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sm-winner-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #d4af37, #b8860b);
    color: white;
    font-size: 1.25rem;
    font-weight: 700;
}

.sm-winner-info {
    flex: 1;
}

.sm-winner-label {
    font-size: 0.8125rem;
    font-weight: 600;
    color: #d4920a;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--sm-space-1);
}

.sm-winner-name {
    font-family: var(--sm-font-heading);
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--sm-navy);
    margin: 0 0 var(--sm-space-2) 0;
}

.sm-winner-name a {
    color: inherit;
    text-decoration: none;
}

.sm-winner-name a:hover {
    color: var(--sm-primary-hover);
}

.sm-winner-flag {
    font-size: 1.125rem;
    margin-left: var(--sm-space-2);
}

.sm-winner-points {
    font-size: var(--sm-fs-15);
    color: var(--sm-text-primary);
}

@media (max-width: 768px) {
    .sm-winner-content {
        flex-direction: column;
        text-align: center;
    }

    .sm-winner-photo {
        margin: 0 auto;
    }

    .sm-winner-name {
        font-size: 1.125rem;
    }
}

/* --------------------------------------------------------------------------
   17.9 EVENTS SECTION (Contest Detail)
   -------------------------------------------------------------------------- */

.sm-events-section {
    background: var(--sm-surface);
    border: 1px solid #e8ecf1;
    border-radius: 14px;
    padding: var(--sm-space-5);
    margin-bottom: var(--sm-space-6);
}

.sm-section-title-data {
    font-family: var(--sm-font-heading);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--sm-navy);
    margin: 0 0 var(--sm-space-4) 0;
    padding-bottom: var(--sm-space-3);
    border-bottom: 2px solid #e8ecf1;
}

.sm-events-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.sm-event-item {
    display: flex;
    gap: var(--sm-space-3);
    padding: var(--sm-space-2) 0;
    border-bottom: 1px solid #f0f1f5;
}

.sm-event-item:last-child {
    border-bottom: none;
}

.sm-event-number {
    font-weight: 600;
    color: var(--sm-text-secondary);
    min-width: 24px;
}

.sm-event-name-detail {
    color: var(--sm-text-primary);
}

/* Results section wrapper */
.sm-results-section {
    background: var(--sm-surface);
    border: 1px solid #e8ecf1;
    border-radius: 14px;
    padding: var(--sm-space-5);
    margin-bottom: var(--sm-space-6);
}

/* Competing Athletes Grid (upcoming contests) */
.sm-competing-athletes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: var(--sm-space-3);
    margin-top: var(--sm-space-4);
}

.sm-competing-athlete-card {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3);
    padding: var(--sm-space-3) var(--sm-space-4);
    background: #f8f9fb;
    border: 1px solid #e8ecf1;
    border-radius: 8px;
    transition: background 0.15s ease;
}

.sm-competing-athlete-card:hover {
    background: #eef0f5;
}

.sm-competing-athlete-flag {
    font-size: 1.25rem;
    line-height: 1;
    flex-shrink: 0;
}

.sm-competing-athlete-name {
    font-weight: 600;
    color: var(--sm-text-primary);
    font-size: var(--sm-fs-15);
}

.sm-competing-athlete-country {
    margin-left: auto;
    font-size: 0.8125rem;
    color: var(--sm-text-secondary);
    white-space: nowrap;
}

@media (max-width: 480px) {
    .sm-competing-athletes-grid {
        grid-template-columns: 1fr;
    }
}

/* --------------------------------------------------------------------------
   17.10 LINK STYLES (Athlete & Contest)
   -------------------------------------------------------------------------- */

.sm-link-athlete {
    color: var(--sm-primary);
    text-decoration: none;
    font-weight: 500;
}

.sm-link-athlete:hover {
    color: var(--sm-primary-hover);
    text-decoration: underline;
}

.sm-link-contest {
    color: var(--sm-primary);
    text-decoration: none;
}

.sm-link-contest:hover {
    color: var(--sm-primary-hover);
    text-decoration: underline;
}

/* --------------------------------------------------------------------------
   17.11 COUNTRY CELL & FLAG
   -------------------------------------------------------------------------- */

.sm-country-cell {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.sm-flag {
    font-size: 1rem;
}

.sm-flag-img {
    width: 20px;
    height: 15px;
    object-fit: cover;
    border: 1px solid var(--sm-border);
    vertical-align: middle;
}

/* --------------------------------------------------------------------------
   17.12 PLACING BADGES
   -------------------------------------------------------------------------- */

.sm-placing {
    display: inline-block;
    min-width: 28px;
    padding: 2px 6px;
    text-align: center;
    font-weight: 600;
    border-radius: 4px;
    background: var(--sm-gray-100);
}

.sm-placing-1 {
    background: linear-gradient(135deg, rgba(245, 166, 35, 0.15), rgba(245, 166, 35, 0.25));
    color: #d4920a;
}

.sm-placing-2 {
    background: linear-gradient(135deg, #e8ecf1, #d1d9e0);
    color: var(--sm-text-primary);
}

.sm-placing-3 {
    background: linear-gradient(135deg, #fed7aa, #fdba74);
    color: #9a3412;
}

/* --------------------------------------------------------------------------
   17.13 EVENT-BY-EVENT RESULTS (Contest Detail)
   -------------------------------------------------------------------------- */

.sm-event-results-section {
    background: var(--sm-surface);
    border: 1px solid #e8ecf1;
    border-radius: 14px;
    padding: var(--sm-space-5);
    margin-bottom: var(--sm-space-6);
}

.sm-event-block {
    margin-bottom: var(--sm-space-5);
}

.sm-event-block:last-child {
    margin-bottom: 0;
}

.sm-event-block-heading {
    font-family: var(--sm-font-heading);
    font-size: 1rem;
    font-weight: 600;
    color: var(--sm-text-primary);
    margin: 0 0 var(--sm-space-3) 0;
    padding: var(--sm-space-2) var(--sm-space-3);
    background: #f8f9fb;
    border-radius: 4px;
    border-left: 3px solid var(--sm-primary);
}

.sm-event-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.sm-event-table thead tr {
    border-bottom: 2px solid #e8ecf1;
}

.sm-event-table thead th {
    background: transparent;
    font-weight: 600;
    color: var(--sm-text-secondary);
    padding: var(--sm-space-2) var(--sm-space-3);
    font-size: 0.8125rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.sm-event-table tbody td {
    padding: var(--sm-space-2) var(--sm-space-3);
    border-bottom: 1px solid #f0f1f5;
    vertical-align: middle;
}

.sm-event-table tbody tr:hover {
    background: #f8f9fb;
}

.sm-event-col-place {
    width: 50px;
    text-align: left;
}

.sm-event-col-athlete {
    text-align: left;
}

.sm-event-col-result {
    text-align: right;
    width: 120px;
    font-variant-numeric: tabular-nums;
}

.sm-event-col-points {
    text-align: right;
    width: 70px;
    font-variant-numeric: tabular-nums;
}

@media (max-width: 768px) {
    .sm-event-table {
        font-size: 0.8125rem;
    }

    .sm-event-col-result {
        width: 90px;
    }

    .sm-event-col-points {
        width: 55px;
    }
}

/* --------------------------------------------------------------------------
   17.14 ATTRIBUTION
   -------------------------------------------------------------------------- */

.sm-attribution {
    margin-top: var(--sm-space-6);
    padding-top: var(--sm-space-4);
    border-top: 1px solid #e8ecf1;
    text-align: center;
    font-size: 0.8125rem;
    color: var(--sm-text-secondary);
}

.sm-attribution a {
    color: var(--sm-primary-hover);
}

.sm-last-updated {
    display: block;
    margin-top: var(--sm-space-1);
}

/* --------------------------------------------------------------------------
   17.15 CONTROLS ROW (Search + Division Filter)
   -------------------------------------------------------------------------- */

.sm-controls-row {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

.sm-search-box {
    position: relative;
    flex: 1;
    min-width: 220px;
}

.sm-search-icon {
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--sm-text-muted);
    pointer-events: none;
}

.sm-search-clear {
    position: absolute;
    right: 6px;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    border: none;
    background: transparent;
    color: var(--sm-text-muted);
    font-size: 18px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    line-height: 1;
}

.sm-search-clear:hover {
    color: var(--sm-text-primary);
}

/* Division / filter button group (tab-style per mockup) */
.sm-division-filter {
    display: flex;
    align-items: center;
    gap: 2px;
    flex-shrink: 0;
    border-bottom: 2px solid var(--sm-border);
    margin-bottom: 20px;
    padding: 0;
}

.sm-division-label {
    font-size: 14px;
    font-weight: 600;
    color: var(--sm-text-primary);
    margin-right: 4px;
}

/* Filter buttons (Men/Women/All divisions) — matches mockup tab style */
.sm-filter-btn {
    padding: 8px 16px;
    font-family: inherit;
    font-size: 14px;
    font-weight: 600;
    color: var(--sm-text-muted);
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    transition: all 0.15s;
}

.sm-filter-btn:hover {
    color: var(--sm-text-primary);
}

.sm-filter-btn-active,
.sm-filter-btn-active:hover {
    color: var(--sm-primary);
    border-bottom-color: var(--sm-primary);
}

/* Duplicate .sm-division-filter removed - canonical definition is above (~line 7860) */

/* --------------------------------------------------------------------------
   17.16 FILTER TABS (Records Page)
   -------------------------------------------------------------------------- */

.sm-filter-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    padding: 0 20px;
    background: transparent;
    border-bottom: 2px solid var(--sm-border);
}

.sm-filter-tab {
    padding: 10px 16px;
    margin-bottom: -2px;
    font-family: inherit;
    font-size: 14px;
    font-weight: 600;
    color: var(--sm-text-muted);
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    transition: all 0.15s ease;
}

.sm-filter-tab:hover {
    color: var(--sm-text-primary);
    background: transparent;
}

.sm-filter-tab-active,
.sm-filter-tab-active:hover {
    color: var(--sm-primary);
    background: transparent;
    border-bottom-color: var(--sm-primary);
}

.sm-filter-tab:focus {
    outline: 2px solid var(--sm-primary);
    outline-offset: 1px;
}

.sm-filter-tabs .sm-tab-count {
    font-size: 11px;
    opacity: 0.8;
    margin-left: 2px;
}

@media (max-width: 768px) {
    .sm-filter-tabs {
        padding: 0 15px;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .sm-filter-tab {
        padding: 8px 12px;
        font-size: 13px;
        white-space: nowrap;
    }
}

@media (max-width: 480px) {
    .sm-filter-tabs {
        padding: 0 10px;
    }

    .sm-filter-tab {
        padding: 8px 10px;
        font-size: 12px;
    }
}

/* --------------------------------------------------------------------------
   17.17 TABLE CELL VARIANTS (Records, Events)
   -------------------------------------------------------------------------- */

.sm-td-record {
    font-weight: 600;
    color: var(--sm-text-primary);
    min-width: 200px;
}

.sm-td-athlete {
    min-width: 150px;
}

.sm-td-country {
    min-width: 120px;
}

.sm-td-value {
    font-weight: bold;
    color: var(--sm-primary);
    white-space: nowrap;
    min-width: 100px;
}

.sm-td-contest {
    min-width: 150px;
}

.sm-td-date {
    white-space: nowrap;
    color: var(--sm-text-secondary);
}

.sm-td-params {
    max-width: 200px;
    font-size: 12px;
    color: var(--sm-text-secondary);
}

.sm-td-location {
    min-width: 120px;
    font-size: 12px;
    color: var(--sm-text-secondary);
}

.sm-params {
    display: inline-block;
}

.sm-no-data {
    color: var(--sm-text-muted);
}

.sm-record-row {
    /* base class for table rows */
}

.sm-value {
    /* inline value display */
}

@media (max-width: 768px) {
    .sm-td-record {
        min-width: 150px;
    }
}

/* --------------------------------------------------------------------------
   17.18 SECTION HEADERS (Records Page)
   -------------------------------------------------------------------------- */

.sm-section-header-sa {
    background: var(--sm-gray-50);
    border-bottom: 1px solid var(--sm-border);
    padding: 15px 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.sm-section-title-sa {
    font-family: inherit;
    font-size: 18px;
    font-weight: bold;
    color: var(--sm-text-primary);
    margin: 0;
}

.sm-section-count {
    font-size: 13px;
    color: var(--sm-text-secondary);
}

.sm-records-section {
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: 6px;
    overflow: hidden;
}

.sm-records-page {
    display: flex;
    flex-direction: column;
    gap: 40px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px 0;
}

.sm-table-container-sa {
    overflow-x: auto;
}

@media (max-width: 768px) {
    .sm-records-page {
        gap: 20px;
        padding: 10px 0;
    }

    .sm-section-header-sa {
        padding: 12px 15px;
    }

    .sm-section-title-sa {
        font-size: 16px;
    }
}

/* --------------------------------------------------------------------------
   17.19 CTA CARD (Records → Events link)
   -------------------------------------------------------------------------- */

.sm-cta-card {
    margin-top: -20px;
}

.sm-cta-link {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 20px;
    background: var(--sm-surface);
    border: 2px solid #e9e9e9;
    border-radius: 6px;
    text-decoration: none;
    color: var(--sm-text-primary);
    transition: all 0.15s ease;
}

.sm-cta-link:hover {
    border-color: var(--sm-primary);
    background: #f8fbff;
    text-decoration: none;
    color: var(--sm-text-primary);
}

.sm-cta-icon {
    flex-shrink: 0;
    color: var(--sm-primary);
}

.sm-cta-text {
    flex: 1;
}

.sm-cta-text strong {
    display: block;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 1px;
}

.sm-cta-text span {
    font-size: 12px;
    color: #777;
}

/* ========================================================================
   AUTH CTA (visitors only - contextual sign-up prompt)
   ======================================================================== */
.sm-auth-cta {
    margin: var(--sm-space-6) 0;
}
.sm-auth-cta-inner {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px 24px;
    background: linear-gradient(135deg, #f0f4ff 0%, #fdf2f4 100%);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius-lg);
}
.sm-auth-cta-icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: var(--sm-primary);
    color: #fff;
    border-radius: var(--sm-radius-full);
}
.sm-auth-cta-content {
    flex: 1;
    min-width: 0;
}
.sm-auth-cta-content strong {
    display: block;
    font-size: 15px;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin-bottom: 2px;
}
.sm-auth-cta-content p {
    font-size: 13px;
    color: var(--sm-text-secondary);
    margin: 0;
    line-height: 1.4;
}
.sm-auth-cta-actions {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}
.strongman-app .sm-auth-cta-login {
    font-size: 12px;
    color: var(--sm-text-muted);
    text-decoration: none;
    white-space: nowrap;
}
.strongman-app .sm-auth-cta-login:hover {
    color: var(--sm-primary);
    text-decoration: underline;
}
@media (max-width: 640px) {
    .sm-auth-cta-inner {
        flex-direction: column;
        text-align: center;
        padding: 20px 16px;
    }
    .sm-auth-cta-actions {
        width: 100%;
    }
    .sm-auth-cta-actions .sm-btn {
        width: 100%;
    }
}

/* --------------------------------------------------------------------------
   17.20 FILTER CONTROLS (Events Category Page)
   -------------------------------------------------------------------------- */

.sm-event-filters {
    display: flex;
    gap: 16px;
    padding: 0 0 16px;
    flex-wrap: wrap;
}

.sm-filter-group {
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Stats bar above table */
.sm-stats-bar {
    display: flex;
    justify-content: space-between;
    padding: 10px 15px;
    background: var(--sm-gray-50);
    border: 1px solid var(--sm-border);
    border-bottom: none;
    border-radius: 6px 6px 0 0;
    font-size: 13px;
    color: var(--sm-text-secondary);
}

/* --------------------------------------------------------------------------
   17.21 NAVIGATION LINKS (Events Category Page)
   -------------------------------------------------------------------------- */

.sm-data-nav-links {
    display: flex;
    justify-content: space-between;
    padding: 16px 0;
    margin-top: 8px;
}

.sm-data-nav-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    color: var(--sm-primary);
    text-decoration: none;
    transition: color 0.15s;
}

.sm-data-nav-link:hover {
    color: var(--sm-primary-hover);
    text-decoration: underline;
}

/* --------------------------------------------------------------------------
   17.22 EVENT HISTORY PAGE
   -------------------------------------------------------------------------- */

.sm-event-history-page {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px 0;
}

@media (max-width: 768px) {
    .sm-event-history-page {
        padding: 10px 0;
    }
}



/* --------------------------------------------------------------------------
   17.25 PAGE HEADER (Events Category variant)
   -------------------------------------------------------------------------- */

.sm-data-page-header {
    max-width: 1200px;
    margin: 0 auto;
    padding: 30px 0 10px;
}

.sm-data-page-title {
    font-family: inherit;
    font-size: 28px;
    font-weight: bold;
    color: var(--sm-text-primary);
    margin: 0 0 8px;
}

.sm-data-page-description {
    font-size: 15px;
    color: var(--sm-text-secondary);
    margin: 0;
}

@media (max-width: 768px) {
    .sm-data-page-header {
        padding: 20px 0 8px;
    }

    .sm-data-page-title {
        font-size: 22px;
    }
}

/* --------------------------------------------------------------------------
   17.26 COUNTRY (inline display for contest detail)
   -------------------------------------------------------------------------- */

.sm-country {
    display: inline-flex;
    align-items: center;
    gap: var(--sm-space-1);
}

/* ==========================================================================
   18. EVENTS INDEX GRID
   ========================================================================== */

.strongman-app .sm-events-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sm-space-4);
    margin-top: var(--sm-space-6);
}

.strongman-app .sm-event-card {
    display: flex;
    align-items: center;
    gap: var(--sm-space-4);
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-md);
    padding: var(--sm-space-4) var(--sm-space-5);
    text-decoration: none;
    color: inherit;
    transition: box-shadow 0.2s, transform 0.2s;
}

.strongman-app .sm-event-card:hover {
    box-shadow: var(--sm-shadow-md);
    transform: translateY(-2px);
}

.strongman-app .sm-event-card-icon {
    width: 48px;
    height: 48px;
    min-width: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sm-primary-soft);
    border-radius: var(--sm-radius-sm);
    color: var(--sm-primary);
}

.strongman-app .sm-event-card-icon svg {
    width: 24px;
    height: 24px;
}

.strongman-app .sm-event-card-body {
    flex: 1;
    min-width: 0;
}

.strongman-app .sm-event-card-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0 0 2px;
}

.strongman-app .sm-event-card-desc {
    font-size: 0.875rem;
    color: var(--sm-text-muted);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin: 0;
}

.strongman-app .sm-event-card-count {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--sm-primary);
    background: var(--sm-primary-light);
    padding: 2px 8px;
    border-radius: 999px;
    white-space: nowrap;
}

.strongman-app .sm-event-card-arrow {
    color: var(--sm-text-muted);
    transition: transform 0.2s;
    flex-shrink: 0;
}

.strongman-app .sm-event-card:hover .sm-event-card-arrow {
    transform: translateX(3px);
    color: var(--sm-primary);
}

@media (max-width: 1024px) {
    .strongman-app .sm-events-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .strongman-app .sm-events-grid {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   18.5 TOP LISTS HUB
   ========================================================================== */

.sm-tl-skeleton {
    min-height: 400px;
}

.sm-tl-skel-icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    margin-bottom: 12px;
}

.sm-tl-skel-title {
    width: 70%;
    height: 20px;
    margin-bottom: 8px;
}

.sm-tl-skel-desc {
    width: 90%;
    height: 14px;
}

.sm-tl-skeleton-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 28px 20px;
}

.sm-tl-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 28px 20px 36px;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.sm-tl-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
}

.sm-tl-card-icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--sm-accent) 0%, var(--sm-accent-hover, #d4920a) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
    flex-shrink: 0;
}

.sm-tl-card-icon svg {
    width: 26px;
    height: 26px;
    color: #fff;
    stroke: #fff;
    fill: none;
}

.sm-tl-card-title {
    font-size: 1.05rem;
    font-weight: 700;
    margin: 0 0 6px;
    color: var(--sm-text-primary);
    line-height: 1.3;
}

.sm-tl-card-desc {
    font-size: 0.85rem;
    color: var(--sm-text-muted);
    margin: 0;
    line-height: 1.5;
}

.sm-tl-card-badge {
    position: absolute;
    top: 12px;
    right: 12px;
    background: var(--sm-accent);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 99px;
    letter-spacing: 0.02em;
}

/* ==========================================================================
   19. SERIES GRID
   ========================================================================== */

.strongman-app .sm-series-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sm-space-4);
    margin-top: var(--sm-space-6);
}

.strongman-app .sm-series-card {
    display: block;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    min-height: 140px;
    border-left: 3px solid var(--sm-primary);
    border-radius: var(--sm-radius-md);
    padding: var(--sm-space-5);
    text-decoration: none;
    color: inherit;
    transition: box-shadow 0.2s, transform 0.2s;
}

.strongman-app .sm-series-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--sm-shadow-md);
}

.strongman-app .sm-series-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sm-space-3);
    margin-bottom: var(--sm-space-2);
}

.strongman-app .sm-series-card-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.strongman-app .sm-series-card-count {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--sm-primary);
    background: var(--sm-primary-light);
    padding: 2px 10px;
    border-radius: 999px;
    white-space: nowrap;
}

.strongman-app .sm-series-card-desc {
    font-size: 0.875rem;
    color: var(--sm-text-muted);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin: 0 0 var(--sm-space-3);
}

.strongman-app .sm-series-card-meta {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3);
    color: var(--sm-text-muted);
    font-size: 0.8125rem;
}

.strongman-app .sm-series-card-years {
    font-size: 0.8125rem;
}

.strongman-app .sm-series-card-arrow {
    margin-left: auto;
    color: var(--sm-text-muted);
    transition: transform 0.2s;
}

.strongman-app .sm-series-card:hover .sm-series-card-arrow {
    transform: translateX(3px);
    color: var(--sm-primary);
}

@media (max-width: 768px) {
    .strongman-app .sm-series-grid {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   20. COMPARE PAGE (see "Compare UI" section below for full styles)
   ========================================================================== */

/* ==========================================================================
   21. WOMEN'S STATS STRIP
   ========================================================================== */

.strongman-app .sm-women-stats {
    margin: var(--sm-space-6) 0;
}

.strongman-app .sm-stats-row {
    display: flex;
    gap: 1px;
    background: var(--sm-border);
    border-radius: var(--sm-radius-md);
    overflow: hidden;
}

.strongman-app .sm-stat {
    flex: 1;
    background: var(--sm-surface);
    padding: var(--sm-space-4) var(--sm-space-3);
    text-align: center;
}

.strongman-app .sm-stat-number {
    font-size: 1.875rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
    line-height: 1.2;
}

.strongman-app .sm-stat-number.highlight {
    color: var(--sm-primary);
}

.strongman-app .sm-stat-label {
    font-size: 0.75rem;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 2px;
}

@media (max-width: 640px) {
    .strongman-app .sm-stats-row {
        flex-wrap: wrap;
    }

    .strongman-app .sm-stat {
        min-width: 45%;
    }
}

/* ==========================================================================
   22. RANKINGS PAGE
   ========================================================================== */

.strongman-app .sm-rankings-page {
    margin-top: var(--sm-space-4);
}

/* .sm-rankings-tabs / .sm-rankings-tab removed — now uses canonical .sm-tabs / .sm-tab */

.strongman-app .sm-rankings-table-wrap {
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-md);
    overflow: hidden;
}

.strongman-app .sm-rank-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 28px;
    padding: 0 6px;
    border-radius: 6px;
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--sm-text-secondary);
    gap: 2px;
}

.strongman-app .sm-rank-1 {
    background: linear-gradient(135deg, var(--sm-gold), var(--sm-gold-end));
    color: var(--sm-gold-text);
}

.strongman-app .sm-rank-2 {
    background: linear-gradient(135deg, var(--sm-silver), var(--sm-silver-end));
    color: var(--sm-silver-text);
}

.strongman-app .sm-rank-3 {
    background: linear-gradient(135deg, var(--sm-bronze), var(--sm-bronze-end));
    color: var(--sm-bronze-text);
}

/* --- Calendar Page --- */

.strongman-app .sm-year-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--sm-space-3);
    margin-bottom: var(--sm-space-6);
}

.strongman-app .sm-year-selector {
    display: flex;
    align-items: center;
    gap: var(--sm-space-2);
    flex-wrap: wrap;
    justify-content: center;
}

.strongman-app .sm-year-pill {
    padding: var(--sm-space-2) var(--sm-space-4);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-full);
    background: var(--sm-bg);
    color: var(--sm-text-secondary);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s ease;
    line-height: 1;
}

.strongman-app .sm-year-pill:hover {
    border-color: var(--sm-primary);
    color: var(--sm-primary);
}

.strongman-app .sm-year-active {
    background: var(--sm-primary);
    color: #fff;
    border-color: var(--sm-primary);
    font-weight: 700;
}

.strongman-app .sm-year-btn {
    flex-shrink: 0;
}

.strongman-app .sm-calendar-stats {
    font-size: 0.9rem;
    color: var(--sm-text-secondary);
    margin-bottom: var(--sm-space-4);
}

.strongman-app .sm-calendar-stats-filter {
    color: var(--sm-text-muted);
}

.strongman-app .sm-calendar-month {
    margin-bottom: var(--sm-space-8);
}

.strongman-app .sm-month-header {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin-bottom: var(--sm-space-4);
    padding-bottom: var(--sm-space-3);
    border-bottom: 2px solid var(--sm-border);
}

.strongman-app .sm-month-count {
    display: inline-flex;
    align-items: center;
    padding: 2px 10px;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: var(--sm-radius-full);
    background: var(--sm-primary-light);
    color: var(--sm-primary);
}

.strongman-app .sm-calendar-grid {
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-3);
}

.strongman-app .sm-calendar-card {
    display: flex;
    align-items: flex-start;
    gap: var(--sm-space-4);
    padding: var(--sm-space-4);
    background: var(--sm-bg);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-lg);
    transition: box-shadow 0.15s ease;
}

.strongman-app .sm-calendar-card:hover {
    box-shadow: var(--sm-shadow-md);
}

.strongman-app .sm-calendar-date-badge {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-width: 52px;
    padding: var(--sm-space-2) var(--sm-space-3);
    background: var(--sm-primary);
    color: #fff;
    border-radius: var(--sm-radius-md);
    line-height: 1;
    flex-shrink: 0;
}

.strongman-app .sm-calendar-day {
    font-size: 1.25rem;
    font-weight: var(--sm-weight-extrabold);
}

.strongman-app .sm-calendar-month-short {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.strongman-app .sm-calendar-info {
    flex: 1;
    min-width: 0;
}

.strongman-app .sm-calendar-name {
    font-weight: 600;
    font-size: 1rem;
    color: var(--sm-primary);
    text-decoration: none;
}

.strongman-app .sm-calendar-name:hover {
    text-decoration: underline;
}

.strongman-app .sm-calendar-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sm-space-3);
    margin-top: var(--sm-space-2);
    font-size: 0.85rem;
    color: var(--sm-text-secondary);
}

.strongman-app .sm-calendar-location {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.strongman-app .sm-calendar-details {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sm-space-3);
    margin-top: var(--sm-space-2);
    font-size: 0.85rem;
    color: var(--sm-text-secondary);
}

.strongman-app .sm-calendar-actions {
    display: flex;
    align-items: center;
    gap: var(--sm-space-2);
    flex-shrink: 0;
}

/* Badge small variant */
.strongman-app .sm-badge-small {
    padding: 1px 8px;
    font-size: 0.7rem;
}

.strongman-app .sm-badge-outline {
    background: transparent;
    border: 1px solid var(--sm-border);
    color: var(--sm-text-secondary);
}

.strongman-app .sm-badge-upcoming {
    background: var(--sm-color-warning, #f59e0b);
    color: #fff;
    font-weight: 600;
}

/* Upcoming contest card highlight */
.strongman-app .sm-calendar-card-upcoming {
    border-left: 3px solid var(--sm-color-warning, #f59e0b);
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.03) 0%, var(--sm-bg) 100%);
}

/* Date range display */
.strongman-app .sm-calendar-date-range {
    font-size: 0.65rem;
    font-weight: 500;
    opacity: 0.85;
    margin-top: 2px;
}

/* Calendar details icons */
.strongman-app .sm-calendar-details span {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

/* Events preview pills */
.strongman-app .sm-calendar-events-preview {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: var(--sm-space-2);
}

.strongman-app .sm-calendar-event-pill {
    display: inline-block;
    padding: 2px 8px;
    font-size: 0.7rem;
    background: var(--sm-bg-secondary, #f3f4f6);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-full, 9999px);
    color: var(--sm-text-secondary);
    white-space: nowrap;
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.strongman-app .sm-calendar-event-more {
    font-size: 0.7rem;
    color: var(--sm-text-muted, #9ca3af);
    padding: 2px 4px;
}

/* Calendar responsive */
@media (max-width: 640px) {
    .strongman-app .sm-calendar-card {
        flex-direction: column;
        gap: var(--sm-space-3);
    }

    .strongman-app .sm-calendar-date-badge {
        flex-direction: row;
        gap: var(--sm-space-2);
        min-width: auto;
    }

    .strongman-app .sm-calendar-actions {
        width: 100%;
    }

    .strongman-app .sm-calendar-actions .sm-btn {
        flex: 1;
        justify-content: center;
    }

    .strongman-app .sm-year-selector {
        gap: 4px;
    }

    .strongman-app .sm-year-pill {
        padding: var(--sm-space-1) var(--sm-space-3);
        font-size: 0.8rem;
    }
}

/* --- Women's Stats --- */

.strongman-app .sm-women-stats {
    margin-bottom: var(--sm-space-8);
}

/* ==========================================================================
   20. SHARED UTILITIES
   ========================================================================== */

/* --- Loading Overlay --- */
.strongman-app .sm-loading-overlay {
    position: absolute;
    inset: 0;
    background: rgba(255, 255, 255, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    border-radius: var(--sm-radius-lg);
}

/* --- Empty State Card --- */
.strongman-app .sm-empty-state-card {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    padding: 48px 24px;
    text-align: center;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.strongman-app .sm-empty-state-card p {
    color: var(--sm-text-muted);
    font-size: 15px;
    margin-top: 8px;
}

/* --- Flag (Tiny) --- */
.strongman-app .sm-flag-tiny {
    width: 16px;
    height: 12px;
    border-radius: 2px;
    object-fit: cover;
    vertical-align: middle;
}

/* --- Input with Icon --- */
.strongman-app .sm-input-with-icon {
    position: relative;
}

.strongman-app .sm-input-with-icon input {
    padding-left: 36px;
}

.strongman-app .sm-input-with-icon svg {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    color: var(--sm-text-muted);
    pointer-events: none;
}

/* --- Ghost Button --- */
.strongman-app .sm-btn-ghost {
    background: transparent;
    color: var(--sm-primary);
    border: none;
    padding: 8px 12px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    border-radius: var(--sm-radius);
    transition: background 0.15s;
    font-family: inherit;
}

.strongman-app .sm-btn-ghost:hover {
    background: rgba(233, 69, 96, 0.08);
}

/* --- Location Display --- */
.strongman-app .sm-location {
    display: flex;
    align-items: center;
    gap: 6px;
}

.strongman-app .sm-location-flag {
    width: 20px;
    height: 15px;
    border-radius: 2px;
    object-fit: cover;
    flex-shrink: 0;
}

.strongman-app .sm-location-text {
    color: var(--sm-text-secondary);
}

/* --- Final CTA Content --- */
.strongman-app .sm-final-cta-content {
    padding: 40px 20px;
    text-align: center;
}


/* =========================================================================
   MOCKUP OVERRIDES — Events, Series, Compare, Stats, Rankings, Calendar, GOAT
   Appended to override older token-based rules with mockup-accurate values
   ========================================================================= */

/* --- Events Grid (overrides) --- */
.strongman-app .sm-events-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.strongman-app .sm-event-card {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    padding: 20px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04), 0 4px 12px rgba(0, 0, 0, 0.03);
    transition: all 0.2s;
    text-decoration: none;
    color: inherit;
    border: none;
}

.strongman-app .sm-event-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.strongman-app .sm-event-card-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: rgba(233, 69, 96, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--sm-primary);
}

.strongman-app .sm-event-card-icon svg {
    width: 24px;
    height: 24px;
}

.strongman-app .sm-event-card-body {
    flex: 1;
    min-width: 0;
}

.strongman-app .sm-event-card-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--sm-navy);
    margin-bottom: 4px;
    letter-spacing: -0.01em;
}

.strongman-app .sm-event-card-desc {
    font-size: 14px;
    color: var(--sm-text-secondary);
    line-height: 1.5;
}

.strongman-app .sm-event-card-count {
    display: inline-flex;
    padding: 2px 10px;
    font-size: 12px;
    font-weight: 700;
    background: rgba(233, 69, 96, 0.08);
    color: var(--sm-primary);
    border-radius: 999px;
    margin-top: 8px;
}

.strongman-app .sm-event-card-arrow {
    color: var(--sm-text-muted);
    transition: color 0.15s;
    flex-shrink: 0;
    margin-top: 2px;
}

.strongman-app .sm-event-card:hover .sm-event-card-arrow {
    color: var(--sm-primary);
}

@media (max-width: 1024px) {
    .strongman-app .sm-events-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .strongman-app .sm-events-grid {
        grid-template-columns: 1fr;
    }
}


/* --- Compare UI --- */
.strongman-app .sm-compare-page {}

.strongman-app .sm-compare-selectors {
    display: flex;
    gap: 24px;
    align-items: flex-start;
    margin-bottom: 24px;
}

.strongman-app .sm-compare-selector {
    flex: 1;
    position: relative;
}

.strongman-app .sm-compare-label {
    font-size: 12px;
    font-weight: 700;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 8px;
}

.strongman-app .sm-compare-search {
    width: 100%;
    padding: 10px 14px;
    font-size: 14px;
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius);
    background: var(--sm-surface);
    outline: none;
    font-family: inherit;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.strongman-app .sm-compare-search:focus {
    border-color: var(--sm-primary);
    box-shadow: 0 0 0 3px rgba(233, 69, 96, 0.08);
}

.strongman-app .sm-compare-selected {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    background: var(--sm-surface);
    border: 2px solid var(--sm-primary);
    border-radius: var(--sm-radius);
}

.strongman-app .sm-compare-clear {
    margin-left: auto;
    background: none;
    border: none;
    color: var(--sm-text-muted);
    cursor: pointer;
    font-size: 18px;
}

.strongman-app .sm-compare-clear:hover {
    color: var(--sm-primary);
}

.strongman-app .sm-compare-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
    z-index: 50;
    max-height: 240px;
    overflow-y: auto;
    margin-top: 4px;
}

.strongman-app .sm-compare-dropdown-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    cursor: pointer;
    transition: background 0.1s;
    font-size: 14px;
    background: var(--sm-surface);
    color: var(--sm-navy);
    border: none;
    width: 100%;
    text-align: left;
    font-family: inherit;
}

.strongman-app .sm-compare-dropdown-item:hover {
    background: var(--sm-bg);
    color: var(--sm-primary);
}

.strongman-app .sm-compare-vs {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--sm-navy);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: var(--sm-weight-extrabold);
    flex-shrink: 0;
    align-self: center;
}

.strongman-app .sm-compare-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    margin-bottom: 32px;
}

.strongman-app .sm-compare-card {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04), 0 4px 12px rgba(0, 0, 0, 0.03);
    text-align: center;
    border: 2px solid transparent;
    padding: 0;
    transition: border-color 0.2s;
}

.strongman-app .sm-compare-card.sm-compare-card--winner {
    border-color: var(--sm-primary);
}

.strongman-app .sm-compare-card-photo {
    height: 200px;
    background: linear-gradient(135deg, var(--sm-navy) 0%, #0f3460 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.strongman-app .sm-compare-photo {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid rgba(255, 255, 255, 0.3);
}

.strongman-app .sm-compare-photo-fallback {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 36px;
    font-weight: 700;
    margin: 0;
}

.strongman-app .sm-compare-card-name {
    font-size: 20px;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-navy);
    padding: 16px 20px 4px;
}

.strongman-app .sm-compare-card-name a {
    color: inherit;
    text-decoration: none;
    transition: color 0.15s;
}

.strongman-app .sm-compare-card-name a:hover {
    color: var(--sm-primary);
}

.strongman-app .sm-compare-card-meta {
    font-size: 13px;
    color: var(--sm-text-muted);
    padding: 0 20px 8px;
    display: flex;
    align-items: center;
    gap: 6px;
    justify-content: center;
}

/* Win rate badge on athlete cards */
.strongman-app .sm-compare-card-winrate {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 12px;
    margin-bottom: 16px;
    font-size: 12px;
    font-weight: 700;
    border-radius: 999px;
    background: rgba(233, 69, 96, 0.08);
    color: var(--sm-primary);
}

.strongman-app .sm-compare-dropdown-country {
    margin-left: auto;
    font-size: 12px;
    color: var(--sm-text-muted);
    text-transform: uppercase;
}

.strongman-app .sm-compare-better {
    font-weight: 700;
    color: #16a34a;
}

/* Stats Table */
.strongman-app .sm-compare-stats-section {
    margin-bottom: 32px;
}

.strongman-app .sm-compare-stats-table {
    width: 100%;
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    border-collapse: collapse;
}

.strongman-app .sm-compare-stats-table th {
    padding: 12px 18px;
    font-size: 11px;
    font-weight: 700;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border-bottom: 2px solid var(--sm-border);
    text-align: center;
}

.strongman-app .sm-compare-stats-table tbody tr:nth-child(even) {
    background: var(--sm-bg, #f8f9fb);
}

.strongman-app .sm-compare-stats-table td {
    padding: 14px 18px;
    border-bottom: 1px solid var(--sm-border);
    text-align: center;
    font-size: 15px;
    font-variant-numeric: tabular-nums;
}

.strongman-app .sm-compare-stat-label {
    font-weight: 600;
    color: var(--sm-navy);
    text-align: center;
}

.strongman-app .sm-compare-winner {
    font-weight: 800;
    color: var(--sm-primary);
    position: relative;
}

.strongman-app .sm-compare-stats-table td:first-child.sm-compare-winner {
    border-left: 3px solid var(--sm-primary);
}

.strongman-app .sm-compare-stats-table td:last-child.sm-compare-winner {
    border-right: 3px solid var(--sm-primary);
}

/* H2H Bar - dramatic */
.strongman-app .sm-compare-h2h {
    margin-bottom: 32px;
}

.strongman-app .sm-compare-h2h-bar {
    height: 48px;
    border-radius: var(--sm-radius);
    overflow: hidden;
    background: var(--sm-bg);
    display: flex;
    margin: 16px 0 8px;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.06);
}

.strongman-app .sm-compare-h2h-a {
    background: linear-gradient(135deg, var(--sm-primary) 0%, #c9364a 100%);
    color: white;
    font-size: 15px;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 48px;
    transition: width 0.4s ease;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.strongman-app .sm-compare-h2h-b {
    background: linear-gradient(135deg, #1a3a6b 0%, var(--sm-navy) 100%);
    color: white;
    font-size: 15px;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 48px;
    transition: width 0.4s ease;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.strongman-app .sm-compare-h2h-draw {
    background: var(--sm-gray-300, #bbb);
    color: #fff;
    text-align: center;
    font-weight: 700;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 48px;
    padding: 0 8px;
}

.strongman-app .sm-compare-h2h-labels {
    display: flex;
    justify-content: space-between;
    font-size: 13px;
    font-weight: 600;
    color: var(--sm-text-secondary);
}

.strongman-app .sm-compare-h2h-record {
    text-align: center;
    font-size: 13px;
    color: var(--sm-text-muted);
    margin-top: 4px;
}

.strongman-app .sm-compare-results {
    margin-bottom: 32px;
}

/* Shared Contests Table */
.strongman-app .sm-compare-shared {
    margin-bottom: 32px;
}

.strongman-app .sm-compare-shared .sm-table-wrapper {
    max-height: 600px;
    overflow-y: auto;
    border-radius: var(--sm-radius-lg);
    border: 1px solid var(--sm-border);
}

.strongman-app .sm-compare-shared .sm-table {
    border-collapse: collapse;
}

.strongman-app .sm-compare-shared .sm-table th {
    position: sticky;
    top: 0;
    background: var(--sm-surface);
    z-index: 2;
    box-shadow: 0 1px 0 var(--sm-border);
}

.strongman-app .sm-compare-shared .sm-table tbody tr:nth-child(even) {
    background: var(--sm-bg, #f8f9fb);
}

.strongman-app .sm-compare-shared .sm-table tbody tr.sm-row-winner-a {
    border-left: 3px solid var(--sm-primary);
}

.strongman-app .sm-compare-shared .sm-table tbody tr.sm-row-winner-b {
    border-left: 3px solid var(--sm-navy);
}

.strongman-app .sm-td-year {
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
    color: #6b7280;
    font-size: 13px;
}

.strongman-app .sm-td-winner {
    white-space: nowrap;
}

.strongman-app .sm-winner-tag {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
}

.strongman-app .sm-winner-a {
    background: rgba(232, 65, 82, 0.12);
    color: #e84152;
}

.strongman-app .sm-winner-b {
    background: rgba(59, 130, 246, 0.12);
    color: #3b82f6;
}

.strongman-app .sm-winner-tie {
    background: var(--sm-bg, #f8f9fb);
    color: var(--sm-text-muted);
}

.strongman-app .sm-compare-show-more {
    text-align: center;
    padding: 16px 0;
}

.strongman-app .sm-compare-share {
    display: flex;
    gap: 8px;
}

.strongman-app .sm-compare-error {
    text-align: center;
    padding: 40px 20px;
    color: var(--sm-text-muted);
    font-size: 15px;
}

.strongman-app .sm-compare-action {
    display: flex;
    justify-content: center;
    margin-top: 24px;
}

/* Compare: Mobile */
@media (max-width: 768px) {
    .strongman-app .sm-compare-selectors {
        flex-direction: column;
        gap: 16px;
    }

    .strongman-app .sm-compare-vs {
        align-self: center;
    }

    .strongman-app .sm-compare-cards {
        grid-template-columns: 1fr;
    }

    .strongman-app .sm-compare-card-photo {
        height: 160px;
    }

    .strongman-app .sm-compare-photo {
        width: 80px;
        height: 80px;
    }

    .strongman-app .sm-compare-photo-fallback {
        width: 80px;
        height: 80px;
        font-size: 24px;
    }

    .strongman-app .sm-compare-h2h-bar {
        height: 40px;
    }

    .strongman-app .sm-compare-h2h-a,
    .strongman-app .sm-compare-h2h-b,
    .strongman-app .sm-compare-h2h-draw {
        font-size: 13px;
        min-width: 36px;
    }

    .strongman-app .sm-compare-stats-table {
        font-size: 13px;
    }

    .strongman-app .sm-compare-stats-table td {
        padding: 10px 12px;
        font-size: 13px;
    }

    .strongman-app .sm-compare-stats-table th {
        padding: 10px 12px;
    }

    .strongman-app .sm-compare-shared .sm-table-wrapper {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
}

/* --- Women's Stats Strip (overrides) --- */
.strongman-app .sm-stats-row {
    display: flex;
    gap: 1px;
    background: var(--sm-border);
    border-radius: var(--sm-radius-lg);
    overflow: hidden;
    margin-bottom: 28px;
}

.strongman-app .sm-stat {
    flex: 1;
    background: var(--sm-surface);
    padding: 20px 24px;
    text-align: center;
}

.strongman-app .sm-stat:first-child {
    border-radius: var(--sm-radius-lg) 0 0 var(--sm-radius-lg);
}

.strongman-app .sm-stat:last-child {
    border-radius: 0 var(--sm-radius-lg) var(--sm-radius-lg) 0;
}

.strongman-app .sm-stat-number {
    font-size: 30px;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-navy);
    letter-spacing: -0.04em;
    line-height: 1.1;
}

.strongman-app .sm-stat-number .highlight {
    color: var(--sm-primary);
}

.strongman-app .sm-stat-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-top: 2px;
}

@media (max-width: 768px) {
    .strongman-app .sm-stats-row {
        flex-direction: column;
    }

    .strongman-app .sm-stat:first-child,
    .strongman-app .sm-stat:last-child {
        border-radius: 0;
    }

    .strongman-app .sm-stat:first-child {
        border-radius: var(--sm-radius-lg) var(--sm-radius-lg) 0 0;
    }

    .strongman-app .sm-stat:last-child {
        border-radius: 0 0 var(--sm-radius-lg) var(--sm-radius-lg);
    }
}

/* --- Rankings (new selectors) --- */
.strongman-app .sm-rankings-page {}

.strongman-app .sm-rankings-table-wrap {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04), 0 4px 12px rgba(0, 0, 0, 0.03);
    border: none;
}

.strongman-app .sm-rankings-table {
    width: 100%;
}

.strongman-app .sm-th-rank {
    width: 60px;
    text-align: center;
}

.strongman-app .sm-th-score {
    width: 100px;
    text-align: right;
}

.strongman-app .sm-td-rank {
    text-align: center;
    font-weight: 700;
}

.strongman-app .sm-td-score {
    text-align: right;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.strongman-app .sm-td-top-result {
    font-size: 13px;
    color: var(--sm-text-secondary);
}

.strongman-app .sm-td-contests {
    font-variant-numeric: tabular-nums;
}

.strongman-app .sm-athlete-cell {
    display: flex;
    align-items: center;
    gap: 12px;
}

.strongman-app .sm-athlete-avatar-sm {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
    background: linear-gradient(135deg, #0f3460 0%, var(--sm-navy) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.strongman-app .sm-avatar-img-sm {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.strongman-app .sm-avatar-fallback-sm {
    color: white;
    font-size: 13px;
    font-weight: 700;
}

.strongman-app .sm-athlete-name-link {
    font-weight: 700;
    color: var(--sm-navy);
    text-decoration: none;
}

.strongman-app .sm-athlete-name-link:hover {
    color: var(--sm-primary);
}

.strongman-app .sm-methodology {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    margin-top: 24px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    overflow: hidden;
}

.strongman-app .sm-methodology-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    cursor: pointer;
    border: none;
    background: none;
    width: 100%;
    font-family: inherit;
}

.strongman-app .sm-methodology-title {
    font-size: 20px;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-navy);
    letter-spacing: -0.02em;
    margin: 0;
}

.strongman-app .sm-methodology-content {
    padding: 0 20px 24px;
    font-size: 15px;
    color: var(--sm-text-secondary);
    line-height: 1.7;
}

.strongman-app .sm-methodology-content h3 {
    font-size: 16px;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 20px 0 6px;
}

.strongman-app .sm-methodology-content p {
    margin: 0 0 8px;
}

.strongman-app .sm-methodology-table {
    width: 100%;
    margin-top: 8px;
    margin-bottom: 16px;
    font-size: 14px;
}

.strongman-app .sm-score-value {
    font-weight: 700;
    color: var(--sm-primary);
    font-variant-numeric: tabular-nums;
}

.strongman-app .sm-results-summary {
    font-size: 13px;
    color: var(--sm-text-muted);
}

/* --- Calendar Page (new selectors) --- */
.strongman-app .sm-calendar-page {}

.strongman-app .sm-calendar-type {}

.strongman-app .sm-calendar-division {}

.strongman-app .sm-col-year {
    width: 70px;
}

.strongman-app .sm-col-name {
    min-width: 200px;
}

.strongman-app .sm-col-location {}

.strongman-app .sm-col-winner {
    min-width: 150px;
}

.strongman-app .sm-col-athletes {
    width: 80px;
    text-align: center;
}

.strongman-app .sm-col-numeric {
    width: 80px;
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.strongman-app .sm-calendar-winner {
    font-weight: 600;
    color: var(--sm-navy);
}

.strongman-app .sm-calendar-winner a {
    color: inherit;
    text-decoration: none;
}

.strongman-app .sm-calendar-winner a:hover {
    color: var(--sm-primary);
}

/* ==========================================================================
   PROGRAM GENERATOR
   ========================================================================== */

.strongman-app .sm-program-config {
    padding: 28px;
    margin-bottom: 24px;
}

.strongman-app .sm-form-grid {
    display: flex;
    flex-direction: column;
    gap: 24px;
    margin-bottom: 28px;
}

.strongman-app .sm-form-label {
    display: block;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sm-text-secondary, #5a6577);
    margin-bottom: 10px;
}

.strongman-app .sm-form-hint-inline {
    font-weight: 400;
    color: var(--sm-text-muted, #6b7585);
    text-transform: none;
    letter-spacing: 0;
}

.strongman-app .sm-form-hint {
    font-size: 13px;
}

.strongman-app .sm-btn-group {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.strongman-app .sm-event-checklist {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.strongman-app .sm-event-check-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: 8px;
    cursor: pointer;
    border: 1px solid var(--sm-border, #e8ecf1);
    background: var(--sm-bg, #f8f9fb);
    font-size: 14px;
    transition: all 0.15s;
    color: var(--sm-text-secondary, #5a6577);
}

.strongman-app .sm-event-check-item:hover {
    border-color: var(--sm-primary);
    background: var(--sm-primary-light, rgba(233, 69, 96, 0.05));
}

.strongman-app .sm-event-check-active {
    border-color: var(--sm-primary);
    background: var(--sm-primary-light, rgba(233, 69, 96, 0.08));
    color: var(--sm-navy);
    font-weight: 600;
}

.strongman-app .sm-event-check-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

.strongman-app .sm-event-check-icon svg {
    width: 18px;
    height: 18px;
}

.strongman-app .sm-program-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 24px;
    flex-wrap: wrap;
    gap: 12px;
}

.strongman-app .sm-program-days {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.strongman-app .sm-day-card {
    padding: 20px;
}

.strongman-app .sm-day-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 16px;
    flex-wrap: wrap;
    gap: 4px;
}

.strongman-app .sm-day-title {
    font-size: 16px;
    font-weight: 700;
    margin: 0;
    color: var(--sm-navy);
}

.strongman-app .sm-day-focus {
    font-size: 12px;
    color: var(--sm-text-muted, #6b7585);
}

.strongman-app .sm-day-exercises {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.strongman-app .sm-exercise-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 4px 16px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--sm-border, #e8ecf1);
}

.strongman-app .sm-exercise-row:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.strongman-app .sm-exercise-name {
    font-weight: 600;
    font-size: 14px;
    color: var(--sm-text-primary);
}

.strongman-app .sm-exercise-sets {
    font-weight: 700;
    color: var(--sm-primary);
    font-size: 14px;
    white-space: nowrap;
}

.strongman-app .sm-exercise-notes {
    font-size: 12px;
    color: var(--sm-text-muted, #6b7585);
    grid-column: 1 / -1;
}

.strongman-app .sm-program-notes {
    padding: 20px;
    margin-top: 8px;
}

.strongman-app .sm-program-notes h3 {
    margin: 0 0 12px;
    font-size: 15px;
    color: var(--sm-navy);
}

.strongman-app .sm-program-notes ul {
    margin: 0;
    padding-left: 20px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.strongman-app .sm-program-notes li {
    font-size: 13px;
    color: var(--sm-text-secondary, #5a6577);
}

.strongman-app .sm-program-actions {
    display: flex;
    gap: 12px;
    margin-top: 20px;
    flex-wrap: wrap;
}

.strongman-app .sm-program-actions .sm-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

@media (max-width: 640px) {
    .strongman-app .sm-program-days {
        grid-template-columns: 1fr;
    }

    .strongman-app .sm-program-header {
        flex-direction: column;
    }

    .strongman-app .sm-program-actions {
        flex-direction: column;
    }

    .strongman-app .sm-program-actions .sm-btn {
        width: 100%;
        justify-content: center;
    }
}

@media print {

    .strongman-app .sm-program-actions,
    .strongman-app .sm-program-config,
    .strongman-app .sm-program-header .sm-btn {
        display: none !important;
    }
}

.strongman-app .sm-calendar-athletes {
    text-align: center;
    font-variant-numeric: tabular-nums;
}

.strongman-app .sm-type-select {
    padding: 8px 32px 8px 12px;
    font-size: 14px;
    font-weight: 500;
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius);
    background: var(--sm-surface);
    font-family: inherit;
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%238b95a5' stroke-width='2'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
}

.strongman-app .sm-year-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 10px;
    font-size: 12px;
    font-weight: 700;
    background: var(--sm-bg);
    border-radius: 6px;
    color: var(--sm-text-secondary);
}

/* --- GOAT Page --- */
.strongman-app .sm-goat-page {}

/* .sm-goat-tabs / .sm-goat-tab removed — now uses canonical .sm-tabs / .sm-tab */

.strongman-app .sm-goat-table {
    width: 100%;
}

.strongman-app .sm-goat-row {}

.strongman-app .sm-goat-rank {
    width: 60px;
    text-align: center;
    font-weight: 700;
}

.strongman-app .sm-goat-score {
    font-weight: 700;
    color: var(--sm-primary);
    font-variant-numeric: tabular-nums;
}

.strongman-app .sm-goat-status {}

.strongman-app .sm-goat-algo {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    margin-top: 24px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    overflow: hidden;
}

.strongman-app .sm-goat-algo-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    cursor: pointer;
    border: none;
    background: none;
    width: 100%;
    font-family: inherit;
    text-align: left;
    color: var(--sm-text-primary);
    font-size: 15px;
    font-weight: 500;
    gap: 10px;
}

.strongman-app .sm-goat-algo-body {
    padding: 0 20px 20px;
    font-size: 14px;
    color: var(--sm-text-secondary);
    line-height: 1.7;
}

.strongman-app .sm-goat-algo-chevron {
    transition: transform 0.2s;
    color: var(--sm-text-muted);
}

.strongman-app .sm-goat-empty {
    text-align: center;
    padding: 40px 20px;
    color: var(--sm-text-muted);
}

.strongman-app .sm-section-title {
    font-size: 20px;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-navy);
    letter-spacing: -0.02em;
}

.strongman-app .sm-section-title .highlight {
    color: var(--sm-primary);
}

.strongman-app .sm-text-muted {
    color: var(--sm-text-muted);
}

/* ==========================================================================
   COUNTRIES INDEX
   ========================================================================== */

.strongman-app .sm-countries-page {
    max-width: 1000px;
    margin: 0 auto;
}

.strongman-app .sm-countries-controls {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sm-space-4);
    align-items: center;
    margin-bottom: var(--sm-space-4);
    padding: var(--sm-space-4);
    background: var(--sm-surface);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius-lg);
}

.strongman-app .sm-countries-sort {
    display: flex;
    align-items: center;
    gap: var(--sm-space-2);
    margin-left: auto;
}

.strongman-app .sm-countries-sort-label {
    font-size: 0.875rem;
    color: var(--sm-text-secondary);
    white-space: nowrap;
}

.strongman-app .sm-countries-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--sm-space-4);
}

.strongman-app .sm-country-card {
    display: flex;
    align-items: center;
    gap: var(--sm-space-4);
    padding: var(--sm-space-4);
    background: var(--sm-surface);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius-lg);
    text-decoration: none;
    color: inherit;
    transition: all var(--sm-transition);
}

.strongman-app .sm-country-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--sm-shadow-md);
    border-color: rgba(15, 52, 96, 0.15);
    background: var(--sm-primary-light);
    text-decoration: none;
    color: inherit;
}

.strongman-app .sm-country-card-flag {
    flex-shrink: 0;
}

.strongman-app .sm-country-card-flag img {
    width: 48px;
    height: 36px;
    object-fit: cover;
    border-radius: 4px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.strongman-app .sm-country-card-info {
    flex: 1;
    min-width: 0;
}

.strongman-app .sm-country-card-name {
    font-family: var(--sm-font-heading);
    font-size: 1rem;
    font-weight: 600;
    margin: 0 0 var(--sm-space-1);
    color: var(--sm-text-primary);
}

.strongman-app .sm-country-card-stats {
    display: flex;
    gap: var(--sm-space-4);
    font-size: 0.8125rem;
    color: var(--sm-text-secondary);
}

.strongman-app .sm-country-stat strong {
    color: var(--sm-text-primary);
}

.strongman-app .sm-country-card-arrow {
    flex-shrink: 0;
    color: var(--sm-gray-300);
    transition: transform var(--sm-transition);
}

.strongman-app .sm-country-card:hover .sm-country-card-arrow {
    transform: translateX(3px);
    color: var(--sm-primary);
}

@media (max-width: 768px) {
    .strongman-app .sm-countries-controls {
        flex-direction: column;
        align-items: stretch;
    }

    .strongman-app .sm-countries-sort {
        margin-left: 0;
    }

    .strongman-app .sm-countries-grid {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   COUNTRY DETAIL
   ========================================================================== */

.strongman-app .sm-country-detail-page {
    max-width: 1200px;
    margin: 0 auto;
}

.strongman-app .sm-country-header {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 28px;
}

.strongman-app .sm-country-header-flag {
    flex-shrink: 0;
}

.strongman-app .sm-country-flag-large {
    width: 64px;
    height: 48px;
    border-radius: 8px;
    object-fit: cover;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.strongman-app .sm-country-header-info {
    flex: 1;
}

.strongman-app .sm-country-header-stats {
    display: flex;
    gap: 16px;
    margin-top: 8px;
}

.strongman-app .sm-country-section {
    margin-bottom: 32px;
}

.strongman-app .sm-stat-card {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    padding: 20px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    text-align: center;
}

.strongman-app .sm-stat-text {
    font-size: 12px;
    font-weight: 600;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-top: 4px;
}

.strongman-app .sm-directory-error {
    text-align: center;
    padding: 40px 20px;
    color: var(--sm-text-muted);
}

.strongman-app .sm-directory-empty {
    text-align: center;
    padding: 40px 20px;
    color: var(--sm-text-muted);
}

.strongman-app .sm-winner-link {
    font-weight: 600;
    color: var(--sm-navy);
    text-decoration: none;
}

.strongman-app .sm-winner-link:hover {
    color: var(--sm-primary);
}

@media (max-width: 768px) {
    .strongman-app .sm-country-header {
        flex-direction: column;
        text-align: center;
    }

    .strongman-app .sm-country-header-stats {
        justify-content: center;
        flex-wrap: wrap;
    }
}

/* ==========================================================================
   CONTEST SERIES DETAIL
   ========================================================================== */

.strongman-app .sm-series-detail {
    max-width: 1200px;
    margin: 0 auto;
    padding: var(--sm-space-4);
}

.strongman-app .sm-series-header {
    background: linear-gradient(135deg, var(--sm-gray-50) 0%, var(--sm-gray-100) 100%);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius-lg);
    padding: var(--sm-space-6);
    margin-bottom: var(--sm-space-6);
}

.strongman-app .sm-series-title {
    font-family: var(--sm-font-heading);
    font-size: clamp(1.5rem, 4vw, 2.25rem);
    font-weight: 700;
    color: var(--sm-navy);
    margin: 0 0 var(--sm-space-3) 0;
    line-height: 1.2;
}

.strongman-app .sm-series-description {
    font-size: 1rem;
    line-height: 1.6;
    color: var(--sm-text-secondary);
    margin: 0 0 var(--sm-space-4) 0;
}

.strongman-app .sm-series-stats {
    display: flex;
    gap: var(--sm-space-6);
    flex-wrap: wrap;
}

.strongman-app .sm-stat-item {
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-1);
    padding: 10px 4px;
}

.strongman-app .sm-series-contests {
    background: var(--sm-surface);
    border: 1px solid var(--sm-gray-200);
    border-radius: var(--sm-radius-lg);
    padding: var(--sm-space-5);
    margin-bottom: var(--sm-space-6);
}

/* Series table overrides */
.strongman-app .sm-series-contests .sm-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--sm-fs-15);
}

.strongman-app .sm-series-contests .sm-table thead {
    background: var(--sm-gray-50);
}

.strongman-app .sm-series-contests .sm-table th {
    padding: var(--sm-space-3);
    text-align: left;
    font-weight: 600;
    font-size: 0.8125rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--sm-text-secondary);
    border-bottom: 2px solid var(--sm-gray-200);
    white-space: nowrap;
}

.strongman-app .sm-series-contests .sm-table tbody tr {
    border-bottom: 1px solid var(--sm-gray-100);
    transition: background-color 0.15s ease;
}

.strongman-app .sm-series-contests .sm-table tbody tr:hover {
    background: var(--sm-gray-50);
}

.strongman-app .sm-series-contests .sm-table td {
    padding: var(--sm-space-3);
    color: var(--sm-text-primary);
}

/* Series footer */
.strongman-app .sm-series-footer {
    padding: var(--sm-space-4) 0;
}

/* Series skeleton loading */
.strongman-app .sm-skeleton-wrapper {
    animation: sm-pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes sm-pulse {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.5;
    }
}

/* Series error state */
.strongman-app .sm-error-state {
    text-align: center;
    padding: var(--sm-space-12, 3rem) var(--sm-space-4);
}

.strongman-app .sm-error-icon {
    margin: 0 auto var(--sm-space-4);
    color: var(--sm-text-muted);
}

.strongman-app .sm-error-title {
    font-family: var(--sm-font-heading);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--sm-navy);
    margin: 0 0 var(--sm-space-2) 0;
}

.strongman-app .sm-error-message {
    font-size: 1rem;
    color: var(--sm-text-secondary);
    margin: 0 0 var(--sm-space-6) 0;
}

/* Series responsive */
@media (max-width: 768px) {
    .strongman-app .sm-series-contests .sm-table {
        font-size: 0.875rem;
    }

    .strongman-app .sm-series-contests .sm-table th,
    .strongman-app .sm-series-contests .sm-table td {
        padding: var(--sm-space-2);
    }

    .strongman-app .sm-col-location {
        display: none;
    }
}

@media (max-width: 640px) {
    .strongman-app .sm-series-title {
        font-size: 1.5rem;
    }

    .strongman-app .sm-col-athletes {
        display: none;
    }
}

/* ==========================================================================
   MOCKUP DESIGN ADDITIONS (2026-02-15)
   ========================================================================== */

/* --- 1. Filter Bar (mockup pattern) --- */
.strongman-app .sm-filter-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.strongman-app .sm-filter-bar .sm-filter-input {
    flex: 1;
    min-width: 200px;
    width: auto;
}

.strongman-app .sm-filter-bar .sm-filter-select {
    width: auto;
}

.strongman-app .sm-filter-bar .sm-btn {
    flex-shrink: 0;
}

@media (max-width: 640px) {
    .strongman-app .sm-filter-bar {
        flex-direction: column;
        align-items: stretch;
    }

    .strongman-app .sm-filter-bar .sm-filter-input {
        min-width: 0;
    }
}

/* --- 2. Focus state override: mockup uses border-only focus --- */
.strongman-app .sm-filter-bar .sm-filter-input:focus,
.strongman-app .sm-filter-bar .sm-filter-select:focus {
    border-color: var(--sm-primary);
    box-shadow: none;
}

/* --- 3. Pagination (mockup pattern) --- */
.strongman-app .sm-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 18px;
    border-top: 2px solid var(--sm-border);
    font-size: 13px;
    color: var(--sm-text-muted);
}

.strongman-app .sm-pagination-info {
    font-size: 13px;
    color: var(--sm-text-muted);
}

.strongman-app .sm-pagination-pages {
    display: flex;
    gap: 4px;
}

.strongman-app .sm-page-btn {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--sm-text-secondary);
    cursor: pointer;
    background: none;
    font-family: inherit;
    transition: all 0.15s;
}

.strongman-app .sm-page-btn:hover {
    background: var(--sm-bg);
}

.strongman-app .sm-page-btn.active,
.strongman-app .sm-page-btn-active {
    background: var(--sm-primary);
    color: white;
}

.strongman-app .sm-page-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

@media (max-width: 640px) {
    .strongman-app .sm-pagination {
        flex-direction: column;
        gap: 12px;
        text-align: center;
    }
}

/* --- 4. Feature Grid (mockup pattern) --- */
.strongman-app .sm-feature-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-top: 36px;
}

.strongman-app .sm-feature-card {
    background: var(--sm-surface);
    border-radius: var(--sm-radius-lg);
    padding: 28px;
    text-decoration: none;
    color: inherit;
    transition: all 0.2s;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    position: relative;
    overflow: hidden;
    display: block;
}

.strongman-app .sm-feature-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.strongman-app .sm-feature-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
}

.strongman-app .sm-feature-card:nth-child(1)::before {
    background: var(--sm-primary);
}

.strongman-app .sm-feature-card:nth-child(2)::before {
    background: var(--sm-accent);
}

.strongman-app .sm-feature-card:nth-child(3)::before {
    background: var(--sm-green);
}

.strongman-app .sm-feature-icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}

.strongman-app .sm-feature-card:nth-child(1) .sm-feature-icon {
    background: rgba(233, 69, 96, 0.08);
    color: var(--sm-primary);
}

.strongman-app .sm-feature-card:nth-child(2) .sm-feature-icon {
    background: rgba(245, 166, 35, 0.12);
    color: #d4920a;
}

.strongman-app .sm-feature-card:nth-child(3) .sm-feature-icon {
    background: rgba(46, 204, 113, 0.1);
    color: var(--sm-green);
}

.strongman-app .sm-feature-title {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 6px;
    letter-spacing: -0.01em;
    color: var(--sm-navy);
}

.strongman-app .sm-feature-desc {
    font-size: 14px;
    color: var(--sm-text-secondary);
    line-height: 1.6;
}

.strongman-app .sm-feature-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-top: 16px;
    font-size: 13px;
    font-weight: 600;
    color: var(--sm-primary);
}

@media (max-width: 1024px) {
    .strongman-app .sm-feature-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .strongman-app .sm-feature-grid {
        grid-template-columns: 1fr;
    }
}

/* --- 5. Table hover fix — match mockup accent-soft --- */
.strongman-app .sm-table tbody tr:hover {
    background: rgba(233, 69, 96, 0.08);
}

/* --- 6. Placement badge fix — match mockup min-width --- */
.strongman-app .sm-place-badge {
    min-width: 28px;
    font-weight: 700;
}

/* --- 7. Section Header (mockup pattern) ---
   NOTE: data pages use .sm-section-header-sa (line ~8000) for flex layout.
   Do NOT override .sm-section-header here — hub/calculator pages need text-align:center. */

.strongman-app .sm-section-title {
    font-size: 20px;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
    letter-spacing: -0.02em;
}

.strongman-app .sm-section-title .highlight {
    color: var(--sm-primary);
}

/* --- 8. Search Box (unified pattern) --- */
.strongman-app .sm-search-box {
    position: relative;
    flex: 1;
    min-width: 200px;
}

.strongman-app .sm-search-box .sm-search-icon {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    color: var(--sm-text-muted);
    pointer-events: none;
    z-index: 1;
}

.strongman-app .sm-search-box input,
.strongman-app .sm-search-box .sm-input {
    padding-left: 38px;
    width: 100%;
}

/* --- 9. Division Filter --- */
/* Duplicate .sm-division-filter removed - canonical definition in Section 17.15 */

/* --- 10. Per-Page Selector --- */
.strongman-app .sm-per-page-select {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

.strongman-app .sm-per-page-label {
    font-size: 13px;
    color: var(--sm-text-muted);
}

.strongman-app .sm-select-sm {
    padding: 6px 30px 6px 10px;
    font-size: 13px;
    min-height: 34px;
}

/* --- 11. Results Summary --- */
.strongman-app .sm-results-summary {
    font-size: 13px;
    color: var(--sm-text-muted);
    margin-bottom: 12px;
}

/* --- 12. Directory Filters Row --- */
.strongman-app .sm-directory-filters-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

@media (max-width: 640px) {
    .strongman-app .sm-directory-filters-row {
        flex-direction: column;
        align-items: stretch;
    }
}

/* =============================================================================
   MOCKUP MATCH ROUND 2 (2026-02-15)
   Additional CSS rules to match approved mockup-final.html design
   ============================================================================= */

/* --- 1. Division Toggle: Tab Style (NOT pill buttons) --- */
/* Duplicate .sm-division-filter removed - canonical definition in Section 17.15 */

.strongman-app .sm-division-label {
    display: none;
    /* Hide "DIVISION:" label - mockup doesn't have it */
}

.strongman-app .sm-division-filter .sm-filter-btn {
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    border-radius: 0;
    padding: 10px 18px;
    background: none;
    color: var(--sm-text-muted);
    font-weight: 600;
}

.strongman-app .sm-division-filter .sm-filter-btn:hover {
    color: var(--sm-text-primary);
    border-color: transparent;
    background: none;
}

.strongman-app .sm-division-filter .sm-filter-btn-active,
.strongman-app .sm-division-filter .sm-filter-btn.active {
    color: var(--sm-primary);
    border-bottom-color: var(--sm-primary);
    background: none;
}

.strongman-app .sm-division-filter .sm-filter-btn-active:hover,
.strongman-app .sm-division-filter .sm-filter-btn.active:hover {
    background: none;
    color: var(--sm-primary);
    border-bottom-color: var(--sm-primary);
}

/* --- 2. Pagination: Numbered Style --- */
/* Pagination: left text + right numbered buttons */
.strongman-app .sm-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 18px;
    border-top: 2px solid var(--sm-border);
}

.strongman-app .sm-pagination-info {
    font-size: 13px;
    color: var(--sm-text-muted);
}

.strongman-app .sm-pagination-pages {
    display: flex;
    align-items: center;
    gap: 4px;
}

.strongman-app .sm-page-btn {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--sm-text-secondary);
    cursor: pointer;
    background: none;
    font-family: inherit;
    transition: all 0.15s;
}

.strongman-app .sm-page-btn:hover:not(:disabled) {
    background: var(--sm-bg);
}

.strongman-app .sm-page-btn.active,
.strongman-app .sm-page-btn-active {
    background: var(--sm-primary);
    color: white;
}

.strongman-app .sm-pagination-controls {
    display: flex;
    gap: 4px;
}

.strongman-app .sm-pagination-info {
    font-size: 13px;
    color: var(--sm-text-muted);
}

.strongman-app .sm-page-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.strongman-app .sm-page-info {
    font-size: 13px;
    color: var(--sm-text-muted);
}

.strongman-app .sm-page-ellipsis {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    color: var(--sm-text-muted);
}

/* --- 3. Search Button in Filter Bar --- */
.strongman-app .sm-filter-bar .sm-btn-search {
    padding: 10px 20px;
    font-size: 14px;
    font-weight: 600;
    color: white;
    background: var(--sm-primary);
    border: none;
    border-radius: var(--sm-radius);
    cursor: pointer;
    font-family: inherit;
    transition: background 0.15s;
    flex-shrink: 0;
    white-space: nowrap;
}

.strongman-app .sm-filter-bar .sm-btn-search:hover {
    background: var(--sm-primary-hover);
}

/* --- 4. Table Header Override --- */
/* Ensure table headers are clean gray uppercase, no bg color */
.strongman-app .sm-directory-container .sm-table th,
.strongman-app .sm-directory-container .sm-table thead th {
    background: transparent;
    color: var(--sm-text-muted);
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border-bottom: 2px solid var(--sm-border);
    padding: 12px 14px;
}

.strongman-app .sm-directory-container .sm-table thead th:hover {
    color: var(--sm-text-primary);
}

/* --- Active sorted column: dark text, not light --- */
.strongman-app .sm-directory-container .sm-table thead th.sm-sort-asc,
.strongman-app .sm-directory-container .sm-table thead th.sm-sort-desc {
    color: var(--sm-navy);
    background: rgba(15, 52, 96, 0.04);
}

.strongman-app .sm-directory-container .sm-table thead th.sm-sort-asc::after {
    content: " \25B2";
    font-size: 9px;
    margin-left: 4px;
}

.strongman-app .sm-directory-container .sm-table thead th.sm-sort-desc::after {
    content: " \25BC";
    font-size: 9px;
    margin-left: 4px;
}

/* Active sorted column cells: subtle highlight */
.strongman-app .sm-directory-container .sm-table td[data-sorted="true"] {
    background: rgba(15, 52, 96, 0.02);
}

/* .sm-goat-tab-active removed — now uses canonical .sm-tab-active */

/* --- GOAT Table: consistent header styling --- */
.strongman-app .sm-goat-table th {
    font-size: 13px;
    font-weight: 700;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 12px 18px;
    border-bottom: 2px solid var(--sm-border);
    background: transparent;
}

.strongman-app .sm-goat-table td {
    padding: 14px 18px;
    border-bottom: 1px solid var(--sm-border);
}

.strongman-app .sm-goat-table tbody tr:hover {
    background: rgba(233, 69, 96, 0.06);
}

/* GOAT rank badges */
.strongman-app .sm-goat-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    border-radius: 8px;
    font-weight: var(--sm-weight-extrabold);
    font-size: 14px;
    background: var(--sm-gray-100);
    color: var(--sm-text-secondary);
}

.strongman-app .sm-goat-rank-gold {
    background: linear-gradient(135deg, var(--sm-gold), var(--sm-gold-end));
    color: var(--sm-gold-text);
    border: 1px solid var(--sm-gold-end);
}

.strongman-app .sm-goat-rank-silver {
    background: linear-gradient(135deg, var(--sm-silver), var(--sm-silver-end));
    color: var(--sm-silver-text);
    border: 1px solid var(--sm-silver-end);
}

.strongman-app .sm-goat-rank-bronze {
    background: linear-gradient(135deg, var(--sm-bronze), var(--sm-bronze-end));
    color: var(--sm-bronze-text);
    border: 1px solid var(--sm-bronze-end);
}

/* GOAT status badges */
.strongman-app .sm-goat-status {
    display: inline-flex;
    padding: 3px 10px;
    font-size: 12px;
    font-weight: 600;
    border-radius: 6px;
}

.strongman-app .sm-goat-status-active {
    background: rgba(22, 163, 74, 0.1);
    color: #16a34a;
}

.strongman-app .sm-goat-status-retired {
    background: var(--sm-gray-100);
    color: var(--sm-text-muted);
}

/* GOAT row top 3 highlight */
.strongman-app .sm-goat-row-top3 {
    background: rgba(245, 166, 35, 0.03);
}

.strongman-app .sm-goat-row-top3:hover {
    background: rgba(245, 166, 35, 0.08);
}

/* --- Athlete Profile: Enhanced stats box --- */
.strongman-app .sm-stats-box {
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: 16px;
    padding: 28px 32px;
    margin-bottom: 28px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.strongman-app .sm-stats-box-title {
    font-size: 18px;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-navy);
    margin-bottom: 24px;
    letter-spacing: -0.01em;
}

.strongman-app .sm-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 20px;
}

.strongman-app .sm-stats-category {
    padding: 20px;
    background: var(--sm-gray-50);
    border-radius: 12px;
    border: 1px solid transparent;
    transition: border-color 0.15s;
}

.strongman-app .sm-stats-category:hover {
    border-color: var(--sm-border);
}

.strongman-app .sm-stats-category-title {
    font-size: 11px;
    font-weight: 700;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--sm-border);
}

.strongman-app .sm-stats-wsm {
    background: linear-gradient(135deg, rgba(15, 52, 96, 0.06) 0%, rgba(200, 30, 69, 0.04) 100%);
    border: 1px solid rgba(15, 52, 96, 0.12);
}

.strongman-app .sm-stats-wsm .sm-stats-category-title {
    color: var(--sm-navy);
    border-bottom-color: rgba(15, 52, 96, 0.15);
}

/* --- Athlete Profile: Powerlifting Records card --- */
.strongman-app .sm-pl-box {
    border-left: 4px solid #e63946;
}

.strongman-app .sm-pl-grid {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

.strongman-app .sm-pl-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 16px;
    margin-top: 18px;
    font-size: 13px;
    color: var(--sm-text-secondary);
}

.strongman-app .sm-pl-meta span:not(:last-child)::after {
    content: "\00b7";
    margin-left: 16px;
    color: var(--sm-text-muted);
}

.strongman-app .sm-pl-attribution {
    margin-top: 12px;
    font-size: 11px;
    color: var(--sm-text-muted);
}

.strongman-app .sm-pl-attribution a {
    color: var(--sm-text-muted);
    text-decoration: underline;
}

.strongman-app .sm-stat-number {
    display: block;
    font-size: 28px;
    font-weight: var(--sm-weight-extrabold);
    font-family: var(--sm-font-heading);
    color: var(--sm-navy);
    line-height: 1;
    margin-bottom: 4px;
}

.strongman-app .sm-stat-wins {
    color: #16a34a;
}

.strongman-app .sm-stat-gold {
    color: #d4920a;
}

.strongman-app .sm-stat-text {
    font-size: 12px;
    font-weight: 500;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.strongman-app .sm-stat-item {
    text-align: center;
    min-width: 70px;
}

/* --- Compare page: Featured rivalries / matchup cards --- */
.strongman-app .sm-matchup-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-top: 16px;
}

.strongman-app .sm-matchup-card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px 24px;
    text-decoration: none;
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius-lg);
    background: var(--sm-surface);
    transition: all 0.2s ease;
}

.strongman-app .sm-matchup-card:hover {
    border-color: var(--sm-primary);
    box-shadow: 0 6px 20px rgba(233, 69, 96, 0.12);
    transform: translateY(-2px);
}

.strongman-app .sm-matchup-card:active {
    transform: translateY(0);
}

.strongman-app .sm-matchup-photos {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.strongman-app .sm-matchup-photo {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--sm-surface);
    background: var(--sm-navy);
}

.strongman-app .sm-matchup-photo:last-child {
    margin-left: -12px;
}

.strongman-app .sm-matchup-photo-fallback {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 2px solid var(--sm-surface);
    background: var(--sm-navy);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
}

.strongman-app .sm-matchup-photo-fallback:last-child {
    margin-left: -12px;
}

.strongman-app .sm-matchup-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.strongman-app .sm-matchup-names {
    font-family: var(--sm-font-heading);
    font-weight: var(--sm-weight-extrabold);
    font-size: 15px;
    color: var(--sm-navy);
    line-height: 1.3;
}

.strongman-app .sm-matchup-meta {
    font-size: 12px;
    color: var(--sm-text-muted);
    line-height: 1.4;
}

.strongman-app .sm-matchup-arrow {
    margin-left: auto;
    color: var(--sm-text-muted);
    flex-shrink: 0;
    transition: transform 0.2s, color 0.2s;
}

.strongman-app .sm-matchup-card:hover .sm-matchup-arrow {
    transform: translateX(3px);
    color: var(--sm-primary);
}

@media (max-width: 640px) {
    .strongman-app .sm-matchup-grid {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   TRACK 5 FIXES (2026-02-18) - Standards, Records, Series, Training, Calculators
   ========================================================================== */


/* STD-03: Tab subtitle paragraph */
.strongman-app .sm-tab-subtitle {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.7);
    margin: 8px 0 16px;
}

/* STD-06: Event step indicator nav */
.strongman-app .sm-event-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.strongman-app .sm-event-position {
    color: rgba(255, 255, 255, 0.6);
    font-size: 14px;
}

/* SER-01: Series card name overflow fix */
.strongman-app .sm-series-card-title {
    word-break: break-word;
    overflow-wrap: break-word;
    min-width: 0;
}

/* SER-04: Series search input */
.strongman-app .sm-search-input {
    padding: 10px 14px;
    font-size: 14px;
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius);
    background: var(--sm-surface);
    outline: none;
    font-family: inherit;
    transition: border-color 0.15s;
}

.strongman-app .sm-search-input:focus {
    border-color: var(--sm-primary);
}

/* CALC-01: Form hint text */
.strongman-app .sm-form-hint {
    font-size: 13px;
    opacity: 0.7;
    margin-top: 4px;
    color: var(--sm-text-secondary);
}

/* =============================================================================
   HUB PAGE FIXES (HOME-01, HOME-03, HOME-05, HOME-06, HOME-07, HOME-10)
   2026-02-18
   ============================================================================= */

/* HOME-07: Coming Soon badge for Gym Finder card */
.strongman-app .sm-coming-soon-badge {
    position: absolute;
    top: 8px;
    right: 8px;
    background: #dc2626;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 20px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    z-index: 1;
}

/* HOME-05: Consistent card heights — description grows to push CTA to bottom */
.strongman-app .sm-calc-card .sm-calc-description {
    flex: 1;
}

/* HOME-06: Center orphaned last-row cards in 3-col calculator grid */
.sm-cards-grid--centered {
    justify-content: center;
}

/* HOME-01: Reduce hero top/bottom padding to trim height */
.sm-hero {
    padding-top: 32px;
    padding-bottom: 32px;
}

@media (max-width: 768px) {
    .sm-hero {
        padding-top: 22px;
        padding-bottom: 22px;
    }
}

/* HOME-10: Reduce vertical whitespace between hub page sections */
.sm-calcs-section {
    padding-top: 48px;
    padding-bottom: 48px;
}

.sm-howit-section {
    padding-top: 48px;
    padding-bottom: 48px;
}

.sm-data-section {
    padding-top: 48px;
    padding-bottom: 48px;
}

.sm-final-cta {
    padding-top: 56px;
    padding-bottom: 56px;
}

/* HOME-03: Did You Know nav arrows — visibility handled in main facts block below */

/* --- Disabled card (e.g. Gym Finder "Coming Soon") --- */
.sm-card--disabled {
    opacity: 0.75;
    pointer-events: none;
}

/* =============================================================================
   HUB PAGE — Styles moved from inline <style> blocks (2026-02-18)
   ============================================================================= */

/* --- Strength Standards CTA Banner --- */
.sm-standards-cta-section {
    margin-bottom: 40px;
}

.sm-standards-cta-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    padding: 32px 36px;
    background: linear-gradient(135deg, var(--sm-navy) 0%, var(--sm-electric) 100%);
    border-radius: var(--sm-radius-xl, 16px);
    border: 1px solid rgba(233, 69, 96, 0.2);
    text-decoration: none;
    color: #fff;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.sm-standards-cta-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(233, 69, 96, 0.15);
}

.sm-standards-cta-content {
    flex: 1;
}

.sm-standards-cta-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 20px;
    background: var(--sm-primary-hover, #c81e45);
    color: #fff;
    font-size: var(--sm-fs-2xs);
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-bottom: 12px;
}

.sm-standards-cta-title {
    font-size: 1.5rem;
    font-weight: var(--sm-weight-extrabold);
    margin: 0 0 8px;
    font-family: var(--sm-font-heading);
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.sm-standards-cta-description {
    font-size: var(--sm-fs-15);
    line-height: 1.6;
    color: var(--sm-gray-300, #cbd5e1);
    margin: 0 0 16px;
    max-width: 600px;
}

.sm-standards-cta-levels {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
}

.sm-standards-cta-level {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--level-color);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.2rem;
    color: #fff;
    box-shadow: 0 0 16px rgba(255, 255, 255, 0.15), 0 4px 12px rgba(0, 0, 0, 0.3);
    border: 2px solid rgba(255, 255, 255, 0.2);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

@media (max-width: 768px) {
    .sm-standards-cta-card {
        flex-direction: column;
        text-align: center;
        padding: 24px 20px;
        gap: 20px;
    }

    .sm-standards-cta-description {
        max-width: none;
    }

    .sm-standards-cta-levels {
        justify-content: center;
    }
}

/* --- Explore More Grid --- */
.sm-explore-section {
    margin: 40px 0;
}

.sm-explore-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.sm-explore-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 24px 16px;
    border-radius: var(--sm-radius-lg, 12px);
    background: var(--sm-surface, #fff);
    border: 1px solid var(--sm-border, #e8ecf1);
    text-decoration: none;
    color: inherit;
    text-align: center;
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}

.sm-explore-card:hover {
    transform: translateY(-2px);
    border-color: var(--sm-primary);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.sm-explore-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
}

.sm-explore-icon svg {
    color: var(--sm-primary);
}

.sm-explore-label {
    font-size: var(--sm-fs-15);
    font-weight: 700;
    color: var(--sm-text-primary, #1e293b);
}

.sm-explore-desc {
    font-size: 0.8125rem;
    color: var(--sm-text-muted, #6b7a90);
}

@media (max-width: 768px) {
    .sm-explore-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .sm-explore-grid {
        grid-template-columns: 1fr;
    }
}

/* --- FitnessVolt News Widget --- */
.sm-news-section {
    padding: var(--sm-space-16) 0;
}

.sm-news-source-link {
    color: var(--sm-primary);
    text-decoration: none;
    font-weight: 600;
}

.sm-news-source-link:hover {
    text-decoration: underline;
}

.sm-news-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sm-space-6);
    margin-top: var(--sm-space-8);
}

.sm-news-card {
    display: flex;
    flex-direction: column;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-lg, 12px);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}

.sm-news-card:hover {
    transform: translateY(-3px);
    border-color: var(--sm-primary);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}

.sm-news-thumb {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    /* 16:9 */
    overflow: hidden;
    background: var(--sm-gray-100);
}

.sm-news-thumb img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s;
}

.sm-news-card:hover .sm-news-thumb img {
    transform: scale(1.05);
}

.sm-news-thumb-fallback {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--sm-gray-400);
}

.sm-news-body {
    padding: var(--sm-space-4) var(--sm-space-5) var(--sm-space-5);
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-2);
    flex: 1;
}

.sm-news-date {
    font-size: var(--sm-fs-xs);
    color: var(--sm-text-muted);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.sm-news-title {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.35;
    color: var(--sm-text-primary);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sm-news-excerpt {
    font-size: var(--sm-fs-sm);
    color: var(--sm-text-secondary);
    line-height: 1.5;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sm-news-footer {
    text-align: center;
    margin-top: var(--sm-space-8);
}

@media (max-width: 1024px) {
    .sm-news-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .sm-news-grid {
        grid-template-columns: 1fr;
    }
}

/* --- Fun Facts Widget --- */
.sm-facts-section {
    margin-bottom: 40px;
}

.sm-facts-card {
    background: linear-gradient(135deg, var(--sm-navy) 0%, var(--sm-electric) 100%);
    border-radius: var(--sm-radius-xl, 16px);
    padding: 28px 32px;
    color: #fff;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 20px;
    position: relative;
    overflow: hidden;
}

.sm-facts-card::before {
    content: '';
    position: absolute;
    top: -40%;
    right: -10%;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(233, 69, 96, 0.08) 0%, transparent 70%);
    pointer-events: none;
}

.sm-facts-header {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    color: var(--sm-primary);
    padding-top: 4px;
}

.sm-facts-label {
    font-size: var(--sm-fs-2xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    white-space: nowrap;
}

.sm-facts-body {
    flex: 1;
    min-width: 0;
}

.sm-facts-title-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
    flex-wrap: wrap;
}

.sm-facts-title {
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: rgba(255, 255, 255, 0.65);
}

.sm-facts-cat-badge {
    background: rgba(233, 69, 96, 0.18);
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.625rem;
    padding: 2px 8px;
    border-radius: 10px;
}

.sm-facts-value {
    font-family: var(--sm-font-heading, 'DM Sans', sans-serif);
    font-size: 2rem;
    font-weight: var(--sm-weight-extrabold);
    line-height: 1.15;
    color: #fff;
    margin-bottom: 8px;
    letter-spacing: -0.02em;
}

.sm-facts-text {
    font-size: var(--sm-fs-15);
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.75);
    margin: 0;
}

.sm-facts-athlete-link {
    display: inline-block;
    margin-top: 10px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--sm-primary);
    text-decoration: none;
    transition: color 0.15s ease;
}

.sm-facts-athlete-link:hover {
    color: #fff;
}

.sm-facts-nav {
    width: 100%;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding-top: 8px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    margin-top: 4px;
}

.sm-facts-nav-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    min-width: 34px;
    min-height: 34px;
    aspect-ratio: 1;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.12);
    border: 1.5px solid rgba(255, 255, 255, 0.35);
    color: rgba(255, 255, 255, 0.8);
    cursor: pointer;
    transition: all 0.15s ease;
    flex-shrink: 0;
    padding: 0;
    box-sizing: border-box;
}

.sm-facts-nav-btn svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

.sm-facts-nav-btn:hover {
    background: rgba(255, 255, 255, 0.28);
    color: #fff;
    border-color: rgba(255, 255, 255, 0.65);
    transform: scale(1.1);
}

.sm-facts-dots {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: center;
    max-width: none;
}

.sm-facts-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.25);
    border: none;
    padding: 0;
    cursor: pointer;
    transition: all 0.2s ease;
}

.sm-facts-dot.active {
    background: var(--sm-primary);
    transform: scale(1.4);
    box-shadow: 0 0 6px rgba(233, 69, 96, 0.5);
}

.sm-facts-dot:hover:not(.active) {
    background: rgba(255, 255, 255, 0.5);
}

@media (max-width: 640px) {
    .sm-facts-card {
        flex-direction: column;
        text-align: center;
        gap: 14px;
        padding: 24px 20px;
    }

    .sm-facts-header {
        flex-direction: row;
    }

    .sm-facts-title-row {
        justify-content: center;
    }

    .sm-facts-value {
        font-size: 1.75rem;
    }

    .sm-facts-nav {
        gap: 8px;
    }
}

/*override theme style*/
.sm-profile-photo-img {
    height: 140px !important;
}

/* PRO-08: Compare CTA button in athlete profile header (styles in profile.php inline <style>) */

/* ==========================================================================
   Inline Style Utilities
   ========================================================================== */

/* Chevron rotation transition (FAQ icons, expand/collapse toggles) */
.sm-chevron-transition {
    transition: transform var(--sm-transition-slow);
}

/* Small info icon (rankings score column, etc.) */
.sm-info-icon {
    opacity: 0.6;
    font-size: 12px;
    cursor: help;
}

/* Form hint with subdued appearance */
.sm-form-hint-muted {
    font-size: 13px;
    opacity: 0.7;
    margin-top: 4px;
}

/* Header CTA button (leaderboard submit, etc.) */
.sm-header-cta {
    margin-top: var(--sm-space-4);
    display: inline-flex;
    align-items: center;
    gap: var(--sm-space-2);
}

/* Smaller stat number variant (years active text, etc.) */
.sm-stat-number-sm {
    font-size: 20px;
}

/* Margin-bottom utilities */
.sm-mb-4 {
    margin-bottom: var(--sm-space-4);
}

/* .sm-search-input-constrained removed — series now uses canonical .sm-search-box */

/* ==========================================================================
   TRACK 4 FIXES (2026-02-18) - Calendar, Rankings, Compare, Countries
   ========================================================================== */

/* CTY-03: Back link on country detail page */
.strongman-app .sm-back-link-wrap {
    margin-bottom: 16px;
}

.strongman-app .sm-back-link {
    color: rgba(255, 255, 255, 0.75);
    text-decoration: none;
    font-size: 14px;
}

.strongman-app .sm-back-link:hover {
    color: #fff;
}

/* .sm-filter-active removed — rankings now uses canonical .sm-tab-active */

/* CMP-01: Featured Rivalries heading subtitle */
.strongman-app .sm-section-subtitle {
    font-size: 14px;
    color: var(--sm-text-muted);
    margin-top: 4px;
    margin-bottom: 16px;
}

/* AI Coach — Coming Soon card (coach.php) */
.sm-coming-soon-card {
    text-align: center;
    padding: var(--sm-space-12) var(--sm-space-8);
    background: var(--sm-surface);
    border-radius: var(--sm-radius-md);
    border: 1px solid var(--sm-border);
}

.sm-coming-soon-card .sm-coming-soon-icon {
    font-size: var(--sm-fs-3xl);
    margin-bottom: var(--sm-space-4);
}

.sm-coming-soon-card h2 {
    margin-bottom: var(--sm-space-2);
}

.sm-coming-soon-card p {
    color: var(--sm-text-muted);
    margin-bottom: var(--sm-space-6);
}

.sm-alternative-resources {
    margin-top: var(--sm-space-6);
}

/* ==========================================================================
   AUTO-LINKED ATHLETE NAMES
   ========================================================================== */

/* Athlete name links in data tables */
.sm-athlete-link {
    color: var(--sm-text-primary);
    text-decoration: none;
    font-weight: inherit;
    transition: color 0.15s ease;
}

.sm-athlete-link:hover {
    color: var(--sm-primary);
    text-decoration: none;
}


/* ==========================================================================
   WEIGHT CLASSES PAGE
   ========================================================================== */

.sm-wc-page {
    max-width: 900px;
    margin: 0 auto;
    padding: 32px 0 48px;
}

/* --- Table of Contents --- */

.sm-wc-toc {
    background: var(--sm-gray-50);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-md);
    padding: 24px 28px;
    margin-bottom: 40px;
}

.sm-wc-toc-title {
    font-size: 15px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--sm-text-muted);
    margin: 0 0 14px;
}

.sm-wc-toc-list {
    list-style: none !important;
    counter-reset: toc-counter;
    margin: 0;
    padding: 0;
    columns: 2;
    column-gap: 24px;
}

.sm-wc-toc-list li {
    list-style: none !important;
    counter-increment: toc-counter;
    break-inside: avoid;
    margin-bottom: 6px;
}

.sm-wc-toc-list li a {
    display: inline-flex;
    align-items: baseline;
    gap: 8px;
    color: var(--sm-text-secondary);
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    padding: 4px 0;
    transition: color 0.15s;
}

.sm-wc-toc-list li a::before {
    content: counter(toc-counter) ".";
    color: var(--sm-primary);
    font-weight: 700;
    font-size: 13px;
    min-width: 18px;
}

.sm-wc-toc-list li a:hover {
    color: var(--sm-primary);
}

/* --- Sections --- */

.sm-wc-section {
    margin-bottom: 48px;
    padding-bottom: 48px;
    border-bottom: 1px solid var(--sm-border);
}

.sm-wc-section:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.sm-wc-section-title {
    font-size: 22px;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
    margin: 0 0 8px;
    padding-left: 16px;
    border-left: 4px solid var(--sm-primary);
}

.sm-wc-section-intro {
    font-size: 15px;
    line-height: 1.7;
    color: var(--sm-text-secondary);
    margin: 0 0 24px;
    max-width: 720px;
}

.sm-wc-subtitle {
    font-size: 16px;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 28px 0 12px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.sm-wc-subtitle::before {
    content: "";
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--sm-primary);
    flex-shrink: 0;
}

/* --- Tables inside weight classes --- */

.sm-wc-section .sm-table-container-sa {
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius);
    overflow: hidden;
    margin-bottom: 8px;
}

.sm-wc-section .sm-table {
    margin: 0;
    border: none;
}

.sm-wc-section .sm-table thead th {
    background: var(--sm-gray-800);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 10px 16px;
    border-bottom: none;
    white-space: nowrap;
}

.sm-wc-section .sm-table tbody td {
    padding: 10px 16px;
    font-size: 14px;
    color: var(--sm-text-primary);
    border-bottom: 1px solid var(--sm-gray-100);
}

.sm-wc-section .sm-table tbody tr:last-child td {
    border-bottom: none;
}

.sm-wc-section .sm-table tbody tr:nth-child(even) {
    background: var(--sm-gray-50);
}

.sm-wc-section .sm-table tbody tr:hover {
    background: var(--sm-primary-light);
}

/* Highlight "No Limit" / "Open" rows */
.sm-wc-section .sm-table tbody tr:last-child td:first-child {
    font-weight: 700;
}

/* --- Timeline --- */

.sm-wc-timeline {
    position: relative;
    padding-left: 36px;
    margin: 24px 0 8px;
}

.sm-wc-timeline::before {
    content: "";
    position: absolute;
    left: 11px;
    top: 8px;
    bottom: 8px;
    width: 2px;
    background: linear-gradient(to bottom, var(--sm-primary), var(--sm-gray-300));
    border-radius: 2px;
}

.sm-wc-timeline-item {
    position: relative;
    margin-bottom: 28px;
}

.sm-wc-timeline-item:last-child {
    margin-bottom: 0;
}

.sm-wc-timeline-item::before {
    content: "";
    position: absolute;
    left: -30px;
    top: 6px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--sm-primary);
    border: 3px solid #fff;
    box-shadow: 0 0 0 2px var(--sm-primary);
    z-index: 1;
}

.sm-wc-timeline-year {
    font-size: 13px;
    font-weight: 700;
    color: var(--sm-primary);
    letter-spacing: 0.02em;
    margin-bottom: 4px;
}

.sm-wc-timeline-body strong {
    display: block;
    font-size: 16px;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin-bottom: 4px;
}

.sm-wc-timeline-body p {
    font-size: 14px;
    line-height: 1.65;
    color: var(--sm-text-secondary);
    margin: 0;
}

/* --- Tips Section --- */

.sm-wc-tips {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 32px;
}

.sm-wc-tip {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    padding: 18px 20px;
    background: var(--sm-gray-50);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius);
    transition: border-color 0.15s, box-shadow 0.15s;
}

.sm-wc-tip:hover {
    border-color: var(--sm-primary);
    box-shadow: var(--sm-shadow-sm);
}

.sm-wc-tip-number {
    width: 32px;
    height: 32px;
    min-width: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sm-primary);
    color: #fff;
    font-size: 14px;
    font-weight: var(--sm-weight-extrabold);
    border-radius: 50%;
}

.sm-wc-tip-body strong {
    display: block;
    font-size: 15px;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin-bottom: 4px;
}

.sm-wc-tip-body p {
    font-size: 14px;
    line-height: 1.65;
    color: var(--sm-text-secondary);
    margin: 0;
}

.sm-wc-tip-body a {
    color: var(--sm-primary);
    font-weight: 600;
    text-decoration: none;
}

.sm-wc-tip-body a:hover {
    text-decoration: underline;
}

/* --- CTA Links --- */

.sm-wc-cta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.sm-wc-cta-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 20px;
    background: var(--sm-gray-50);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-sm);
    color: var(--sm-text-primary);
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.15s;
}

.sm-wc-cta-link:hover {
    background: var(--sm-primary);
    border-color: var(--sm-primary);
    color: #fff;
    box-shadow: var(--sm-shadow-sm);
}

.sm-wc-cta-link svg {
    transition: transform 0.15s;
}

.sm-wc-cta-link:hover svg {
    transform: translateX(2px);
}

/* --- Federation Comparison Table --- */

#federation-comparison .sm-table tbody td:first-child {
    font-weight: 600;
    white-space: nowrap;
}

/* --- Equipment Specs Table --- */

#equipment-specs .sm-table tbody td:first-child {
    font-weight: 600;
    white-space: nowrap;
}

/* --- Responsive --- */

@media (max-width: 768px) {
    .sm-wc-page {
        padding: 20px 0 32px;
    }

    .sm-wc-toc {
        padding: 18px 20px;
    }

    .sm-wc-toc-list {
        columns: 1;
    }

    .sm-wc-section {
        margin-bottom: 32px;
        padding-bottom: 32px;
    }

    .sm-wc-section-title {
        font-size: 19px;
    }

    .sm-wc-tip {
        padding: 14px 16px;
    }

    .sm-wc-cta-row {
        flex-direction: column;
    }

    .sm-wc-cta-link {
        justify-content: center;
    }
}

/* --- Weight Class Leaderboard Tabs & Components --- */

.sm-wc-leaderboards {
    margin: 0 auto 2rem;
    max-width: 1100px;
}

.sm-wc-tabs {
    display: flex;
    gap: 0.375rem;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
}

.sm-wc-tab {
    padding: 8px 16px;
    font-size: 0.875rem;
    font-weight: 600;
    border: 1px solid var(--sm-border);
    border-radius: 999px;
    background: var(--sm-surface);
    color: var(--sm-text-secondary);
    cursor: pointer;
    transition: all 0.15s;
    font-family: inherit;
    line-height: 1.4;
}

.sm-wc-tab:hover {
    border-color: var(--sm-primary);
    color: var(--sm-primary);
}

.sm-wc-tab-active {
    background: var(--sm-primary);
    border-color: var(--sm-primary);
    color: #fff;
}

.sm-wc-tab-active:hover {
    color: #fff;
}

.sm-wc-count {
    display: inline-block;
    min-width: 22px;
    padding: 1px 6px;
    font-size: 0.75rem;
    font-weight: 700;
    border-radius: 99px;
    background: rgba(0, 0, 0, 0.08);
    margin-left: 6px;
}

.sm-wc-tab-active .sm-wc-count {
    background: rgba(255, 255, 255, 0.25);
}

/* Summary cards */
.sm-wc-summary {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 1.5rem;
}

.sm-wc-summary-card {
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius);
    padding: 16px 20px;
    text-align: center;
    transition: border-color 0.15s;
}

.sm-wc-summary-card:hover {
    border-color: var(--sm-primary);
}

.sm-wc-summary-value {
    font-size: 1.75rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
    line-height: 1.2;
}

.sm-wc-summary-label {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-top: 2px;
}

/* Sort bar */
.sm-wc-sort-bar {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}

.sm-wc-sort-label {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--sm-text-muted);
    margin-right: 4px;
}

.sm-wc-sort-btn {
    padding: 5px 12px;
    font-size: 0.8125rem;
    font-weight: 600;
    font-family: inherit;
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-sm);
    background: var(--sm-surface);
    color: var(--sm-text-secondary);
    cursor: pointer;
    transition: all 0.12s;
}

.sm-wc-sort-btn:hover {
    border-color: var(--sm-primary);
    color: var(--sm-primary);
}

.sm-wc-sort-active {
    background: var(--sm-primary-light);
    border-color: var(--sm-primary);
    color: var(--sm-primary);
}

/* Toolbar (per-page + results info) */
.sm-wc-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}

.sm-wc-results-info {
    font-size: 0.8125rem;
    color: var(--sm-text-muted);
}

/* Rank badges */
.sm-wc-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    font-size: 0.8125rem;
    font-weight: 700;
    border-radius: 50%;
    color: var(--sm-text-secondary);
}

.sm-wc-rank-gold {
    background: linear-gradient(135deg, var(--sm-gold), var(--sm-gold-end));
    color: var(--sm-gold-text);
    box-shadow: 0 1px 4px rgba(255, 184, 0, 0.35);
}

.sm-wc-rank-silver {
    background: linear-gradient(135deg, var(--sm-silver), var(--sm-silver-end));
    color: var(--sm-silver-text);
    box-shadow: 0 1px 4px rgba(168, 168, 168, 0.35);
}

.sm-wc-rank-bronze {
    background: linear-gradient(135deg, var(--sm-bronze), var(--sm-bronze-end));
    color: var(--sm-bronze-text);
    box-shadow: 0 1px 4px rgba(181, 105, 42, 0.35);
}

/* Highlight for athletes with 5+ wins */
.sm-wc-highlight {
    font-weight: 700;
    color: var(--sm-primary);
}

/* Responsive: Weight Class Leaderboards */
@media (max-width: 768px) {
    .sm-wc-summary {
        grid-template-columns: repeat(2, 1fr);
    }

    .sm-wc-summary-value {
        font-size: 1.375rem;
    }

    .sm-wc-tabs {
        gap: 0.25rem;
    }

    .sm-wc-tab {
        padding: 6px 12px;
        font-size: 0.8125rem;
    }

    .sm-wc-sort-bar {
        gap: 4px;
    }
}

@media (max-width: 480px) {
    .sm-wc-summary {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }

    .sm-wc-summary-card {
        padding: 12px 14px;
    }

    .sm-wc-summary-value {
        font-size: 1.125rem;
    }
}


/* ============================================================
   TRAINING GUIDES - HUB PAGE
   ============================================================ */

.sm-training-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
    gap: 20px;
    max-width: 1200px;
    margin: 24px auto 0;
    padding: 0 0 24px;
}

.sm-training-card {
    display: flex;
    gap: 18px;
    padding: 22px;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius, 8px);
    text-decoration: none;
    color: inherit;
    transition: all 0.2s ease;
    position: relative;
}

.sm-training-card:hover {
    border-color: var(--sm-primary);
    box-shadow: 0 4px 16px rgba(233, 69, 96, 0.12);
    transform: translateY(-2px);
}

.sm-training-card-icon {
    flex-shrink: 0;
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(233, 69, 96, 0.08);
    border-radius: 12px;
    color: var(--sm-primary);
    transition: background 0.2s ease;
}

.sm-training-card:hover .sm-training-card-icon {
    background: rgba(233, 69, 96, 0.14);
}

.sm-training-card-icon svg {
    width: 26px;
    height: 26px;
}

.sm-training-card-body {
    flex: 1;
    min-width: 0;
}

.sm-training-card-title {
    font-family: inherit;
    font-size: 17px;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0 0 6px;
}

.sm-training-card-desc {
    font-family: inherit;
    font-size: 14px;
    color: var(--sm-text-secondary);
    margin: 0 0 10px;
    line-height: 1.5;
}

.sm-training-card-cta {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-family: inherit;
    font-size: 14px;
    font-weight: 600;
    color: var(--sm-primary);
    transition: gap 0.15s;
}

.sm-training-card:hover .sm-training-card-cta {
    gap: 8px;
}

/* Related Links - pill buttons */
.sm-training-links {
    display: flex;
    justify-content: center;
    gap: 12px;
    padding: 8px 0 16px;
    flex-wrap: wrap;
}

.sm-training-link {
    font-family: inherit;
    font-size: 14px;
    font-weight: 500;
    color: var(--sm-primary);
    text-decoration: none;
    padding: 8px 18px;
    border: 1px solid rgba(233, 69, 96, 0.25);
    border-radius: 20px;
    transition: all 0.2s ease;
}

.sm-training-link:hover {
    background: var(--sm-primary);
    color: #fff;
    border-color: var(--sm-primary);
    text-decoration: none;
}


/* ============================================================
   TRAINING GUIDES - EVENT DETAIL PAGE
   ============================================================ */

.sm-training-guide-page {
    max-width: 860px;
    margin: 0 auto;
    padding: 0 0 24px;
}

/* Hero Image */
.sm-training-hero-image {
    margin: 0 0 8px;
    border-radius: var(--sm-radius, 8px);
    overflow: hidden;
    background: var(--sm-gray-50, #f8f9fb);
}

.sm-training-hero-image img {
    display: block;
    width: 100%;
    height: auto;
    max-height: 480px;
    object-fit: cover;
    object-position: center top;
}

.sm-training-hero-image figcaption {
    font-size: 0.75rem;
    color: var(--sm-text-muted, #6b7585);
    padding: 6px 12px;
    text-align: right;
}

/* Quick Nav TOC */
.sm-training-quicknav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 16px 0 8px;
    margin-bottom: 16px;
    border-bottom: 1px solid var(--sm-gray-200, #e8ecf1);
}

.sm-training-quicknav-link {
    font-size: 13px;
    font-weight: 500;
    color: var(--sm-text-secondary, #5a6577);
    text-decoration: none;
    padding: 5px 14px;
    border-radius: 16px;
    background: var(--sm-gray-50, #f8f9fb);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    transition: all 0.2s ease;
}

.sm-training-quicknav-link:hover {
    color: var(--sm-primary);
    border-color: var(--sm-primary);
    background: rgba(233, 69, 96, 0.05);
    text-decoration: none;
}

/* Section Headings */
.sm-training-guide-page .sm-section-heading {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin-bottom: 20px;
    padding-top: 8px;
}

.sm-training-guide-page .sm-section-icon {
    color: var(--sm-primary);
    flex-shrink: 0;
}

/* Technique Steps */
.sm-technique-steps {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.sm-technique-step {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    padding: 14px 16px;
    background: var(--sm-surface, #fff);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius, 8px);
    transition: border-color 0.15s ease;
}

.sm-technique-step:hover {
    border-color: rgba(233, 69, 96, 0.25);
}

.sm-step-number {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--sm-primary) 0%, var(--sm-primary-hover, #c81e45) 100%);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
}

.sm-step-text {
    flex: 1;
    font-size: var(--sm-fs-15);
    line-height: 1.6;
    color: var(--sm-text-primary);
    margin: 6px 0 0;
}

/* Common Mistakes */
.sm-mistakes-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.sm-mistake-item {
    background: var(--sm-gray-50, #f8f9fb);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius, 8px);
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.sm-mistake-wrong,
.sm-mistake-right {
    display: flex;
    gap: 12px;
    align-items: flex-start;
}

.sm-mistake-icon {
    flex-shrink: 0;
    margin-top: 2px;
}

.sm-mistake-icon-wrong {
    color: #ef4444;
}

.sm-mistake-icon-right {
    color: var(--sm-success, #2ecc71);
}

.sm-mistake-label {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 4px;
}

.sm-mistake-wrong .sm-mistake-label {
    color: #ef4444;
}

.sm-mistake-right .sm-mistake-label {
    color: var(--sm-success, #2ecc71);
}

.sm-mistake-text {
    font-size: var(--sm-fs-15);
    line-height: 1.5;
    color: var(--sm-text-primary);
}

/* Equipment Grid */
.sm-equipment-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 16px;
}

.sm-equipment-card {
    background: var(--sm-surface, #fff);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius, 8px);
    padding: 18px;
    border-top: 3px solid var(--sm-primary);
    transition: box-shadow 0.2s ease;
}

.sm-equipment-card:hover {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.sm-equipment-name {
    font-size: var(--sm-fs-15);
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0 0 6px;
}

.sm-equipment-desc {
    font-size: 0.8125rem;
    line-height: 1.5;
    color: var(--sm-text-secondary, #5a6577);
    margin: 0;
}

/* Progression Table */
.sm-progression-table th {
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.sm-progression-table td {
    font-size: var(--sm-fs-15);
}

.sm-training-guide-page .sm-text-muted {
    color: var(--sm-text-secondary, #5a6577);
    font-size: 0.8125rem;
}

/* Level badge in progression table */
.sm-level-badge {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 10px;
    font-size: 0.8125rem;
    font-weight: 600;
}

.sm-level-badge--beginner {
    background: rgba(46, 204, 113, 0.12);
    color: var(--sm-level-beginner, #2ecc71);
}

.sm-level-badge--intermediate {
    background: rgba(52, 152, 219, 0.12);
    color: var(--sm-level-intermediate, #3498db);
}

.sm-level-badge--advanced {
    background: rgba(243, 156, 18, 0.12);
    color: var(--sm-level-advanced, #f39c12);
}

.sm-level-badge--competition {
    background: rgba(233, 69, 96, 0.12);
    color: var(--sm-level-elite);
}

/* Related Links */
.sm-related-links-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 14px;
}

.sm-related-link-card {
    display: flex;
    gap: 14px;
    padding: 18px;
    background: var(--sm-surface);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius, 8px);
    text-decoration: none;
    transition: all 0.2s ease;
}

.sm-related-link-card:hover {
    border-color: var(--sm-primary);
    box-shadow: 0 4px 12px rgba(233, 69, 96, 0.1);
    text-decoration: none;
}

.sm-related-link-icon {
    flex-shrink: 0;
    color: var(--sm-primary);
}

.sm-related-link-title {
    font-size: var(--sm-fs-15);
    font-weight: 600;
    color: var(--sm-text-primary);
    margin: 0 0 3px;
}

.sm-related-link-desc {
    font-size: 0.8125rem;
    color: var(--sm-text-secondary, #5a6577);
    margin: 0;
}

/* Event Navigation */
.sm-event-nav {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding-top: 24px;
    margin-top: 8px;
    border-top: 1px solid var(--sm-gray-200, #e8ecf1);
}

.sm-event-nav-link {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    color: var(--sm-text-secondary, #5a6577);
    padding: 12px 16px;
    border-radius: var(--sm-radius, 8px);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    transition: all 0.15s ease;
}

.sm-event-nav-link:hover {
    background: var(--sm-gray-50, #f8f9fb);
    border-color: var(--sm-primary);
    color: var(--sm-primary);
    text-decoration: none;
}

.sm-event-nav-next {
    margin-left: auto;
    text-align: right;
}

.sm-event-nav-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--sm-text-muted, #6b7585);
}

.sm-event-nav-name {
    display: block;
    font-size: var(--sm-fs-15);
    font-weight: 600;
}

/* Section divider between major sections */
.sm-training-guide-page .sm-section {
    padding-bottom: 24px;
    border-bottom: 1px solid var(--sm-gray-100, #f0f2f5);
}

.sm-training-guide-page .sm-section:last-of-type {
    border-bottom: none;
}


/* Records & Benchmarks Callout */
.sm-training-records-callout {
    background: var(--sm-gray-50, #f8f9fb);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-left: 4px solid var(--sm-accent, #f5a623);
    border-radius: var(--sm-radius, 8px);
    padding: 20px 24px;
}

.sm-training-records-context {
    font-size: var(--sm-fs-15);
    line-height: 1.65;
    color: var(--sm-text-primary);
    margin: 0 0 16px 0;
}

.sm-training-records-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.sm-training-records-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--sm-electric, #0f3460);
    background: var(--sm-surface, #fff);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius-full, 9999px);
    text-decoration: none;
    transition: all 0.15s ease;
    white-space: nowrap;
}

.sm-training-records-link:hover {
    color: var(--sm-primary);
    border-color: var(--sm-primary);
    background: var(--sm-primary-light, rgba(233, 69, 96, 0.08));
}

.sm-training-records-link svg {
    flex-shrink: 0;
    opacity: 0.7;
}

.sm-training-records-link:hover svg {
    opacity: 1;
}

/* ============================================================
   TRAINING GUIDES - RESPONSIVE
   ============================================================ */

@media (max-width: 768px) {
    .sm-training-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .sm-training-card {
        padding: 16px;
    }

    .sm-training-links {
        flex-direction: column;
        align-items: center;
        gap: 10px;
    }

    .sm-training-link {
        width: 100%;
        text-align: center;
    }

    .sm-training-quicknav {
        gap: 6px;
    }

    .sm-training-quicknav-link {
        font-size: 12px;
        padding: 4px 10px;
    }

    .sm-technique-step {
        padding: 12px;
    }

    .sm-equipment-grid {
        grid-template-columns: 1fr;
    }

    .sm-related-links-grid {
        grid-template-columns: 1fr;
    }

    .sm-event-nav {
        flex-direction: column;
    }

    .sm-event-nav-next {
        margin-left: 0;
        text-align: left;
    }

    .sm-mistake-item {
        padding: 16px;
    }

    .sm-training-records-callout {
        padding: 16px;
    }

    .sm-training-records-links {
        gap: 8px;
    }

    .sm-training-records-link {
        font-size: 0.75rem;
        padding: 6px 12px;
    }
}

/* --------------------------------------------------------------------------
   SHARE BUTTON
   -------------------------------------------------------------------------- */

.sm-share-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius-full, 9999px);
    background: transparent;
    color: var(--sm-text-secondary, #5a6577);
    font-size: 13px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.sm-share-btn:hover {
    border-color: var(--sm-primary);
    color: var(--sm-primary);
}

/* White variant for dark headers */
.sm-share-btn-light {
    border-color: rgba(255, 255, 255, 0.3);
    color: rgba(255, 255, 255, 0.7);
}

.sm-share-btn-light:hover {
    border-color: rgba(255, 255, 255, 0.6);
    color: white;
}

/* --------------------------------------------------------------------------
   YEAR & COUNTRY HIGHLIGHTS
   -------------------------------------------------------------------------- */

.sm-year-highlights,
.sm-country-highlights {
    margin-bottom: var(--sm-space-6, 24px);
}

.sm-highlights-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 12px;
}

.sm-highlight-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 16px 12px;
    background: var(--sm-surface, #fff);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius, 8px);
    text-align: center;
}

.sm-highlight-value {
    font-size: 1.75rem;
    font-weight: 700;
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    color: var(--sm-primary);
    line-height: 1.2;
}

.sm-highlight-label {
    font-size: 0.75rem;
    color: var(--sm-text-secondary, #5a6577);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 4px;
    font-weight: 600;
}

@media (max-width: 480px) {
    .sm-highlights-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .sm-highlight-value {
        font-size: 1.375rem;
    }

    .sm-highlight-label {
        font-size: var(--sm-fs-2xs);
    }
}

/* ==========================================================================
   TRAINING GUIDE RESPONSIVE IMAGES
   ========================================================================== */

.sm-training-img {
    width: 100%;
    height: auto;
    border-radius: var(--sm-radius-md);
    object-fit: cover;
}

.sm-training-hero-img {
    max-height: 400px;
    width: 100%;
    object-fit: cover;
    border-radius: var(--sm-radius-lg);
}

@media (max-width: 768px) {
    .sm-training-hero-img {
        max-height: 250px;
    }
}

/* ==========================================================================
   NEWS HUB
   ========================================================================== */

.sm-news-toolbar {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.sm-news-search-wrap {
    position: relative;
    flex: 1;
    min-width: 200px;
}

.sm-news-search-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--sm-text-muted);
    pointer-events: none;
}

.sm-news-search-input {
    width: 100%;
    padding: 10px 14px 10px 42px;
    font-size: var(--sm-fs-15);
    font-family: var(--sm-font-body);
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
    background: var(--sm-surface);
    color: var(--sm-text-primary);
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.sm-news-search-input:focus {
    border-color: var(--sm-primary);
    box-shadow: 0 0 0 3px rgba(233, 69, 96, 0.08);
}

.sm-news-count {
    font-size: 0.875rem;
    color: var(--sm-text-muted);
    white-space: nowrap;
}

.sm-news-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.sm-news-card {
    display: flex;
    flex-direction: column;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform 0.2s, box-shadow 0.2s;
}

.sm-news-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.sm-news-card-image {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: var(--sm-gray-100);
}

.sm-news-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s;
}

.sm-news-card:hover .sm-news-card-image img {
    transform: scale(1.03);
}

.sm-news-card-body {
    padding: 1rem 1.25rem 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    flex: 1;
}

.sm-news-card-meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.75rem;
    color: var(--sm-text-muted);
}

.sm-news-source {
    font-weight: 600;
    color: var(--sm-primary);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.sm-news-date {
    color: var(--sm-text-muted);
}

.sm-news-card-title {
    font-size: 1.0625rem;
    font-weight: 700;
    font-family: var(--sm-font-heading);
    color: var(--sm-text-primary);
    line-height: 1.35;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sm-news-card-snippet {
    font-size: 0.875rem;
    color: var(--sm-text-secondary);
    line-height: 1.5;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sm-news-card-cta {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--sm-primary);
    margin-top: auto;
    padding-top: 0.5rem;
}

.sm-news-card-skeleton .sm-news-card-body {
    gap: 0.75rem;
}

/* Error state (shared by news, videos, glossary) */
.sm-error-state {
    text-align: center;
    padding: 3rem 1.5rem;
    color: var(--sm-text-muted);
}

.sm-error-state svg {
    color: var(--sm-error, #ef4444);
    margin-bottom: 1rem;
}

.sm-error-state h2 {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0 0 0.5rem;
}

.sm-error-state p {
    font-size: var(--sm-fs-15);
    margin: 0 0 1.5rem;
}

@media (max-width: 640px) {
    .sm-news-grid {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   VIDEOS HUB
   ========================================================================== */

.sm-videos-toolbar {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.sm-videos-search-wrap {
    position: relative;
    flex: 1;
    min-width: 200px;
}

.sm-videos-search-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--sm-text-muted);
    pointer-events: none;
}

.sm-videos-search-input {
    width: 100%;
    padding: 10px 14px 10px 42px;
    font-size: var(--sm-fs-15);
    font-family: var(--sm-font-body);
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
    background: var(--sm-surface);
    color: var(--sm-text-primary);
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.sm-videos-search-input:focus {
    border-color: var(--sm-primary);
    box-shadow: 0 0 0 3px rgba(233, 69, 96, 0.08);
}

.sm-videos-filters {
    display: flex;
    gap: 0.375rem;
    flex-wrap: wrap;
}

.sm-videos-filter-btn {
    padding: 6px 14px;
    font-size: 0.8125rem;
    font-weight: 600;
    font-family: var(--sm-font-body);
    border: 1px solid var(--sm-border);
    border-radius: 999px;
    background: var(--sm-surface);
    color: var(--sm-text-secondary);
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
}

.sm-videos-filter-btn:hover {
    border-color: var(--sm-primary);
    color: var(--sm-primary);
}

.sm-videos-filter-active {
    background: var(--sm-primary);
    border-color: var(--sm-primary);
    color: #fff;
}

.sm-videos-filter-active:hover {
    background: var(--sm-primary-hover);
    border-color: var(--sm-primary-hover);
    color: #fff;
}

.sm-videos-count {
    font-size: 0.875rem;
    color: var(--sm-text-muted);
    white-space: nowrap;
}

.sm-videos-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.sm-video-card {
    display: flex;
    flex-direction: column;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform 0.2s, box-shadow 0.2s;
}

.sm-video-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.sm-video-card-thumb {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: var(--sm-gray-900);
}

.sm-video-card-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s;
}

.sm-video-card:hover .sm-video-card-thumb img {
    transform: scale(1.03);
}

.sm-video-play-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.55);
    border-radius: 50%;
    color: #fff;
    opacity: 0.85;
    transition: opacity 0.2s, transform 0.2s;
}

.sm-video-card:hover .sm-video-play-icon {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.08);
}

.sm-video-card-thumb-skeleton {
    aspect-ratio: 16/9;
    width: 100%;
    border-radius: 0;
}

.sm-video-card-body {
    padding: 0.875rem 1rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    flex: 1;
}

.sm-video-card-title {
    font-size: var(--sm-fs-15);
    font-weight: 700;
    font-family: var(--sm-font-heading);
    color: var(--sm-text-primary);
    line-height: 1.35;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sm-video-card-meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.75rem;
    color: var(--sm-text-muted);
}

.sm-video-channel {
    font-weight: 600;
    color: var(--sm-text-secondary);
}

.sm-video-date {
    color: var(--sm-text-muted);
}

@media (max-width: 1024px) {
    .sm-videos-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .sm-videos-grid {
        grid-template-columns: 1fr;
    }

    .sm-videos-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .sm-videos-filters {
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 4px;
    }
}

/* ==========================================================================
   GLOSSARY
   ========================================================================== */

.sm-glossary-toolbar {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.sm-glossary-search-wrap {
    position: relative;
    flex: 1;
    min-width: 200px;
}

.sm-glossary-search-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--sm-text-muted);
    pointer-events: none;
}

.sm-glossary-search-input {
    width: 100%;
    padding: 10px 14px 10px 42px;
    font-size: var(--sm-fs-15);
    font-family: var(--sm-font-body);
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
    background: var(--sm-surface);
    color: var(--sm-text-primary);
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.sm-glossary-search-input:focus {
    border-color: var(--sm-primary);
    box-shadow: 0 0 0 3px rgba(233, 69, 96, 0.08);
}

.sm-glossary-count {
    font-size: 0.875rem;
    color: var(--sm-text-muted);
    white-space: nowrap;
}

/* A-Z Index */
.sm-glossary-az-index {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 1.5rem;
    padding: 0.75rem 1rem;
    background: var(--sm-gray-50, #f8f9fb);
    border-radius: var(--sm-radius-md, 10px);
    border: 1px solid var(--sm-border);
}

.sm-glossary-az-btn {
    width: 34px;
    height: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8125rem;
    font-weight: 700;
    font-family: var(--sm-font-heading);
    border: 1px solid transparent;
    border-radius: 6px;
    background: transparent;
    color: var(--sm-text-secondary);
    cursor: pointer;
    transition: all 0.15s;
}

.sm-glossary-az-btn:hover:not(:disabled) {
    background: var(--sm-surface);
    border-color: var(--sm-border);
    color: var(--sm-primary);
}

.sm-glossary-az-active {
    background: var(--sm-primary);
    border-color: var(--sm-primary);
    color: #fff;
}

.sm-glossary-az-disabled {
    opacity: 0.3;
    cursor: default;
}

/* Glossary Skeleton */
.sm-glossary-skeleton {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.sm-glossary-term-skeleton {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 1.25rem;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
}

/* Glossary Content */
.sm-glossary-content {
    margin-bottom: 2rem;
}

.sm-glossary-group {
    margin-bottom: 1.5rem;
    scroll-margin-top: 80px;
}

.sm-glossary-letter-heading {
    font-size: 1.5rem;
    font-weight: var(--sm-weight-extrabold);
    font-family: var(--sm-font-heading);
    color: var(--sm-primary);
    margin: 0 0 0.75rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--sm-primary-light);
}

.sm-glossary-terms {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.sm-glossary-term {
    padding: 1rem 1.25rem;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
    transition: border-color 0.2s;
}

.sm-glossary-term:hover {
    border-color: var(--sm-border-strong);
}

.sm-glossary-term-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.375rem;
    flex-wrap: wrap;
}

.sm-glossary-term-name {
    font-size: 1.0625rem;
    font-weight: 700;
    font-family: var(--sm-font-heading);
    color: var(--sm-text-primary);
    margin: 0;
}

.sm-glossary-category-badge {
    display: inline-flex;
    padding: 2px 10px;
    font-size: var(--sm-fs-2xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-radius: 999px;
    background: var(--sm-gray-100);
    color: var(--sm-text-secondary);
}

/* Category badge colors */
.sm-glossary-cat-deadlift {
    background: rgba(233, 69, 96, 0.1);
    color: var(--sm-primary);
}

.sm-glossary-cat-overhead {
    background: rgba(15, 52, 96, 0.1);
    color: var(--sm-electric);
}

.sm-glossary-cat-carry {
    background: rgba(46, 204, 113, 0.1);
    color: var(--sm-green-700);
}

.sm-glossary-cat-loading {
    background: rgba(245, 166, 35, 0.1);
    color: #b87800;
}

.sm-glossary-cat-yoke {
    background: rgba(155, 89, 182, 0.1);
    color: #7d3c98;
}

.sm-glossary-cat-throw,
.sm-glossary-cat-throwing {
    background: rgba(52, 152, 219, 0.1);
    color: #2471a3;
}

.sm-glossary-cat-grip {
    background: rgba(230, 126, 34, 0.1);
    color: #ca6f1e;
}

.sm-glossary-cat-stones {
    background: rgba(127, 140, 141, 0.1);
    color: #566573;
}

.sm-glossary-cat-squat {
    background: rgba(192, 57, 43, 0.1);
    color: #a93226;
}

.sm-glossary-cat-medley {
    background: rgba(39, 174, 96, 0.1);
    color: #1e8449;
}

.sm-glossary-term-desc {
    font-size: var(--sm-fs-15);
    color: var(--sm-text-secondary);
    line-height: 1.55;
    margin: 0 0 0.5rem;
}

.sm-glossary-term-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.sm-glossary-meta-item {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8125rem;
    color: var(--sm-text-muted);
}

.sm-glossary-meta-item svg {
    flex-shrink: 0;
    color: var(--sm-text-muted);
}

.sm-glossary-meta-item strong {
    color: var(--sm-text-secondary);
    font-weight: 600;
}

@media (max-width: 640px) {
    .sm-glossary-az-index {
        gap: 3px;
        padding: 0.5rem 0.75rem;
    }

    .sm-glossary-az-btn {
        width: 28px;
        height: 28px;
        font-size: 0.75rem;
    }

    .sm-glossary-term {
        padding: 0.875rem 1rem;
    }

    .sm-glossary-term-meta {
        flex-direction: column;
        gap: 0.5rem;
    }
}

/* ============================================================================
   Newsletter CTA
   ============================================================================ */
.sm-newsletter-cta {
    background: linear-gradient(135deg, var(--sm-navy) 0%, var(--sm-navy-light) 100%);
    border-radius: var(--sm-radius-lg);
    padding: 2.5rem;
    margin: 2rem 0;
    color: #fff;
}

.sm-newsletter-inner {
    max-width: 560px;
    margin: 0 auto;
    text-align: center;
}

.sm-newsletter-text h2 {
    font-size: 1.5rem;
    font-weight: var(--sm-weight-extrabold);
    margin: 0 0 0.5rem;
    color: #fff;
}

.sm-newsletter-text p {
    font-size: var(--sm-fs-15);
    color: rgba(255, 255, 255, 0.75);
    margin: 0 0 1.5rem;
    line-height: 1.5;
}

.sm-newsletter-input-wrap {
    display: flex;
    gap: 0.5rem;
}

.sm-newsletter-input {
    flex: 1;
    padding: 12px 16px;
    font-size: var(--sm-fs-15);
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--sm-radius-md);
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    outline: none;
    transition: border-color 0.2s;
}

.sm-newsletter-input::placeholder {
    color: rgba(255, 255, 255, 0.4);
}

.sm-newsletter-input:focus {
    border-color: var(--sm-primary);
}

.sm-newsletter-btn {
    padding: 12px 24px;
    font-size: var(--sm-fs-15);
    font-weight: 700;
    background: var(--sm-primary);
    color: #fff;
    border: none;
    border-radius: var(--sm-radius-md);
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.2s;
}

.sm-newsletter-btn:hover {
    background: #d63851;
}

.sm-newsletter-btn:disabled {
    opacity: 0.6;
    cursor: wait;
}

.sm-newsletter-privacy {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.45);
    margin: 0.75rem 0 0;
}

.sm-newsletter-success {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    color: #4ade80;
}

.sm-newsletter-success p {
    margin: 0;
    font-weight: 600;
}

@media (max-width: 640px) {
    .sm-newsletter-cta {
        padding: 1.5rem;
    }

    .sm-newsletter-input-wrap {
        flex-direction: column;
    }

    .sm-newsletter-text h2 {
        font-size: 1.25rem;
    }
}

/* ============================================================
   COMPARE VS - Static Head-to-Head Pages
   /strongman/compare/{slug-a}-vs-{slug-b}/
   ============================================================ */

/* Header */
.strongman-app .sm-vs-header {
    text-align: center;
    padding-bottom: var(--sm-space-4);
}

.strongman-app .sm-vs-title {
    font-size: clamp(1.5rem, 4vw, 2.5rem);
    letter-spacing: -0.02em;
}

/* Cards layout with VS badge in center — higher specificity to beat .sm-compare-cards from data bundle */
.strongman-app .sm-compare-cards.sm-vs-cards {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: var(--sm-space-4);
    align-items: start;
    margin-bottom: var(--sm-space-8);
}

.strongman-app .sm-vs-card {
    text-align: center;
    padding: 0;
}

.strongman-app .sm-vs-card .sm-compare-card-photo {
    height: 220px;
}

.strongman-app .sm-vs-card .sm-compare-card-name {
    font-size: var(--sm-fs-xl);
}

.strongman-app .sm-vs-card .sm-compare-card-name a {
    color: var(--sm-text-primary);
    text-decoration: none;
    transition: color 0.15s;
}

.strongman-app .sm-vs-card .sm-compare-card-name a:hover {
    color: var(--sm-primary);
}

/* Physical stats pills under each card */
.strongman-app .sm-vs-card-stats {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--sm-space-2);
    margin-top: var(--sm-space-3);
    padding: 0 16px 16px;
}

.strongman-app .sm-vs-stat-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: var(--sm-bg, #f8f9fb);
    border: 1px solid var(--sm-border, #e8ecf1);
    border-radius: 999px;
    font-size: var(--sm-fs-xs);
    color: var(--sm-text-secondary);
}

.strongman-app .sm-vs-stat-label {
    font-weight: 600;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-size: 10px;
}

/* VS Badge (centered between cards) */
.strongman-app .sm-vs-badge {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--sm-space-2);
    padding-top: 100px;
}

.strongman-app .sm-vs-badge-text {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--sm-primary) 0%, #c9364a 100%);
    color: #fff;
    font-weight: var(--sm-weight-extrabold);
    font-size: 1.25rem;
    letter-spacing: 0.02em;
    box-shadow: 0 4px 16px rgba(233, 69, 96, 0.3);
}

.strongman-app .sm-vs-switch-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 12px;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border, #e8ecf1);
    border-radius: var(--sm-radius);
    font-size: var(--sm-fs-xs);
    color: var(--sm-text-muted);
    cursor: pointer;
    transition: all 0.15s;
    font-family: inherit;
    font-weight: 500;
}

.strongman-app .sm-vs-switch-btn:hover {
    border-color: var(--sm-primary);
    color: var(--sm-primary);
    background: rgba(233, 69, 96, 0.04);
}

.strongman-app .sm-vs-switch-btn svg {
    width: 14px;
    height: 14px;
}

/* Action buttons row */
.strongman-app .sm-vs-actions {
    display: flex;
    justify-content: center;
    gap: var(--sm-space-3);
    margin-top: var(--sm-space-6);
    padding-top: var(--sm-space-4);
    border-top: 1px solid var(--sm-border, #e8ecf1);
}

/* Responsive: stack cards on mobile */
@media (max-width: 768px) {
    .strongman-app .sm-compare-cards.sm-vs-cards {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .strongman-app .sm-vs-badge {
        flex-direction: row;
        padding-top: 0;
        padding: var(--sm-space-3) 0;
        justify-content: center;
    }

    .strongman-app .sm-vs-badge-text {
        width: 44px;
        height: 44px;
        font-size: 1rem;
    }

    .strongman-app .sm-vs-card {
        padding: 0;
    }

    .strongman-app .sm-vs-card .sm-compare-card-photo {
        height: 160px;
    }

    .strongman-app .sm-vs-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .strongman-app .sm-vs-actions .sm-btn {
        text-align: center;
        justify-content: center;
    }
}

/* ==========================================================================
   Record Progression Pillar Page (sm-rp-)
   ========================================================================== */

/* Skeleton Loader */
.sm-rp-skeleton {
    animation: sm-rp-shimmer 1.5s ease-in-out infinite;
}

@keyframes sm-rp-shimmer {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.5;
    }
}

.sm-rp-skel-header {
    margin-bottom: 24px;
}

.sm-rp-skel-badges {
    display: flex;
    gap: 8px;
    margin-top: 12px;
}

.sm-skeleton-badge {
    width: 100px;
    height: 24px;
    border-radius: 12px;
    background: #e5e7eb;
}

.sm-rp-skel-record-card {
    margin-bottom: 24px;
}

/* Badges Row in Header */
.sm-rp-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
}

/* Division Toggle in Header */
.sm-rp-division-toggle {
    display: flex;
    gap: 6px;
    margin-top: 16px;
}

/* Current Record Holder Card */
.sm-rp-current-record {
    margin: 24px 0;
}

.sm-rp-record-card {
    background: linear-gradient(135deg, #fef2f2 0%, #fff 100%);
    border: 1px solid #fecaca;
    border-radius: 12px;
    padding: 24px;
    display: flex;
    align-items: center;
    gap: 20px;
    position: relative;
    overflow: hidden;
}

.sm-rp-record-label {
    position: absolute;
    top: 12px;
    left: 24px;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #dc2626;
}

.sm-rp-record-main {
    flex: 1;
    padding-top: 16px;
}

.sm-rp-record-value {
    font-size: 2rem;
    font-weight: var(--sm-weight-extrabold);
    color: #111827;
    line-height: 1.2;
    font-family: var(--sm-font-heading, 'DM Sans', sans-serif);
}

.sm-rp-record-details {
    margin-top: 6px;
}

.sm-rp-record-name {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--sm-navy);
}

a.sm-rp-record-name:hover {
    color: #dc2626;
}

.sm-rp-record-meta {
    font-size: 0.85rem;
    color: #6b7280;
    margin-top: 4px;
}

.sm-rp-record-icon {
    flex-shrink: 0;
    color: #fbbf24;
    opacity: 0.6;
}

/* Chart Section */
.sm-rp-chart-section {
    margin: 24px 0;
}

.sm-rp-chart-section .sm-section-heading {
    margin-bottom: 12px;
}

/* Highlights Row */
.sm-rp-highlights {
    margin: 32px 0;
}

.sm-rp-highlight-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.sm-rp-highlight-card {
    background: var(--sm-surface);
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    padding: 20px;
}

.sm-rp-highlight-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.95rem;
    font-weight: 700;
    color: #111827;
    margin: 0 0 16px 0;
    font-family: var(--sm-font-heading, 'DM Sans', sans-serif);
}

.sm-rp-highlight-title svg {
    color: #dc2626;
    flex-shrink: 0;
}

.sm-rp-highlight-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.sm-rp-highlight-empty {
    font-size: 0.85rem;
    color: #9ca3af;
    font-style: italic;
}

/* Biggest Jump Items */
.sm-rp-jump-item {
    display: flex;
    align-items: center;
    gap: 12px;
}

.sm-rp-jump-rank {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fef2f2;
    color: #dc2626;
    font-weight: 700;
    font-size: 0.75rem;
    border-radius: 50%;
}

.sm-rp-jump-info {
    flex: 1;
}

.sm-rp-jump-delta {
    font-weight: 700;
    font-size: 1rem;
    color: #16a34a;
}

.sm-rp-jump-details {
    font-size: 0.8rem;
    color: #6b7280;
}

.sm-rp-jump-year {
    color: #9ca3af;
}

/* Longest-Held Record */
.sm-rp-longest-item {
    display: flex;
    align-items: center;
    gap: 16px;
}

.sm-rp-longest-duration {
    flex-shrink: 0;
    text-align: center;
    min-width: 60px;
}

.sm-rp-longest-years {
    display: block;
    font-size: 2rem;
    font-weight: var(--sm-weight-extrabold);
    color: #dc2626;
    line-height: 1.1;
}

.sm-rp-longest-label {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #6b7280;
}

.sm-rp-longest-info {
    flex: 1;
}

.sm-rp-longest-value {
    font-weight: 700;
    font-size: 1rem;
    color: #111827;
}

.sm-rp-longest-details {
    font-size: 0.85rem;
    color: #6b7280;
    margin-top: 2px;
}

.sm-rp-longest-period {
    display: block;
    font-size: 0.75rem;
    color: #9ca3af;
    margin-top: 2px;
}

/* Record Timeline Table */
.sm-rp-timeline {
    margin: 32px 0;
}

.sm-rp-timeline-table .sm-rp-value-cell {
    font-weight: 700;
    color: #111827;
}

.sm-rp-row-current {
    background: #f0fdf4;
}

.sm-rp-row-current td {
    font-weight: 600;
}

/* Delta badges */
.sm-rp-delta {
    display: inline-block;
    font-size: 0.8rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
    background: #f3f4f6;
    color: #6b7280;
    white-space: nowrap;
}

.sm-rp-delta-positive {
    background: #dcfce7;
    color: #16a34a;
}

.sm-rp-delta-first {
    background: #dbeafe;
    color: #2563eb;
    font-style: italic;
}

/* Pillar CTA (selector view link to full page) */
.sm-rp-pillar-cta {
    margin-bottom: 16px;
    text-align: right;
}

.sm-rp-pillar-cta .sm-btn-outline {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    font-size: 0.85rem;
    font-weight: 600;
    color: #dc2626;
    border: 1px solid #dc2626;
    border-radius: 8px;
    text-decoration: none;
    transition: all 0.15s;
    background: transparent;
}

.sm-rp-pillar-cta .sm-btn-outline:hover {
    background: #dc2626;
    color: #fff;
}

/* Progression Controls (selector view) */
.sm-progression-controls {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: flex-end;
    margin-bottom: 24px;
    padding: 16px;
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
}

.sm-progression-select-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.sm-progression-label {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #6b7280;
}

.sm-progression-division {
    display: flex;
    gap: 6px;
}

.sm-progression-empty {
    text-align: center;
    padding: 60px 24px;
    color: #6b7280;
}

.sm-progression-empty svg {
    color: #d1d5db;
    margin-bottom: 16px;
}

.sm-progression-empty h2 {
    font-size: 1.1rem;
    font-weight: 600;
    color: #374151;
    margin: 0 0 8px;
}

.sm-progression-empty p {
    font-size: 0.9rem;
    max-width: 400px;
    margin: 0 auto;
}

.sm-progression-chart-wrap {
    background: var(--sm-surface);
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    padding: 20px;
    margin-bottom: 24px;
    position: relative;
    min-height: 300px;
}

.sm-progression-table-section {
    margin-top: 24px;
}

/* Responsive */
@media (max-width: 768px) {
    .sm-rp-highlight-grid {
        grid-template-columns: 1fr;
    }

    .sm-rp-record-card {
        flex-direction: column;
        text-align: center;
    }

    .sm-rp-record-icon {
        position: absolute;
        top: 12px;
        right: 16px;
        opacity: 0.3;
    }

    .sm-rp-record-value {
        font-size: 1.5rem;
    }

    .sm-progression-controls {
        flex-direction: column;
        align-items: stretch;
    }

    .sm-rp-pillar-cta {
        text-align: center;
    }
}

/* ===================================================================
   SECTION 25: World's Strongest Man Hub
   =================================================================== */

/* WSM Page Header Enhancement */
.strongman-app .sm-wsm-page-header {
    background: linear-gradient(135deg, var(--sm-navy) 0%, var(--sm-navy-light) 50%, var(--sm-electric) 100%);
    position: relative;
    overflow: hidden;
}

.strongman-app .sm-wsm-page-header::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(233, 69, 96, 0.15) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}

/* Quick Stats Bar */
.strongman-app .sm-wsm-stats-bar {
    margin-bottom: var(--sm-space-8, 32px);
}

.strongman-app .sm-wsm-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--sm-space-4, 16px);
}

.strongman-app .sm-wsm-stat-card {
    background: var(--sm-bg-card, #fff);
    border: 1px solid var(--sm-border, #e8ecf1);
    border-radius: var(--sm-radius-lg, 12px);
    padding: var(--sm-space-5, 20px);
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.strongman-app .sm-wsm-stat-card-champion {
    border-color: #d4a017;
    background: linear-gradient(135deg, #fffbeb 0%, #fef3c7 100%);
}

.strongman-app .sm-wsm-stat-value {
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-size: 1.75rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
    line-height: 1.2;
}

.strongman-app .sm-wsm-stat-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--sm-text-muted, #6b7280);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Champions Timeline */
.strongman-app .sm-wsm-timeline {
    position: relative;
    padding: var(--sm-space-4, 16px) 0;
}

.strongman-app .sm-wsm-timeline-line {
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 3px;
    background: linear-gradient(180deg, var(--sm-primary) 0%, var(--sm-border, #e8ecf1) 100%);
    transform: translateX(-50%);
    border-radius: 2px;
}

.strongman-app .sm-wsm-year-card {
    position: relative;
    display: flex;
    align-items: flex-start;
    margin-bottom: var(--sm-space-4, 16px);
    width: 50%;
}

.strongman-app .sm-wsm-year-card-left {
    padding-right: var(--sm-space-8, 32px);
    flex-direction: row-reverse;
    margin-left: 0;
    text-align: right;
}

.strongman-app .sm-wsm-year-card-right {
    padding-left: var(--sm-space-8, 32px);
    margin-left: 50%;
}

/* Year marker dot + label */
.strongman-app .sm-wsm-year-marker {
    position: absolute;
    display: flex;
    align-items: center;
    gap: var(--sm-space-2, 8px);
    z-index: 2;
}

.strongman-app .sm-wsm-year-card-left .sm-wsm-year-marker {
    right: -12px;
    flex-direction: row-reverse;
}

.strongman-app .sm-wsm-year-card-right .sm-wsm-year-marker {
    left: -12px;
}

.strongman-app .sm-wsm-year-dot {
    display: inline-block;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--sm-bg-card, #fff);
    border: 3px solid var(--sm-border, #e8ecf1);
    flex-shrink: 0;
}

.strongman-app .sm-wsm-year-dot-current {
    border-color: #d4a017;
    background: #fbbf24;
    box-shadow: 0 0 0 4px rgba(251, 191, 36, 0.25);
}

.strongman-app .sm-wsm-year-dot-start {
    border-color: var(--sm-primary);
    background: var(--sm-primary);
}

.strongman-app .sm-wsm-year-label {
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--sm-text-muted, #6b7280);
    white-space: nowrap;
}

/* Year card content box */
.strongman-app .sm-wsm-year-content {
    background: var(--sm-bg-card, #fff);
    border: 1px solid var(--sm-border, #e8ecf1);
    border-radius: var(--sm-radius-lg, 12px);
    padding: var(--sm-space-4, 16px);
    flex: 1;
    transition: box-shadow 0.2s ease, border-color 0.2s ease;
}

.strongman-app .sm-wsm-year-content:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    border-color: var(--sm-primary);
}

/* Current champion highlight */
.strongman-app .sm-wsm-champion-highlight .sm-wsm-year-content {
    border-color: #d4a017;
    background: linear-gradient(135deg, #fffbeb 0%, #fff 50%);
    box-shadow: 0 4px 16px rgba(212, 160, 23, 0.15);
}

.strongman-app .sm-wsm-year-header {
    margin-bottom: var(--sm-space-2, 8px);
}

.strongman-app .sm-wsm-contest-link {
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-size: var(--sm-fs-15);
    font-weight: 700;
    color: var(--sm-text-primary);
    text-decoration: none;
    transition: color 0.15s;
}

.strongman-app .sm-wsm-contest-link:hover {
    color: var(--sm-primary);
}

.strongman-app .sm-wsm-year-details {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 0.8125rem;
    color: var(--sm-text-secondary, #4b5563);
}

/* Winner row */
.strongman-app .sm-wsm-winner {
    display: flex;
    align-items: center;
    gap: 6px;
    font-weight: 600;
}

.strongman-app .sm-wsm-year-card-left .sm-wsm-winner {
    justify-content: flex-end;
}

.strongman-app .sm-wsm-trophy-icon {
    color: #d4a017;
    flex-shrink: 0;
}

.strongman-app .sm-wsm-winner-name {
    color: var(--sm-text-primary);
    text-decoration: none;
    font-weight: 700;
    transition: color 0.15s;
}

.strongman-app .sm-wsm-winner-name:hover {
    color: var(--sm-primary);
}

/* Runner-up */
.strongman-app .sm-wsm-runner-up {
    font-size: 0.75rem;
    color: var(--sm-text-muted, #6b7280);
}

.strongman-app .sm-wsm-runner-up-label {
    font-weight: 600;
}

/* Location */
.strongman-app .sm-wsm-location {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 0.75rem;
    color: var(--sm-text-muted, #6b7280);
}

.strongman-app .sm-wsm-year-card-left .sm-wsm-location {
    justify-content: flex-end;
}

/* Athletes count */
.strongman-app .sm-wsm-athletes-count {
    font-size: 0.75rem;
    color: var(--sm-text-muted, #6b7280);
}

/* Timeline start marker */
.strongman-app .sm-wsm-timeline-start {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: var(--sm-space-4, 16px);
    position: relative;
}

.strongman-app .sm-wsm-timeline-start-label {
    margin-top: var(--sm-space-2, 8px);
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--sm-primary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Leaderboard Section */
.strongman-app .sm-wsm-leaderboard-section {
    margin-top: var(--sm-space-8, 32px);
}

.strongman-app .sm-wsm-leaderboard-table .sm-rank-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    font-weight: var(--sm-weight-extrabold);
    font-size: 0.875rem;
    background: var(--sm-bg, #f8f9fb);
    color: var(--sm-text-secondary, #4b5563);
}

.strongman-app .sm-wsm-leaderboard-table .sm-rank-gold {
    background: linear-gradient(135deg, var(--sm-gold), var(--sm-gold-end));
    color: var(--sm-gold-text);
    box-shadow: 0 2px 6px rgba(251, 191, 36, 0.4);
}

.strongman-app .sm-wsm-leaderboard-table .sm-rank-silver {
    background: linear-gradient(135deg, var(--sm-silver), var(--sm-silver-end));
    color: var(--sm-silver-text);
    box-shadow: 0 2px 6px rgba(156, 163, 175, 0.4);
}

.strongman-app .sm-wsm-leaderboard-table .sm-rank-bronze {
    background: linear-gradient(135deg, var(--sm-bronze), var(--sm-bronze-end));
    color: var(--sm-bronze-text);
    box-shadow: 0 2px 6px rgba(217, 119, 6, 0.4);
}

.strongman-app .sm-wsm-row-top3 {
    background: rgba(251, 191, 36, 0.04);
}

.strongman-app .sm-wsm-titles-count {
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-weight: var(--sm-weight-extrabold);
    font-size: 1.125rem;
    color: var(--sm-text-primary);
}

.strongman-app .sm-wsm-years-won {
    font-size: 0.8125rem;
    color: var(--sm-text-secondary, #4b5563);
}

/* Decade Breakdown */
.strongman-app .sm-wsm-decades-section {
    margin-top: var(--sm-space-8, 32px);
}

.strongman-app .sm-wsm-decades {
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-3, 12px);
}

.strongman-app .sm-wsm-decade {
    background: var(--sm-bg-card, #fff);
    border: 1px solid var(--sm-border, #e8ecf1);
    border-radius: var(--sm-radius-lg, 12px);
    overflow: hidden;
}

.strongman-app .sm-wsm-decade-toggle {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3, 12px);
    width: 100%;
    padding: var(--sm-space-4, 16px) var(--sm-space-5, 20px);
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    transition: background 0.15s;
}

.strongman-app .sm-wsm-decade-toggle:hover {
    background: var(--sm-bg, #f8f9fb);
}

.strongman-app .sm-wsm-decade-label {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--sm-text-primary);
}

.strongman-app .sm-wsm-decade-summary {
    font-size: 0.8125rem;
    color: var(--sm-text-muted, #6b7280);
    margin-left: auto;
}

.strongman-app .sm-wsm-decade-chevron {
    color: var(--sm-text-muted, #6b7280);
    flex-shrink: 0;
    transition: transform 0.3s ease;
}

.strongman-app .sm-wsm-decade-body {
    padding: 0 var(--sm-space-5, 20px) var(--sm-space-5, 20px);
}

.strongman-app .sm-wsm-decade-highlights {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sm-space-6, 24px);
    padding: var(--sm-space-4, 16px);
    background: var(--sm-bg, #f8f9fb);
    border-radius: var(--sm-radius, 8px);
    margin-bottom: var(--sm-space-4, 16px);
}

.strongman-app .sm-wsm-decade-fact {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.strongman-app .sm-wsm-decade-fact-label {
    font-size: var(--sm-fs-2xs);
    font-weight: 600;
    color: var(--sm-text-muted, #6b7280);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.strongman-app .sm-wsm-decade-fact-value {
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-size: 1rem;
    font-weight: 700;
    color: var(--sm-text-primary);
}

/* Compact table variant for decade breakdown */
.strongman-app .sm-table--compact th,
.strongman-app .sm-table--compact td {
    padding: 8px 12px;
    font-size: 0.8125rem;
}

/* Section subtext (used under leaderboard heading) */
.strongman-app .sm-section-subtext {
    font-size: 0.875rem;
    color: var(--sm-text-muted, #6b7280);
    margin: -8px 0 var(--sm-space-4, 16px) 0;
}

/* ============================
   WSM Hub - Responsive
   ============================ */

@media (max-width: 1024px) {
    .strongman-app .sm-wsm-stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {

    /* Stats: 2 columns on tablet, stack nicely */
    .strongman-app .sm-wsm-stat-value {
        font-size: 1.375rem;
    }

    /* Timeline: single column layout on mobile */
    .strongman-app .sm-wsm-timeline-line {
        left: 16px;
    }

    .strongman-app .sm-wsm-year-card,
    .strongman-app .sm-wsm-year-card-left,
    .strongman-app .sm-wsm-year-card-right {
        width: 100%;
        margin-left: 0;
        padding-left: 48px;
        padding-right: 0;
        flex-direction: row;
        text-align: left;
    }

    .strongman-app .sm-wsm-year-card-left .sm-wsm-year-marker,
    .strongman-app .sm-wsm-year-card-right .sm-wsm-year-marker {
        left: 6px;
        right: auto;
        flex-direction: row;
    }

    .strongman-app .sm-wsm-year-card-left .sm-wsm-winner,
    .strongman-app .sm-wsm-year-card-left .sm-wsm-location {
        justify-content: flex-start;
    }

    .strongman-app .sm-wsm-timeline-start {
        margin-left: 6px;
        align-items: flex-start;
    }

    /* Decades: stack facts */
    .strongman-app .sm-wsm-decade-highlights {
        gap: var(--sm-space-4, 16px);
    }

    .strongman-app .sm-wsm-decade-toggle {
        padding: var(--sm-space-3, 12px) var(--sm-space-4, 16px);
    }
}

@media (max-width: 480px) {
    .strongman-app .sm-wsm-stats-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--sm-space-2, 8px);
    }

    .strongman-app .sm-wsm-stat-card {
        padding: var(--sm-space-3, 12px);
    }

    .strongman-app .sm-wsm-stat-value {
        font-size: 1.125rem;
    }

    .strongman-app .sm-wsm-year-content {
        padding: var(--sm-space-3, 12px);
    }

    .strongman-app .sm-wsm-decade-label {
        font-size: 1rem;
    }
}

/* ==========================================================================
   RECORDS CTA ROW
   ========================================================================== */

.sm-records-cta-row {
    display: flex;
    gap: 16px;
    margin: 32px 0;
}

.sm-records-cta-card {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 20px 24px;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-md);
    text-decoration: none !important;
    color: var(--sm-text-primary) !important;
    transition: all 0.15s ease;
}

.sm-records-cta-card:hover {
    border-color: var(--sm-primary);
    box-shadow: 0 2px 12px rgba(233, 69, 96, 0.1);
    transform: translateY(-2px);
}

.sm-records-cta-card-title {
    font-weight: 700;
    font-size: 1rem;
    color: var(--sm-text-primary);
}

.sm-records-cta-card:hover .sm-records-cta-card-title {
    color: var(--sm-primary);
}

.sm-records-cta-card-desc {
    font-size: 0.85rem;
    color: var(--sm-text-secondary);
    line-height: 1.4;
}

@media (max-width: 768px) {
    .sm-records-cta-row {
        flex-direction: column;
        gap: 12px;
    }
}

/* ==========================================================================
   COMMUNITY FEED ACTION ROW
   ========================================================================== */

.sm-feed-action-row {
    display: flex;
    gap: 10px;
    padding: 16px 0;
    margin-bottom: 8px;
    flex-wrap: wrap;
}

.sm-feed-action-pill {
    gap: 6px;
    white-space: nowrap;
}

@media (max-width: 480px) {
    .sm-feed-action-row {
        gap: 8px;
    }

    .sm-feed-action-pill {
        flex: 1;
        justify-content: center;
    }
}

/* ==========================================================================
   COMPETITION HEADER ACTIONS (Share + Follow)
   ========================================================================== */

.sm-contest-header-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 8px;
    flex-wrap: wrap;
}

.sm-follow-btn-active {
    background: var(--sm-primary-light);
    border-color: var(--sm-primary);
    color: var(--sm-primary);
}

/* ==========================================================================
   EVENT CHIPS - Inline pill links for event names
   ========================================================================== */

.sm-event-chip {
    display: inline-flex;
    align-items: center;
    padding: 2px 10px;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--sm-gray-700);
    background: var(--sm-gray-50);
    border: 1px solid var(--sm-gray-200);
    border-radius: 999px;
    text-decoration: none;
    transition: all 0.15s ease;
    white-space: nowrap;
    line-height: 1.5;
}

.sm-event-chip:hover {
    background: var(--sm-primary-light);
    border-color: var(--sm-primary-soft);
    color: var(--sm-primary-hover);
}

/* ==========================================================================
   TRAIN THIS EVENT CTA - Button/link for records to training cross-links
   ========================================================================== */

.sm-train-cta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    font-size: 0.875rem;
    font-weight: 600;
    color: #fff;
    background: var(--sm-primary);
    border: none;
    border-radius: var(--sm-radius);
    text-decoration: none;
    transition: all 0.15s ease;
    cursor: pointer;
}

.sm-train-cta:hover {
    background: var(--sm-primary-hover);
    color: #fff;
}

.sm-train-cta svg {
    flex-shrink: 0;
}

.sm-train-cta-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 16px 0;
    flex-wrap: wrap;
}

/* =========================================================================
   Following Panel (shared classes for dashboard + future reuse)
   ========================================================================= */

.sm-following-panel {
    margin-bottom: var(--sm-space-6, 24px);
}

.sm-following-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.sm-following-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sm-space-3, 12px);
    padding: var(--sm-space-3, 12px) 0;
    border-bottom: 1px solid var(--sm-gray-100, #f0f2f5);
}

.sm-following-item:last-child {
    border-bottom: none;
}

/* ==========================================================================
   RECORD MINI-CHART (records/event page sparkline)
   ========================================================================== */

.sm-record-mini-chart {
    background: var(--sm-surface, #fff);
    border: 1px solid var(--sm-border, #e5e7eb);
    border-radius: 10px;
    padding: 16px 20px;
    margin-bottom: 16px;
}

.sm-record-mini-chart__header {
    display: flex;
    align-items: baseline;
    gap: 12px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}

.sm-record-mini-chart__title {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--sm-text-primary, #111827);
    margin: 0;
}

.sm-record-mini-chart__title svg {
    color: var(--sm-primary);
    flex-shrink: 0;
}

.sm-record-mini-chart__subtitle {
    font-size: 0.8rem;
    color: var(--sm-text-secondary, #6b7280);
}

.sm-record-mini-chart__canvas-wrap {
    position: relative;
    height: 200px;
    max-height: 200px;
}

@media (max-width: 768px) {
    .sm-record-mini-chart {
        padding: 12px 14px;
    }

    .sm-record-mini-chart__canvas-wrap {
        height: 160px;
        max-height: 160px;
    }
}

/* ==========================================================================
   YEAR HIGHLIGHTS - Champion cards, trophy, top countries
   ========================================================================== */

.sm-section-title-icon {
    display: inline-block;
    vertical-align: -3px;
    margin-right: 6px;
    color: var(--sm-primary);
}

.sm-champions-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: var(--sm-space-3, 12px);
}

.sm-champion-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: var(--sm-space-4, 16px);
    background: var(--sm-surface, #fff);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius, 8px);
    transition: box-shadow 0.15s ease;
}

.sm-champion-card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}

.sm-champion-card--major {
    border-color: rgba(233, 69, 96, 0.3);
    background: linear-gradient(135deg, rgba(233, 69, 96, 0.03) 0%, rgba(255, 215, 0, 0.03) 100%);
}

.sm-champion-trophy {
    position: absolute;
    top: 10px;
    right: 10px;
    color: #d4a017;
}

.sm-champion-series {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--sm-text-secondary, #6b7a90);
}

.sm-champion-name {
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-size: 1.0625rem;
    font-weight: 700;
    color: var(--sm-text-primary);
}

.sm-champion-name a {
    color: inherit;
    text-decoration: none;
}

.sm-champion-name a:hover {
    color: var(--sm-primary);
}

.sm-champion-country {
    font-size: 0.8125rem;
    color: var(--sm-text-secondary, #6b7a90);
    display: flex;
    align-items: center;
    gap: 4px;
}

.sm-top-countries {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sm-space-3, 12px);
}

.sm-top-country-card {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3, 12px);
    padding: var(--sm-space-3, 12px) var(--sm-space-4, 16px);
    background: var(--sm-surface, #fff);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius, 8px);
    min-width: 200px;
    flex: 1;
}

.sm-top-country-rank {
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--sm-primary);
    min-width: 28px;
}

.sm-top-country-flag {
    font-size: 1.5rem;
    line-height: 1;
}

.sm-top-country-info {
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.sm-top-country-name {
    font-weight: 600;
    color: var(--sm-text-primary);
    font-size: var(--sm-fs-15);
}

.sm-top-country-stats {
    font-size: 0.75rem;
    color: var(--sm-text-secondary, #6b7a90);
}

@media (max-width: 640px) {
    .sm-champions-grid {
        grid-template-columns: 1fr;
    }

    .sm-top-countries {
        flex-direction: column;
    }

    .sm-top-country-card {
        min-width: 0;
    }
}

/* ==========================================================================
   SERIES CHAMPIONS TIMELINE & MOST TITLES
   ========================================================================== */

.sm-series-champions-section {
    margin-bottom: var(--sm-space-6, 24px);
}

.sm-series-champions-layout {
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: var(--sm-space-6, 24px);
    align-items: start;
}

@media (max-width: 768px) {
    .sm-series-champions-layout {
        grid-template-columns: 1fr;
    }
}

/* Most Titles Leaderboard Card */
.sm-series-most-titles {
    background: var(--sm-surface, #fff);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius-lg, 14px);
    padding: var(--sm-space-5, 20px);
    position: sticky;
    top: 80px;
}

.sm-series-most-titles-heading {
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-size: 1rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0 0 var(--sm-space-4, 16px) 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.sm-series-most-titles-heading svg {
    color: var(--sm-primary);
}

.sm-most-titles-list {
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-2, 8px);
}

.sm-most-titles-row {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3, 12px);
    padding: var(--sm-space-2, 8px) 0;
    border-bottom: 1px solid var(--sm-gray-100, #f0f2f5);
}

.sm-most-titles-row:last-child {
    border-bottom: none;
}

.sm-most-titles-rank {
    width: 26px;
    height: 26px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-weight: 700;
    font-size: 0.8125rem;
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    background: var(--sm-gray-100, #f0f2f5);
    color: var(--sm-text-secondary, #6b7a90);
    flex-shrink: 0;
}

.sm-rank-1 {
    background: linear-gradient(135deg, var(--sm-gold), var(--sm-gold-end));
    color: var(--sm-gold-text);
}

.sm-rank-2 {
    background: linear-gradient(135deg, var(--sm-silver), var(--sm-silver-end));
    color: var(--sm-silver-text);
}

.sm-rank-3 {
    background: linear-gradient(135deg, var(--sm-bronze), var(--sm-bronze-end));
    color: var(--sm-bronze-text);
}

.sm-most-titles-info {
    display: flex;
    flex-direction: column;
    gap: 1px;
    flex: 1;
    min-width: 0;
}

.sm-most-titles-name {
    font-weight: 600;
    font-size: var(--sm-fs-15);
    color: var(--sm-text-primary);
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

a.sm-most-titles-name:hover {
    color: var(--sm-primary);
}

.sm-most-titles-years {
    font-size: var(--sm-fs-2xs);
    color: var(--sm-text-secondary, #6b7a90);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sm-most-titles-count {
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--sm-primary);
    flex-shrink: 0;
}

/* Champions by Year Timeline */
.sm-series-champions-timeline {
    background: var(--sm-surface, #fff);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius-lg, 14px);
    padding: var(--sm-space-5, 20px);
    max-height: 600px;
    overflow-y: auto;
}

.sm-series-timeline-heading {
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-size: 1rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0 0 var(--sm-space-4, 16px) 0;
}

.sm-timeline-list {
    position: relative;
    padding-left: 0;
}

.sm-timeline-item {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3, 12px);
    padding: var(--sm-space-2, 8px) 0;
    position: relative;
}

.sm-timeline-item::before {
    content: '';
    position: absolute;
    left: 70px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--sm-gray-200, #e8ecf1);
}

.sm-timeline-item:first-child::before {
    top: 50%;
}

.sm-timeline-item:last-child::before {
    bottom: 50%;
}

.sm-timeline-item--streak::before {
    background: var(--sm-primary);
    opacity: 0.3;
    width: 3px;
    left: 69.5px;
}

.sm-timeline-year {
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-size: var(--sm-fs-15);
    font-weight: 700;
    color: var(--sm-text-secondary, #6b7a90);
    min-width: 52px;
    text-align: right;
}

.sm-timeline-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--sm-gray-300, #d1d5db);
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    border: 2px solid var(--sm-surface, #fff);
    box-sizing: content-box;
}

.sm-timeline-item--streak .sm-timeline-dot {
    background: var(--sm-primary);
    box-shadow: 0 0 0 3px rgba(233, 69, 96, 0.15);
}

.sm-timeline-content {
    display: flex;
    align-items: center;
    gap: var(--sm-space-2, 8px);
    flex: 1;
    min-width: 0;
}

.sm-timeline-name {
    font-size: var(--sm-fs-15);
    font-weight: 600;
    color: var(--sm-text-primary);
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

a.sm-timeline-name:hover {
    color: var(--sm-primary);
}

.sm-timeline-streak-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    font-size: var(--sm-fs-2xs);
    font-weight: 600;
    color: var(--sm-primary);
    background: rgba(233, 69, 96, 0.08);
    border-radius: var(--sm-radius-full, 9999px);
    white-space: nowrap;
    flex-shrink: 0;
}

@media (max-width: 640px) {
    .sm-series-champions-timeline {
        max-height: 400px;
    }

    .sm-timeline-year {
        min-width: 42px;
        font-size: 0.8125rem;
    }

    .sm-timeline-item::before {
        left: 58px;
    }

    .sm-timeline-item--streak::before {
        left: 57.5px;
    }
}

/* ==========================================================================
   EVENT TYPES HUB
   ========================================================================== */

.sm-et-toolbar {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.sm-et-search-wrap {
    position: relative;
    flex: 1;
    min-width: 200px;
}

.sm-et-search-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--sm-text-muted);
    pointer-events: none;
}

.sm-et-search-input {
    width: 100%;
    padding: 10px 14px 10px 42px;
    font-size: var(--sm-fs-15);
    font-family: var(--sm-font-body);
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
    background: var(--sm-surface);
    color: var(--sm-text-primary);
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.sm-et-search-input:focus {
    border-color: var(--sm-primary);
    box-shadow: 0 0 0 3px rgba(233, 69, 96, 0.08);
}

.sm-et-count {
    font-size: 0.875rem;
    color: var(--sm-text-muted);
    white-space: nowrap;
}

/* Category Filter Pills */
.sm-et-categories {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 1.25rem;
    padding: 0.75rem 1rem;
    background: var(--sm-gray-50, #f8f9fb);
    border-radius: var(--sm-radius-md, 10px);
    border: 1px solid var(--sm-border);
}

.sm-et-cat-pill {
    padding: 6px 14px;
    font-size: 0.8125rem;
    font-weight: 600;
    font-family: var(--sm-font-body);
    border: 1px solid var(--sm-border);
    border-radius: 999px;
    background: var(--sm-surface);
    color: var(--sm-text-secondary);
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
}

.sm-et-cat-pill:hover {
    border-color: var(--sm-primary);
    color: var(--sm-primary);
}

.sm-et-cat-active {
    background: var(--sm-primary);
    border-color: var(--sm-primary);
    color: #fff;
}

/* Quick Stats */
.sm-et-stats-bar {
    display: flex;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.sm-et-stat {
    flex: 1;
    min-width: 120px;
    text-align: center;
    padding: 1rem;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
}

.sm-et-stat-value {
    display: block;
    font-size: 1.5rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-primary);
    font-family: var(--sm-font-heading);
    line-height: 1.2;
}

.sm-et-stat-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 4px;
}

/* Skeleton */
.sm-et-skeleton-pills {
    display: flex;
    gap: 6px;
    margin-bottom: 1.25rem;
    padding: 0.75rem 1rem;
}

/* Event Type Grid */
.sm-et-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.25rem;
    margin-bottom: 2rem;
}

.sm-et-card {
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    transition: transform 0.2s, box-shadow 0.2s;
}

.sm-et-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.06);
}

.sm-et-card-skeleton {
    min-height: 180px;
    padding: 1.25rem;
}

.sm-et-card-name {
    font-size: 1.0625rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0 0 8px;
    font-family: var(--sm-font-heading);
}

/* Category badges with dynamic colors */
.sm-et-card-category {
    display: inline-block;
    padding: 3px 10px;
    font-size: var(--sm-fs-2xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-radius: 999px;
    margin-bottom: 10px;
    width: fit-content;
    /* Default */
    background: var(--sm-gray-100);
    color: var(--sm-text-secondary);
}

.sm-et-cat-badge-deadlift {
    background: rgba(233, 69, 96, 0.1);
    color: #c81e45;
}

.sm-et-cat-badge-overhead {
    background: rgba(59, 130, 246, 0.1);
    color: #2563eb;
}

.sm-et-cat-badge-stones {
    background: rgba(139, 92, 246, 0.1);
    color: #7c3aed;
}

.sm-et-cat-badge-carry {
    background: rgba(245, 166, 35, 0.1);
    color: #d4920a;
}

.sm-et-cat-badge-farmers {
    background: rgba(245, 166, 35, 0.1);
    color: #d4920a;
}

.sm-et-cat-badge-yoke {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.sm-et-cat-badge-throw {
    background: rgba(236, 72, 153, 0.1);
    color: #db2777;
}

.sm-et-cat-badge-flip {
    background: rgba(251, 146, 60, 0.1);
    color: #ea580c;
}

.sm-et-cat-badge-grip {
    background: rgba(107, 114, 128, 0.1);
    color: #4b5563;
}

.sm-et-cat-badge-loading {
    background: rgba(34, 197, 94, 0.1);
    color: #16a34a;
}

.sm-et-cat-badge-vehicle {
    background: rgba(100, 116, 139, 0.1);
    color: #475569;
}

.sm-et-cat-badge-medley {
    background: rgba(168, 85, 247, 0.1);
    color: #9333ea;
}

.sm-et-cat-badge-duel {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

.sm-et-cat-badge-squat {
    background: rgba(14, 165, 233, 0.1);
    color: #0284c7;
}

.sm-et-cat-badge-other {
    background: var(--sm-gray-100);
    color: var(--sm-text-secondary);
}

.sm-et-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 8px;
}

.sm-et-meta-item {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8125rem;
    color: var(--sm-text-muted);
}

.sm-et-meta-item svg {
    flex-shrink: 0;
    color: var(--sm-text-muted);
}

.sm-et-card-desc {
    font-size: 0.875rem;
    color: var(--sm-text-secondary);
    line-height: 1.55;
    margin: 0 0 auto;
    padding-bottom: 10px;
}

.sm-et-card-footer {
    margin-top: auto;
    padding-top: 10px;
    border-top: 1px solid var(--sm-border);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.sm-et-usage {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.8125rem;
    color: var(--sm-text-muted);
}

.sm-et-usage svg {
    flex-shrink: 0;
}

.sm-et-card-links {
    display: flex;
    gap: 8px;
}

.sm-et-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--sm-primary);
    text-decoration: none;
    padding: 4px 8px;
    border-radius: 6px;
    transition: background 0.15s;
}

.sm-et-link:hover {
    background: rgba(233, 69, 96, 0.06);
}

.sm-et-link svg {
    flex-shrink: 0;
}

.sm-link-btn {
    background: none;
    border: none;
    color: var(--sm-primary);
    font-weight: 600;
    font-family: var(--sm-font-body);
    font-size: inherit;
    cursor: pointer;
    text-decoration: underline;
    padding: 0;
}

.sm-link-btn:hover {
    color: var(--sm-primary-hover);
}

@media (max-width: 640px) {
    .sm-et-grid {
        grid-template-columns: 1fr;
    }

    .sm-et-stats-bar {
        flex-direction: row;
    }

    .sm-et-stat {
        min-width: 0;
    }

    .sm-et-card-footer {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* ==========================================================================
   UPCOMING COMPETITIONS HUB
   ========================================================================== */

.sm-uc-stats-bar {
    display: flex;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.sm-uc-stat {
    flex: 1;
    min-width: 120px;
    text-align: center;
    padding: 1rem;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
}

.sm-uc-stat-value {
    display: block;
    font-size: 1.75rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-primary);
    font-family: var(--sm-font-heading);
    line-height: 1.2;
}

.sm-uc-stat-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 4px;
}

/* Toolbar */
.sm-uc-toolbar {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.sm-uc-search-wrap {
    position: relative;
    flex: 1;
    min-width: 200px;
}

.sm-uc-search-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--sm-text-muted);
    pointer-events: none;
}

.sm-uc-search-input {
    width: 100%;
    padding: 10px 14px 10px 42px;
    font-size: var(--sm-fs-15);
    font-family: var(--sm-font-body);
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
    background: var(--sm-surface);
    color: var(--sm-text-primary);
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.sm-uc-search-input:focus {
    border-color: var(--sm-primary);
    box-shadow: 0 0 0 3px rgba(233, 69, 96, 0.08);
}

.sm-uc-filters {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.sm-uc-select {
    padding: 9px 32px 9px 12px;
    font-size: 0.875rem;
    font-family: var(--sm-font-body);
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
    background: var(--sm-surface);
    color: var(--sm-text-primary);
    cursor: pointer;
    outline: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7585' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    transition: border-color 0.2s;
}

.sm-uc-select:focus {
    border-color: var(--sm-primary);
}

.sm-uc-count {
    font-size: 0.875rem;
    color: var(--sm-text-muted);
    white-space: nowrap;
}

/* Skeleton */
.sm-uc-skeleton {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.sm-uc-card-skeleton {
    display: flex;
    gap: 1rem;
    padding: 1.25rem;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-md, 10px);
}

/* Month groups */
.sm-uc-month-group {
    margin-bottom: 2rem;
}

.sm-uc-month-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 16px;
    background: var(--sm-navy);
    color: #fff;
    border-radius: var(--sm-radius-md, 10px) var(--sm-radius-md, 10px) 0 0;
    font-size: 1.0625rem;
    font-weight: 700;
    font-family: var(--sm-font-heading);
    margin: 0;
}

.sm-uc-month-count {
    font-size: 0.8125rem;
    font-weight: 500;
    opacity: 0.7;
}

.sm-uc-month-list {
    border: 1px solid var(--sm-border);
    border-top: none;
    border-radius: 0 0 var(--sm-radius-md, 10px) var(--sm-radius-md, 10px);
    overflow: hidden;
}

/* Contest Card */
.sm-uc-card {
    display: flex;
    gap: 1rem;
    padding: 1rem 1.25rem;
    background: var(--sm-surface);
    border-bottom: 1px solid var(--sm-border);
    transition: background 0.15s;
    align-items: flex-start;
}

.sm-uc-card:last-child {
    border-bottom: none;
}

.sm-uc-card:hover {
    background: var(--sm-gray-50, #f8f9fb);
}

/* Date badge */
.sm-uc-date-badge {
    flex-shrink: 0;
    width: 56px;
    text-align: center;
    padding: 8px 4px;
    background: var(--sm-primary-light, rgba(233, 69, 96, 0.08));
    border-radius: 10px;
    border: 1px solid rgba(233, 69, 96, 0.15);
}

.sm-uc-day {
    display: block;
    font-size: 1.25rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-primary);
    line-height: 1.2;
    font-family: var(--sm-font-heading);
}

.sm-uc-month-short {
    display: block;
    font-size: var(--sm-fs-2xs);
    font-weight: 600;
    color: var(--sm-primary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* Card body */
.sm-uc-card-body {
    flex: 1;
    min-width: 0;
}

.sm-uc-card-name {
    font-size: 1rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    text-decoration: none;
    display: block;
    margin-bottom: 6px;
    transition: color 0.15s;
}

.sm-uc-card-name:hover {
    color: var(--sm-primary);
}

.sm-uc-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 6px;
    align-items: center;
}

.sm-uc-meta-item {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8125rem;
    color: var(--sm-text-muted);
}

.sm-uc-meta-item svg {
    flex-shrink: 0;
    color: var(--sm-text-muted);
}

/* Events preview */
.sm-uc-events-preview {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-top: 6px;
}

.sm-uc-event-pill {
    display: inline-block;
    padding: 2px 8px;
    font-size: var(--sm-fs-2xs);
    font-weight: 500;
    background: var(--sm-gray-100, #f0f2f5);
    color: var(--sm-text-secondary);
    border-radius: 999px;
    white-space: nowrap;
}

.sm-uc-event-more {
    display: inline-block;
    padding: 2px 8px;
    font-size: var(--sm-fs-2xs);
    font-weight: 600;
    color: var(--sm-text-muted);
}

/* Card actions */
.sm-uc-card-actions {
    flex-shrink: 0;
    display: flex;
    gap: 6px;
    align-items: flex-start;
}

@media (max-width: 640px) {
    .sm-uc-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .sm-uc-filters {
        width: 100%;
    }

    .sm-uc-select {
        flex: 1;
        min-width: 0;
    }

    .sm-uc-card {
        flex-direction: column;
        gap: 0.75rem;
    }

    .sm-uc-date-badge {
        width: auto;
        display: flex;
        gap: 6px;
        padding: 6px 12px;
        align-items: baseline;
    }

    .sm-uc-day {
        font-size: 1rem;
    }

    .sm-uc-card-actions {
        width: 100%;
        justify-content: flex-start;
    }

    .sm-uc-stats-bar {
        flex-direction: row;
    }

    .sm-uc-stat {
        min-width: 0;
    }
}

/* ==========================================================================
   SEARCH RESULTS PAGE
   ========================================================================== */

.sm-search-page {
    padding: 0 0 40px;
}

/* Search Input */
.sm-srp-input-wrap {
    position: relative;
    max-width: 680px;
    margin: -24px auto 32px;
}

.sm-srp-search-icon {
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--sm-text-muted);
    pointer-events: none;
}

.sm-srp-input {
    width: 100%;
    padding: 16px 48px 16px 52px;
    font-size: 1.125rem;
    font-family: inherit;
    border: 2px solid var(--sm-border);
    border-radius: 16px;
    background: var(--sm-surface);
    color: var(--sm-text-primary);
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.sm-srp-input:focus {
    border-color: var(--sm-primary);
    box-shadow: 0 0 0 4px rgba(233, 69, 96, 0.1);
}

.sm-srp-input::placeholder {
    color: var(--sm-text-muted);
}

.sm-srp-clear-btn {
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: var(--sm-text-muted);
    cursor: pointer;
    padding: 4px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.15s, background 0.15s;
}

.sm-srp-clear-btn:hover {
    color: var(--sm-primary);
    background: rgba(233, 69, 96, 0.08);
}

/* Meta / Result Count */
.sm-srp-meta {
    text-align: center;
    color: var(--sm-text-muted);
    font-size: var(--sm-fs-15);
    margin-bottom: 24px;
}

/* Loading Skeleton */
.sm-srp-skeleton {
    max-width: 680px;
    margin: 0 auto;
}

.sm-srp-skel-group {
    margin-bottom: 28px;
}

.sm-srp-skel-row {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 10px 0;
}

/* Error / Empty States */
.sm-srp-empty {
    text-align: center;
    padding: 48px 20px;
    color: var(--sm-text-muted);
}

.sm-srp-empty h2 {
    color: var(--sm-text-primary);
    margin: 16px 0 8px;
    font-size: 1.25rem;
}

.sm-srp-empty p {
    max-width: 480px;
    margin: 0 auto 16px;
}

.sm-srp-suggestions {
    text-align: left;
    display: inline-block;
    margin-top: 8px;
}

.sm-srp-suggestions p {
    font-weight: 600;
    color: var(--sm-text-secondary);
    margin-bottom: 4px;
}

.sm-srp-suggestions ul {
    padding-left: 20px;
    margin: 0;
}

.sm-srp-suggestions li {
    font-size: var(--sm-fs-15);
    line-height: 1.7;
}

/* Results */
.sm-srp-results {
    max-width: 680px;
    margin: 0 auto;
}

.sm-srp-group {
    margin-bottom: 32px;
}

.sm-srp-group-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.8125rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--sm-text-muted);
    margin: 0 0 12px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--sm-border);
}

.sm-srp-group-title svg {
    flex-shrink: 0;
}

.sm-srp-group-count {
    background: var(--sm-gray-100);
    color: var(--sm-text-secondary);
    font-size: 0.75rem;
    padding: 2px 8px;
    border-radius: 999px;
    font-weight: 600;
}

.sm-srp-list {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

/* Result Item */
.sm-srp-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    border-radius: 12px;
    text-decoration: none;
    color: var(--sm-text-primary);
    transition: background 0.15s;
}

.sm-srp-item:hover {
    background: var(--sm-gray-50, #f8f9fb);
}

.sm-srp-item-icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sm-gray-100);
    border-radius: 50%;
    color: var(--sm-text-muted);
}

.sm-srp-item-contest .sm-srp-item-icon {
    border-radius: 8px;
    background: rgba(233, 69, 96, 0.08);
    color: var(--sm-primary);
}

.sm-srp-flag {
    width: 24px;
    height: 18px;
    border-radius: 2px;
    object-fit: cover;
}

.sm-srp-icon-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
}

.sm-srp-item-body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.sm-srp-item-name {
    font-weight: 600;
    font-size: var(--sm-fs-15);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sm-srp-item-meta {
    font-size: 0.8125rem;
    color: var(--sm-text-muted);
}

.sm-srp-arrow {
    flex-shrink: 0;
    color: var(--sm-text-muted);
    opacity: 0;
    transition: opacity 0.15s;
}

.sm-srp-item:hover .sm-srp-arrow {
    opacity: 1;
}

/* Default State: Popular Searches & Browse */
.sm-srp-default {
    max-width: 680px;
    margin: 0 auto;
}

.sm-srp-popular-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.sm-srp-popular-btn {
    padding: 8px 16px;
    font-size: 0.875rem;
    font-family: inherit;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: 999px;
    color: var(--sm-text-secondary);
    cursor: pointer;
    transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.sm-srp-popular-btn:hover {
    border-color: var(--sm-primary);
    color: var(--sm-primary);
    background: rgba(233, 69, 96, 0.04);
}

.sm-srp-browse-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

.sm-srp-browse-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 20px 12px;
    border-radius: 14px;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    text-decoration: none;
    color: var(--sm-text-secondary);
    font-weight: 600;
    font-size: 0.875rem;
    transition: border-color 0.15s, box-shadow 0.15s, transform 0.15s;
}

.sm-srp-browse-card:hover {
    border-color: var(--sm-primary);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
    transform: translateY(-2px);
    color: var(--sm-primary);
}

@media (max-width: 640px) {
    .sm-srp-input-wrap {
        margin-top: -16px;
    }

    .sm-srp-input {
        font-size: 1rem;
        padding: 14px 44px 14px 46px;
    }

    .sm-srp-browse-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .sm-srp-item {
        padding: 10px 12px;
    }
}

/* ==========================================================================
   DATABASE STATS PAGE
   ========================================================================== */

.sm-stats-page {
    padding: 0 0 40px;
}

/* Skeleton */
.sm-dbstats-skeleton {
    min-height: 300px;
}

.sm-dbstats-skel-counter {
    text-align: center;
    padding: 24px 16px;
}

/* Counter Grid */
.sm-dbstats-counter-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 48px;
}

.sm-dbstats-counter-card {
    text-align: center;
    padding: 28px 16px;
    border-radius: 16px;
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    transition: box-shadow 0.2s, transform 0.2s;
}

.sm-dbstats-counter-card:hover {
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.06);
    transform: translateY(-2px);
}

.sm-dbstats-counter-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 12px;
}

.sm-dbstats-icon-athletes {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.sm-dbstats-icon-contests {
    background: rgba(233, 69, 96, 0.1);
    color: var(--sm-primary);
}

.sm-dbstats-icon-results {
    background: rgba(34, 197, 94, 0.1);
    color: #22c55e;
}

.sm-dbstats-icon-events {
    background: rgba(234, 179, 8, 0.1);
    color: #eab308;
}

.sm-dbstats-icon-records {
    background: rgba(168, 85, 247, 0.1);
    color: #a855f7;
}

.sm-dbstats-icon-years {
    background: rgba(236, 72, 153, 0.1);
    color: #ec4899;
}

.sm-dbstats-counter-value {
    font-size: 2.25rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
    line-height: 1.1;
    margin-bottom: 4px;
    font-variant-numeric: tabular-nums;
}

.sm-dbstats-counter-label {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* Coverage Section */
.sm-dbstats-coverage {
    margin-bottom: 48px;
}

.sm-dbstats-coverage-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.sm-dbstats-chart-card {
    padding: 24px;
    border-radius: 16px;
}

.sm-dbstats-chart-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0 0 20px;
}

/* Bar Chart */
.sm-dbstats-bar-chart {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.sm-dbstats-bar-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

.sm-dbstats-bar-label {
    width: 100px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--sm-text-secondary);
    flex-shrink: 0;
}

.sm-dbstats-bar-track {
    flex: 1;
    height: 24px;
    background: var(--sm-gray-100);
    border-radius: 6px;
    overflow: hidden;
}

.sm-dbstats-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--sm-primary), #f06292);
    border-radius: 6px;
    transition: width 0.8s ease-out;
    min-width: 4px;
}

.sm-dbstats-bar-value {
    width: 48px;
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    text-align: right;
    flex-shrink: 0;
}

/* Highlights */
.sm-dbstats-highlights {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.sm-dbstats-highlight-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 12px;
    border-radius: 10px;
    background: var(--sm-gray-50, #f8f9fb);
}

.sm-dbstats-highlight-value {
    font-size: 1.5rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-primary);
    line-height: 1.2;
}

.sm-dbstats-highlight-label {
    font-size: 0.8125rem;
    color: var(--sm-text-muted);
    font-weight: 500;
}

/* Methodology */
.sm-dbstats-methodology {
    margin-bottom: 48px;
}

.sm-dbstats-method-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.sm-dbstats-method-card {
    padding: 24px 20px;
    border-radius: 16px;
    text-align: center;
}

.sm-dbstats-method-card h3 {
    font-size: var(--sm-fs-15);
    font-weight: 700;
    margin: 8px 0;
    color: var(--sm-text-primary);
}

.sm-dbstats-method-card p {
    font-size: 0.8125rem;
    color: var(--sm-text-secondary);
    line-height: 1.55;
    margin: 0;
}

.sm-dbstats-method-step {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--sm-primary), #f06292);
    color: #fff;
    font-weight: var(--sm-weight-extrabold);
    font-size: 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
}

/* Sources */
.sm-dbstats-sources {
    margin-bottom: 48px;
}

.sm-dbstats-sources-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.sm-dbstats-source-card {
    padding: 24px;
    border-radius: 16px;
}

.sm-dbstats-source-card h3 {
    font-size: 1rem;
    font-weight: 700;
    margin: 0 0 8px;
    color: var(--sm-text-primary);
}

.sm-dbstats-source-card p {
    font-size: 0.875rem;
    color: var(--sm-text-secondary);
    line-height: 1.55;
    margin: 0;
}

/* Updated At */
.sm-dbstats-updated {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 0.8125rem;
    color: var(--sm-text-muted);
    padding: 16px 0;
}

/* Responsive */
@media (max-width: 768px) {
    .sm-dbstats-counter-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .sm-dbstats-counter-value {
        font-size: 1.75rem;
    }

    .sm-dbstats-coverage-grid {
        grid-template-columns: 1fr;
    }

    .sm-dbstats-method-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .sm-dbstats-sources-grid {
        grid-template-columns: 1fr;
    }

    .sm-dbstats-bar-label {
        width: 80px;
        font-size: 0.75rem;
    }
}

@media (max-width: 480px) {
    .sm-dbstats-counter-grid {
        grid-template-columns: 1fr 1fr;
    }

    .sm-dbstats-method-grid {
        grid-template-columns: 1fr;
    }

    .sm-dbstats-highlights {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   RESOURCE PAGES (sm-res-*)
   Conversions, Substitutions, Benchmarks
   ========================================================================== */

/* --- Shared Resource Styles --- */

.strongman-app .sm-res-intro {
    margin-bottom: var(--sm-space-8);
}

.strongman-app .sm-res-intro-text {
    color: var(--sm-text-secondary);
    font-size: var(--sm-fs-15);
    line-height: 1.7;
    margin-bottom: var(--sm-space-3);
    max-width: 800px;
}

.strongman-app .sm-res-intro-text code {
    background: var(--sm-gray-100);
    padding: 2px 8px;
    border-radius: var(--sm-radius-sm);
    font-size: 0.875rem;
    font-family: 'Fira Code', 'Consolas', monospace;
    color: var(--sm-primary);
}

.strongman-app .sm-res-intro-text strong {
    color: var(--sm-text-primary);
    font-weight: 700;
}

/* --- Unit Toggle (shared) --- */

.strongman-app .sm-res-unit-toggle {
    display: inline-flex;
    gap: 4px;
    background: var(--sm-gray-100);
    border-radius: var(--sm-radius);
    padding: 3px;
}

.strongman-app .sm-res-unit-btn {
    padding: 6px 16px;
    font-size: 0.8125rem;
    font-weight: 700;
    border: none;
    border-radius: var(--sm-radius-sm);
    cursor: pointer;
    background: transparent;
    color: var(--sm-text-muted);
    transition: all 0.15s ease;
}

.strongman-app .sm-res-unit-btn:hover {
    color: var(--sm-text-primary);
}

.strongman-app .sm-res-unit-btn-active {
    background: var(--sm-surface);
    color: var(--sm-primary);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

/* --- Filter Bar --- */

.strongman-app .sm-res-filter-bar {
    display: flex;
    align-items: center;
    gap: var(--sm-space-3);
    margin-bottom: var(--sm-space-6);
    flex-wrap: wrap;
}

.strongman-app .sm-res-filter-bar .sm-select {
    min-width: 200px;
}

/* --- Controls Bar (benchmarks) --- */

.strongman-app .sm-res-controls-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sm-space-4);
    margin-bottom: var(--sm-space-4);
    flex-wrap: wrap;
}

/* --- Gender Tabs --- */

.strongman-app .sm-res-gender-tabs {
    display: inline-flex;
    gap: 4px;
    background: var(--sm-gray-100);
    border-radius: var(--sm-radius);
    padding: 3px;
}

.strongman-app .sm-res-tab-btn {
    padding: 6px 18px;
    font-size: 0.8125rem;
    font-weight: 700;
    border: none;
    border-radius: var(--sm-radius-sm);
    cursor: pointer;
    background: transparent;
    color: var(--sm-text-muted);
    transition: all 0.15s ease;
}

.strongman-app .sm-res-tab-btn:hover {
    color: var(--sm-text-primary);
}

.strongman-app .sm-res-tab-active {
    background: var(--sm-surface);
    color: var(--sm-primary);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

/* --- Weight Class Tabs --- */

.strongman-app .sm-res-wc-tabs {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: var(--sm-space-6);
    padding-bottom: var(--sm-space-3);
    border-bottom: 1px solid var(--sm-border);
}

.strongman-app .sm-res-wc-tab {
    padding: 8px 16px;
    font-size: 0.8125rem;
    font-weight: 700;
    border: 2px solid var(--sm-border);
    border-radius: var(--sm-radius);
    cursor: pointer;
    background: var(--sm-surface);
    color: var(--sm-text-secondary);
    transition: all 0.15s ease;
}

.strongman-app .sm-res-wc-tab:hover {
    border-color: var(--sm-primary);
    color: var(--sm-primary);
}

.strongman-app .sm-res-wc-tab-active {
    background: var(--sm-primary);
    border-color: var(--sm-primary);
    color: #fff;
}

/* ==========================================================================
   CONVERSIONS PAGE
   ========================================================================== */

/* --- Quick Calculator --- */

.strongman-app .sm-res-calculator-section {
    margin-bottom: var(--sm-space-8);
}

.strongman-app .sm-res-calc-card {
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-lg);
    padding: 24px;
}

.strongman-app .sm-res-calc-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sm-space-4);
    margin-bottom: var(--sm-space-4);
}

.strongman-app .sm-res-calc-field .sm-label {
    display: block;
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--sm-text-secondary);
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.strongman-app .sm-res-input-group {
    position: relative;
}

.strongman-app .sm-res-input-group .sm-input {
    padding-right: 48px;
}

.strongman-app .sm-res-input-unit {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--sm-text-muted);
    pointer-events: none;
}

.strongman-app .sm-res-calc-results {
    margin-top: var(--sm-space-6);
    padding-top: var(--sm-space-6);
    border-top: 1px solid var(--sm-border);
}

.strongman-app .sm-res-calc-results-title {
    font-size: 1rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
    margin-bottom: var(--sm-space-4);
}

.strongman-app .sm-res-calc-subtitle {
    font-weight: 500;
    color: var(--sm-text-muted);
    font-size: 0.875rem;
}

.strongman-app .sm-res-results-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--sm-space-3);
}

.strongman-app .sm-res-result-card {
    background: var(--sm-gray-50);
    border-radius: var(--sm-radius);
    padding: 16px;
    text-align: center;
    border: 1px solid var(--sm-border);
}

.strongman-app .sm-res-result-event {
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--sm-text-secondary);
    margin-bottom: 4px;
}

.strongman-app .sm-res-result-value {
    font-size: 1.25rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-primary);
    margin-bottom: 2px;
}

.strongman-app .sm-res-result-ratio {
    font-size: 0.75rem;
    color: var(--sm-text-muted);
}

.strongman-app .sm-res-no-results {
    color: var(--sm-text-muted);
    font-style: italic;
    padding: var(--sm-space-4);
}

/* --- Conversion Table --- */

.strongman-app .sm-res-table-section {
    margin-bottom: var(--sm-space-8);
}

.strongman-app .sm-res-table-intro {
    color: var(--sm-text-secondary);
    font-size: 0.875rem;
    margin-bottom: var(--sm-space-4);
    max-width: 700px;
}

.strongman-app .sm-res-event-name {
    font-weight: 700;
    color: var(--sm-text-primary);
    white-space: nowrap;
}

.strongman-app .sm-res-base-tag {
    display: inline-block;
    padding: 3px 10px;
    background: var(--sm-primary-light);
    color: var(--sm-primary);
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 700;
    white-space: nowrap;
}

.strongman-app .sm-res-notes-cell {
    font-size: 0.8125rem;
    color: var(--sm-text-muted);
    max-width: 260px;
}

/* --- Example Calculations --- */

.strongman-app .sm-res-examples {
    margin-bottom: var(--sm-space-8);
}

.strongman-app .sm-res-examples-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--sm-space-4);
}

.strongman-app .sm-res-example-card {
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-lg);
    padding: 20px;
}

.strongman-app .sm-res-example-label {
    font-size: 0.8125rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--sm-text-muted);
    margin-bottom: 12px;
}

.strongman-app .sm-res-example-calc {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}

.strongman-app .sm-res-example-input,
.strongman-app .sm-res-example-ratio {
    padding: 4px 12px;
    background: var(--sm-gray-100);
    border-radius: var(--sm-radius-sm);
    font-weight: 700;
    font-size: 1rem;
    color: var(--sm-text-primary);
}

.strongman-app .sm-res-example-result {
    padding: 4px 12px;
    background: var(--sm-primary-light);
    border-radius: var(--sm-radius-sm);
    font-weight: var(--sm-weight-extrabold);
    font-size: 1rem;
    color: var(--sm-primary);
}

.strongman-app .sm-res-example-op {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--sm-text-muted);
}

.strongman-app .sm-res-example-note {
    font-size: 0.8125rem;
    color: var(--sm-text-muted);
    line-height: 1.5;
}

/* ==========================================================================
   SUBSTITUTIONS PAGE
   ========================================================================== */

/* --- Event Section --- */

.strongman-app .sm-res-subs-list {
    display: flex;
    flex-direction: column;
    gap: var(--sm-space-8);
}

.strongman-app .sm-res-event-section {
    padding-bottom: var(--sm-space-6);
    border-bottom: 1px solid var(--sm-border);
}

.strongman-app .sm-res-event-section:last-child {
    border-bottom: none;
}

.strongman-app .sm-res-event-heading {
    font-family: var(--sm-font-heading);
    font-size: 1.375rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
    margin-bottom: var(--sm-space-4);
    letter-spacing: -0.02em;
}

/* --- Substitution Cards Grid --- */

.strongman-app .sm-res-subs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--sm-space-4);
}

.strongman-app .sm-res-sub-card {
    background: var(--sm-surface);
    border: 1px solid var(--sm-border);
    border-radius: var(--sm-radius-lg);
    padding: 20px;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.strongman-app .sm-res-sub-card:hover {
    border-color: var(--sm-gray-300);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.strongman-app .sm-res-sub-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sm-space-3);
    margin-bottom: var(--sm-space-3);
}

.strongman-app .sm-res-sub-name {
    font-size: 1rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
    margin: 0;
}

.strongman-app .sm-res-sub-desc {
    font-size: 0.875rem;
    color: var(--sm-text-secondary);
    line-height: 1.6;
    margin-bottom: var(--sm-space-3);
}

/* --- Effectiveness Badge --- */

.strongman-app .sm-res-effectiveness-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: var(--sm-weight-extrabold);
    white-space: nowrap;
    flex-shrink: 0;
}

.strongman-app .sm-res-eff-excellent {
    background: var(--sm-green-soft);
    color: var(--sm-green-700);
}

.strongman-app .sm-res-eff-good {
    background: rgba(52, 152, 219, 0.1);
    color: #2471a3;
}

.strongman-app .sm-res-eff-moderate {
    background: var(--sm-accent-light);
    color: #b7791f;
}

.strongman-app .sm-res-eff-low {
    background: var(--sm-error-light);
    color: var(--sm-error);
}

/* --- Substitution Meta --- */

.strongman-app .sm-res-sub-meta {
    display: flex;
    gap: var(--sm-space-6);
    margin-bottom: var(--sm-space-3);
}

.strongman-app .sm-res-sub-meta-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.strongman-app .sm-res-sub-meta-label {
    font-size: var(--sm-fs-2xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--sm-text-muted);
}

.strongman-app .sm-res-sub-meta-value {
    font-size: var(--sm-fs-15);
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
}

/* --- Difficulty Tags --- */

.strongman-app .sm-res-difficulty {
    text-transform: capitalize;
}

.strongman-app .sm-res-diff-beginner {
    color: var(--sm-green-600);
}

.strongman-app .sm-res-diff-intermediate {
    color: var(--sm-accent);
}

.strongman-app .sm-res-diff-advanced {
    color: var(--sm-primary);
}

/* --- Equipment Tags --- */

.strongman-app .sm-res-sub-equipment {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-bottom: var(--sm-space-3);
}

.strongman-app .sm-res-equip-tag {
    display: inline-block;
    padding: 2px 8px;
    background: var(--sm-gray-100);
    border-radius: var(--sm-radius-sm);
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--sm-text-secondary);
}

/* --- Notes --- */

.strongman-app .sm-res-sub-notes {
    font-size: 0.8125rem;
    color: var(--sm-text-muted);
    line-height: 1.5;
    padding: 8px 12px;
    background: var(--sm-gray-50);
    border-radius: var(--sm-radius-sm);
    margin-bottom: var(--sm-space-3);
}

.strongman-app .sm-res-sub-notes strong {
    color: var(--sm-text-secondary);
}

/* --- Effectiveness Bar --- */

.strongman-app .sm-res-eff-bar-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
}

.strongman-app .sm-res-eff-bar {
    flex: 1;
    height: 6px;
    background: var(--sm-gray-100);
    border-radius: 3px;
    overflow: hidden;
}

.strongman-app .sm-res-eff-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.3s ease;
}

.strongman-app .sm-res-eff-fill.sm-res-eff-excellent {
    background: var(--sm-green-500);
}

.strongman-app .sm-res-eff-fill.sm-res-eff-good {
    background: #3498db;
}

.strongman-app .sm-res-eff-fill.sm-res-eff-moderate {
    background: var(--sm-accent);
}

.strongman-app .sm-res-eff-fill.sm-res-eff-low {
    background: var(--sm-error);
}

.strongman-app .sm-res-eff-label {
    font-size: var(--sm-fs-2xs);
    font-weight: 700;
    color: var(--sm-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    flex-shrink: 0;
}

/* ==========================================================================
   BENCHMARKS PAGE
   ========================================================================== */

.strongman-app .sm-res-bm-header {
    display: flex;
    align-items: baseline;
    gap: var(--sm-space-3);
    margin-bottom: var(--sm-space-4);
    flex-wrap: wrap;
}

.strongman-app .sm-res-bm-title {
    font-family: var(--sm-font-heading);
    font-size: 1.25rem;
    font-weight: var(--sm-weight-extrabold);
    color: var(--sm-text-primary);
    margin: 0;
}

.strongman-app .sm-res-bm-limit {
    font-size: 0.8125rem;
    color: var(--sm-text-muted);
}

.strongman-app .sm-res-bm-note {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--sm-text-muted);
    margin-left: 4px;
}

/* --- Benchmark Table Colors --- */

.strongman-app .sm-res-bm-table th {
    white-space: nowrap;
}

.strongman-app .sm-res-bm-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-right: 4px;
    vertical-align: middle;
}

.strongman-app .sm-res-bm-dot-national {
    background: var(--sm-accent);
}

.strongman-app .sm-res-bm-dot-wc {
    background: #3498db;
}

.strongman-app .sm-res-bm-dot-elite {
    background: var(--sm-green-500);
}

.strongman-app .sm-res-bm-cell {
    font-weight: 700;
    text-align: center;
}

.strongman-app .sm-res-bm-national {
    background: rgba(245, 166, 35, 0.06);
    color: #b7791f;
}

.strongman-app .sm-res-bm-wc {
    background: rgba(52, 152, 219, 0.06);
    color: #2471a3;
}

.strongman-app .sm-res-bm-elite {
    background: rgba(46, 204, 113, 0.08);
    color: var(--sm-green-700);
}

.strongman-app .sm-res-bm-row-active {
    outline: 2px solid var(--sm-primary);
    outline-offset: -2px;
    border-radius: var(--sm-radius-sm);
}

.strongman-app .sm-res-bm-row-active td {
    cursor: pointer;
}

.strongman-app .sm-table tbody tr[class*="sm-res-bm-row"]:hover {
    cursor: pointer;
}

/* --- CTA Section --- */

.strongman-app .sm-res-cta-section {
    margin: var(--sm-space-8) 0;
}

.strongman-app .sm-res-cta-card {
    background: linear-gradient(135deg, var(--sm-navy) 0%, #1a3a5c 100%);
    border-radius: var(--sm-radius-lg);
    padding: 32px;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.strongman-app .sm-res-cta-card::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -10%;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(233, 69, 96, 0.12) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}

.strongman-app .sm-res-cta-title {
    font-family: var(--sm-font-heading);
    font-size: 1.5rem;
    font-weight: var(--sm-weight-extrabold);
    color: #fff;
    margin-bottom: var(--sm-space-2);
    position: relative;
    z-index: 1;
}

.strongman-app .sm-res-cta-text {
    color: rgba(255, 255, 255, 0.75);
    font-size: var(--sm-fs-15);
    margin-bottom: var(--sm-space-6);
    position: relative;
    z-index: 1;
}

.strongman-app .sm-res-cta-buttons {
    display: flex;
    gap: var(--sm-space-3);
    justify-content: center;
    flex-wrap: wrap;
    position: relative;
    z-index: 1;
}

.strongman-app .sm-res-cta-buttons .sm-btn-outline {
    border: 2px solid rgba(255, 255, 255, 0.3);
    color: #fff;
    background: transparent;
}

.strongman-app .sm-res-cta-buttons .sm-btn-outline:hover {
    border-color: rgba(255, 255, 255, 0.6);
    background: rgba(255, 255, 255, 0.05);
}

/* --- Comparison Section --- */

.strongman-app .sm-res-comparison-section {
    margin: var(--sm-space-8) 0;
}

/* ==========================================================================
   RESOURCE PAGES - RESPONSIVE
   ========================================================================== */

@media (max-width: 768px) {
    .strongman-app .sm-res-calc-grid {
        grid-template-columns: 1fr;
    }

    .strongman-app .sm-res-results-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .strongman-app .sm-res-subs-grid {
        grid-template-columns: 1fr;
    }

    .strongman-app .sm-res-examples-grid {
        grid-template-columns: 1fr;
    }

    .strongman-app .sm-res-wc-tabs {
        gap: 4px;
    }

    .strongman-app .sm-res-wc-tab {
        padding: 6px 10px;
        font-size: 0.75rem;
    }

    .strongman-app .sm-res-controls-bar {
        flex-direction: column;
        align-items: flex-start;
    }

    .strongman-app .sm-res-bm-header {
        flex-direction: column;
        gap: var(--sm-space-1);
    }

    .strongman-app .sm-res-cta-card {
        padding: 24px 16px;
    }
}

@media (max-width: 480px) {
    .strongman-app .sm-res-results-grid {
        grid-template-columns: 1fr;
    }

    .strongman-app .sm-res-sub-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .strongman-app .sm-res-sub-meta {
        flex-direction: column;
        gap: var(--sm-space-2);
    }
}

/* ==========================================================================
   COUNTRY DETAIL CHARTS
   ========================================================================== */

.sm-country-charts-section {
    margin-bottom: 32px;
}

.sm-country-charts {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.sm-country-chart-card {
    background: var(--sm-surface, #fff);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius-lg, 12px);
    padding: 20px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.sm-country-chart-title {
    font-size: var(--sm-fs-15);
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0 0 2px;
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
}

.sm-country-chart-subtitle {
    font-size: 0.75rem;
    color: var(--sm-text-muted, #6b7585);
    margin: 0 0 16px;
    line-height: 1.4;
}

.sm-country-chart-canvas {
    position: relative;
    height: 240px;
    width: 100%;
}

.sm-country-chart-canvas-doughnut {
    height: 280px;
}

@media (max-width: 1024px) {
    .sm-country-charts {
        grid-template-columns: 1fr 1fr;
    }

    /* Let the doughnut chart span full width on 2-col layout */
    .sm-country-chart-card:last-child:nth-child(odd) {
        grid-column: 1 / -1;
        max-width: 480px;
        margin: 0 auto;
        width: 100%;
    }
}

@media (max-width: 768px) {
    .sm-country-charts {
        grid-template-columns: 1fr;
    }

    .sm-country-chart-card:last-child:nth-child(odd) {
        max-width: 100%;
    }

    .sm-country-chart-canvas {
        height: 220px;
    }

    .sm-country-chart-canvas-doughnut {
        height: 260px;
    }
}

/* ==========================================================================
   BEGINNER PROGRAM & COMPETITION PREP (sm-bp-*, sm-cp-*)
   ========================================================================== */

/* Overview Grid */
.sm-bp-overview-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin: 20px 0 28px;
}

.sm-bp-overview-card {
    background: var(--sm-gray-50, #f8f9fb);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius, 8px);
    padding: 16px;
    text-align: center;
}

.sm-bp-overview-label {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--sm-text-muted, #6b7585);
    margin-bottom: 4px;
}

.sm-bp-overview-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--sm-text-primary);
}

/* Lists */
.sm-bp-list {
    padding-left: 20px;
    margin: 10px 0 16px;
}

.sm-bp-list li {
    margin-bottom: 8px;
    font-size: var(--sm-fs-15);
    line-height: 1.6;
    color: var(--sm-text-secondary, #5a6577);
}

.sm-bp-list li strong {
    color: var(--sm-text-primary);
}

/* Equipment Grid */
.sm-bp-equipment {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 20px;
    margin: 16px 0;
}

.sm-bp-equipment-group {
    background: var(--sm-gray-50, #f8f9fb);
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius, 8px);
    padding: 20px;
}

.sm-bp-equipment-group h3 {
    font-size: var(--sm-fs-15);
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0 0 12px;
}

/* Checklist style */
.sm-bp-checklist {
    list-style: none;
    padding-left: 0;
}

.sm-bp-checklist li {
    position: relative;
    padding-left: 26px;
}

.sm-bp-checklist li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 6px;
    width: 16px;
    height: 16px;
    border: 2px solid var(--sm-gray-300, #d1d9e0);
    border-radius: 3px;
}

/* Callouts */
.sm-bp-callout {
    border-radius: var(--sm-radius, 8px);
    padding: 20px 24px;
    margin: 20px 0;
    font-size: var(--sm-fs-15);
    line-height: 1.6;
}

.sm-bp-callout h3 {
    margin: 0 0 10px;
    font-size: 1.0625rem;
}

.sm-bp-callout p {
    margin: 8px 0;
    color: inherit;
}

.sm-bp-callout .sm-bp-list {
    margin: 8px 0;
}

.sm-bp-callout-info {
    background: rgba(15, 52, 96, 0.06);
    border-left: 4px solid var(--sm-electric, #0f3460);
    color: var(--sm-text-secondary, #5a6577);
}

.sm-bp-callout-warning {
    background: rgba(245, 166, 35, 0.08);
    border-left: 4px solid var(--sm-accent, #f5a623);
    color: var(--sm-text-secondary, #5a6577);
}

.sm-bp-callout-primary {
    background: var(--sm-primary-light, rgba(233, 69, 96, 0.08));
    border-left: 4px solid var(--sm-primary);
    color: var(--sm-text-secondary, #5a6577);
}

/* Schedule Table */
.sm-bp-schedule-table td,
.sm-bp-schedule-table th {
    vertical-align: top;
}

.sm-bp-rest-day {
    font-style: italic;
    color: var(--sm-text-muted, #6b7585);
    text-align: center;
}

/* Competition Prep Phases */
.sm-cp-phase {
    border: 1px solid var(--sm-gray-200, #e8ecf1);
    border-radius: var(--sm-radius, 8px);
    margin-bottom: 20px;
    overflow: hidden;
}

.sm-cp-phase-highlight {
    border-color: var(--sm-primary);
}

.sm-cp-phase-header {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 20px;
    background: var(--sm-gray-50, #f8f9fb);
    border-bottom: 1px solid var(--sm-gray-200, #e8ecf1);
}

.sm-cp-phase-highlight .sm-cp-phase-header {
    background: var(--sm-primary-light, rgba(233, 69, 96, 0.08));
}

.sm-cp-phase-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-radius: 999px;
    background: var(--sm-navy);
    color: #fff;
    white-space: nowrap;
}

.sm-cp-badge-primary {
    background: var(--sm-primary);
}

.sm-cp-phase-title {
    font-size: 1.0625rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0;
}

.sm-cp-phase-body {
    padding: 20px;
}

.sm-cp-phase-body h4 {
    font-size: 0.875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--sm-text-muted, #6b7585);
    margin: 16px 0 8px;
}

.sm-cp-phase-body h4:first-child {
    margin-top: 0;
}

/* Responsive */
@media (max-width: 768px) {
    .sm-bp-overview-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    .sm-bp-equipment {
        grid-template-columns: 1fr;
    }

    .sm-cp-phase-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .sm-bp-callout {
        padding: 16px;
    }
}

@media (max-width: 480px) {
    .sm-bp-overview-grid {
        grid-template-columns: 1fr 1fr;
    }

    .sm-bp-overview-value {
        font-size: 1.0625rem;
    }
}

/* ============================================
   Auth Required Section (shared by account pages)
   ============================================ */
.sm-auth-required {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 400px;
    padding: var(--sm-space-8, 32px);
}

.sm-auth-required-content {
    text-align: center;
    max-width: 440px;
}

.sm-auth-icon {
    color: var(--sm-text-muted, #6b7585);
    margin-bottom: var(--sm-space-4, 16px);
}

.sm-auth-title {
    font-family: var(--sm-font-heading, 'Space Grotesk', sans-serif);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--sm-text-primary);
    margin: 0 0 var(--sm-space-3, 12px);
}

.sm-auth-description {
    font-size: var(--sm-fs-15);
    color: var(--sm-text-secondary, #5a6577);
    line-height: 1.6;
    margin: 0 0 var(--sm-space-6, 24px);
}

.sm-auth-buttons {
    display: flex;
    gap: var(--sm-space-3, 12px);
    justify-content: center;
}

/* Print styles for data pages */
@media print {

    /* Hide interactive elements */
    .sm-nav,
    .sm-mobile-nav,
    .sm-hero,
    .sm-search-bar,
    .sm-pagination,
    .sm-btn,
    .sm-filter-bar,
    .sm-account-filter-bar,
    .sm-share-card,
    .sm-toast,
    .sm-live-region,
    .sm-skeleton,
    .sm-loading-skeleton,
    [x-cloak],
    footer {
        display: none !important;
    }

    /* Ensure tables print cleanly */
    .sm-table-container-sa {
        overflow: visible !important;
    }

    .sm-table {
        font-size: 10pt;
    }

    .sm-table th,
    .sm-table td {
        padding: 4px 8px;
        border: 1px solid #ccc;
    }

    /* Athlete profile print */
    .sm-profile-header {
        page-break-after: avoid;
    }

    .sm-profile-photo-img {
        max-width: 120px;
    }

    /* Competition detail print */
    .sm-contest-info {
        page-break-after: avoid;
    }

    /* Records print */
    .sm-records-table {
        page-break-inside: auto;
    }

    .sm-records-table tr {
        page-break-inside: avoid;
    }

    /* General page layout */
    .strongman-app {
        max-width: 100%;
        padding: 0;
    }

    body {
        font-size: 11pt;
        line-height: 1.4;
    }

    a[href]::after {
        content: none;
    }
}