:root {
    color-scheme: dark;
    --bg: #06090c;
    --bg-soft: #0d1115;
    --panel: #101418;
    --panel-2: #141a1f;
    --panel-3: #171d23;
    --line: rgba(255, 255, 255, 0.08);
    --line-strong: rgba(255, 255, 255, 0.14);
    --text: #f3f5f7;
    --text-soft: #b9c0c8;
    --text-dim: #7f8791;
    --accent: #8fcd2f;
    --accent-strong: #a9e03f;
    --accent-soft: rgba(143, 205, 47, 0.14);
    --danger-soft: rgba(174, 72, 59, 0.16);
    --success-soft: rgba(143, 205, 47, 0.16);
    --radius-lg: 1.1rem;
    --radius-md: 0.9rem;
    --radius-sm: 0.7rem;
    --shell: 74rem;
    --app-shell: 26rem;
    --nav-height: 5rem;
    --shadow: 0 16px 34px rgba(0, 0, 0, 0.28);
    --font-ui: "Segoe UI", "Helvetica Neue", Arial, sans-serif;
    --text-primary: var(--text);
    --text-secondary: var(--text-soft);
    --border-color: var(--line);
    --accent-color: var(--accent);
}

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

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    min-height: 100vh;
    color: var(--text);
    font-family: var(--font-ui);
    background: #090c0f;
}

body.app-page {
    background: #07090b;
}

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

button,
input,
select,
textarea {
    font: inherit;
}

button {
    cursor: pointer;
}

a {
    color: inherit;
    text-decoration: none;
}

.app-background {
    position: fixed;
    inset: 0;
    pointer-events: none;
    background: transparent;
}

.site-shell {
    position: relative;
    z-index: 1;
    width: min(100%, var(--shell));
    margin: 0 auto;
    padding: 1rem 1rem calc(var(--nav-height) + env(safe-area-inset-bottom, 0px) + 1.5rem);
}

.desktop-nav,
.desktop-topbar,
.desktop-topbar-actions,
.desktop-profile-link,
.dashboard-summary,
.dashboard-side-stack,
.dashboard-live-head,
.dashboard-mini-scorecard div,
.handicap-summary-layout,
.dashboard-handicap-metrics,
.dashboard-recent-row,
.dashboard-recent-score,
.dashboard-recent-list,
.desktop-news-grid,
.desktop-quick-grid,
.profile-columns {
    display: grid;
}

.desktop-sidebar,
.desktop-topbar {
    display: none;
}

.desktop-app-shell,
.desktop-main-shell {
    display: block;
}

body.app-page .site-shell {
    max-width: var(--app-shell);
}

body.auth-page .site-shell {
    max-width: 58rem;
}

.is-auth-shell {
    min-height: 100vh;
}

.panel {
    border: 1px solid var(--line);
    border-radius: 0.95rem;
    background: var(--panel);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
    min-width: 0;
}

.screen-stack,
.section-group,
.stack-list,
.flash-stack,
.auth-layout,
.story-list,
.screen-stack .tab-shell,
.setting-stack {
    display: grid;
    gap: 0.9rem;
}

.screen-stack {
    gap: 0.85rem;
}

.page-top,
.dashboard-top,
.section-heading,
.feature-card-head,
.feature-card-footer,
.round-top,
.score-editor-core,
.inline-actions,
.course-row-main,
.course-actions,
.scorecard-live-strip,
.profile-head,
.profile-summary-list,
.history-row,
.leaderboard-row,
.activity-row,
.settings-row,
.split-metrics,
.hole-row,
.round-hero,
.recent-score-list,
.score-line,
.metric-strip,
.hero-info-strip,
.quick-grid,
.compact-card-grid {
    display: flex;
}

.page-top,
.dashboard-top,
.section-heading,
.feature-card-head,
.round-top,
.course-row-main,
.history-row,
.leaderboard-row,
.activity-row,
.settings-row,
.scorecard-live-strip {
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
}

.section-heading, .article-card-padding {
    padding-left: 0.4rem;
    padding-bottom: 0.2rem;
}

.dashboard-top {
    padding-bottom: 0.2rem;
}

.section-label,
.identity-metric .label,
.feature-link,
.course-line,
.support-line,
.activity-copy span,
.activity-copy small,
.story-copy small,
.helper-note,
.profile-subline,
.profile-summary-list span,
.identity-strip span,
.round-heading p,
.metric-strip span,
.course-meta span,
.course-meta small,
.hole-row span,
.hole-row small,
.stat-row span,
.trend-row span,
.mini-stat-card span,
.leaderboard-row span,
.settings-row span,
.toggle-row small,
.compact-heading .section-link,
.auth-intro p,
.auth-footnote,
.demo-card-label,
.field-group span,
.field-group label,
.flash-dismiss,
.brandmark small,
.flash p {
    color: var(--text-soft);
}

.section-label {
    font-size: 0.72rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.screen-title {
    margin: 0;
    font-size: clamp(1.45rem, 4vw, 1.9rem);
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 1.02;
}

.compact-heading h2,
.round-heading h1,
.tab-button,
.activity-copy strong,
.story-copy strong,
.history-row strong,
.leaderboard-row strong,
.settings-row strong,
.profile-summary-list strong,
.identity-metric strong {
    margin: 0;
}

.story-copy,
.activity-copy,
.profile-head-copy,
.toggle-row > span,
.settings-row > span,
.settings-row > strong,
.profile-summary-list > div {
    min-width: 0;
    overflow-wrap: anywhere;
}

.compact-heading h2 {
    font-size: 1rem;
    font-weight: 700;
}

.section-link,
.chip-link,
.back-link,
.compact-heading .section-link {
    font-size: 0.82rem;
    color: var(--accent);
}

.flash-stack {
    margin-bottom: 0.9rem;
}

.flash {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 0.85rem 0.95rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: var(--panel-2);
}

.flash-success {
    background: rgba(143, 205, 47, 0.1);
}

.flash-error {
    background: var(--danger-soft);
}

.flash-info {
    background: rgba(255, 255, 255, 0.04);
}

.flash-dismiss {
    border: 0;
    background: transparent;
}

.auth-brand-bar {
    margin-bottom: 1rem;
}

.public-site-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.public-site-nav {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.public-social-links,
.desktop-social-links {
    display: none;
    align-items: center;
    gap: 0.55rem;
}

.social-icon-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--panel-2);
    color: var(--text-soft);
}

.social-icon-link svg {
    width: 1rem;
    height: 1rem;
    fill: currentColor;
}

.mobile-social-strip {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    overflow-x: auto;
    padding: 0 0.1rem 0.95rem;
}

.mobile-social-link {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    min-height: 2.75rem;
    padding: 0.55rem 0.8rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--panel-2);
    color: var(--text-soft);
    white-space: nowrap;
}

.mobile-social-link .social-icon-link {
    width: 1.9rem;
    height: 1.9rem;
    border: 0;
    background: transparent;
}

.public-site-link {
    display: inline-flex;
    align-items: center;
    min-height: 2.6rem;
    padding: 0.65rem 0.9rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--text-soft);
    background: var(--panel-2);
}

.public-site-link-static {
    cursor: default;
    border-style: dashed;
}

.public-site-link.is-active {
    color: var(--accent-strong);
    border-color: rgba(143, 205, 47, 0.38);
    background: rgba(143, 205, 47, 0.1);
}

.public-site-cta {
    min-height: 2.6rem;
}

.brandmark {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
}

.brandmark strong {
    display: block;
    font-size: 1rem;
}

.brandmark small {
    display: block;
    margin-top: 0.15rem;
    font-size: 0.78rem;
}

.brandmark-badge,
.avatar-badge,
.icon-action,
.score-adjust {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.brandmark-badge,
.avatar-badge {
    width: 2.45rem;
    height: 2.45rem;
    border-radius: 50%;
    border: 1px solid rgba(143, 205, 47, 0.24);
    background: rgba(143, 205, 47, 0.14);
    color: var(--text);
    font-weight: 800;
}

.brandmark-logo-wrap {
    overflow: hidden;
    padding: 0;
    background: transparent;
    border-radius: 0.55rem;
}

.brandmark-logo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.avatar-large {
    width: 3rem;
    height: 3rem;
}

.icon-action {
    position: relative;
    width: 2.6rem;
    height: 2.6rem;
    border: 1px solid var(--line);
    border-radius: 50%;
    background: var(--panel-2);
}

.notification-bell {
    color: inherit;
    text-decoration: none;
}

.icon-action svg,
.nav-link svg {
    width: 1.1rem;
    height: 1.1rem;
    fill: currentColor;
}

.live-dot {
    position: absolute;
    top: 0.65rem;
    right: 0.65rem;
    width: 0.42rem;
    height: 0.42rem;
    border-radius: 50%;
    background: var(--accent-strong);
}

.notification-count {
    position: absolute;
    top: -0.15rem;
    right: -0.15rem;
    min-width: 1.2rem;
    height: 1.2rem;
    padding: 0 0.24rem;
    border-radius: 999px;
    border: 1px solid rgba(7, 9, 11, 0.9);
    background: var(--accent-strong);
    color: #081007;
    font-size: 0.68rem;
    font-weight: 800;
    line-height: 1.1rem;
    text-align: center;
}

.notification-count.is-hidden {
    display: none;
}

.identity-strip {
    display: grid;
    gap: 0.55rem;
    margin-top: 0.8rem;
}

.identity-metric {
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
}

.identity-metric strong {
    display: block;
    margin-top: 0.14rem;
    font-size: 1.2rem;
    font-weight: 800;
    letter-spacing: -0.04em;
}

.identity-metric small {
    font-size: 0.72rem;
    color: var(--text-dim);
}

.last-round-card,
.activity-row,
.history-row,
.course-row,
.settings-row,
.leaderboard-row {
    padding: 0.8rem;
}

.last-round-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 7rem;
    gap: 0.75rem;
}

.round-numbers strong {
    font-size: 2.6rem;
    line-height: 0.92;
    letter-spacing: -0.06em;
}

.score-line {
    align-items: flex-end;
    gap: 0.55rem;
}

.score-line span {
    color: var(--accent);
    font-size: 1.2rem;
    font-weight: 800;
}

.course-line,
.support-line {
    margin: 0.3rem 0 0;
    font-size: 0.88rem;
}

.image-block,
.round-hero-media,
.story-thumb {
    border-radius: var(--radius-md);
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: #1b232b;
}

.image-block,
.round-hero-media {
    overflow: hidden;
    position: relative;
}

.image-block img,
.round-hero-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.image-course {
    min-height: 7.6rem;
}

.image-course-fallback {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem;
    color: rgba(243, 245, 247, 0.92);
    font-size: 1.2rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: rgba(255, 255, 255, 0.02);
}

.image-course-fallback-wide {
    font-size: 2rem;
}

.mini-card,
.history-metrics,
.course-meta {
    display: grid;
    gap: 0.15rem;
    text-align: right;
}

.mini-card strong,
.history-metrics strong,
.activity-score strong,
.leaderboard-value,
.score-editor-meta strong,
.score-box strong,
.handicap-result-panel strong,
.handicap-summary-panel strong,
.mini-stat-card strong,
.stat-hero strong,
.profile-summary-list strong,
.identity-metric strong,
.settings-row strong {
    font-weight: 800;
}

.activity-row {
    align-items: center;
    gap: 0.8rem;
}

.activity-copy,
.story-copy,
.course-row-main > div:first-child,
.history-row > div:first-child {
    display: grid;
    gap: 0.18rem;
}

.activity-score {
    display: grid;
    gap: 0.18rem;
    text-align: right;
}

.quick-grid,
.compact-card-grid {
    gap: 0.8rem;
    flex-wrap: wrap;
}

.quick-tile,
.mini-stat-card {
    flex: 1 1 9.5rem;
    min-width: 0;
    padding: 1rem;
}

.quick-tile strong,
.mini-stat-card strong {
    display: block;
    margin-top: 0.25rem;
    font-size: 1.2rem;
}

.story-list {
    gap: 0.55rem;
}

.story-row {
    display: grid;
    grid-template-columns: 4.5rem minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--line);
}

.story-row.panel {
    padding: 1rem;
    border-bottom: 0;
}

.story-row:last-child {
    border-bottom: 0;
}

.story-thumb {
    overflow: hidden;
}

.story-thumb img,
.blog-cover-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.story-thumb-green,
.story-thumb-course,
.story-thumb-ball,
.story-thumb-swing,
.story-thumb-gear,
.story-thumb-rules,
.story-thumb-players,
.story-thumb-silhouette {
    background: #2d4023;
}

.story-arrow {
    color: var(--text-dim);
}

.chip-link,
.action-button,
.filter-chip,
.tab-button,
.score-adjust,
.hole-pill,
.icon-action,
.brandmark,
.nav-link {
    transition:
        border-color 160ms ease,
        background-color 160ms ease,
        color 160ms ease,
        transform 160ms ease;
}

.action-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.75rem;
    padding: 0.75rem 1rem;
    border-radius: 0.85rem;
    border: 1px solid var(--line);
    font-size: 0.9rem;
    font-weight: 700;
}

.action-button-primary {
    color: #081007;
    border-color: rgba(143, 205, 47, 0.5);
    background: var(--accent);
}

.action-button-secondary {
    background: var(--panel-3);
}

.action-button-ghost {
    background: transparent;
}

.social-icon-link:hover,
.social-icon-link:focus-visible,
.mobile-social-link:hover,
.mobile-social-link:focus-visible {
    color: var(--accent-strong);
    border-color: rgba(143, 205, 47, 0.38);
    background: rgba(143, 205, 47, 0.08);
}

.permission-panel,
.search-panel,
.form-panel,
.inplay-settings-panel,
.scorecard-panel,
.signout-panel,
.stat-hero,
.handicap-summary-panel,
.handicap-result-panel,
.quick-tile,
.mini-stat-card,
.settings-row,
.leaderboard-row,
.course-row,
.history-row,
.activity-row,
.profile-top,
.feature-card,
.round-hero,
.scorecard-live-strip {
    background: var(--panel);
}

.form-panel,
.permission-panel,
.search-panel,
.profile-top,
.round-hero,
.scorecard-panel,
.handicap-form,
.stat-hero,
.handicap-summary-panel {
    padding: 1.1rem;
}

.form-grid {
    display: grid;
    gap: 0.8rem;
}

.field-group {
    display: grid;
    gap: 0.4rem;
}

input:not([type="checkbox"]):not([type="radio"]),
select,
textarea {
    width: 100%;
    min-height: 2.9rem;
    padding: 0.8rem 0.9rem;
    color: var(--text);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--panel-2);
}

textarea {
    resize: vertical;
}

.tab-bar,
.chip-row,
.hole-pill-row {
    display: flex;
    gap: 0.45rem;
    overflow-x: auto;
    padding-bottom: 0.1rem;
}

.tab-button,
.filter-chip,
.hole-pill {
    padding: 0.58rem 0.82rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--panel-2);
    color: var(--text-soft);
    white-space: nowrap;
    font-size: 0.8rem;
    font-weight: 700;
}

.tab-button.is-active,
.filter-chip.is-active,
.hole-pill.is-active {
    color: var(--accent-strong);
    border-color: rgba(143, 205, 47, 0.4);
    background: rgba(143, 205, 47, 0.1);
}

.tab-panel {
    display: none;
}

.tab-panel.is-active {
    display: grid;
    gap: 0.9rem;
}

.leaderboard-row,
.settings-row,
.stat-row,
.trend-row {
    padding: 1rem;
}

.leaderboard-row,
.settings-row,
.stat-row,
.trend-row,
.course-row,
.history-row {
    border-radius: var(--radius-md);
}

.course-meta span,
.history-row span,
.history-row small,
.activity-score span,
.activity-score small,
.profile-subline small {
    font-size: 0.78rem;
}

.metric-strip {
    gap: 0.6rem;
    flex-wrap: wrap;
    margin-top: 0.7rem;
}

.metric-strip span {
    padding: 0.4rem 0.55rem;
    border-radius: 999px;
    background: var(--panel-2);
}

.course-actions {
    gap: 0.55rem;
    flex-wrap: wrap;
    margin-top: 0.8rem;
}

.wide-actions .action-button {
    flex: 1;
}

.round-top {
    align-items: flex-start;
}

.round-heading {
    display: grid;
    gap: 0.3rem;
}

.round-hero {
    display: grid;
    gap: 0.9rem;
}

.round-page .round-hero-media {
    min-height: 10rem;
    max-height: 13rem;
}

.round-hero-body {
    display: grid;
    gap: 0.35rem;
}

.split-metrics {
    gap: 0.6rem;
    flex-wrap: wrap;
}

.split-metrics > div,
.recent-score-list > div,
.scorecard-cell,
.stat-hero > div:first-child,
.profile-summary-list > div,
.handicap-result-panel,
.handicap-summary-panel,
.score-box,
.putt-box,
.course-row,
.history-row,
.leaderboard-row,
.mini-stat-card {
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: var(--panel-2);
}

.split-metrics > div,
.recent-score-list > div,
.scorecard-cell,
.profile-summary-list > div {
    flex: 1;
    min-width: 8.5rem;
    padding: 1rem;
}

.recent-score-strip,
.hole-list-panel,
.stat-list-panel {
    padding: 0.95rem;
}

.recent-score-list {
    gap: 0.55rem;
    flex-wrap: wrap;
    margin-top: 0.75rem;
}

.recent-score-list > div strong {
    display: block;
    font-size: 1.3rem;
}

.scorecard-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
}

.scorecard-cell {
    padding: 0.8rem;
    text-align: center;
}

.scorecard-cell.is-good {
    border-color: rgba(143, 205, 47, 0.3);
}

.scorecard-cell strong {
    display: block;
    margin-top: 0.2rem;
    font-size: 1.2rem;
}

.hole-list {
    display: grid;
    gap: 0.55rem;
}

.hole-row,
.stat-row,
.trend-row {
    padding: 0.7rem 0;
    border-bottom: 1px solid var(--line);
}

.hole-row:last-child,
.stat-row:last-child,
.trend-row:last-child {
    border-bottom: 0;
}

.hole-row {
    gap: 0.65rem;
    flex-wrap: wrap;
}

.setting-stack {
    gap: 0.8rem;
}

.toggle-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.toggle-row strong {
    display: block;
    margin-bottom: 0.2rem;
}

.toggle-row input,
.toggle-chip input {
    accent-color: var(--accent);
}

.scorecard-live-strip {
    flex-wrap: wrap;
    padding: 0.9rem 1rem;
}

.scorecard-live-strip > div {
    min-width: 7rem;
}

.score-editor {
    display: grid;
    gap: 1rem;
}

.score-editor-meta {
    display: grid;
    gap: 0.25rem;
    text-align: center;
}

.score-editor-core {
    align-items: center;
    justify-content: center;
    gap: 1rem;
}

.score-adjust {
    width: 2.8rem;
    height: 2.8rem;
    border: 1px solid var(--line);
    border-radius: 50%;
    background: var(--panel-2);
    color: var(--text);
    font-size: 1.2rem;
    font-weight: 800;
}

.score-box {
    min-width: 7rem;
    padding: 1rem;
    text-align: center;
}

.score-box strong {
    display: block;
    margin-top: 0.25rem;
    font-size: 3rem;
    line-height: 1;
    min-height: 3rem;
}

.putt-box {
    padding: 0.9rem;
}

.putt-box input {
    margin-top: 0.35rem;
}

.toggle-grid {
    display: grid;
    gap: 0.7rem;
    min-width: 0;
}

.toggle-chip {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    padding: 0.8rem 0.9rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: var(--panel-2);
    min-width: 0;
}

.toggle-chip span {
    min-width: 0;
    overflow-wrap: anywhere;
    line-height: 1.4;
}

.toggle-chip input,
.toggle-row input {
    width: 1.1rem;
    min-width: 1.1rem;
    height: 1.1rem;
    min-height: 1.1rem;
    margin: 0;
    padding: 0;
    flex: 0 0 auto;
}

.score-adjust:disabled,
.putt-box input:disabled,
.toggle-chip input:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.hole-pill.is-complete {
    border-color: rgba(169, 224, 63, 0.45);
    color: var(--text);
}

.hole-pill.is-skipped {
    border-style: dashed;
    color: var(--text-soft);
}

.profile-top {
    display: grid;
    gap: 1.1rem;
}

.profile-head {
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.profile-subline {
    margin: 0.25rem 0 0;
}

.profile-head-copy {
    display: grid;
    gap: 0.2rem;
}

.profile-summary-list {
    gap: 0.8rem;
    flex-wrap: wrap;
}

.profile-summary-list > div {
    display: grid;
    gap: 0.35rem;
}

.settings-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.settings-row > span {
    flex: 1 1 12rem;
}

.settings-row > strong {
    flex: 0 1 auto;
    text-align: right;
    font-size: 1rem;
}

.notifications-panel {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.notification-page-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.18rem;
    text-align: right;
}

.notification-page-meta strong {
    font-size: 1.1rem;
}

.notification-page-meta small {
    color: var(--muted);
}

.notification-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.notification-row {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    padding: 1rem;
    text-decoration: none;
    color: inherit;
}

.notification-row-head,
.notification-row-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    flex-wrap: wrap;
}

.notification-row-head small,
.notification-row-foot span:first-child,
.notification-row p {
    color: var(--muted);
}

.notification-row strong {
    font-size: 1rem;
}

.notification-row p {
    margin: 0;
    line-height: 1.6;
}

.profile-columns {
    display: flex;
    flex-wrap: wrap;
    gap: 0.95rem;
}

.profile-card {
    flex: 1 1 20rem;
    padding: 1.1rem;
}

.feature-card-footer {
    margin-top: 0.85rem;
    padding-top: 0.8rem;
    border-top: 1px solid var(--line);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    font-size: 0.9rem;
}

.public-screen,
.landing-section,
.landing-hero-copy,
.landing-hero-panels,
.landing-feature-row,
.landing-benefit-row,
.landing-faq-list {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.landing-hero,
.landing-faq {
    padding: 1.1rem;
}

.landing-hero {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    justify-content: center;
}

.landing-hero-content {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.landing-hero-copy p,
.landing-feature-card p,
.landing-benefit-card p,
.landing-faq p {
    margin: 0;
    color: var(--text-soft);
    line-height: 1.65;
}

.landing-hero-copy h1,
.landing-feature-card h3,
.landing-faq h3 {
    margin: 0;
}


.landing-cta-row,
.landing-proof-list,
.landing-blog-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.landing-proof-list {
    margin: 0;
    padding-left: 1rem;
    color: var(--text-soft);
    line-height: 1.6;
}

.landing-mini-panel,
.landing-feature-card,
.landing-benefit-card,
.landing-blog-card {
    flex: 1 1 14rem;
    min-width: 0;
    padding: 1rem;
}

.landing-mini-panel,
.landing-feature-card,
.landing-benefit-card {
    border: 1px solid var(--line);
    border-radius: 0.95rem;
    background: var(--panel-2);
}

.landing-mini-panel strong,
.landing-benefit-card strong {
    display: block;
    margin: 0.2rem 0 0.35rem;
    font-size: 1rem;
}

.landing-mini-panel small {
    color: var(--text-soft);
    line-height: 1.55;
}

.landing-feature-card h3,
.landing-faq h3 {
    font-size: 1rem;
    font-weight: 700;
}

.landing-blog-card {
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    min-height: 100%;
}

.landing-blog-card .story-copy,
.landing-blog-card .story-arrow {
    padding: 0 1rem 1rem;
}

.landing-blog-card .story-copy {
    padding-top: 1rem;
    flex: 1 1 auto;
    align-content: start;
}

.landing-blog-card .story-thumb {
    border: 0;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #0b0f13;
}

.landing-blog-card .story-thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.landing-story-section {
    gap: 1rem;
}

.landing-story-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.landing-story-card {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1rem;
    overflow: hidden;
    opacity: 1;
    transform: none;
    transition:
        opacity 420ms ease,
        transform 520ms ease;
}

.landing-story-card[data-scroll-reveal] {
    opacity: 0;
}

.landing-story-card[data-reveal-direction="left"] {
    transform: translateX(-2rem);
}

.landing-story-card[data-reveal-direction="right"] {
    transform: translateX(2rem);
}

.landing-story-card.is-visible {
    opacity: 1;
    transform: translateX(0);
}

.landing-story-media {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 20rem;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 0.95rem;
    background: #0b0f12;
}

.landing-story-media img {
    width: 100%;
    max-width: 23rem;
    height: auto;
    max-height: 42rem;
    object-fit: contain;
    object-position: center;
    border-radius: 0.8rem;
}

.landing-story-content {
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    min-width: 0;
}

.landing-story-content h3 {
    margin: 0;
    font-size: clamp(1.35rem, 4vw, 2rem);
    line-height: 1.05;
    letter-spacing: -0.04em;
}

.landing-story-content p {
    margin: 0;
    color: var(--text-soft);
    line-height: 1.65;
}

.landing-story-points {
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.landing-story-points li {
    position: relative;
    padding-left: 1rem;
    color: var(--text-soft);
    line-height: 1.55;
}

.landing-story-points li::before {
    content: "";
    position: absolute;
    top: 0.65rem;
    left: 0;
    width: 0.38rem;
    height: 0.38rem;
    border-radius: 50%;
    background: var(--accent);
}

.landing-faq-list article {
    padding-top: 0.8rem;
    border-top: 1px solid var(--line);
}

.landing-faq-list article:first-child {
    padding-top: 0;
    border-top: 0;
}

.dashboard-summary {
    gap: 0;
}

.dashboard-summary-card {
    padding: 1rem 1.05rem;
    border-top: 1px solid var(--line);
}

.dashboard-summary-card:first-child {
    border-top: 0;
}

.dashboard-summary-card strong {
    display: block;
    margin-top: 0.35rem;
    font-size: 1.9rem;
    letter-spacing: -0.04em;
}

.dashboard-side-stack,
.dashboard-handicap-metrics,
.dashboard-recent-list {
    gap: 0;
}

.dashboard-live,
.dashboard-handicap-summary,
.dashboard-recent-rounds,
.dashboard-quick-links {
    padding: 1rem;
}

.dashboard-live-card {
    display: grid;
    gap: 0.9rem;
}

.dashboard-live-head {
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 0.75rem;
}

.dashboard-mini-scorecard {
    display: grid;
    gap: 0.55rem;
    margin-top: 0.1rem;
}

.dashboard-mini-scorecard div {
    grid-template-columns: 2.1rem repeat(4, 1fr);
    align-items: center;
    gap: 0.55rem;
    font-size: 0.82rem;
    color: var(--text-soft);
}

.dashboard-mini-scorecard strong {
    text-align: center;
    color: var(--text);
}

.dashboard-mini-scorecard .is-highlight {
    border: 1px solid rgba(143, 205, 47, 0.4);
    border-radius: 0.32rem;
    padding: 0.25rem 0;
    color: var(--accent);
}

.handicap-summary-layout {
    gap: 1rem;
    margin-top: 0.4rem;
}

.desktop-handicap-ring {
    width: 7.75rem;
    height: 7.75rem;
    margin: 0 auto;
    border-radius: 50%;
    border: 0.7rem solid rgba(143, 205, 47, 0.2);
    box-shadow: inset 0 0 0 0.22rem rgba(143, 205, 47, 0.1);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.desktop-handicap-ring strong {
    font-size: 2.4rem;
    line-height: 1;
    letter-spacing: -0.05em;
}

.desktop-handicap-ring span {
    margin-top: 0.15rem;
    color: var(--text-soft);
}

.dashboard-handicap-metrics {
    gap: 0.75rem;
}

.dashboard-handicap-metrics div {
    display: grid;
    gap: 0.15rem;
}

.dashboard-handicap-metrics span {
    color: var(--text-soft);
    font-size: 0.8rem;
}

.dashboard-handicap-metrics strong {
    font-size: 1.6rem;
    letter-spacing: -0.04em;
}

.dashboard-recent-row {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.8rem;
    padding: 0.9rem 0;
    border-top: 1px solid var(--line);
}

.dashboard-recent-row:first-child {
    border-top: 0;
}

.dashboard-recent-row small {
    color: var(--text-soft);
}

.dashboard-recent-row strong {
    display: block;
    margin-top: 0.15rem;
}

.dashboard-recent-score {
    gap: 0.3rem;
    text-align: right;
}

.dashboard-recent-score span {
    color: var(--accent);
    font-weight: 800;
}

.desktop-news-grid {
    gap: 0.8rem;
}

.desktop-story-card {
    padding: 0.8rem;
    min-height: 100%;
}

.dashboard-quick-links {
    gap: 0.9rem;
}

.desktop-quick-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 0.2rem;
}

.desktop-quick-card {
    flex: 1 1 10rem;
    min-width: 0;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 0.8rem;
    background: var(--panel-2);
}

.desktop-quick-card strong {
    display: block;
    margin-bottom: 0.3rem;
    font-size: 1rem;
}

.desktop-quick-card span {
    color: var(--text-soft);
    font-size: 0.82rem;
}

.settings-row strong {
    color: var(--text-soft);
}

.settings-push-summary {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    margin-bottom: 1rem;
}

.settings-push-metric {
    display: grid;
    gap: 0.2rem;
    padding: 0.95rem;
    border: 1px solid var(--line);
    border-radius: 0.9rem;
    background: var(--panel-2);
}

.settings-push-metric strong {
    font-size: 2rem;
    line-height: 1;
}

.settings-push-copy {
    display: grid;
    gap: 0.35rem;
}

.settings-push-copy p {
    margin: 0;
    color: var(--text-soft);
    line-height: 1.6;
}

.stat-hero {
    display: grid;
    gap: 1rem;
}

.stat-hero strong {
    display: block;
    margin-top: 0.2rem;
    font-size: 2.8rem;
    line-height: 1;
}

.trend-bars {
    display: flex;
    align-items: end;
    gap: 0.35rem;
    min-height: 7.5rem;
}

.trend-bars span {
    flex: 1;
    border-radius: 999px;
    background: var(--accent-strong);
}

.handicap-entry-list {
    display: grid;
    gap: 0.8rem;
}

.handicap-entry {
    padding: 0.95rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: var(--panel-2);
}

.handicap-result-panel {
    display: grid;
    gap: 0.45rem;
    padding: 0.95rem;
}

.handicap-result-panel strong,
.handicap-summary-panel strong {
    font-size: 2rem;
    line-height: 1;
}

.helper-note {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.5;
}

.news-page-list .story-row {
    border-bottom: 0;
}

.news-page-list .story-row.panel {
    padding: 0.8rem;
    min-height: 100%;
}

.is-hidden {
    display: none !important;
}

.empty-panel {
    padding: 1rem;
}

.empty-panel p {
    margin: 0;
    color: var(--text-soft);
}

.bottom-nav {
    position: fixed;
    right: 1rem;
    bottom: calc(env(safe-area-inset-bottom, 0px) + 0.75rem);
    left: 1rem;
    z-index: 60;
    display: flex;
    gap: 0.3rem;
    padding: 0.38rem 0.4rem calc(0.38rem + env(safe-area-inset-bottom, 0px));
    border: 1px solid var(--line-strong);
    border-radius: 0.9rem;
    background: rgba(10, 13, 16, 0.96);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.24);
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    will-change: transform;
}

.nav-link {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.28rem;
    min-height: 3.5rem;
    border-radius: 0.75rem;
    color: var(--text-dim);
    font-size: 0.68rem;
    font-weight: 700;
}

.nav-link.is-active {
    color: var(--accent);
}

.auth-layout {
    gap: 1rem;
}

.auth-intro,
.auth-card,
.demo-card {
    padding: 1rem;
}

.auth-intro h1 {
    margin: 0 0 0.75rem;
    font-size: clamp(1.9rem, 6vw, 2.6rem);
    line-height: 1;
    letter-spacing: -0.05em;
}

.auth-intro p,
.auth-footnote,
.demo-card dd {
    margin: 0;
    line-height: 1.55;
}

.auth-card .form-stack {
    display: grid;
    gap: 0.95rem;
}

.auth-submit-button {
    width: 100%;
    min-height: 3.25rem;
    margin-top: 0.25rem;
    padding-inline: 1.05rem 1.1rem;
    border-radius: 0.95rem;
    justify-content: space-between;
    font-size: 0.95rem;
    letter-spacing: 0.01em;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.22);
}

.auth-submit-button-mark {
    color: rgba(8, 16, 7, 0.78);
    font-size: 1rem;
    font-weight: 900;
}

.demo-card dl {
    display: grid;
    gap: 0.7rem;
    margin: 0;
}

.demo-card div {
    padding: 0.75rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: var(--panel-2);
}

.demo-card dt {
    margin-bottom: 0.2rem;
    color: var(--text-dim);
    font-size: 0.78rem;
}

input:focus-visible,
select:focus-visible,
textarea:focus-visible,
button:focus-visible,
a:focus-visible {
    outline: 2px solid var(--accent-strong);
    outline-offset: 2px;
}

.action-button:hover,
.action-button:focus-visible,
.tab-button:hover,
.filter-chip:hover,
.hole-pill:hover,
.nav-link:hover,
.nav-link:focus-visible,
.icon-action:hover,
.icon-action:focus-visible {
    transform: translateY(-1px);
}

.action-button-primary:hover,
.action-button-primary:focus-visible {
    background: var(--accent-strong);
    border-color: rgba(169, 224, 63, 0.62);
}

@media (min-width: 42rem) {
    .identity-strip,
    .form-grid,
    .toggle-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    body.auth-page .quick-grid,
    body.auth-page .compact-card-grid {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .scorecard-grid {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }

    .round-hero {
        grid-template-columns: 1.2fr 1fr;
        align-items: stretch;
    }

    .round-page .round-hero-media {
        min-height: 11.5rem;
        max-height: 15rem;
    }

    .auth-layout {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        align-items: start;
    }

    .stat-hero {
        grid-template-columns: minmax(0, 1fr) 1.3fr;
        align-items: end;
    }

    .landing-hero,
    .landing-feature-row,
    .landing-benefit-row,
    .landing-blog-row {
        flex-direction: row;
        align-items: stretch;
    }

    .landing-hero-content {
        flex: 1 1;
    }

    .landing-hero-copy {
        flex: 1 1;
    }

    .landing-hero-panels {
        flex: 1 1 20rem;
    }

    .settings-push-summary {
        flex-direction: row;
        align-items: start;
    }

    .settings-push-metric {
        flex: 0 0 11rem;
    }

    .settings-push-copy {
        flex: 1 1 20rem;
        padding-top: 0.2rem;
    }

}

@media (min-width: 64rem) {
    body.app-page .site-shell {
        max-width: none;
        width: 100%;
        margin: 0;
        padding: 1.6rem 1.9rem 2rem;
    }

    body.round-page .site-shell,
    body.course-page .site-shell,
    body.scorecard-page .site-shell {
        max-width: none;
    }

    .desktop-app-shell {
        display: flex;
        min-height: 100vh;
    }

    .desktop-sidebar {
        position: sticky;
        top: 0;
        width: 15rem;
        min-width: 15rem;
        flex: 0 0 15rem;
        height: 100vh;
        display: flex;
        flex-direction: column;
        gap: 1rem;
        padding: 1.3rem 1rem;
        border-right: 1px solid var(--line);
        background: rgba(5, 8, 10, 0.96);
    }

    .desktop-sidebar-brand {
        padding-bottom: 0.8rem;
        border-bottom: 1px solid var(--line);
    }

    .desktop-sidebar .brandmark {
        align-items: center;
    }

    .desktop-sidebar .brandmark strong {
        font-size: 1.45rem;
        letter-spacing: -0.04em;
    }

    .desktop-sidebar .brandmark-badge {
        width: 2.2rem;
        height: 2.2rem;
        border-radius: 0.45rem;
    }

    .desktop-nav {
        display: flex;
        flex-direction: column;
        gap: 0.35rem;
    }

    .desktop-nav-link {
        display: flex;
        align-items: center;
        min-height: 3rem;
        padding: 0.75rem 0.95rem;
        border-radius: 0.7rem;
        color: var(--text-soft);
        border-left: 2px solid transparent;
    }

    .desktop-nav-link.is-active {
        border-left-color: var(--accent);
        background: rgba(143, 205, 47, 0.12);
        color: var(--accent-strong);
    }

    .desktop-signout {
        align-self: end;
        margin-top: auto;
        width: 100%;
    }

    .desktop-signout-button {
        width: 100%;
        justify-content: flex-start;
        background: transparent;
        border: 0;
        padding-left: 0.95rem;
    }

    .desktop-main-shell {
        display: flex;
        flex: 1 1 auto;
        flex-direction: column;
        min-width: 0;
    }

    .desktop-topbar {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        min-height: 4.25rem;
        padding: 0 1.9rem;
        border-bottom: 1px solid var(--line);
    }

    .desktop-topbar-actions {
        display: flex;
        align-items: center;
        gap: 1rem;
    }

    .desktop-social-links,
    .public-social-links {
        display: flex;
    }

    .mobile-social-strip {
        display: none;
    }

    .desktop-profile-link {
        display: flex;
        align-items: center;
        gap: 0.7rem;
        padding-left: 1rem;
        border-left: 1px solid var(--line);
    }

    .desktop-profile-link strong {
        font-size: 1rem;
        font-weight: 700;
    }

    .desktop-bell {
        width: 2.4rem;
        height: 2.4rem;
        border: 0;
        background: transparent;
    }

    .bottom-nav {
        display: none;
    }

    body.has-bottom-nav .site-legal-footer-inner {
        padding-bottom: 1.1rem;
    }

    .landing-hero {
        gap: 1.25rem;
    }

    .landing-story-card {
        flex-direction: row;
        align-items: center;
        gap: 1.25rem;
        padding: 1.25rem;
    }

    .landing-story-card-right {
        flex-direction: row-reverse;
    }

    .landing-story-media,
    .landing-story-content {
        flex: 1 1 24rem;
    }

    .landing-story-media {
        min-height: 28rem;
        padding: 1.25rem;
    }

    .landing-story-media img {
        max-width: 28rem;
        max-height: 36rem;
    }

    .dashboard-page .screen-stack {
        align-items: start;
        gap: 1rem;
    }

    .dashboard-page .dashboard-top {
        flex: 1 1 30rem;
        padding-top: 0.5rem;
        order: 1;
    }

    .dashboard-page .dashboard-summary {
        display: flex;
        flex: 1 1 22rem;
        flex-wrap: wrap;
        border-radius: 0.95rem;
        order: 2;
    }

    .dashboard-page .dashboard-summary-card {
        flex: 1 1 10rem;
        min-height: 7.6rem;
        border-top: 0;
        border-left: 1px solid var(--line);
    }

    .dashboard-page .dashboard-summary-card:first-child {
        border-left: 0;
    }

    .dashboard-page .last-round-card {
        flex: 1 1 32rem;
        order: 3;
    }

    .dashboard-page .dashboard-side-stack {
        display: flex;
        flex: 1 1 22rem;
        flex-direction: column;
        gap: 1rem;
        order: 4;
    }

    .dashboard-page .dashboard-news {
        flex: 1 1 32rem;
        order: 5;
    }

    .dashboard-page .dashboard-quick-links {
        flex: 1 1 32rem;
        order: 6;
    }

    .dashboard-page .dashboard-live,
    .dashboard-page .dashboard-handicap-summary,
    .dashboard-page .dashboard-recent-rounds,
    .dashboard-page .dashboard-news,
    .dashboard-page .dashboard-quick-links {
        border-radius: 0.95rem;
        background: rgba(10, 14, 17, 0.94);
    }

    .dashboard-page .desktop-news-grid {
        display: flex;
        flex-wrap: wrap;
    }

    .dashboard-page .desktop-story-card {
        display: grid;
        flex: 1 1 15rem;
        grid-template-columns: 1fr;
        gap: 0.65rem;
        padding: 0;
        overflow: hidden;
        background: rgba(14, 18, 22, 0.94);
        min-height: 21rem;
    }

    .dashboard-page .desktop-story-card .story-thumb {
        min-height: 10rem;
        border-radius: 0;
        border: 0;
        background: #0b0f13;
    }

    .dashboard-page .desktop-story-card .story-thumb img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }

    .dashboard-page .desktop-story-card .story-copy,
    .dashboard-page .desktop-story-card .story-arrow {
        padding-inline: 0.9rem;
    }

    .dashboard-page .desktop-story-card .story-copy {
        padding-top: 0.1rem;
        flex: 1 1 auto;
        align-content: start;
    }

    .dashboard-page .desktop-story-card .story-arrow {
        padding-bottom: 0.9rem;
    }

    .rounds-page .screen-stack {
        display: flex;
        flex-wrap: wrap;
        align-items: start;
    }

    .rounds-page .page-top {
        flex: 1 1 100%;
    }

    .rounds-page .rounds-history-section {
        flex: 1 1 32rem;
    }

    .rounds-page .rounds-entry-section {
        flex: 1 1 22rem;
    }

    .profile-page .screen-stack {
        display: flex;
        flex-wrap: wrap;
        align-items: start;
    }

    .profile-page .profile-top {
        flex: 1 1 100%;
    }

    .profile-page .profile-columns {
        flex: 1 1 100%;
    }

    .profile-page .profile-primary-links,
    .profile-page .profile-inplay,
    .profile-page .profile-notifications,
    .profile-page .profile-secondary-links {
        flex: 1 1 22rem;
    }

    .profile-page .profile-signout {
        flex: 1 1 100%;
    }

    .courses-page [data-course-list],
    .news-page .news-page-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        align-items: start;
    }

    .friends-page .tab-panel.is-active {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .friends-page .activity-row,
    .friends-page .leaderboard-row,
    .courses-page .course-row,
    .news-page .story-row.panel,
    .profile-page .settings-row,
    .rounds-page .history-row {
        background: rgba(10, 14, 17, 0.94);
    }

    .stats-page .compact-card-grid {
        display: flex;
        flex-wrap: wrap;
    }

    .stats-page .screen-stack {
        gap: 1rem;
    }

    .course-page .split-metrics {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .scorecard-page .scorecard-live-strip {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.8rem;
    }

    .public-page .site-shell {
        max-width: min(100%, 74rem);
        padding-inline: 1.4rem;
    }

.landing-page .landing-feature-row,
.landing-page .landing-benefit-row,
.landing-page .landing-blog-row {
    align-items: stretch;
}

.shot-replay-intro {
    margin: 0.55rem 0 0;
    max-width: 42rem;
    color: var(--text-soft);
    line-height: 1.6;
}

.shot-replay-builder,
.shot-replay-config,
.shot-replay-preview-stack,
.shot-replay-stage-panel,
.shot-replay-video-panel,
.shot-replay-summary,
.shot-replay-export-note {
    display: grid;
    gap: 0.9rem;
}

.shot-replay-builder,
.shot-replay-preview-stack {
    align-items: start;
}

.shot-replay-summary,
.shot-replay-export-note {
    padding: 0.95rem 1rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: var(--panel-2);
}

.shot-replay-summary-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.72rem 0;
    border-bottom: 1px solid var(--line);
}

.shot-replay-summary-row:first-child {
    padding-top: 0;
}

.shot-replay-summary-row:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.shot-replay-summary-row span {
    color: var(--text-soft);
}

.shot-replay-summary-row strong {
    max-width: 60%;
    text-align: right;
    overflow-wrap: anywhere;
}

.shot-replay-action-grid {
    display: grid;
    gap: 0.75rem;
}

.shot-replay-export-note strong,
.shot-replay-export-note p,
.shot-replay-stage-help p {
    margin: 0;
}

.shot-replay-export-note p,
.shot-replay-stage-help p {
    color: var(--text-soft);
    line-height: 1.55;
}

.shot-replay-stage-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.shot-replay-stage-meta span {
    display: inline-flex;
    align-items: center;
    min-height: 2.2rem;
    padding: 0.45rem 0.75rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--panel-2);
    color: var(--text-soft);
    font-size: 0.8rem;
    font-weight: 700;
}

.shot-replay-stage-shell {
    position: relative;
}

.shot-replay-stage {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 11;
    overflow: hidden;
    border: 1px solid var(--line-strong);
    border-radius: 1rem;
    background: #090d11;
    touch-action: none;
}

.shot-replay-stage.is-dragging {
    cursor: grabbing;
}

.shot-replay-stage-canvas {
    width: 100%;
    height: 100%;
    display: block;
}

.shot-handle {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 2;
    min-width: 4.1rem;
    min-height: 2.7rem;
    padding: 0.45rem 0.7rem;
    border: 1px solid var(--line-strong);
    border-radius: 999px;
    background: rgba(11, 15, 19, 0.96);
    color: var(--text);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    transform: translate(-50%, -50%);
    box-shadow: 0 12px 20px rgba(0, 0, 0, 0.24);
}

.shot-handle-start {
    border-color: rgba(143, 205, 47, 0.38);
}

.shot-handle-end {
    border-color: rgba(255, 255, 255, 0.18);
}

.shot-handle:focus-visible,
.shot-handle:hover {
    color: var(--accent-strong);
    border-color: rgba(143, 205, 47, 0.48);
}

.shot-replay-video-frame {
    position: relative;
    overflow: hidden;
    min-height: 18rem;
    border: 1px solid var(--line);
    border-radius: 1rem;
    background: #080b0e;
}

.shot-replay-video {
    width: 100%;
    min-height: 18rem;
    background: #080b0e;
    object-fit: contain;
}

.shot-replay-video-empty {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 1rem;
    text-align: center;
    background: rgba(8, 11, 14, 0.96);
}

.shot-replay-video-empty strong,
.shot-replay-video-empty p {
    margin: 0;
}

.shot-replay-video-empty p {
    margin-top: 0.35rem;
    color: var(--text-soft);
    line-height: 1.55;
}

.news-page .news-page-list {
    align-items: stretch;
}

    .news-page .story-row.panel {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        min-height: 21rem;
        padding: 0;
        overflow: hidden;
    }

    .news-page .story-row.panel .story-thumb {
        width: 100%;
        aspect-ratio: 16 / 9;
        border: 0;
        background: #0b0f13;
    }

    .news-page .story-row.panel .story-thumb img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }

    .news-page .story-row.panel .story-copy {
        flex: 1 1 auto;
        padding: 1rem;
        align-content: start;
    }

    .news-page .story-row.panel .story-arrow {
        padding: 0 1rem 1rem;
    }

    .shot-replay-builder {
        grid-template-columns: minmax(19rem, 23rem) minmax(0, 1fr);
    }

    .shot-replay-preview-stack {
        grid-template-columns: minmax(0, 1.45fr) minmax(18rem, 0.75fr);
    }

    .shot-replay-action-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.admin-shell-head {
    display: grid;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.admin-shell-note {
    margin: 0;
    color: var(--text-secondary);
}

.admin-subnav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-bottom: 1rem;
}

.admin-subnav-link {
    flex: 1 1 9rem;
    border: 1px solid var(--border-color);
    border-radius: 0.9rem;
    padding: 0.85rem 1rem;
    background: rgba(255, 255, 255, 0.02);
    color: var(--text-primary);
    text-decoration: none;
    text-align: center;
    font-size: 0.95rem;
}

.admin-subnav-link.is-active {
    border-color: var(--accent-color);
    color: var(--accent-color);
    background: rgba(163, 255, 79, 0.08);
}

.admin-screen {
    gap: 1rem;
}

.admin-metric-grid,
.admin-grid,
.admin-action-grid,
.admin-scorecard-grid,
.admin-yard-grid {
    display: grid;
    gap: 0.85rem;
}

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

.admin-metric-card strong {
    display: block;
    font-size: 1.8rem;
    margin-top: 0.35rem;
}

.admin-panel {
    gap: 1rem;
}

.admin-course-map-panel {
    display: grid;
    gap: 0.85rem;
    padding: 1rem;
    background: rgba(255, 255, 255, 0.02);
}

.admin-course-map-wrap {
    position: relative;
    border: 1px solid var(--line);
    border-radius: 1rem;
    overflow: hidden;
    background: #0b1116;
    min-height: 22rem;
}

.admin-course-map-canvas {
    display: block;
    width: 100%;
    height: 22rem;
    touch-action: none;
    cursor: grab;
}

.admin-course-map-canvas.is-panning {
    cursor: grabbing;
}

.admin-course-map-controls {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.admin-course-map-badge {
    position: absolute;
    left: 0.75rem;
    right: 4.2rem;
    top: 0.75rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.admin-course-map-badge span {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.32rem 0.7rem;
    border-radius: 999px;
    background: rgba(6, 8, 10, 0.84);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--text);
    font-size: 0.78rem;
    font-weight: 700;
}

.admin-course-map-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.rich-editor {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    margin-bottom: 1rem;
}

.rich-editor-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.rich-editor-button,
.rich-editor-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.5rem;
    padding: 0.55rem 0.9rem;
    border: 1px solid var(--line, rgba(255, 255, 255, 0.1));
    border-radius: 0.8rem;
    background: var(--panel, #11161b);
    color: var(--text, #f3f5f7);
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    transition: border-color 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}

.rich-editor-button:hover,
.rich-editor-button:focus-visible,
.rich-editor-toggle:hover,
.rich-editor-toggle:focus-visible,
.rich-editor-toggle.is-active {
    border-color: var(--accent, #9bdc28);
    color: var(--accent, #9bdc28);
    outline: none;
}

.rich-editor-surface {
    min-height: 18rem;
    padding: 1rem 1rem 1.15rem;
    border: 1px solid var(--line, rgba(255, 255, 255, 0.1));
    border-radius: 1rem;
    background: var(--panel, #11161b);
    color: var(--text, #f3f5f7);
    line-height: 1.65;
}

.rich-editor-surface:focus-visible,
.rich-editor-html-input:focus-visible {
    outline: 2px solid var(--accent, #9bdc28);
    outline-offset: 0;
    border-color: var(--accent, #9bdc28);
}

.rich-editor-surface h2,
.rich-editor-surface h3,
.rich-editor-surface p,
.rich-editor-surface ul,
.rich-editor-surface ol {
    margin: 0 0 0.9rem;
}

.rich-editor-surface ul,
.rich-editor-surface ol {
    padding-left: 1.4rem;
}

.rich-editor-surface a {
    color: var(--accent, #9bdc28);
    text-decoration: underline;
    text-underline-offset: 0.18em;
}

.rich-editor-html {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.rich-editor-html-label,
.rich-editor-help {
    margin: 0;
    color: var(--muted, #aeb7c1);
    font-size: 0.92rem;
}

.rich-editor-html-input {
    min-height: 12rem;
    padding: 1rem;
    border: 1px solid var(--line, rgba(255, 255, 255, 0.1));
    border-radius: 1rem;
    background: var(--panel, #11161b);
    color: var(--text, #f3f5f7);
    font: 500 0.95rem/1.5 "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
    resize: vertical;
}

.course-tee-dropdown {
    padding: 0;
    overflow: hidden;
}

.course-tee-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.1rem;
    cursor: pointer;
    list-style: none;
}

.course-tee-summary::-webkit-details-marker {
    display: none;
}

.course-tee-summary-copy {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-width: 0;
}

.course-tee-heading {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    min-width: 0;
}

.course-tee-summary-copy strong {
    color: var(--text, #f3f5f7);
}

.course-tee-summary-copy small {
    color: var(--muted, #aeb7c1);
    line-height: 1.45;
}

.course-tee-dropdown .story-arrow {
    transition: transform 0.18s ease;
}

.course-tee-dropdown[open] .story-arrow {
    transform: rotate(90deg);
}

.course-tee-dropdown-body {
    padding: 0 1.1rem 1.1rem;
    border-top: 1px solid var(--line, rgba(255, 255, 255, 0.08));
}

.tee-color-dot {
    width: 0.9rem;
    height: 0.9rem;
    flex: 0 0 0.9rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.12);
}

.tee-color-dot.is-fallback {
    background: var(--accent, #9bdc28);
}

.course-tee-meta-table {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.course-tee-meta-table > div {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    min-width: 8rem;
    padding: 0.8rem 0.9rem;
    border: 1px solid var(--line, rgba(255, 255, 255, 0.08));
    border-radius: 0.9rem;
    background: rgba(255, 255, 255, 0.02);
}

.course-tee-meta-table span {
    color: var(--muted, #aeb7c1);
    font-size: 0.82rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.course-tee-meta-table strong {
    color: var(--text, #f3f5f7);
}

.course-scorecard-table th,
.course-scorecard-table td {
    white-space: nowrap;
}

.course-scorecard-table tbody tr:nth-child(odd) {
    background: rgba(255, 255, 255, 0.02);
}

.course-scorecard-sections {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.course-scorecard-section {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.course-scorecard-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.course-scorecard-summary span {
    display: inline-flex;
    align-items: baseline;
    gap: 0.35rem;
    padding: 0.65rem 0.85rem;
    border: 1px solid var(--line, rgba(255, 255, 255, 0.08));
    border-radius: 0.85rem;
    background: rgba(255, 255, 255, 0.02);
    color: var(--muted, #aeb7c1);
    font-size: 0.92rem;
}

.course-scorecard-summary strong {
    color: var(--text, #f3f5f7);
}

.course-hole-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
}

.course-hole-card {
    flex: 1 1 10rem;
    min-width: 9.2rem;
    padding: 0.95rem;
    border: 1px solid var(--line, rgba(255, 255, 255, 0.08));
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.02);
}

.course-hole-card dl {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    margin: 0;
}

.course-hole-card dl > div {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.75rem;
}

.course-hole-card dt {
    margin: 0;
    color: var(--muted, #aeb7c1);
    font-size: 0.78rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.course-hole-card dd {
    margin: 0;
    color: var(--text, #f3f5f7);
    font-size: 1rem;
    font-weight: 700;
}

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

.admin-list,
.admin-request-stack,
.admin-tee-stack {
    display: grid;
    gap: 0.8rem;
}

.admin-list-row,
.admin-request-card,
.admin-tee-card {
    border: 1px solid var(--border-color);
    border-radius: 1rem;
    padding: 0.95rem 1rem;
    background: rgba(255, 255, 255, 0.02);
}

.admin-list-row {
    display: grid;
    gap: 0.75rem;
}

.admin-list-row strong,
.admin-request-card strong,
.admin-tee-card strong {
    display: block;
}

.admin-list-row small,
.admin-request-card small,
.admin-tee-card small {
    color: var(--text-secondary);
}

.admin-row-meta,
.admin-row-actions,
.admin-request-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    align-items: center;
}

.admin-request-head,
.admin-tee-head,
.admin-page-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.admin-request-copy,
.admin-note-copy p {
    margin: 0;
}

.admin-request-form,
.admin-inline-form {
    display: grid;
    gap: 0.85rem;
}

.admin-status-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 0.3rem 0.7rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    border: 1px solid var(--border-color);
}

.status-pending {
    color: var(--accent-color);
    border-color: rgba(163, 255, 79, 0.35);
}

.status-reviewing {
    color: #f7d77a;
    border-color: rgba(247, 215, 122, 0.35);
}

.status-resolved {
    color: #8acdf5;
    border-color: rgba(138, 205, 245, 0.35);
}

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

.admin-hole-card,
.admin-yard-input {
    display: grid;
    gap: 0.4rem;
}

.admin-hole-card {
    border: 1px solid var(--border-color);
    border-radius: 0.9rem;
    padding: 0.75rem;
    background: rgba(255, 255, 255, 0.02);
}

.admin-hole-card label,
.admin-yard-input span {
    font-size: 0.82rem;
    color: var(--text-secondary);
}

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

.admin-inline-delete {
    margin-top: 0.75rem;
}

.admin-blogs-page .admin-list-row,
.admin-blog-page .admin-list-row {
    align-items: flex-start;
}

.admin-editor-shell,
.admin-blog-side-stack,
.admin-media-grid {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.admin-blog-editor-form {
    min-width: 0;
}

.blog-editor-panel {
    display: grid;
    gap: 0.85rem;
}

.blog-editor-modebar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.blog-editor-toolbar,
.admin-media-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.blog-editor-toolbar .action-button {
    min-height: 2.4rem;
    padding: 0.6rem 0.85rem;
}

.blog-editor-surface {
    min-height: 24rem;
    padding: 1rem;
    border: 1px solid var(--border-color);
    border-radius: 0.9rem;
    background: var(--panel-2);
    color: var(--text);
    line-height: 1.7;
    overflow-wrap: anywhere;
}

.blog-editor-surface:focus {
    outline: 2px solid var(--accent-strong);
    outline-offset: 2px;
}

.blog-editor-input {
    min-height: 24rem;
    padding: 1rem;
    border: 1px solid var(--border-color);
    border-radius: 0.9rem;
    background: var(--panel-2);
    color: var(--text);
    line-height: 1.7;
    font-family: Consolas, "Courier New", monospace;
}

.blog-editor-surface h2,
.blog-editor-surface h3,
.blog-editor-surface h4,
.blog-article-body h2,
.blog-article-body h3,
.blog-article-body h4 {
    margin: 1.2rem 0 0.5rem;
    line-height: 1.25;
}

.blog-editor-surface p,
.blog-editor-surface ul,
.blog-editor-surface ol,
.blog-editor-surface blockquote,
.blog-article-body p,
.blog-article-body ul,
.blog-article-body ol,
.blog-article-body blockquote {
    margin: 0 0 1rem;
}

.blog-editor-surface ul,
.blog-editor-surface ol,
.blog-article-body ul,
.blog-article-body ol {
    padding-left: 1.2rem;
}

.blog-editor-surface blockquote,
.blog-article-body blockquote {
    padding-left: 1rem;
    border-left: 3px solid rgba(143, 205, 47, 0.35);
    color: var(--text-soft);
}

.blog-editor-surface figure,
.blog-article-body figure {
    margin: 1.2rem 0;
}

.blog-editor-surface img,
.blog-article-body img {
    width: 100%;
    height: auto;
    border-radius: 0.9rem;
    border: 1px solid var(--line);
}

.blog-editor-surface figcaption,
.blog-article-body figcaption {
    margin-top: 0.55rem;
    color: var(--text-soft);
    font-size: 0.88rem;
    line-height: 1.5;
    text-align: center;
}

.blog-article-body a,
.blog-editor-surface a {
    color: var(--accent-strong);
    text-decoration: underline;
}

.blog-ai-prompt {
    min-height: 20rem;
    font-family: Consolas, "Courier New", monospace;
}

.admin-media-card {
    display: grid;
    gap: 0.85rem;
    padding: 0.9rem;
}

.admin-media-preview {
    min-height: 10rem;
}

.blog-cover-preview {
    overflow: hidden;
    min-height: 11rem;
    border: 1px solid var(--border-color);
    border-radius: 0.9rem;
    background: var(--panel-2);
}

.blog-cover-preview-article {
    min-height: 13rem;
}

.blog-cover-credit {
    margin: -0.15rem 0 0;
    color: var(--text-dim);
    font-size: 0.8rem;
    line-height: 1.5;
}

.admin-toggle-row {
    border: 1px solid var(--border-color);
    border-radius: 0.9rem;
    padding: 0.9rem 1rem;
}

.admin-log-viewer {
    margin: 0;
    max-height: 100%;
    overflow: auto;
    padding: 0.35rem;
    border: 1px solid var(--border-color);
    border-radius: 0.9rem;
    background: var(--panel-2);
    color: var(--text);
}

.admin-log-line {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    padding: 0.65rem 0.75rem;
    border-radius: 0.7rem;
}

.admin-log-line + .admin-log-line {
    margin-top: 0.2rem;
}

.admin-log-line code {
    flex: 1 1 auto;
    min-width: 0;
    color: var(--text);
    font-family: Consolas, "Courier New", monospace;
    font-size: 0.82rem;
    line-height: 1.65;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

.admin-log-line-number {
    flex: 0 0 2.2rem;
    color: var(--text-dim);
    font-size: 0.74rem;
    line-height: 1.8;
    text-align: right;
}

.admin-log-line-neutral {
    background: rgba(255, 255, 255, 0.02);
}

.admin-log-line-warning {
    background: rgba(241, 211, 122, 0.08);
    border: 1px solid rgba(241, 211, 122, 0.14);
}

.admin-log-line-error {
    background: rgba(240, 141, 128, 0.08);
    border: 1px solid rgba(240, 141, 128, 0.16);
}

.admin-log-line-success {
    background: rgba(143, 205, 47, 0.08);
    border: 1px solid rgba(143, 205, 47, 0.16);
}

.compact-inline-form {
    align-items: start;
}

.course-copy-panel {
    display: grid;
    gap: 0.6rem;
}

.course-copy-panel h2,
.course-copy-panel p {
    margin: 0;
}

.course-scorecard-stack {
    display: grid;
    gap: 0.85rem;
}

.course-scorecard-card {
    display: grid;
    gap: 0.8rem;
}

.course-tee-selector-panel {
    margin-bottom: 0.85rem;
}

.course-scorecard-head {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    align-items: center;
    flex-wrap: wrap;
}

.course-tee-row {
    align-items: start;
}

.site-legal-footer {
    position: relative;
    z-index: 2;
    border-top: 1px solid var(--line);
    background: rgba(8, 11, 14, 0.96);
}

.site-legal-footer-inner {
    width: min(100%, var(--shell));
    margin: 0 auto;
    padding: 0.9rem 1rem 1.1rem;
    display: grid;
    gap: 0.55rem;
}

body.has-bottom-nav .site-legal-footer-inner {
    padding-bottom: calc(var(--nav-height) + env(safe-area-inset-bottom, 0px) + 1.1rem);
}

.site-legal-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    align-items: center;
}

.site-legal-links a,
.legal-link-button {
    color: var(--accent);
    font-size: 0.85rem;
    font-weight: 700;
    text-decoration: underline;
    text-decoration-thickness: 0.08em;
    text-underline-offset: 0.18em;
}

.legal-link-button {
    padding: 0;
    border: 0;
    background: transparent;
    font: inherit;
    cursor: pointer;
}

.site-legal-copy {
    margin: 0;
    color: var(--text-dim);
    font-size: 0.78rem;
    line-height: 1.5;
}

.cookie-banner {
    position: fixed;
    left: 1rem;
    right: 1rem;
    bottom: calc(var(--nav-height) + 1rem);
    z-index: 30;
    display: grid;
    gap: 0.9rem;
    padding: 1rem;
    border: 1px solid var(--line-strong);
    border-radius: 1rem;
    background: rgba(11, 15, 18, 0.98);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
}

.cookie-banner-copy,
.cookie-category-copy,
.profile-head-copy,
.story-copy,
.activity-copy,
.toggle-row > span,
.settings-row > span,
.settings-row > strong,
.profile-summary-list > div,
.desktop-quick-card,
.mini-stat-card {
    min-width: 0;
    overflow-wrap: anywhere;
}

.cookie-banner-copy {
    display: grid;
    gap: 0.45rem;
}

.cookie-banner-copy strong,
.cookie-category-copy strong {
    font-size: 1rem;
}

.cookie-banner-copy p,
.cookie-category-copy p {
    margin: 0;
    color: var(--text-soft);
    line-height: 1.55;
}

.cookie-banner-actions,
.cookie-modal-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.cookie-banner-actions .action-button,
.cookie-modal-actions .action-button {
    flex: 1 1 11rem;
}

.cookie-modal {
    position: fixed;
    inset: 0;
    z-index: 40;
}

.cookie-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.66);
}

.cookie-modal-panel {
    position: relative;
    width: min(100% - 2rem, 44rem);
    margin: 5vh auto 0;
    padding: 1.1rem;
    display: grid;
    gap: 1rem;
}

.cookie-modal-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.cookie-modal-head h2 {
    margin: 0.2rem 0 0;
    font-size: 1.15rem;
    line-height: 1.3;
}

.cookie-category-list {
    display: grid;
    gap: 0.85rem;
}

.cookie-category {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem;
    background: var(--panel-2);
}

.cookie-category-copy {
    flex: 1 1 16rem;
}

.cookie-toggle,
.cookie-category-control {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    min-height: 2.75rem;
    color: var(--text-soft);
    font-size: 0.9rem;
}

.cookie-toggle input {
    accent-color: var(--accent);
}

.cookie-lock-label {
    color: var(--text-dim);
    font-weight: 700;
}

.story-row.panel,
.leaderboard-row,
.settings-row,
.stat-row,
.trend-row,
.history-row,
.activity-row,
.course-row,
.mini-stat-card {
    padding: 1rem;
}

.form-panel,
.permission-panel,
.search-panel,
.profile-top,
.round-hero,
.scorecard-panel,
.handicap-form,
.stat-hero,
.handicap-summary-panel,
.profile-card {
    padding: 1.1rem;
}

.quick-tile,
.mini-stat-card {
    min-width: 0;
    padding: 1rem;
}

.split-metrics > div,
.recent-score-list > div,
.scorecard-cell,
.profile-summary-list > div {
    min-width: 8.5rem;
    padding: 1rem;
}

.toggle-row {
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 1rem;
}

.toggle-row > span {
    flex: 1 1 14rem;
}

.profile-top {
    gap: 1.1rem;
}

.profile-head {
    flex-wrap: wrap;
    gap: 1rem;
}

.profile-head-copy {
    display: grid;
    gap: 0.2rem;
}

.profile-columns {
    display: flex;
    flex-wrap: wrap;
    gap: 0.95rem;
}

.profile-card {
    flex: 1 1 20rem;
}

.profile-summary-list {
    gap: 0.8rem;
    flex-wrap: wrap;
}

.profile-summary-list > div {
    display: grid;
    gap: 0.35rem;
}

.settings-row {
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
}

.settings-row > span {
    flex: 1 1 12rem;
}

.settings-row > strong {
    flex: 0 1 auto;
    text-align: right;
}

.desktop-quick-grid,
.dashboard-page .desktop-news-grid,
.stats-page .compact-card-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
}

.desktop-quick-card {
    flex: 1 1 10rem;
    padding: 1rem;
}

.dashboard-page .desktop-story-card {
    flex: 1 1 15rem;
}

.legal-layout {
    width: min(100%, 62rem);
    margin: 0 auto;
}

.legal-panel {
    display: grid;
    gap: 0.8rem;
    padding: 1.1rem;
}

.legal-panel h2,
.legal-panel p,
.legal-panel li {
    margin: 0;
}

.legal-panel a,
.legal-copy a,
.legal-list a,
.legal-table a {
    color: var(--accent);
    font-weight: 700;
    text-decoration: underline;
    text-decoration-thickness: 0.08em;
    text-underline-offset: 0.18em;
    word-break: break-word;
}

.legal-panel a:hover,
.legal-copy a:hover,
.legal-list a:hover,
.legal-table a:hover,
.site-legal-links a:hover,
.legal-link-button:hover {
    color: var(--text);
}

.legal-panel a:focus-visible,
.legal-copy a:focus-visible,
.legal-list a:focus-visible,
.legal-table a:focus-visible,
.site-legal-links a:focus-visible,
.legal-link-button:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 0.16rem;
    border-radius: 0.2rem;
}

.legal-list {
    display: grid;
    gap: 0.65rem;
    padding-left: 1.1rem;
    color: var(--text-soft);
    line-height: 1.6;
}

.legal-table-wrap {
    overflow-x: auto;
}

.legal-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 34rem;
}

.legal-table th,
.legal-table td {
    padding: 0.85rem 0.9rem;
    border-bottom: 1px solid var(--line);
    text-align: left;
    vertical-align: top;
    line-height: 1.5;
}

.legal-table th {
    color: var(--text);
    font-size: 0.82rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.legal-table td {
    color: var(--text-soft);
}

.legal-table code {
    color: var(--text);
    font-size: 0.82rem;
}

.legal-copy {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.legal-copy p {
    margin: 0;
    color: var(--text-soft);
}

.danger-panel {
    border-color: rgba(210, 86, 86, 0.35);
}

.privacy-centre-page .stat-list-panel strong,
.admin-privacy-page .stat-list-panel strong {
    max-width: 100%;
    text-align: right;
    white-space: normal;
    overflow-wrap: anywhere;
}

@media (min-width: 48rem) {
    .admin-grid {
        grid-template-columns: 1.15fr 1fr;
    }

    .admin-grid-wide {
        grid-template-columns: 1fr 1.15fr;
    }

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

    .admin-action-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .admin-list-row {
        grid-template-columns: minmax(0, 1.5fr) auto auto;
        align-items: center;
    }

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

    .admin-yard-grid {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }

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

@media (min-width: 64rem) {
    .cookie-banner {
        left: auto;
        right: 1.5rem;
        bottom: 1.5rem;
        width: min(34rem, calc(100vw - 18rem - 4rem));
    }

    .desktop-signout {
        margin-top: auto;
        width: 100%;
    }

    .profile-page .profile-columns {
        flex: 1 1 100%;
    }

    .profile-page .profile-signout {
        flex: 1 1 100%;
    }

    .admin-editor-shell {
        flex-direction: row;
        align-items: flex-start;
    }

    .admin-blog-editor-form {
        flex: 1 1 0;
    }

    .admin-blog-side-stack {
        flex: 0 0 25rem;
        width: 25rem;
    }
}

.shot-replay-map-intro,
.shot-replay-status-panel p,
.shot-replay-map-help,
.shot-replay-video-empty-v2 p {
    margin: 0;
    color: var(--text-soft);
    line-height: 1.65;
}

.shot-replay-map-layout,
.shot-replay-preview-column,
.shot-replay-preview-grid,
.shot-replay-action-row,
.shot-replay-map-summary,
.shot-replay-map-meta,
.shot-replay-inline-meta {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.shot-replay-map-layout {
    gap: 1rem;
}

.shot-replay-control-panel,
.shot-replay-preview-panel,
.shot-replay-status-panel,
.shot-replay-map-summary,
.shot-replay-trim-panel {
    padding: 1rem;
}

.shot-replay-map-summary {
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.02);
}

.shot-replay-map-summary-row,
.shot-replay-map-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.shot-replay-map-summary-row span,
.shot-replay-map-meta span,
.shot-replay-surface-head small {
    color: var(--text-soft);
    font-size: 0.9rem;
}

.shot-replay-map-summary-row strong,
.shot-replay-surface-head strong {
    color: var(--text);
}

.shot-replay-action-row {
    flex-direction: row;
    flex-wrap: wrap;
}

.shot-replay-action-row .action-button {
    flex: 1 1 10rem;
    min-width: 0;
}

.shot-replay-action-row .action-button.is-active {
    border-color: var(--accent);
    color: var(--text);
    background: rgba(143, 205, 47, 0.12);
}

.shot-replay-preview-grid {
    gap: 1rem;
}

.shot-replay-video-surface,
.shot-replay-map-surface {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    min-width: 0;
}

.shot-replay-surface-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.75rem;
}

.shot-replay-video-frame-v2,
.shot-replay-map-canvas-wrap {
    position: relative;
    border: 1px solid var(--line);
    border-radius: 1rem;
    overflow: hidden;
    background: #0b1116;
}

.shot-replay-video-frame-v2 {
    min-height: 24rem;
}

.shot-replay-source-video {
    display: block;
    width: 100%;
    height: 24rem;
    object-fit: cover;
    object-position: center center;
    transform-origin: center center;
    background: #050709;
}

.shot-replay-crop-guide {
    position: absolute;
    inset: 0.9rem;
    border: 1px dashed rgba(255, 255, 255, 0.35);
    border-radius: 0.85rem;
    pointer-events: none;
}

.shot-replay-video-empty-v2 {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.5rem;
    padding: 1rem;
}

.shot-replay-map-canvas-wrap {
    min-height: 24rem;
}

.shot-replay-map-canvas {
    display: block;
    width: 100%;
    height: 24rem;
    touch-action: none;
    cursor: grab;
}

.shot-replay-map-canvas.is-panning {
    cursor: grabbing;
}

.shot-replay-map-canvas.is-placing {
    cursor: crosshair;
}

.shot-replay-map-controls {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.shot-replay-map-controls .icon-action {
    min-width: 2.3rem;
    min-height: 2.3rem;
    font-size: 1.1rem;
    font-weight: 700;
}

.shot-replay-map-badges {
    position: absolute;
    left: 0.75rem;
    right: 4.25rem;
    top: 0.75rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.shot-replay-map-badges span {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(6, 8, 10, 0.86);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--text);
    font-size: 0.84rem;
}

.shot-replay-map-help {
    font-size: 0.92rem;
}

.shot-replay-inline-meta {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.shot-replay-inline-meta .helper-note {
    margin: 0;
}

@media (min-width: 76rem) {
    .shot-replay-map-layout {
        flex-direction: row;
        align-items: flex-start;
    }

    .shot-replay-control-panel {
        flex: 0 0 22rem;
    }

    .shot-replay-preview-column {
        flex: 1 1 auto;
    }

    .shot-replay-preview-grid {
        flex-direction: row;
        align-items: stretch;
    }

    .shot-replay-video-surface,
    .shot-replay-map-surface {
        flex: 1 1 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }

    *,
    *::before,
    *::after {
        transition: none !important;
        animation: none !important;
    }
}
