@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@500;700;800&family=Rajdhani:wght@400;500;600;700&display=swap');

:root {
    --ink: #f7f8fb;
    --ink-strong: #fff;
    --ink-soft: #97a0b7;
    --copy: #d3d9e8;
    --surface: #0d1320;
    --surface-strong: #131b2c;
    --surface-soft: #1b2336;
    --line: rgba(255, 255, 255, 0.1);
    --brand: #e31f2b;
    --brand-dark: #8c1017;
    --accent: #79c2e8;
    --accent-rgb: 121, 194, 232;
    --danger: #ff6d6d;
    --difficulty-beginner: #7ed7a5;
    --difficulty-beginner-rgb: 126, 215, 165;
    --difficulty-intermediate: #8cc9ff;
    --difficulty-intermediate-rgb: 140, 201, 255;
    --difficulty-challenging: #ffb37a;
    --difficulty-challenging-rgb: 255, 179, 122;
    --difficulty-advanced: #ff8484;
    --difficulty-advanced-rgb: 255, 132, 132;
    --shadow: 0 24px 60px rgba(0, 0, 0, 0.28);
    --radius: 24px;
    --page-background:
        radial-gradient(circle at top right, rgba(227, 31, 43, 0.18), transparent 26%),
        radial-gradient(circle at 20% 20%, rgba(var(--accent-rgb), 0.12), transparent 22%),
        linear-gradient(180deg, #09101b 0%, #0b1220 45%, #11192b 100%);
    --topbar-background: rgba(7, 11, 18, 0.92);
    --nav-background: rgba(10, 15, 24, 0.84);
    --search-background: rgba(12, 18, 29, 0.94);
    --input-border: rgba(255, 255, 255, 0.12);
    --input-background: rgba(255, 255, 255, 0.04);
    --panel-background: linear-gradient(180deg, rgba(18, 26, 41, 0.94), rgba(12, 18, 29, 0.98));
    --panel-background-feature:
        linear-gradient(180deg, rgba(18, 26, 41, 0.96), rgba(12, 18, 29, 0.98)),
        linear-gradient(135deg, rgba(227, 31, 43, 0.2), transparent 48%);
    --card-background: rgba(255, 255, 255, 0.03);
    --card-background-strong: rgba(255, 255, 255, 0.04);
    --card-background-stronger: rgba(255, 255, 255, 0.08);
    --card-background-hover: rgba(255, 255, 255, 0.05);
    --card-border: rgba(255, 255, 255, 0.08);
    --card-border-soft: rgba(255, 255, 255, 0.06);
    --button-primary-text: #fff;
    --button-secondary-text: #fff;
    --button-secondary-background: transparent;
    --hero-location-color: #fff;
    --toast-background: rgba(10, 16, 26, 0.96);
    --toast-message: #eef2fb;
    --spinner-track: rgba(255, 255, 255, 0.28);
}

:root[data-theme='light'] {
    color-scheme: light;
    --ink: #18263c;
    --ink-strong: #18263c;
    --ink-soft: #5f7188;
    --copy: #51637c;
    --surface: #edf4fb;
    --surface-strong: #ffffff;
    --surface-soft: #f4f8fc;
    --line: rgba(24, 38, 60, 0.14);
    --brand: #d61b29;
    --brand-dark: #8c1017;
    --accent: #156f99;
    --accent-rgb: 21, 111, 153;
    --difficulty-beginner: #25794b;
    --difficulty-beginner-rgb: 37, 121, 75;
    --difficulty-intermediate: #156f99;
    --difficulty-intermediate-rgb: 21, 111, 153;
    --difficulty-challenging: #af5f1e;
    --difficulty-challenging-rgb: 175, 95, 30;
    --difficulty-advanced: #b53e3e;
    --difficulty-advanced-rgb: 181, 62, 62;
    --shadow: 0 24px 60px rgba(67, 88, 112, 0.16);
    --page-background:
        radial-gradient(circle at top right, rgba(227, 31, 43, 0.08), transparent 26%),
        radial-gradient(circle at 20% 20%, rgba(var(--accent-rgb), 0.12), transparent 22%),
        linear-gradient(180deg, #f7fbff 0%, #edf3f9 45%, #e7eef6 100%);
    --topbar-background: rgba(255, 255, 255, 0.94);
    --nav-background: rgba(247, 250, 254, 0.96);
    --search-background: rgba(251, 253, 255, 0.98);
    --input-border: rgba(24, 38, 60, 0.12);
    --input-background: rgba(24, 38, 60, 0.03);
    --panel-background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 248, 252, 0.98));
    --panel-background-feature:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 248, 252, 0.98)),
        linear-gradient(135deg, rgba(227, 31, 43, 0.08), transparent 48%);
    --card-background: rgba(24, 38, 60, 0.03);
    --card-background-strong: rgba(24, 38, 60, 0.045);
    --card-background-stronger: rgba(24, 38, 60, 0.08);
    --card-background-hover: rgba(24, 38, 60, 0.06);
    --card-border: rgba(24, 38, 60, 0.1);
    --card-border-soft: rgba(24, 38, 60, 0.08);
    --button-secondary-text: #18263c;
    --button-secondary-background: rgba(24, 38, 60, 0.03);
    --hero-location-color: #22324a;
    --toast-background: rgba(255, 255, 255, 0.98);
    --toast-message: #22324a;
    --spinner-track: rgba(24, 38, 60, 0.18);
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: "Rajdhani", "Trebuchet MS", sans-serif;
    color: var(--ink);
    background: var(--page-background);
}

a {
    color: inherit;
}

.material-symbols-outlined {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: 'Material Symbols Outlined';
    font-weight: 400;
    font-style: normal;
    font-size: 1.25rem;
    line-height: 1;
    letter-spacing: normal;
    text-transform: none;
    white-space: nowrap;
    word-wrap: normal;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

h1,
h2,
h3 {
    margin: 0;
    line-height: 1.06;
    font-family: "Barlow Condensed", Impact, sans-serif;
    letter-spacing: 0.02em;
}

h1 {
    font-size: clamp(2.8rem, 14vw, 4.4rem);
}

h2 {
    font-size: clamp(1.8rem, 8vw, 2.4rem);
}

h3 {
    font-size: clamp(1.35rem, 6vw, 1.8rem);
}

p {
    margin: 0;
}

.page-shell,
.admin-shell,
.sports-header,
.sports-main {
    width: min(100%, 1280px);
    margin: 0 auto;
    padding-inline: 16px;
}

.sports-page {
    min-height: 100vh;
}

.sports-header {
    padding-top: 14px;
}

.sports-topbar {
    display: grid;
    gap: 16px;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: 22px 22px 0 0;
    background: var(--topbar-background);
}

.sports-brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: var(--ink-strong);
    text-decoration: none;
}

.sports-brand strong,
.sports-nav a,
.sports-nav__link,
.sports-utility__links a,
.hero-scorecard__label,
.fixture-card__index,
.news-rail__eyebrow,
.ticker-strip__label,
.button,
.eyebrow,
.story-stats dt,
.course-meta dt,
.muted-label,
.fixture-card__label {
    font-family: "Barlow Condensed", Impact, sans-serif;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sports-brand strong {
    display: block;
    font-size: 1.7rem;
    line-height: 1;
}

.sports-brand__sub {
    display: block;
    margin-top: 2px;
    color: var(--ink-soft);
    font-size: 0.9rem;
}

.sports-brand__crest {
    width: 52px;
    height: 52px;
    border-radius: 16px;
    display: grid;
    place-items: center;
    color: #fff;
    background: linear-gradient(145deg, #ff3945 0%, #b80f1c 100%);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.15);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 1.4rem;
}

.sports-utility {
    display: grid;
    gap: 12px;
    justify-items: end;
}

.settings-link {
    text-decoration: none;
}

.sports-utility .actions,
.topbar .actions {
    width: 100%;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.topbar .actions .settings-menu {
    width: 100%;
    display: flex;
    justify-content: flex-end;
    margin-left: 0;
}

.auth-tools .settings-menu {
    width: 100%;
    display: flex;
    justify-content: flex-end;
}

.sports-utility__links,
.sports-nav,
.hero-actions,
.fixture-card__actions,
.course-links,
.actions,
.stack {
    display: flex;
    align-items: center;
    gap: 12px;
}

.sports-nav {
    flex-wrap: wrap;
}

.sports-utility__links,
.sports-nav {
    overflow-x: auto;
    padding-bottom: 2px;
    scrollbar-width: none;
}

}

.sports-utility__links a,
.sports-nav a,
.sports-nav__link {
    flex: 0 0 auto;
    color: var(--ink-soft);
    text-decoration: none;
    font-size: 0.88rem;
    white-space: nowrap;
}

.sports-utility__links a:hover,
.sports-nav a:hover,
.sports-nav__link:hover,
.sports-brand:hover,
.text-link-light:hover {
    color: var(--ink-strong);
}

.sports-nav__link {
    position: relative;
    padding: 0.3rem 0;
}

.sports-nav__link--active {
    color: var(--ink-strong);
}

.sports-nav__link--active::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -0.35rem;
    height: 2px;
    border-radius: 999px;
    background: var(--accent);
}

.sports-nav {
    gap: 22px;
    padding: 14px 16px 16px;
    border: 1px solid var(--line);
    border-top: 0;
    background: var(--nav-background);
}

.sports-search {
    display: grid;
    gap: 10px;
    padding: 16px;
    border: 1px solid var(--line);
    border-top: 0;
    background: var(--search-background);
}

.sports-search__form {
    display: grid;
    gap: 10px;
}

.sports-search__label {
    color: var(--ink-soft);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 0.92rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.sports-search__controls {
    display: block;
}

.sports-search__input {
    width: 100%;
    min-height: 52px;
    padding: 0.95rem 1rem;
    border: 1px solid var(--input-border);
    border-radius: 16px;
    background: var(--input-background);
    color: var(--ink-strong);
    font: inherit;
}

.sports-search__input::placeholder {
    color: #8290ac;
}

.sports-search__input:focus {
    outline: 2px solid rgba(227, 31, 43, 0.28);
    border-color: rgba(227, 31, 43, 0.6);
}

.sports-search__status {
    color: var(--ink-soft);
    font-size: 0.98rem;
}

.player-console,
.play-session-card,
.pending-invite-card,
.invite-search-option,
.play-session-members__item,
.invite-chip {
    border: 1px solid var(--card-border);
    background: var(--card-background);
}

.player-console,
.play-session-panel,
.play-session-card,
.play-session-form,
.pending-invite-list,
.play-session-members,
.play-session-members__list {
    display: grid;
    gap: 12px;
}

.player-console {
    padding: 14px;
    border-radius: 18px;
}

.player-console__head,
.player-console__invites-head,
.play-session-card__summary {
    display: grid;
    gap: 12px;
}

.player-console__field,
.player-console__current,
.player-console__invites {
    display: grid;
    gap: 8px;
}

.player-console__current strong {
    color: var(--ink-strong);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 1.35rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.pending-invite-card,
.play-session-members__item,
.invite-search-option {
    padding: 14px;
    border-radius: 16px;
}

.pending-invite-card,
.play-session-members__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.pending-invite-card .button {
    flex: 0 0 auto;
}

.play-session-panel {
    overflow: hidden;
}

.play-session-card {
    padding: 16px;
    border-radius: 18px;
}

.invite-chip-list,
.play-session-form .actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.invite-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0.65rem 0.9rem;
    border-radius: 999px;
    color: var(--ink-strong);
    cursor: pointer;
}

.invite-chip .material-symbols-outlined {
    font-size: 1rem;
}

.invite-search-list {
    display: grid;
    gap: 8px;
}

.invite-search-option {
    width: 100%;
    color: var(--ink-strong);
    text-align: left;
    cursor: pointer;
}

.invite-search-option small {
    display: block;
    margin-top: 4px;
    color: var(--ink-soft);
    font-size: 0.9rem;
}

.play-session-members__list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.badge--subtle {
    background: var(--card-background-strong);
    color: var(--ink-strong);
}

.sports-main {
    padding-top: 18px;
    padding-bottom: 42px;
}

.course-show {
    display: grid;
    gap: 16px;
}

.hero-splash {
    position: relative;
    display: grid;
    gap: 18px;
    overflow: hidden;
    padding: 24px 18px 22px;
    border: 1px solid var(--line);
    border-top: 0;
    background:
        linear-gradient(110deg, rgba(6, 10, 18, 0.88) 0%, rgba(9, 13, 22, 0.7) 42%, rgba(16, 24, 38, 0.62) 100%),
        linear-gradient(135deg, rgba(227, 31, 43, 0.5), rgba(8, 14, 24, 0.15) 35%),
        radial-gradient(circle at 75% 40%, rgba(255, 255, 255, 0.2), transparent 25%),
        linear-gradient(160deg, #101726 0%, #0b111c 50%, #162235 100%);
}

.hero-splash::before {
    content: "";
    position: absolute;
    inset: auto -14% -18% auto;
    width: 240px;
    height: 240px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.16), transparent 62%);
    filter: blur(6px);
}

.hero-splash::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.045) 0 1px, transparent 1px 100%);
    background-size: 90px 100%;
    mix-blend-mode: soft-light;
    opacity: 0.35;
    pointer-events: none;
}

.hero-splash__media {
    position: absolute;
    right: -32px;
    bottom: -22px;
    width: 170px;
    height: 240px;
    border-radius: 42% 42% 18% 18%;
    background:
        linear-gradient(180deg, rgba(248, 249, 252, 0.9), rgba(216, 224, 234, 0.96) 42%, rgba(212, 29, 42, 0.95) 42%, rgba(158, 14, 24, 0.94) 70%, rgba(20, 25, 35, 0.98) 70%),
        radial-gradient(circle at 50% 15%, #ffe1c4 0 20%, transparent 20%),
        radial-gradient(circle at 50% 30%, #101827 0 7%, transparent 7%);
    box-shadow: 0 18px 50px rgba(0, 0, 0, 0.32);
    opacity: 0.28;
}

.hero-splash__content,
.hero-scorecard,
.sports-panel,
.ticker-strip,
.sports-empty,
.site-header,
.panel,
.course-card,
.empty-state,
.auth-card {
    position: relative;
    z-index: 1;
}

.hero-splash__content {
    max-width: 100%;
    padding-top: 6px;
}

.eyebrow {
    margin: 0 0 8px;
    color: var(--brand);
    font-size: 0.8rem;
}

.eyebrow-light {
    color: var(--accent);
}

.hero-location {
    margin-top: 8px;
    color: var(--hero-location-color);
    font-size: 0.98rem;
}

.hero-summary,
.story-copy,
.news-rail__item p,
.course-description,
.muted,
.field-help,
.sports-empty p {
    color: var(--copy);
    line-height: 1.6;
}

.hero-summary {
    max-width: 100%;
    margin-top: 18px;
    padding-right: 48px;
    font-size: 1rem;
}

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0.82rem 1.15rem;
    border: 1px solid transparent;
    text-decoration: none;
    font-weight: 700;
    cursor: pointer;
}

.button-primary {
    background: var(--brand);
    color: var(--button-primary-text);
}

.button-secondary {
    background: var(--button-secondary-background);
    color: var(--button-secondary-text);
    border-color: var(--line);
}

.button-dark {
    background: var(--card-background-strong);
}

.button-primary:hover,
.button-secondary:hover,
.text-link:hover {
    opacity: 0.9;
}

.button-with-spinner {
    min-width: 134px;
}

.button-with-spinner[disabled] {
    opacity: 0.76;
    cursor: wait;
}

.button-spinner-wrap {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.button-spinner {
    width: 1rem;
    height: 1rem;
    border: 2px solid var(--spinner-track);
    border-top-color: currentColor;
    border-radius: 50%;
    animation: button-spin 0.8s linear infinite;
}

.toast-shell {
    position: fixed;
    inset: auto 16px 16px 16px;
    z-index: 1000;
    display: flex;
    justify-content: center;
    pointer-events: none;
}

.toast {
    width: min(100%, 420px);
    padding: 14px 16px;
    border: 1px solid var(--card-border);
    border-radius: 18px;
    background: var(--toast-background);
    color: var(--ink-strong);
    box-shadow: var(--shadow);
    transform: translateY(10px);
    opacity: 0;
    transition: opacity 160ms ease, transform 160ms ease;
}

.toast[data-state='visible'] {
    transform: translateY(0);
    opacity: 1;
}

.toast[data-type='error'] {
    border-color: rgba(255, 109, 109, 0.35);
}

.toast[data-type='success'] {
    border-color: rgba(var(--accent-rgb), 0.35);
}

.toast__status {
    margin-bottom: 6px;
    color: var(--accent);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 0.84rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.toast[data-type='error'] .toast__status {
    color: var(--danger);
}

.toast__message {
    margin: 0;
    color: var(--toast-message);
    line-height: 1.5;
}

.hero-actions {
    flex-wrap: wrap;
    margin-top: 20px;
}

.hero-actions .button {
    width: 100%;
}

.hero-scorecard {
    display: grid;
    gap: 2px;
    padding: 18px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(15, 22, 35, 0.92), rgba(11, 16, 27, 0.98));
    backdrop-filter: blur(8px);
}

.hero-scorecard__label {
    margin: 0 0 10px;
    color: var(--accent);
    font-size: 0.9rem;
}

.hero-scorecard__row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    color: #bcc4d6;
}

.hero-scorecard__row:first-of-type {
    border-top: 0;
    padding-top: 0;
}

.hero-scorecard__row strong {
    color: #fff;
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 1.35rem;
}

.ticker-strip {
    display: grid;
    gap: 1px;
    margin-top: 16px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.08);
}

.ticker-strip__item {
    padding: 16px 18px;
    background: rgba(10, 16, 26, 0.96);
}

.ticker-strip__item strong {
    display: block;
    margin: 6px 0;
    color: #fff;
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 1.55rem;
}

.ticker-strip__item span:last-child {
    color: var(--ink-soft);
}

.sports-grid,
.sports-grid__main,
.sports-grid__side,
.course-list,
.panel-grid,
.import-form {
    display: grid;
    gap: 16px;
}

.course-index-list,
.course-gallery {
    display: grid;
    gap: 12px;
}

.sports-grid {
    margin-top: 16px;
}

.sports-panel,
.site-header,
.panel,
.course-card,
.empty-state,
.auth-card {
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 20px;
    background: var(--panel-background);
    box-shadow: var(--shadow);
}

.sports-panel--feature {
    background: var(--panel-background-feature);
}

.sports-panel--index {
    padding-block: 22px;
}

.sports-panel__heading,
.course-card__top,
.dashboard-header,
.topbar {
    display: grid;
    gap: 10px;
    margin-bottom: 18px;
    min-width: 0;
}

.dashboard-header > div,
.topbar > div,
.course-list-item,
.course-list-item > *,
.panel,
.admin-shell,
.actions,
.course-list,
.sports-panel {
    min-width: 0;
}

.panel-note {
    color: var(--ink-soft);
}

.score-pill {
    width: fit-content;
    min-width: 64px;
    padding: 8px 14px;
    border-radius: 16px;
    background: linear-gradient(180deg, var(--brand), var(--brand-dark));
    color: var(--button-primary-text);
    text-align: center;
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 1.7rem;
}

.story-grid {
    display: grid;
    gap: 16px;
}

.story-stats,
.course-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 0;
}

.course-index-card {
    display: grid;
    gap: 14px;
    padding: 18px;
    border: 1px solid var(--card-border);
    border-radius: 18px;
    background: var(--card-background);
    text-decoration: none;
}

.course-index-card:hover {
    border-color: rgba(var(--accent-rgb), 0.42);
    background: var(--card-background-hover);
}

.course-index-card__title h2 {
    font-size: clamp(1.7rem, 8vw, 2.2rem);
}

.course-index-card__title {
    display: grid;
    gap: 10px;
}

.course-index-card__stats,
.course-show__stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 0;
}

.course-index-card__stats div,
.course-show__stats div {
    padding: 12px;
    border-radius: 16px;
    background: var(--card-background-strong);
    border: 1px solid var(--card-border-soft);
}

.course-index-card__stats dt,
.course-show__stats dt {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
    color: var(--ink-soft);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.course-stat-card {
    display: grid;
    gap: 8px;
}

.course-stat-card__icon {
    width: 1.75rem;
    height: 1.75rem;
    border-radius: 999px;
    background: rgba(227, 31, 43, 0.14);
    color: var(--brand);
    flex: 0 0 auto;
    font-size: 1rem;
}

.course-index-card__stats dd,
.course-show__stats dd {
    margin: 0;
    color: var(--ink-strong);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 1.3rem;
}

.course-show__hero {
    display: grid;
    gap: 18px;
}

.course-show__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.course-gallery__item {
    display: block;
    overflow: hidden;
    border-radius: 18px;
    border: 1px solid var(--card-border);
    background: var(--card-background);
}

.course-gallery__item img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.course-facts__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 0;
}

.course-facts__grid div,
.course-layout-card {
    padding: 14px;
    border-radius: 18px;
    border: 1px solid var(--card-border);
    background: var(--card-background);
}

.course-fact-card {
    display: grid;
    gap: 8px;
}

.course-facts__grid dt {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
    color: var(--ink-soft);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.course-fact-card__icon {
    width: 1.75rem;
    height: 1.75rem;
    border-radius: 999px;
    background: rgba(var(--accent-rgb), 0.16);
    color: var(--accent);
    flex: 0 0 auto;
    font-size: 1rem;
}

.course-difficulty-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.course-difficulty-token {
    display: inline-flex;
    align-items: center;
    min-height: 1.75rem;
    padding: 0.22rem 0.55rem;
    border: 1px solid currentcolor;
    border-radius: 999px;
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 0.92rem;
    letter-spacing: 0.04em;
    line-height: 1;
}

.course-difficulty-token--beginner {
    color: var(--difficulty-beginner);
    background: rgba(var(--difficulty-beginner-rgb), 0.12);
}

.course-difficulty-token--intermediate {
    color: var(--difficulty-intermediate);
    background: rgba(var(--difficulty-intermediate-rgb), 0.12);
}

.course-difficulty-token--challenging {
    color: var(--difficulty-challenging);
    background: rgba(var(--difficulty-challenging-rgb), 0.12);
}

.course-difficulty-token--advanced {
    color: var(--difficulty-advanced);
    background: rgba(var(--difficulty-advanced-rgb), 0.12);
}

.course-facts__grid dd {
    margin: 0;
    color: var(--ink-strong);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 1.2rem;
}

.course-feature-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 16px 0 0;
    padding: 0;
    list-style: none;
}

.course-feature-list li {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.8rem 1rem;
    border: 1px solid rgba(var(--accent-rgb), 0.24);
    border-radius: 999px;
    background: var(--card-background);
    color: var(--ink-strong);
    font-family: "Barlow Condensed", Impact, sans-serif;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.course-feature-list .material-symbols-outlined {
    color: var(--accent);
    font-size: 1rem;
}

.course-accessibility {
    margin-top: 18px;
    padding: 14px;
    border-left: 3px solid rgba(var(--accent-rgb), 0.55);
    background: var(--card-background);
}

.course-accessibility__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.course-accessibility__eyebrow .material-symbols-outlined {
    color: var(--brand);
    font-size: 1rem;
}

.course-layouts {
    display: grid;
    gap: 14px;
}

.course-layout-card {
    display: grid;
    gap: 14px;
}

.course-layout-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.course-layout-card__actions {
    margin-top: 12px;
}

.course-layout-card__difficulty {
    margin-top: 8px;
}

.course-holes-table {
    overflow-x: auto;
}

.course-holes-table table {
    width: 100%;
    min-width: 280px;
    border-collapse: collapse;
}

.course-holes-table th,
.course-holes-table td {
    padding: 0.9rem 0.35rem;
    border-bottom: 1px solid var(--card-border);
    text-align: left;
}

.course-holes-table th {
    color: var(--ink-soft);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 0.82rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.course-holes-table td {
    color: var(--ink-strong);
}

.story-stats div,
.course-meta div,
.stat {
    padding: 12px;
    border: 1px solid var(--card-border-soft);
    border-radius: 16px;
    background: var(--card-background-strong);
}

.story-stats dd,
.course-meta dd,
.stat strong {
    margin: 0;
    color: var(--ink-strong);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 1.25rem;
}

.fixture-list,
.news-rail {
    display: grid;
    gap: 12px;
}

.course-admin-footer,
.course-admin-footer__stats,
.course-admin-footer__actions {
    display: grid;
    gap: 12px;
}

.course-admin-footer__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.course-admin-footer__actions .button,
.course-admin-footer__actions .text-link {
    width: 100%;
    justify-content: center;
}

.course-admin-footer__actions .text-link {
    display: inline-flex;
    align-items: center;
    min-height: 48px;
    padding: 0.82rem 1.15rem;
    border: 1px solid rgba(var(--accent-rgb), 0.22);
    border-radius: 999px;
    background: var(--card-background);
    text-decoration: none;
}

.fixture-card,
.course-list-item {
    display: grid;
    gap: 14px;
    padding: 16px;
    border: 1px solid var(--card-border);
    border-radius: 18px;
    background: var(--card-background);
}

.fixture-card--lead {
    background:
        linear-gradient(110deg, rgba(227, 31, 43, 0.18), transparent 42%),
        var(--card-background);
}

.fixture-card__meta {
    display: flex;
    align-items: center;
    gap: 14px;
}

.fixture-card__meta p,
.news-rail__item p,
.fixture-card__meta h3 + p {
    color: var(--ink-soft);
}

.course-list-item h3,
.course-list-item p,
.course-list-item .muted,
.dashboard-header h2,
.dashboard-header h3,
.topbar h1,
.topbar p {
    min-width: 0;
    overflow-wrap: break-word;
    word-break: normal;
}

.course-list-item .text-link,
.field-help,
.sports-search__status {
    overflow-wrap: anywhere;
}

.fixture-card__index {
    min-width: 48px;
    padding: 10px 8px;
    border-radius: 14px;
    background: var(--card-background-stronger);
    color: var(--ink-strong);
    text-align: center;
    font-size: 1.05rem;
}

.fixture-card__score {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.fixture-card__score strong {
    display: block;
    color: var(--ink-strong);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 1.55rem;
}

.fixture-card__actions {
    flex-wrap: wrap;
    padding-top: 10px;
    border-top: 1px solid var(--card-border);
}

.news-rail__item {
    padding: 16px 0;
    border-top: 1px solid var(--card-border);
}

.news-rail__item:first-child {
    padding-top: 0;
    border-top: 0;
}

.news-rail__eyebrow {
    margin: 0 0 8px;
    color: var(--accent);
    font-size: 0.86rem;
}

.news-rail__meta {
    display: grid;
    gap: 4px;
    margin-top: 10px;
    color: var(--ink-soft);
    font-size: 0.95rem;
}

.sports-empty {
    margin: 0 auto;
    padding: 56px 22px;
    text-align: center;
    border: 1px solid var(--line);
    border-top: 0;
    background: var(--panel-background);
}

.sports-empty p {
    max-width: 34ch;
    margin: 18px auto 0;
}

.course-grid {
    display: grid;
    gap: 16px;
}

.badge {
    width: fit-content;
    padding: 0.4rem 0.7rem;
    border-radius: 999px;
    background: var(--card-background-stronger);
    color: var(--ink-strong);
    font-weight: 700;
    white-space: nowrap;
}

.lead {
    max-width: 62ch;
    margin: 12px 0 0;
    color: var(--ink-soft);
    font-size: 1rem;
    line-height: 1.6;
}

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

.text-link-light {
    color: var(--ink-strong);
}

.empty-state,
.auth-wrap {
    padding: 32px 18px;
    text-align: center;
}

.topbar {
    margin-bottom: 20px;
}

.brand-link {
    font-size: 1.4rem;
    font-weight: 700;
    text-decoration: none;
}

.auth-wrap {
    min-height: calc(100vh - 64px);
    display: grid;
    place-items: center;
    padding-inline: 16px;
}

.auth-card {
    width: min(100%, 480px);
    margin-inline: auto;
    text-align: left;
}

.sports-nav__button {
    border: 0;
    padding: 0;
    color: inherit;
    background: transparent;
    cursor: pointer;
}

.logout-form--nav {
    display: inline-flex;
}

.field {
    display: grid;
    gap: 8px;
    margin-top: 18px;
}

.field label {
    font-weight: 700;
}

.field input {
    width: 100%;
    border: 1px solid var(--input-border);
    border-radius: 14px;
    padding: 0.95rem 1rem;
    font: inherit;
    color: var(--ink-strong);
    background: var(--input-background);
}

.field input:focus {
    outline: 2px solid rgba(227, 31, 43, 0.28);
    border-color: rgba(227, 31, 43, 0.6);
}

.error-text {
    color: var(--danger);
    font-size: 0.92rem;
}

.flash {
    margin-bottom: 18px;
    padding: 14px 16px;
    border-radius: 14px;
    background: rgba(227, 31, 43, 0.16);
    color: var(--button-primary-text);
}

.settings-menu {
    position: relative;
}

.settings-menu--nav {
    flex: 0 0 auto;
}

.settings-menu__summary {
    min-width: 0;
    list-style: none;
}

.settings-menu__summary::-webkit-details-marker {
    display: none;
}

.settings-menu__summary--nav {
    display: inline-flex;
    align-items: center;
    min-height: auto;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--ink-soft);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 0.88rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
}

.settings-menu__summary--nav:hover {
    color: var(--ink-strong);
}

.settings-menu__panel {
    position: absolute;
    right: 0;
    top: calc(100% + 12px);
    z-index: 20;
    width: min(92vw, 360px);
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: var(--panel-background);
    box-shadow: var(--shadow);
}

.settings-menu__header {
    display: grid;
    gap: 6px;
    margin-bottom: 16px;
}

.settings-form {
    display: grid;
    gap: 16px;
}

.settings-group {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    border: 0;
}

.settings-group legend {
    margin-bottom: 4px;
    color: var(--ink-soft);
    font-family: "Barlow Condensed", Impact, sans-serif;
    font-size: 0.84rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.settings-choice-grid {
    display: grid;
    gap: 10px;
}

.settings-choice {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0.8rem 0.95rem;
    border: 1px solid var(--card-border);
    border-radius: 14px;
    background: var(--card-background);
    color: var(--ink-strong);
}

.settings-choice input {
    margin: 0;
}

.settings-form__submit {
    width: 100%;
}

.auth-tools {
    display: flex;
    justify-content: flex-end;
    width: min(100%, 480px);
    margin: 0 auto 14px;
}

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

.admin-shell {
    padding-top: 20px;
    padding-bottom: 48px;
}

.logout-form {
    margin: 0;
}

@media (min-width: 700px) {
    .page-shell,
    .admin-shell,
    .sports-header,
    .sports-main {
        padding-inline: 24px;
    }

    .sports-topbar {
        padding: 18px 22px;
    }

    .player-console__head,
    .player-console__invites-head,
    .play-session-card__summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        align-items: end;
    }

    .player-console__current {
        justify-items: end;
        text-align: right;
    }

    .sports-brand strong {
        font-size: 2rem;
    }

    .sports-utility {
        justify-items: end;
    }

    .sports-utility .actions,
    .topbar .actions {
        width: auto;
    }

    .topbar .actions .settings-menu,
    .auth-tools .settings-menu {
        width: auto;
        display: block;
    }

    .sports-utility__links,
    .sports-nav {
        gap: 20px;
    }

    .sports-search {
        padding: 18px 22px;
    }

    .sports-search__controls {
        display: block;
    }

    .hero-splash {
        padding: 30px 24px 24px;
    }

    .hero-splash__media {
        width: 220px;
        height: 310px;
        right: -10px;
        bottom: -14px;
        opacity: 0.42;
    }

    .hero-actions .button {
        width: auto;
    }

    .ticker-strip {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .sports-panel,
    .site-header,
    .panel,
    .course-card,
    .empty-state,
    .auth-card {
        padding: 24px;
    }

    .story-stats,
    .course-meta {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .course-index-card {
        grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
        align-items: center;
    }

    .course-index-card__stats {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .course-gallery {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .course-facts__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .news-rail__meta {
        display: flex;
        justify-content: space-between;
        gap: 10px;
    }

    .topbar,
    .sports-panel__heading,
    .dashboard-header,
    .course-card__top {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        gap: 16px;
    }

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

    .course-admin-footer {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
    }

    .course-admin-footer__actions {
        grid-auto-flow: column;
        align-items: center;
    }

    .course-admin-footer__actions .button,
    .course-admin-footer__actions .text-link {
        width: auto;
    }
}

@media (min-width: 960px) {
    .page-shell,
    .admin-shell,
    .sports-header,
    .sports-main {
        padding-inline: 32px;
    }

    .sports-topbar {
        grid-template-columns: auto 1fr;
        align-items: center;
    }

    .play-session-form .actions .button,
    .pending-invite-card .button {
        width: auto;
    }

    .sports-utility {
        display: flex;
        align-items: center;
        justify-content: flex-end;
        gap: 18px;
    }

    .sports-nav {
        gap: 28px;
        padding: 16px 24px 18px;
    }

    .hero-splash {
        grid-template-columns: minmax(0, 1.5fr) minmax(280px, 360px);
        gap: 24px;
        padding: 42px;
        min-height: 520px;
    }

    .hero-splash::before {
        inset: auto -8% -22% auto;
        width: 420px;
        height: 420px;
    }

    .hero-splash__media {
        width: 340px;
        height: 440px;
        right: 3%;
        bottom: -4%;
        opacity: 0.8;
    }

    .hero-splash__content {
        max-width: 640px;
        padding-top: 26px;
    }

    .hero-summary {
        max-width: 56ch;
        padding-right: 0;
        font-size: 1.15rem;
    }

    .hero-scorecard {
        align-self: end;
        padding: 26px;
    }

    .hero-scorecard__row strong {
        font-size: 1.5rem;
    }

    .sports-grid {
        grid-template-columns: minmax(0, 1.55fr) minmax(300px, 0.78fr);
        gap: 22px;
        margin-top: 22px;
    }

    .course-show__hero {
        grid-template-columns: minmax(0, 1.45fr) minmax(320px, 0.9fr);
        align-items: start;
    }

    .course-layout-card__head {
        align-items: center;
    }

    .course-gallery {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .sports-grid__main,
    .sports-grid__side,
    .course-list,
    .panel-grid,
    .import-form {
        gap: 22px;
    }

    .story-grid {
        grid-template-columns: minmax(0, 1.3fr) minmax(220px, 0.9fr);
        gap: 22px;
    }

    .story-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fixture-card {
        grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
        gap: 18px;
        padding: 18px 20px;
    }

    .fixture-card__actions {
        grid-column: 1 / -1;
    }

    .sports-empty {
        width: min(900px, 100%);
        padding: 80px 32px;
    }

    .sports-empty p {
        max-width: 44ch;
    }

    .panel-grid {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    }

    .panel-grid .panel:first-child {
        grid-column: span 2;
    }
}