:root {
    /* ── Colors ── */
    --bg: #000000;
    --panel: #0A0A0A;
    --panel-raised: #111111;
    --surface: #1A1A1A;
    --text: rgba(255, 255, 255, 0.95);
    --text-secondary: rgba(229, 229, 229, 0.92);
    --text-muted: rgba(229, 229, 229, 0.65);
    --accent: #FF0000;
    --accent-dark: #DC143C;
    --accent-glow: rgba(255, 0, 0, 0.15);
    --accent-glow-strong: rgba(255, 0, 0, 0.3);
    --border: rgba(255, 255, 255, 0.08);
    --border-accent: rgba(255, 0, 0, 0.2);
    --border-accent-strong: rgba(255, 0, 0, 0.5);

    /* ── Typography ── */
    --font-display: 'Bebas Neue', 'Impact', sans-serif;
    --font-body: 'DM Sans', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-heading: 'Montserrat', sans-serif;
    --h1-landing: clamp(4rem, 12vw, 8rem);
    --h1-article: clamp(2rem, 5vw, 2.8rem);
    --h2-size: clamp(1.5rem, 3vw, 1.9rem);
    --h3-size: clamp(1.15rem, 2vw, 1.35rem);
    --body-size: 1.05rem;
    --body-lh: 1.75;
    --heading-weight: 700;

    /* ── Design Tokens: Spacing (4dp grid from DesignTokens.dart) ── */
    --dt-space-xxs: 2px;
    --dt-space-xs: 4px;
    --dt-space-xs-plus: 6px;
    --dt-space-sm: 8px;
    --dt-space-sm-plus: 12px;
    --dt-space-md: 16px;
    --dt-space-md-plus: 20px;
    --dt-space-lg: 24px;
    --dt-space-xl: 32px;
    --dt-space-2xl: 48px;
    --dt-space-3xl: 64px;
    --dt-space-4xl: 128px;

    /* ── Design Tokens: Border Radius (MD3 Shape tokens from DesignTokens.dart) ── */
    --dt-radius-none: 0px;
    --dt-radius-xs: 4px;
    --dt-radius-sm: 8px;
    --dt-radius-md: 12px;
    --dt-radius-lg: 16px;
    --dt-radius-xl: 24px;
    --dt-radius-2xl: 32px;
    --dt-radius-full: 9999px;

    /* ── Design Tokens: Elevation (MD3 from DesignTokens.dart) ── */
    --dt-elevation-none: none;
    --dt-elevation-sm: 0 2px 4px rgba(0, 0, 0, 0.3);
    --dt-elevation-md: 0 4px 8px rgba(0, 0, 0, 0.4);
    --dt-elevation-lg: 0 8px 16px rgba(0, 0, 0, 0.5);
    --dt-elevation-xl: 0 16px 32px rgba(0, 0, 0, 0.6);

    /* ── Design Tokens: Opacity (MD3 State layers from DesignTokens.dart) ── */
    --dt-opacity-light: 0.05;
    --dt-opacity-very-light: 0.15;
    --dt-opacity-medium: 0.12;
    --dt-opacity-medium-high: 0.4;
    --dt-opacity-hover: 0.08;
    --dt-opacity-focus: 0.12;
    --dt-opacity-pressed: 0.12;
    --dt-opacity-dragged: 0.16;
    --dt-opacity-disabled: 0.38;
    --dt-opacity-disabled-container: 0.12;
    --dt-opacity-high: 0.24;
    --dt-opacity-very-high: 0.7;
    --dt-opacity-almost-full: 0.9;

    /* ── Design Tokens: Icon Sizes (MD3 from DesignTokens.dart) ── */
    --dt-icon-xs: 14px;
    --dt-icon-sm: 16px;
    --dt-icon-md: 24px;
    --dt-icon-md-plus: 28px;
    --dt-icon-lg: 32px;
    --dt-icon-xl: 48px;
    --dt-icon-2xl: 64px;
    --dt-icon-3xl: 100px;

    /* ── Design Tokens: Avatar Sizes (from DesignTokens.dart) ── */
    --dt-avatar-sm: 20px;
    --dt-avatar-md: 32px;
    --dt-avatar-lg: 40px;
    --dt-avatar-xl: 48px;

    /* ── Design Tokens: Touch Targets (WCAG AA from DesignTokens.dart) ── */
    --dt-touch-min: 44px;
    --dt-touch-md: 48px;
    --dt-touch-lg: 56px;

    /* ── Design Tokens: Border Widths (MD3 from DesignTokens.dart) ── */
    --dt-border-thin: 1px;
    --dt-border-md: 2px;
    --dt-border-thick: 3px;

    /* ── Design Tokens: Stroke Widths (from DesignTokens.dart) ── */
    --dt-stroke-thin: 2px;
    --dt-stroke-md: 3px;
    --dt-stroke-thick: 4px;

    /* ── Design Tokens: Component Sizes (from DesignTokens.dart) ── */
    --dt-challenge-card-w: 180px;
    --dt-challenge-card-h: 150px;
    --dt-stat-chip-min-w: 48px;

    /* ── Design Tokens: Animation (from DesignTokens.dart) ── */
    --dt-animation-mult: 1;
    --dt-animation-mult-reduced: 0.1;

    /* ── Design Tokens: Podium Heights (from DesignTokens.dart) ── */
    --dt-podium-3rd: 120px;
    --dt-podium-2nd: 140px;
    --dt-podium-1st: 180px;

    /* ── Design Tokens: Bottom Sheet (from DesignTokens.dart) ── */
    --dt-bottom-sheet-compact: 50%;
    --dt-bottom-sheet-standard: 75%;
    --dt-bottom-sheet-large: 90%;
    --dt-bottom-sheet-min: 40%;
    --dt-bottom-sheet-max: 95%;

    /* ── LuxMaxTokens: Brand-specific (from LuxMaxTokens.dart) ── */
    --lmt-workout-card-spacing: var(--dt-space-lg);
    --lmt-achievement-spacing: var(--dt-space-md);
    --lmt-progress-spacing: var(--dt-space-sm);
    --lmt-workout-card-radius: var(--dt-radius-lg);
    --lmt-achievement-radius: var(--dt-radius-full);
    --lmt-progress-radius: var(--dt-radius-full);
    --lmt-achievement-elevation: var(--dt-elevation-md);
    --lmt-workout-elevation: var(--dt-elevation-sm);
    --lmt-celebration-elevation: var(--dt-elevation-xl);

    /* ── Semantic: Layout ── */
    --content-width: 1000px;
    --article-width: 740px;
    --transition: 0.25s ease;
    --nav-height: calc(var(--dt-touch-lg) + var(--dt-space-sm));
    --hero-padding-top: calc(var(--dt-touch-lg) + var(--dt-space-2xl) + var(--dt-space-lg));
    --hero-padding-bottom: var(--dt-space-2xl);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { color-scheme: dark; }

.skip-link {
    position: absolute;
    top: -100%;
    left: var(--dt-space-md);
    padding: var(--dt-space-sm) var(--dt-space-md);
    background: var(--accent);
    color: var(--text);
    font-weight: 700;
    font-size: 0.9rem;
    text-decoration: none;
    border-radius: var(--dt-radius-sm);
    z-index: 200;
    transition: top var(--transition);
}

.skip-link:focus {
    top: var(--dt-space-sm);
}

body {
    font-family: var(--font-body);
    background: var(--bg);
    color: var(--text);
    line-height: var(--body-lh);
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    touch-action: manipulation;
}

a { color: inherit; }
img, svg { display: block; max-width: 100%; }

.container {
    width: min(100% - var(--dt-space-3xl), var(--content-width));
    margin: 0 auto;
}

.narrow {
    width: min(100% - var(--dt-space-3xl), var(--article-width));
    margin: 0 auto;
}

/* ── Navigation ── */
.site-nav,
.article-nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    background: rgba(0, 0, 0, 0.88);
    backdrop-filter: blur(var(--dt-space-md));
    -webkit-backdrop-filter: blur(var(--dt-space-md));
    border-bottom: var(--dt-border-thin) solid var(--border);
}

.site-nav .container,
.article-nav .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: var(--nav-height);
}

.nav-brand {
    display: flex;
    align-items: center;
    gap: var(--dt-space-sm-plus);
    text-decoration: none;
    font-family: var(--font-display);
    font-size: 1.6rem;
    letter-spacing: 0.06em;
    color: var(--text);
}

.nav-brand svg {
    width: var(--dt-icon-md-plus);
    height: var(--dt-icon-md-plus);
}

.nav-links,
.nav-right {
    display: flex;
    align-items: center;
    gap: var(--dt-space-lg);
}

.nav-links a,
.nav-right a {
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 0.92rem;
    font-weight: 600;
    letter-spacing: 0.01em;
    transition: color var(--transition);
}

.nav-links a:hover,
.nav-right a:hover { color: var(--accent); }

.lang-switcher {
    display: flex;
    gap: var(--dt-space-xs);
}

.lang-switcher a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    min-height: var(--dt-touch-min);
    padding: var(--dt-space-xxs) var(--dt-space-xs-plus);
    border: var(--dt-border-thin) solid var(--border-accent);
    background: transparent;
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 700;
    text-decoration: none;
    letter-spacing: 0.04em;
    transition: background var(--transition), color var(--transition), border-color var(--transition);
    border-radius: var(--dt-radius-xs);
}

.lang-switcher a:hover {
    background: var(--accent-glow);
    border-color: var(--border-accent-strong);
    color: var(--text);
}

.lang-switcher a.active {
    background: var(--accent-glow-strong);
    border-color: var(--accent);
    color: var(--accent);
}

/* ── Buttons ── */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--dt-space-sm-plus);
    padding: var(--dt-space-sm-plus) var(--dt-space-lg);
    min-height: var(--dt-touch-min);
    border-radius: var(--dt-radius-sm);
    font-family: var(--font-body);
    font-weight: 700;
    font-size: 0.95rem;
    text-decoration: none;
    cursor: pointer;
    transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition), box-shadow var(--transition);
    border: none;
}

.btn-filled {
    background: var(--accent-dark);
    color: var(--text);
}

.btn-filled:hover {
    background: #C41230;
    transform: translateY(calc(-1 * var(--dt-border-md)));
    box-shadow: var(--dt-elevation-lg), 0 var(--dt-space-sm) var(--dt-space-xl) var(--accent-glow-strong);
}

.btn-outline {
    background: transparent;
    border: var(--dt-border-thin) solid var(--border-accent-strong);
    color: var(--text);
}

.btn-outline:hover {
    background: var(--accent-glow);
    border-color: var(--accent);
    transform: translateY(calc(-1 * var(--dt-border-md)));
}

.btn-soft {
    background: var(--accent-glow);
    border: var(--dt-border-thin) solid var(--border-accent);
    color: var(--text);
}

.btn-soft:hover {
    background: rgba(255, 0, 0, calc(var(--dt-opacity-very-light) + var(--dt-opacity-light)));
    border-color: var(--border-accent-strong);
}

.btn svg { width: var(--dt-icon-md); height: var(--dt-icon-md); }

a:focus-visible,
.btn:focus-visible,
.tag-filter-btn:focus-visible,
.store-btn:focus-visible,
.related-card:focus-visible,
.article-card:focus-visible,
.lang-switcher a:focus-visible {
    outline: var(--dt-border-md) solid var(--accent);
    outline-offset: var(--dt-border-md);
    border-radius: var(--dt-border-md);
}

/* ── Section dividers ── */
.section-divider {
    border: none;
    height: var(--dt-border-thin);
    background: linear-gradient(90deg, transparent, var(--border-accent), transparent);
    margin: var(--dt-space-xl) 0;
}

/* ── Landing: Hero ── */
.hero {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--hero-padding-top) 0 var(--hero-padding-bottom);
    background:
        radial-gradient(ellipse 80% 60% at 50% 40%, var(--accent-glow), transparent),
        linear-gradient(180deg, var(--bg) 0%, var(--panel) 100%);
    position: relative;
}

.hero-content {
    position: relative;
    z-index: 2;
}

.hero-crown {
    width: var(--dt-touch-min);
    height: var(--dt-touch-min);
    margin: 0 auto var(--dt-space-lg);
    filter: drop-shadow(0 0 var(--dt-space-lg) var(--accent-glow-strong));
    animation: crownPulse 3s ease-in-out infinite alternate;
}

@keyframes crownPulse {
    0% { filter: drop-shadow(0 0 var(--dt-space-md) var(--accent-glow-strong)); transform: scale(1); }
    100% { filter: drop-shadow(0 0 var(--dt-space-xl) rgba(255, 0, 0, 0.45)); transform: scale(1.04); }
}

.hero-title {
    font-family: var(--font-display);
    font-size: var(--h1-landing);
    letter-spacing: 0.08em;
    line-height: 0.9;
    text-wrap: balance;
    color: var(--accent);
    margin-bottom: var(--dt-space-md);
}

.hero-subtitle {
    font-family: var(--font-body);
    font-size: clamp(1.1rem, 2.5vw, 1.45rem);
    color: var(--text-secondary);
    max-width: 560px;
    margin: 0 auto var(--dt-space-lg);
    line-height: 1.6;
}

.hero-tagline {
    font-family: var(--font-heading);
    font-size: clamp(0.75rem, 1.5vw, 0.9rem);
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(255, 0, 0, calc(var(--dt-opacity-very-high) - var(--dt-opacity-light)));
    margin-bottom: var(--dt-space-lg);
}

.hero-cta {
    display: flex;
    gap: var(--dt-space-md);
    justify-content: center;
    flex-wrap: wrap;
}

/* ── Landing: Features ── */
.features-section {
    padding: var(--dt-space-3xl) 0;
    background: var(--panel);
}

.features-section .section-header {
    text-align: center;
    margin-bottom: var(--dt-space-xl);
}

.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--dt-space-lg);
}

.feature-card {
    background: var(--panel-raised);
    border: var(--dt-border-thin) solid var(--border);
    border-radius: var(--lmt-workout-card-radius);
    padding: var(--dt-space-xl) var(--dt-space-lg);
    transition: background var(--transition), border-color var(--transition), transform var(--transition);
    position: relative;
    overflow: hidden;
}

.feature-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: var(--dt-border-thick);
    background: linear-gradient(90deg, var(--accent), var(--accent-dark));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--transition);
}

.feature-card:hover::after { transform: scaleX(1); }

.feature-card:hover {
    border-color: var(--border-accent);
    transform: translateY(calc(-1 * var(--dt-border-md) * 2));
    box-shadow: var(--lmt-celebration-elevation);
}

.feature-icon {
    width: var(--dt-touch-min);
    height: var(--dt-touch-min);
    margin-bottom: var(--dt-space-md);
    color: var(--accent);
}

.feature-card h3 {
    font-family: var(--font-heading);
    font-size: var(--h3-size);
    font-weight: var(--heading-weight);
    margin-bottom: var(--dt-space-sm);
}

.feature-card p {
    color: var(--text-secondary);
    font-size: 0.95rem;
    line-height: 1.6;
}

/* ── Landing: Social Proof ── */
.social-proof {
    padding: var(--dt-space-3xl) 0;
    background: var(--bg);
    text-align: center;
}

.proof-strip {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--dt-space-lg);
    flex-wrap: wrap;
    margin-top: var(--dt-space-lg);
}

.proof-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--dt-space-sm);
}

.proof-item svg {
    width: var(--dt-icon-lg);
    height: var(--dt-icon-lg);
    color: var(--accent);
    opacity: var(--dt-opacity-very-high);
}

.proof-item span {
    font-family: var(--font-heading);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-muted);
}

/* ── Landing: Download CTA ── */
.download-section {
    padding: var(--dt-space-3xl) 0;
    background:
        radial-gradient(ellipse 60% 50% at 50% 50%, var(--accent-glow), transparent),
        var(--panel);
    text-align: center;
}

.download-buttons {
    display: flex;
    justify-content: center;
    gap: var(--dt-space-md);
    flex-wrap: wrap;
    margin-top: var(--dt-space-lg);
}

.store-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--dt-space-sm-plus);
    padding: var(--dt-space-sm-plus) var(--dt-space-xl);
    min-height: var(--dt-touch-min);
    background: rgba(255, 255, 255, var(--dt-opacity-hover));
    border: var(--dt-border-thin) solid var(--border-accent);
    border-radius: var(--dt-radius-md);
    color: var(--text);
    text-decoration: none;
    font-weight: 700;
    font-size: 0.92rem;
    transition: background var(--transition), border-color var(--transition), transform var(--transition);
}

.store-btn svg { width: var(--dt-icon-md); height: var(--dt-icon-md); }

.store-btn:hover {
    background: rgba(255, 255, 255, calc(var(--dt-opacity-light) + var(--dt-opacity-medium)));
    border-color: var(--border-accent);
    transform: translateY(calc(-1 * var(--dt-border-md)));
    box-shadow: var(--dt-elevation-lg);
}

/* ── Landing: Articles Teaser ── */
.articles-teaser {
    padding: var(--dt-space-3xl) 0;
    background: var(--panel);
    text-align: center;
}

/* ── Footer ── */
.site-footer {
    padding: var(--dt-space-lg) 0;
    background: var(--bg);
    border-top: var(--dt-border-thin) solid var(--border);
}

.footer-grid {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: var(--dt-space-lg);
}

.footer-brand {
    display: flex;
    align-items: center;
    gap: var(--dt-space-sm-plus);
    font-family: var(--font-display);
    font-size: 1.4rem;
    letter-spacing: 0.06em;
    color: var(--text);
    text-decoration: none;
}

.footer-brand svg { width: var(--dt-icon-md); height: var(--dt-icon-md); }

.footer-links-group {
    display: flex;
    gap: var(--dt-space-lg);
    flex-wrap: wrap;
}

.footer-col {
    display: flex;
    flex-direction: column;
    gap: var(--dt-space-sm);
}

.footer-col-title {
    font-family: var(--font-heading);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: var(--dt-space-xs);
}

.footer-col a {
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 0.9rem;
    transition: color var(--transition);
}

.footer-col a:hover { color: var(--accent); }

.footer-bottom {
    margin-top: var(--dt-space-lg);
    padding-top: var(--dt-space-lg);
    border-top: var(--dt-border-thin) solid var(--border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--dt-space-md);
}

.footer-copy {
    color: var(--text-muted);
    font-size: 0.82rem;
}

.footer-store-badges {
    display: flex;
    gap: var(--dt-space-md);
}

.footer-store-badges a {
    display: inline-flex;
    align-items: center;
    gap: var(--dt-space-sm);
    padding: var(--dt-space-sm) var(--dt-space-md);
    background: rgba(255, 255, 255, calc(var(--dt-opacity-light) - var(--dt-opacity-light) + 0.04));
    border: var(--dt-border-thin) solid var(--border);
    border-radius: var(--dt-radius-sm);
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 0.78rem;
    font-weight: 600;
    transition: color var(--transition), opacity var(--transition);
}

.footer-store-badges a svg { width: var(--dt-icon-sm); height: var(--dt-icon-sm); }

.footer-store-badges a:hover {
    background: rgba(255, 255, 255, var(--dt-opacity-hover));
    border-color: var(--border-accent);
}

/* ── Article: Breadcrumbs ── */
.breadcrumb {
    padding: calc(var(--nav-height) + var(--dt-space-sm)) 0 0;
    background: var(--bg);
}

.breadcrumb ol {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--dt-space-xs-plus);
    list-style: none;
    font-size: 0.82rem;
    font-weight: 600;
}

.breadcrumb li { display: flex; align-items: center; gap: var(--dt-space-xs-plus); }

.breadcrumb li + li::before {
    content: '\203A';
    color: var(--text-muted);
    font-size: 1rem;
}

.breadcrumb a {
    color: var(--text-muted);
    text-decoration: none;
    transition: color var(--transition);
}

.breadcrumb a:hover { color: var(--accent); }

.breadcrumb [aria-current="page"] {
    color: var(--text-secondary);
}

/* ── Article: Hero ── */
.article-hero {
    padding: var(--dt-space-lg) 0 var(--dt-space-lg);
    background: var(--bg);
}

.article-hero .kicker {
    display: inline-block;
    margin-bottom: var(--dt-space-sm);
    color: var(--accent);
    font-family: var(--font-heading);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.article-hero h1 {
    font-family: var(--font-heading);
    font-size: var(--h1-article);
    font-weight: var(--heading-weight);
    line-height: 1.2;
    text-wrap: balance;
    margin-bottom: var(--dt-space-md);
    max-width: 860px;
}

.article-hero .meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--dt-space-md);
    align-items: center;
    color: var(--text-muted);
    font-size: 0.85rem;
    font-weight: 600;
}

.article-hero .meta .author-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--dt-space-sm);
    color: var(--text-secondary);
}

.article-hero .meta .author-badge svg {
    width: var(--dt-avatar-sm);
    height: var(--dt-avatar-sm);
    color: var(--accent);
    opacity: var(--dt-opacity-very-high);
}

.article-hero .meta .author-role {
    font-size: 0.75rem;
    color: var(--text-muted);
    font-weight: 500;
}

.article-hero .dek {
    margin-top: var(--dt-space-md);
    max-width: var(--article-width);
    color: var(--text-secondary);
    font-size: 1.1rem;
    line-height: 1.65;
}

/* ── Article: Body ── */
.article-body {
    padding: var(--dt-space-xl) 0;
    background: var(--panel);
}

.article-body article {
    background: var(--panel-raised);
    border-radius: var(--dt-radius-lg);
    padding: var(--dt-space-lg);
}

.article-body h2 {
    font-family: var(--font-heading);
    font-size: var(--h2-size);
    font-weight: var(--heading-weight);
    line-height: 1.25;
    text-wrap: balance;
    margin: var(--dt-space-2xl) 0 var(--dt-space-md-plus);
    padding-top: var(--dt-space-sm-plus);
    border-top: var(--dt-border-thin) solid var(--border-accent);
    scroll-margin-top: var(--nav-height);
}

.article-body h2:first-child {
    margin-top: 0;
    border-top: none;
    padding-top: 0;
}

.article-body h3 {
    font-family: var(--font-heading);
    font-size: var(--h3-size);
    font-weight: 700;
    margin: var(--dt-space-xl) 0 var(--dt-space-sm-plus);
    color: rgba(255, 0, 0, var(--dt-opacity-almost-full));
    scroll-margin-top: var(--nav-height);
}

.article-body p {
    margin-bottom: var(--dt-space-md-plus);
    color: var(--text-secondary);
}

.article-body a {
    color: var(--accent);
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 0.15em;
    transition: color var(--transition);
}

.article-body .btn-filled,
.article-body .btn-outline,
.article-body .btn-soft {
    color: var(--text);
    text-decoration: none;
}

.article-body a:hover { color: var(--accent-dark); }

.article-body ul,
.article-body ol {
    margin: var(--dt-space-md-plus) 0 var(--dt-space-lg) var(--dt-space-lg);
    color: var(--text-secondary);
}

.article-body li {
    margin-bottom: var(--dt-space-sm-plus);
    padding-left: var(--dt-space-xs-plus);
}

.article-body table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--dt-space-lg) 0;
    font-size: 0.95rem;
}

.article-body thead th {
    font-family: var(--font-heading);
    font-weight: 700;
    text-align: left;
    padding: var(--dt-space-sm-plus) var(--dt-space-md);
    border-bottom: var(--dt-border-md) solid var(--border-accent);
    color: var(--text);
    font-size: 0.85rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.article-body tbody td {
    padding: var(--dt-space-sm-plus) var(--dt-space-md);
    border-bottom: var(--dt-border-thin) solid var(--border);
    color: var(--text-secondary);
    vertical-align: top;
}

.article-body tbody tr:hover {
    background: var(--accent-glow);
}

.article-body tbody td:first-child {
    font-weight: 700;
    color: var(--accent);
    width: 60px;
    text-align: center;
}

@media (max-width: 768px) {
    .article-body table { font-size: 0.88rem; }
    .article-body thead th,
    .article-body tbody td { padding: var(--dt-space-sm-plus) var(--dt-space-sm-plus); }
}

.callout {
    margin: var(--dt-space-xl) 0;
    padding: var(--dt-space-lg);
    border-left: var(--dt-border-thick) solid var(--accent);
    background: var(--accent-glow);
    color: var(--text);
    border-radius: 0 var(--dt-radius-sm) var(--dt-radius-sm) 0;
    font-weight: 600;
}

/* ── Article: Social Share ── */
.social-share {
    display: flex;
    align-items: center;
    gap: var(--dt-space-md);
    padding: var(--dt-space-sm-plus) 0;
    margin: var(--dt-space-md) 0;
}

.social-share-label {
    font-family: var(--font-heading);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-muted);
    white-space: nowrap;
}

.social-share-buttons {
    display: flex;
    align-items: center;
    gap: var(--dt-space-sm);
    flex-wrap: wrap;
}

.share-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--dt-touch-min);
    height: var(--dt-touch-min);
    border: var(--dt-border-thin) solid var(--border-accent);
    border-radius: var(--dt-radius-sm);
    background: rgba(255, 255, 255, var(--dt-opacity-light));
    color: var(--text-secondary);
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition), color var(--transition), transform var(--transition), box-shadow var(--transition);
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
    text-decoration: none;
    font: inherit;
    padding: 0;
}

.share-btn svg {
    width: var(--dt-icon-md);
    height: var(--dt-icon-md);
}

.share-btn:hover {
    background: var(--accent-glow);
    border-color: var(--accent);
    color: var(--text);
    transform: translateY(calc(-1 * var(--dt-border-md)));
    box-shadow: 0 var(--dt-space-sm) var(--dt-space-md) var(--accent-glow-strong);
}

.share-btn:focus-visible {
    outline: var(--dt-border-md) solid var(--accent);
    outline-offset: var(--dt-border-md);
    border-radius: var(--dt-radius-xs);
}

.share-copy .icon-copy,
.share-copy .icon-check {
    width: var(--dt-icon-md);
    height: var(--dt-icon-md);
}

.share-copy.copied {
    color: #22c55e;
    border-color: rgba(34, 197, 94, 0.3);
    background: rgba(34, 197, 94, 0.08);
}

.share-telegram:hover {
    border-color: #0088cc;
    box-shadow: 0 var(--dt-space-sm) var(--dt-space-md) rgba(0, 136, 204, 0.25);
}

@media (prefers-reduced-motion: reduce) {
    .share-btn {
        transition: none;
    }
    .share-btn:hover {
        transform: none;
        box-shadow: none;
    }
}

/* ── Article: Mid-article CTA ── */
.mid-cta {
    margin: var(--dt-space-2xl) 0;
    padding: var(--dt-space-lg);
    background: var(--accent-glow);
    border: var(--dt-border-thin) solid var(--border-accent);
    border-radius: var(--dt-radius-md);
    text-align: center;
}

.mid-cta p {
    color: var(--text-secondary);
    margin-bottom: var(--dt-space-md);
    font-size: 0.95rem;
}

.mid-cta .btn-filled {
    padding: var(--dt-space-sm) var(--dt-space-lg);
}

/* ── Article: Related Articles ── */
.related-articles {
    margin-top: var(--dt-space-xl);
    padding-top: var(--dt-space-lg);
    border-top: var(--dt-border-thin) solid var(--border);
}

.related-articles h3 {
    font-family: var(--font-heading);
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: var(--dt-space-lg);
}

.related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--dt-space-md);
}

.related-card {
    display: block;
    padding: var(--dt-space-lg);
    background: var(--panel);
    border: var(--dt-border-thin) solid var(--border);
    border-radius: var(--lmt-workout-card-radius);
    text-decoration: none;
    transition: border-color var(--transition), transform var(--transition);
}

.related-card:hover {
    border-color: var(--border-accent);
    transform: translateY(calc(-1 * var(--dt-border-md)));
}

.related-card h4 {
    font-family: var(--font-heading);
    font-size: 0.95rem;
    font-weight: var(--heading-weight);
    color: var(--text);
    margin-bottom: var(--dt-space-xs-plus);
}

.related-card p {
    color: var(--text-muted);
    font-size: 0.82rem;
    line-height: 1.5;
}

/* ── Article: Footer CTA ── */
.article-cta-footer {
    margin-top: var(--dt-space-lg);
    padding: var(--dt-space-lg);
    background: linear-gradient(135deg, rgba(255, 0, 0, var(--dt-opacity-light)), rgba(220, 20, 60, var(--dt-opacity-light)));
    border: var(--dt-border-thin) solid var(--border-accent);
    border-radius: var(--dt-radius-lg);
    text-align: center;
}

.article-cta-footer h3 {
    font-family: var(--font-heading);
    font-size: var(--h3-size);
    font-weight: var(--heading-weight);
    color: var(--text);
    margin-bottom: var(--dt-space-sm);
}

.article-cta-footer p {
    color: var(--text-secondary);
    margin-bottom: var(--dt-space-lg);
}

.article-cta-footer .btn-row {
    display: flex;
    gap: var(--dt-space-md);
    justify-content: center;
    flex-wrap: wrap;
}

/* ── Article List / Index ── */
.article-list {
    padding: var(--dt-space-xl) 0 var(--dt-space-2xl);
    background: var(--panel);
}

.article-grid {
    display: grid;
    gap: var(--dt-space-md);
}

.article-card {
    display: block;
    padding: var(--dt-space-xl);
    color: var(--text);
    text-decoration: none;
    border: var(--dt-border-thin) solid var(--border);
    border-radius: var(--lmt-workout-card-radius);
    background: var(--panel-raised);
    transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}

.article-card:hover {
    border-color: var(--border-accent);
    transform: translateY(calc(-1 * var(--dt-border-thick)));
    box-shadow: var(--lmt-achievement-elevation);
}

.article-card time {
    display: block;
    margin-bottom: var(--dt-space-sm);
    color: var(--text-muted);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.article-card h2 {
    font-family: var(--font-heading);
    font-size: clamp(1.3rem, 2.5vw, 1.75rem);
    font-weight: var(--heading-weight);
    line-height: 1.2;
    margin-bottom: var(--dt-space-sm);
}

.article-card p {
    color: var(--text-secondary);
    font-size: 0.95rem;
    line-height: 1.6;
}

.article-link {
    color: var(--accent);
    text-decoration: none;
    font-weight: 700;
    transition: color var(--transition);
}

.article-link:hover { color: var(--accent-dark); text-decoration: underline; }

/* ── Tag Filter Bar ── */
.tag-filter {
    padding: var(--dt-space-lg) 0;
    background: var(--panel);
    border-top: var(--dt-border-thin) solid var(--border);
    border-bottom: var(--dt-border-thin) solid var(--border);
}

.tag-filter .container {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--dt-space-sm-plus);
}

.tag-filter-label {
    color: var(--text-muted);
    font-size: 0.85rem;
    font-weight: 600;
    margin-right: var(--dt-space-sm);
}

.tag-filter-btn {
    padding: var(--dt-space-sm) var(--dt-space-md-plus);
    border: var(--dt-border-thin) solid var(--border);
    border-radius: var(--dt-radius-full);
    background: transparent;
    color: var(--text-muted);
    font-family: var(--font-body);
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition), color var(--transition);
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
}

.tag-filter-btn:hover {
    border-color: var(--accent);
    color: var(--text-secondary);
}

.tag-filter-btn.active {
    background: var(--accent);
    border-color: var(--accent);
    color: #000;
}

.tag-filter-btn:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

.tag-clear-btn {
    border-style: dashed;
    color: var(--text-muted);
    opacity: 0.7;
    transition: background var(--transition), border-color var(--transition), color var(--transition), opacity var(--transition);
}

.tag-clear-btn::before {
    content: '\00d7\0020';
}

.tag-clear-btn:hover {
    opacity: 1;
    border-color: var(--accent-dark);
    color: var(--accent-dark);
}

.tag-no-results {
    color: var(--text-muted);
    font-family: var(--font-body);
    font-size: var(--body-size);
    text-align: center;
    padding: var(--dt-space-3xl) 0;
    margin: 0;
}

/* ── Tag Labels on Cards ── */
.article-card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--dt-space-xs);
    margin-top: var(--dt-space-sm);
}

.tag-label {
    font-size: 0.72rem;
    font-weight: 600;
    padding: 2px var(--dt-space-sm);
    border-radius: var(--dt-radius-full);
    background: var(--accent-glow);
    color: var(--accent);
    text-transform: capitalize;
}

/* ── No Results ── */
.no-results {
    text-align: center;
    padding: var(--dt-space-2xl) var(--dt-space-lg);
    color: var(--text-muted);
}

.no-results h2 {
    font-family: var(--font-heading);
    font-size: var(--h2-size);
    font-weight: var(--heading-weight);
    color: var(--text-secondary);
    margin-bottom: var(--dt-space-sm);
}

.no-results p {
    color: var(--text-muted);
    font-size: 0.95rem;
}

/* ── Legal Pages ── */
.legal-page {
    padding: var(--hero-padding-top) 0 var(--hero-padding-bottom);
    max-width: 800px;
    margin: 0 auto;
}

.legal-page h1 {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: var(--heading-weight);
    margin-bottom: var(--dt-space-md);
}

.legal-page .last-updated {
    color: var(--text-muted);
    margin-bottom: var(--dt-space-lg);
}

.legal-page h2 {
    font-family: var(--font-heading);
    font-size: var(--h2-size);
    font-weight: var(--heading-weight);
    margin-top: var(--dt-space-lg);
    margin-bottom: var(--dt-space-md);
}

.legal-page h3 {
    font-family: var(--font-heading);
    font-size: var(--h3-size);
    font-weight: 700;
    margin-top: var(--dt-space-lg);
    margin-bottom: var(--dt-space-sm);
}

.legal-page p {
    margin-bottom: var(--dt-space-md);
    color: var(--text-secondary);
}

.legal-page ul, .legal-page ol {
    margin-left: var(--dt-space-lg);
    margin-bottom: var(--dt-space-md);
}

.legal-page li {
    margin-bottom: var(--dt-space-sm);
    color: var(--text-secondary);
}

.legal-page a {
    color: var(--accent);
    text-decoration: none;
}

.legal-page a:hover { text-decoration: underline; }

.legal-closing {
    margin-top: var(--dt-space-xl);
    text-align: center;
    font-style: italic;
    color: rgba(229, 229, 229, var(--dt-opacity-very-high));
}

.highlight-box {
    background: var(--accent-glow);
    border-left: var(--dt-border-thick) solid var(--accent);
    padding: var(--dt-space-md-plus) var(--dt-space-lg);
    margin: var(--dt-space-lg) 0;
}

.highlight-box strong { color: var(--text); font-weight: 600; }

/* ── Section Header ── */
.section-header h2 {
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 6vw, 4rem);
    letter-spacing: 0.04em;
    line-height: 1;
    text-wrap: balance;
    color: var(--text);
    margin-bottom: var(--dt-space-md);
}

.section-header p {
    color: var(--text-secondary);
    font-size: clamp(1rem, 2vw, 1.15rem);
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
}

.section-header.centered { text-align: center; }

.section-header.centered p { margin-left: auto; margin-right: auto; }

/* ── Responsive ── */
@media (max-width: 768px) {
    .container, .narrow { width: min(100% - var(--dt-space-xl), var(--content-width)); }

    .site-nav .container,
    .article-nav .container { height: var(--dt-touch-lg); }
    .nav-links,
    .nav-right { gap: var(--dt-space-md); }

    .hero { min-height: 90vh; padding: calc(var(--dt-touch-md) + var(--dt-space-2xl)) 0 var(--dt-space-3xl); }
    .hero-crown { width: var(--dt-touch-min); height: var(--dt-touch-min); }
    .hero-cta { flex-direction: column; align-items: center; }

    .features-grid { grid-template-columns: 1fr; }
    .feature-card { padding: var(--dt-space-lg) var(--dt-space-md-plus); }

    .proof-strip { gap: var(--dt-space-lg); }

    .download-buttons { flex-direction: column; align-items: center; }

    .footer-grid { flex-direction: column; gap: var(--dt-space-lg); }
    .footer-bottom { flex-direction: column; align-items: center; text-align: center; }

    .article-body article { padding: var(--dt-space-lg); }

    .related-grid { grid-template-columns: 1fr; }

    .article-card { padding: var(--dt-space-lg); }

    .tag-filter-btn {
        padding: var(--dt-space-xs-plus) var(--dt-space-md);
        font-size: 0.76rem;
    }

    .features-section,
    .social-proof,
    .download-section,
    .articles-teaser,
    .article-list { padding: var(--dt-space-xl) 0; }
}

@media (max-width: 480px) {
    .container, .narrow { width: min(100% - var(--dt-space-lg), var(--content-width)); }
    .hero-title { font-size: clamp(3rem, 15vw, 5rem); }
    .proof-strip { flex-direction: column; }
}

@media (hover: none) and (pointer: coarse) {
    .btn, .store-btn, .feature-card, .article-card, .related-card, .tag-filter-btn {
        -webkit-tap-highlight-color: rgba(255, 0, 0, var(--dt-opacity-very-light));
    }
    .btn:active, .store-btn:active, .tag-filter-btn:active { transform: scale(0.97); }
}

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(var(--dt-space-lg)); }
    to { opacity: 1; transform: translateY(0); }
}

.feature-card, .article-card { animation: fadeInUp 0.5s ease forwards; }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: calc(0.01ms * var(--dt-animation-mult-reduced)) !important;
        animation-iteration-count: 1 !important;
        transition-duration: calc(0.01ms * var(--dt-animation-mult-reduced)) !important;
    }
    .hero-crown { animation: none; }
}
