html {
    --page-bg: #f3efe7;
    --page-bg-elevated: #faf7f1;
    --surface: #fffdf9;
    --surface-2: #f6f0e8;
    --surface-3: #ebe2d7;
    --sidebar-bg: #dce5ee;
    --sidebar-bg-strong: #cfd9e4;
    --header-bg: #edf3f8;
    --border: #c4d0db;
    --border-strong: #a9b8c7;
    --text-primary: #1e2d3b;
    --text-secondary: #3a5268;
    --text-muted: #6f8192;
    --accent: #4f6d8a;
    --accent-strong: #3d5870;
    --accent-soft: rgba(79, 109, 138, 0.14);
    --accent-contrast: #f5f8fb;
    --success: #6988a1;
    --warning: #b68553;
    --danger: #ba665c;
    --shadow-soft: 0 20px 44px rgba(27, 42, 57, 0.1);
}

[hidden] {
    display: none !important;
}

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

@keyframes upload-indeterminate {
    0% {
        transform: translateX(-120%);
    }

    100% {
        transform: translateX(320%);
    }
}

.workout-video-picker__play {
    position: absolute;
    inset: 50% auto auto 50%;
    transform: translate(-50%, -50%);
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.56);
    color: #ffffff;
    backdrop-filter: blur(6px);
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.18);
    pointer-events: none;
}

.program-item-image-preview {
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    width: 140px;
    aspect-ratio: 1;
    border: 1px solid #d8e1ec;
    border-radius: 16px;
    background: var(--program-card-color, #3b82f6);
    color: #fff;
    font-weight: 800;
}

.program-item-image-preview img,
.program-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

@media (max-width: 900px) {

    .program-item-image-preview {
        width: 100%;
        max-width: 220px;
    }
}

html[data-theme="dark"] {
    --page-bg: #0f1720;
    --page-bg-elevated: #111c27;
    --surface: #16212c;
    --surface-2: #1b2733;
    --surface-3: #21303e;
    --sidebar-bg: #121b24;
    --sidebar-bg-strong: #17232d;
    --header-bg: #141f29;
    --border: #273746;
    --border-strong: #34485a;
    --text-primary: #e6edf4;
    --text-secondary: #bfd0df;
    --text-muted: #8ca1b5;
    --accent: #88a7c0;
    --accent-strong: #a4bed4;
    --accent-soft: rgba(136, 167, 192, 0.16);
    --accent-contrast: #102131;
    --success: #8ea9c0;
    --warning: #d5a46b;
    --danger: #d37b72;
    --shadow-soft: 0 28px 60px rgba(0, 0, 0, 0.28);
}

body {
    margin: 0;
    font-family: -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: 15px;
    line-height: 1.5;
    background: #0b1220;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    height: auto;
    box-sizing: border-box;
    padding: 32px 18px;
}

.auth-container {
    width: min(420px, 100%);
}

.logo {
    text-align: center;
    margin-bottom: 40px;
}

.logo-icon {
    width: 64px;
    height: 64px;
    border-radius: 16px;
    margin: 0 auto 16px;
}

.logo-image {
    display: block;
    width: 96px;
    height: 96px;
    object-fit: cover;
    margin: 0 auto 18px;
    border-radius: 24px;
    box-shadow: 0 24px 54px rgba(0, 0, 0, 0.28);
}

.logo h1 {
    margin: 0;
    font-size: 32px;
}

.logo p {
    color: #8a94a6;
    margin-top: 8px;
}

.auth-title {
    margin: 0 0 18px;
    color: #ffffff;
    font-size: 24px;
    font-weight: 800;
    line-height: 1.2;
    text-align: center;
}

.login-form input,
.login-form button {
    box-sizing: border-box;
    display: block;
}

.login-form input {
    width: 100%;
    padding: 14px 16px;
    margin-bottom: 14px;
    border-radius: 12px;
    border: 1px solid #1f2a44;
    background: #111827;
    color: #fff;
    font-size: 15px;
}

.login-form button {
    width: 100%;
    padding: 14px 16px;
    border-radius: 12px;
    border: none;
    background: #2ecc71;
    color: #000;
    font-weight: bold;
    font-size: 15px;
    cursor: pointer;
}


.error {
    color: #ff6b6b;
    margin-top: 10px;
}

.success {
    color: #2ecc71;
    margin-top: 12px;
}

.login-form .error,
.login-form .success {
    margin: 0 0 14px;
    padding: 12px 14px;
    border: 1px solid transparent;
    border-radius: 12px;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.4;
}

.login-form .error {
    border-color: color-mix(in srgb, var(--danger) 30%, transparent);
    background: color-mix(in srgb, var(--danger) 10%, var(--surface));
    color: var(--danger);
}

.login-form .success {
    border-color: color-mix(in srgb, var(--success) 34%, transparent);
    background: color-mix(in srgb, var(--success) 12%, var(--surface));
    color: var(--success);
}

.form-actions {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 16px;
}

.login-options {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}

.remember-field {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #8a94a6;
    font-size: 14px;
    line-height: 1.2;
    cursor: pointer;
}

.login-form .remember-field input {
    width: 18px;
    height: 18px;
    margin: 0;
    padding: 0;
    border-radius: 4px;
    cursor: pointer;
}

.forgot {
    color: #8a94a6;
    font-size: 14px;
    text-decoration: none;
}

.forgot:hover {
    color: var(--accent-strong);
}

.auth-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 20px 0 16px;
    color: #8a94a6;
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
}

.auth-divider::before,
.auth-divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background: #1f2a44;
}

.auth-provider-login {
    margin-top: 4px;
}

.auth-provider-buttons {
    display: grid;
    gap: 10px;
}

.auth-provider-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    min-height: 48px;
    box-sizing: border-box;
    padding: 12px 14px;
    border: 1px solid #26344f;
    border-radius: 12px;
    background: #111827;
    color: #ffffff;
    font-size: 15px;
    font-weight: 800;
    cursor: pointer;
}

.auth-provider-button:hover,
.auth-provider-button:focus-visible {
    border-color: #3f577a;
    background: #172033;
}

.auth-provider-button:disabled {
    cursor: wait;
    opacity: 0.72;
}

.auth-google-shell {
    position: relative;
    min-height: 48px;
}

.auth-google-shell__visual {
    pointer-events: none;
}

.auth-google-shell__button {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: flex;
    align-items: center;
    opacity: 0;
    overflow: hidden;
}

.auth-google-shell__button iframe {
    width: 100% !important;
}

.auth-provider-mark {
    display: grid;
    place-items: center;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: #ffffff;
    color: #101827;
    font-size: 14px;
    font-weight: 900;
}

.auth-provider-mark svg {
    width: 17px;
    height: 17px;
}

.auth-provider-button--vipps .auth-provider-mark {
    background: #ff5b24;
    color: #ffffff;
}

.auth-provider-button--golfsmart .auth-provider-mark {
    background: #2ecc71;
    color: #06100a;
}

.auth-provider-error {
    margin: -2px 0 14px;
    padding: 2px 0 2px 12px;
    border-left: 3px solid #ff8e88;
    background: transparent;
    color: #ffaaa5;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.45;
}

.auth-login-switch {
    margin-top: 18px;
    text-align: center;
}

.auth-login-switch a {
    color: #9eb5cc;
    font-size: 14px;
    font-weight: 800;
    text-decoration: none;
}

.auth-login-switch a:hover {
    color: #ffffff;
}

.language-switch {
    margin-top: 24px;
    text-align: center;
}

.language-switch a {
    color: #8a94a6;
    margin: 0 8px;
    text-decoration: none;
    font-size: 14px;
}

.language-switch a:hover {
    color: var(--accent-strong);
}

.auth-footer-links {
    margin-top: 14px;
    text-align: center;
}

.auth-footer-links a,
.auth-footer-links span {
    color: #6b7f98;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
}

.auth-footer-links {
    display: grid;
    gap: 14px;
}

.auth-footer-links div {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    flex-wrap: wrap;
}

.auth-footer-links a:hover {
    color: var(--accent-strong);
}

.privacy-policy-body {
    align-items: flex-start;
    min-height: 100vh;
    height: auto;
    padding: 32px 18px;
    overflow-y: auto;
}

.privacy-policy-page {
    width: min(920px, 100%);
    margin: 0 auto;
}

.privacy-policy-card {
    color: #1e2d3b;
    background: linear-gradient(180deg, #fffdf9 0%, #f8f4ed 100%);
    border: 1px solid #cdd8e3;
    border-radius: 28px;
    padding: clamp(24px, 4vw, 48px);
    box-shadow: 0 24px 60px rgba(30, 45, 59, 0.14);
}

.privacy-policy-back {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    margin-bottom: 24px;
    color: #4f6d8a;
    font-weight: 800;
    text-decoration: none;
}

.privacy-policy-back:hover {
    color: #1e2d3b;
}

.privacy-policy-header {
    margin-bottom: 32px;
    text-align: center;
}

.privacy-policy-header .logo-image {
    width: 78px;
    height: 78px;
    margin-bottom: 16px;
}

.privacy-policy-eyebrow {
    margin: 0 0 10px;
    color: #4f6d8a;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.privacy-policy-header h1 {
    margin: 0;
    color: #132236;
    font-size: clamp(30px, 5vw, 48px);
    line-height: 1.05;
}

.privacy-policy-header p:last-child {
    margin: 14px 0 0;
    color: #5f7088;
    font-weight: 700;
}

.privacy-policy-card section {
    border-top: 1px solid #dce5ee;
    padding: 24px 0 0;
    margin-top: 24px;
}

.privacy-policy-card h2 {
    margin: 0 0 12px;
    color: #132236;
    font-size: 20px;
}

.privacy-policy-card p,
.privacy-policy-card li {
    color: #3a5268;
    font-size: 16px;
    line-height: 1.7;
}

.privacy-policy-card p {
    margin: 0 0 14px;
}

.privacy-policy-card ul {
    columns: 2;
    gap: 36px;
    margin: 12px 0 18px;
    padding-left: 22px;
}

.privacy-policy-card li {
    break-inside: avoid;
    margin-bottom: 8px;
}

.privacy-policy-card a {
    color: #365f86;
    font-weight: 800;
}

@media (max-width: 760px) {
    .privacy-policy-card ul {
        columns: 1;
    }
}

.support-page-body {
    align-items: center;
    min-height: 100vh;
    height: auto;
    padding: 32px 18px;
    overflow-y: auto;
}

.support-page {
    width: min(680px, 100%);
    margin: 0 auto;
}

.support-card {
    color: #1e2d3b;
    background: linear-gradient(180deg, #fffdf9 0%, #f5f1ea 100%);
    border: 1px solid #cdd8e3;
    border-radius: 28px;
    padding: clamp(24px, 4vw, 36px);
    box-shadow: 0 24px 60px rgba(30, 45, 59, 0.16);
}

.support-header {
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
    padding-bottom: 24px;
    border-bottom: 1px solid #dce5ee;
}

.support-logo {
    width: 54px;
    height: 54px;
    object-fit: cover;
    border-radius: 16px;
    box-shadow: 0 14px 30px rgba(30, 45, 59, 0.18);
}

.support-eyebrow {
    margin: 0 0 6px;
    color: #4f6d8a;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.13em;
    text-transform: uppercase;
}

.support-header h1 {
    margin: 0;
    color: #132236;
    font-size: clamp(28px, 5vw, 40px);
    line-height: 1.08;
}

.support-header p:last-child,
.support-contact p {
    margin: 10px 0 0;
    color: #3a5268;
    font-size: 16px;
    line-height: 1.6;
}

.support-section {
    padding-top: 24px;
}

.support-section h2 {
    margin: 0 0 14px;
    color: #132236;
    font-size: 20px;
}

.support-faq-list {
    display: grid;
    gap: 10px;
}

.support-faq-list details {
    background: #fffdf9;
    border: 1px solid #cdd8e3;
    border-radius: 16px;
    padding: 0;
}

.support-faq-list summary {
    cursor: pointer;
    padding: 16px 18px;
    color: #132236;
    font-weight: 900;
}

.support-faq-list details[open] summary {
    border-bottom: 1px solid #dce5ee;
}

.support-faq-list p {
    margin: 0;
    padding: 16px 18px 18px;
    color: #3a5268;
    line-height: 1.6;
}

.support-contact {
    border-top: 1px solid #dce5ee;
    margin-top: 24px;
}

.support-contact-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    margin-top: 18px;
    padding: 0 22px;
    color: #f5f8fb;
    background: #4f6d8a;
    border-radius: 999px;
    box-shadow: 0 14px 28px rgba(79, 109, 138, 0.24);
    font-size: 14px;
    font-weight: 900;
    letter-spacing: 0.02em;
    text-decoration: none;
    text-transform: uppercase;
}

.support-contact-button:hover {
    background: #3d5870;
}

.support-footer {
    display: flex;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 28px;
    color: #5f7088;
    font-size: 14px;
}

.support-footer a {
    color: #365f86;
    font-weight: 800;
    text-decoration: none;
}

.support-footer a:hover {
    color: #132236;
}

@media (max-width: 560px) {
    .support-header {
        grid-template-columns: 1fr;
    }
}

.organization-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.organization-card {
    background: #111827;
    border: 1px solid #1f2a44;
    border-radius: 16px;
    padding: 20px;
}

.organization-card h3 {
    margin: 0 0 12px 0;
    font-size: 18px;
}

.roles {
    display: flex;
    gap: 12px;
}

.role-btn {
    flex: 1;
    padding: 12px;
    border-radius: 10px;
    text-align: center;
    text-decoration: none;
    background: #2ecc71;
    color: #000;
    font-weight: 600;
}

.role-btn.secondary {
    background: transparent;
    border: 1px solid #2ecc71;
    color: #2ecc71;
}

.role-btn:hover {
    opacity: 0.9;
}

body.app-body {
    align-items: stretch;
    justify-content: stretch;
    min-height: 100vh;
    height: auto;
    background: var(--page-bg);
}

.app-shell {
    display: flex;
    min-height: 100vh;
    width: 100%;
    background: linear-gradient(180deg, var(--page-bg) 0%, var(--page-bg-elevated) 100%);
}

.sidebar {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    width: 248px;
    flex: 0 0 248px;
    max-width: 100vw;
    min-height: 100vh;
    height: 100vh;
    position: sticky;
    top: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 18px 14px;
    border-right: 1px solid rgba(196, 208, 219, 0.72);
    backdrop-filter: blur(20px);
    scrollbar-gutter: stable;
}

.sidebar-header {
    display: grid;
    gap: 8px;
    padding: 2px 8px 16px;
    border-bottom: 1px solid rgba(196, 208, 219, 0.72);
    justify-items: center;
    text-align: center;
}

.sidebar-brand-logo {
    display: block;
    width: min(148px, 100%);
    height: auto;
    margin-inline: auto;
    border-radius: 22px;
}

.sidebar-title {
    font-size: 17px;
    font-weight: 750;
    letter-spacing: -0.02em;
}

.sidebar-subtitle,
.sidebar-meta,
.nav-section-title {
    color: #8a94a6;
}

.sidebar-subtitle {
    margin-top: 0;
    font-size: 13px;
}

.sidebar-nav {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
    overflow-x: hidden;
    padding: 18px 0;
}

.nav-section-title {
    margin: 8px 8px 10px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.nav-section {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.nav-item-link {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    min-height: 44px;
    margin-bottom: 0;
    padding: 0 8px 0 14px;
    border: 1px solid transparent;
    border-radius: 10px;
    color: var(--text-secondary);
    text-decoration: none;
    font-size: 14px;
    font-weight: 650;
    transition: 0.18s ease;
}

.nav-group {
    display: grid;
    gap: 0;
    min-width: 0;
}

.nav-group-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 32px;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.nav-group-head .nav-item-link {
    min-width: 0;
}

.nav-group-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    border: 0;
    border-radius: 10px;
    background: transparent;
    color: var(--text-muted);
    cursor: pointer;
    transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.nav-group-toggle:hover {
    background: color-mix(in srgb, var(--surface-2) 62%, transparent);
    color: var(--text-primary);
}

.nav-group-toggle svg {
    width: 16px;
    height: 16px;
    transition: transform 0.18s ease;
}

.nav-group.is-open .nav-group-toggle svg {
    transform: rotate(0deg);
}

.nav-group:not(.is-open) .nav-group-toggle svg {
    transform: rotate(-90deg);
}

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

.nav-item-leading {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.sidebar .nav-item-leading .nav-item-label:only-child {
    padding-left: 2px;
}

.nav-item-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    color: var(--text-muted);
    flex: 0 0 auto;
}

.nav-item-icon svg {
    width: 20px;
    height: 20px;
}

.nav-item-label {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.nav-item-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    padding: 2px 8px;
    border-radius: 10px;
    background: var(--accent-soft);
    color: var(--accent);
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    flex: 0 0 auto;
}

.nav-item-link:hover {
    border-color: color-mix(in srgb, var(--border) 72%, transparent);
    background: color-mix(in srgb, var(--surface-2) 62%, transparent);
    color: var(--text-primary);
}

.nav-item-link.active {
    border-color: color-mix(in srgb, var(--accent) 26%, var(--border));
    background: color-mix(in srgb, var(--accent-soft) 80%, transparent);
    color: var(--accent-strong);
    box-shadow: inset 3px 0 0 0 var(--accent);
}

.nav-item-link:hover .nav-item-icon,
.nav-item-link.active .nav-item-icon {
    color: var(--accent);
}

.nav-submenu {
    display: grid;
    gap: 6px;
    margin: 2px 0 10px 36px;
    padding-left: 14px;
    border-left: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
    min-width: 0;
    overflow-x: hidden;
}

.nav-submenu[hidden] {
    display: none;
}

.nav-subitem-link {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    min-height: 36px;
    padding: 8px 10px 8px 12px;
    border-radius: 8px;
    color: var(--text-secondary);
    text-decoration: none;
    transition: background 0.18s ease, color 0.18s ease;
}

.nav-subitem-link:hover {
    background: color-mix(in srgb, var(--surface-2) 54%, transparent);
    color: var(--text-primary);
}

.nav-subitem-link.active::before {
    content: "";
    position: absolute;
    top: 9px;
    bottom: 9px;
    left: -15px;
    width: 3px;
    border-radius: 999px;
    background: var(--accent);
}

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

.nav-subitem-label {
    min-width: 0;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.35;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.nav-subitem-link.active .nav-subitem-label {
    font-weight: 750;
}

.sidebar-footer {
    display: grid;
    gap: 12px;
    min-width: 0;
    overflow-x: hidden;
    padding-top: 16px;
    border-top: 1px solid rgba(196, 208, 219, 0.72);
}

.logout-link {
    width: 100%;
    padding: 11px 12px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 14px;
    font-weight: 700;
    transition: 0.18s ease;
}

.logout-link:hover {
    border-color: var(--accent);
    background: var(--accent-soft);
    color: var(--accent-strong);
}

.language-switch-footer {
    margin-top: 18px;
}

.sidebar-user-card {
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
    padding: 8px;
    border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
    border-radius: 10px;
    background: color-mix(in srgb, var(--surface) 88%, transparent);
    color: inherit;
    text-decoration: none;
    transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}

.sidebar-user-card:hover,
.sidebar-user-card:focus-visible,
.sidebar-user-card.active {
    border-color: color-mix(in srgb, var(--accent) 42%, var(--border));
    background: color-mix(in srgb, var(--accent-soft) 52%, var(--surface));
    box-shadow: 0 10px 24px rgba(31, 45, 61, 0.08);
    outline: none;
}

.sidebar-user-avatar {
    display: grid;
    place-items: center;
    overflow: hidden;
    width: 40px;
    height: 40px;
    min-width: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, #e8d5c5, #f7f2ec);
    color: #31445c;
    font-weight: 900;
}

.sidebar-user-avatar img {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
}

.sidebar-user-copy {
    min-width: 0;
}

.sidebar-user-more {
    min-width: 0;
    overflow: hidden;
    color: var(--text-muted);
    font-size: 16px;
    font-weight: 800;
    line-height: 1;
}

.language-switch a.active {
    color: #fff;
    font-weight: 700;
}

.sidebar-meta {
    margin-top: 4px;
    font-size: 12px;
    line-height: 1.5;
    min-width: 0;
    max-width: 100%;
    overflow-wrap: anywhere;
}

.content {
    flex: 1;
    min-width: 0;
    min-height: 100vh;
    background: transparent;
}

.status-message {
    font-size: 14px;
}

.delete-modal-open {
    overflow: hidden;
}

.delete-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: grid;
    place-items: center;
    padding: 24px;
}

.delete-modal[hidden] {
    display: none;
}

.delete-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(6, 10, 16, 0.62);
    cursor: pointer;
}

.delete-modal__dialog {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 18px;
    width: min(100%, 420px);
    padding: 24px;
    border: 1px solid var(--border);
    border-radius: 20px;
    background: var(--surface);
    box-shadow: var(--shadow-soft);
    color: var(--text-primary);
}

.delete-modal__title {
    font-size: 20px;
    font-weight: 800;
}

.delete-modal__text {
    color: var(--text-secondary);
    line-height: 1.6;
}

.delete-modal__actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    flex-wrap: wrap;
}

.delete-modal__actions button,
.delete-modal__actions a,
.delete-modal [data-delete-modal-close] {
    cursor: pointer;
}

.dashboard-placeholder .page-kicker {
    margin: 0 0 10px;
    color: #2ecc71;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
}

.coach-dashboard {
    width: 100%;
    color: #d9dee7;
}

.coach-dashboard-header {
    display: flex;
    margin: -32px -32px 32px;
    border-bottom: 1px solid #202936;
}

.coach-dashboard-badge {
    display: inline-flex;
    align-items: center;
    background: rgba(34, 197, 94, 0.22);
    color: #22c55e;
    font-weight: 800;
    text-transform: uppercase;
}

.coach-dashboard-header h1 {
    margin: 0;
    font-weight: 800;
}

.coach-metric-card,
.coach-panel {
    border: 1px solid #202936;
    border-radius: 8px;
    background: #10151d;
}

.coach-metric-card {
    display: grid;
    padding: 16px;
}

.coach-metric-icon {
    width: 28px;
    height: 28px;
}

.coach-metric-icon svg {
    width: 100%;
    height: 100%;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
}

.coach-metric-icon.green {
    color: #22c55e;
}

.coach-metric-icon.orange {
    color: #f5a623;
}

.coach-metric-icon.red {
    color: #ef4444;
}

.coach-metric-card strong {
    color: #e5e7eb;
    line-height: 1;
}

.coach-metric-card span {
    color: #7d8796;
}

.coach-chart-grid,
.coach-pie-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.coach-chart-grid {
    align-items: start;
}

.coach-pie-grid {
    margin-bottom: 22px;
}

.coach-panel {
    min-width: 0;
}

.coach-chart-grid .coach-panel:nth-child(3) {
    grid-column: span 1;
}

.coach-panel h2 {
    margin: 0 0 18px;
    color: #d9dee7;
    font-weight: 800;
}

.coach-line-chart {
    width: 100%;
}

.coach-line-chart svg {
    width: 100%;
    height: auto;
}

.coach-line-chart text {
    font-size: 13px;
}

.chart-axis {
    fill: none;
    stroke-width: 1.5;
}

.chart-line {
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 3;
}

.chart-line.green {
    stroke: #22c55e;
}

.chart-line.orange {
    stroke: #f5a623;
}

.chart-line.red {
    stroke: #ef4444;
}

.chart-point {
    outline: none;
}

.chart-point-hit {
    fill: transparent;
    cursor: pointer;
}

.chart-point-marker {
    fill: var(--accent, #22c55e);
    stroke: var(--panel, #14202b);
    stroke-width: 2;
    opacity: 0;
    transition: opacity 0.16s ease, r 0.16s ease;
}

.chart-tooltip {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.16s ease;
}

.chart-tooltip rect {
    fill: var(--surface-2, #1d2b38);
    stroke: var(--border-strong, #40546a);
    stroke-width: 1;
}

.chart-tooltip text {
    fill: var(--text-muted, #9fb8d3);
    font-size: 12px;
    font-weight: 700;
}

.chart-tooltip .chart-tooltip-value {
    fill: var(--text-primary, #ffffff);
    font-size: 13px;
    font-weight: 800;
}

.chart-point:hover .chart-point-marker,
.chart-point:focus .chart-point-marker {
    opacity: 1;
}

.chart-point:hover .chart-tooltip,
.chart-point:focus .chart-tooltip {
    opacity: 1;
}

.coach-pie-wrap {
    display: grid;
    grid-template-columns: minmax(180px, 260px) 1fr;
    align-items: center;
    gap: 32px;
    min-height: 260px;
}

.coach-pie {
    width: min(240px, 100%);
    aspect-ratio: 1;
    border: 2px solid rgba(255, 255, 255, 0.75);
    border-radius: 50%;
    justify-self: center;
}

.coach-pie-labels {
    display: grid;
    gap: 18px;
}

.coach-pie-labels span {
    color: var(--segment-color);
    font-size: 18px;
}

.coach-pie-legend {
    display: flex;
    justify-content: center;
    gap: 18px;
    flex-wrap: wrap;
    margin-top: 8px;
}

.coach-pie-legend span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--segment-color);
    font-size: 14px;
}

.coach-pie-legend span::before {
    content: "";
    display: block;
    width: 18px;
    height: 14px;
    background: var(--segment-color);
}

.coach-group-empty {
    margin: 0;
    color: var(--text-muted);
}

.admin-dashboard-metrics {
    margin-top: 4px;
    margin-bottom: 18px;
}

.admin-dashboard-mini-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.admin-mini-card {
    padding: 18px 20px;
    border: 1px solid var(--border);
    border-radius: 22px;
    background: color-mix(in srgb, var(--surface) 92%, transparent);
}

.admin-click-card,
.admin-panel-link,
.admin-ranking-row--link {
    color: inherit;
    text-decoration: none;
    cursor: pointer;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}

.admin-click-card:hover,
.admin-panel-link:hover,
.admin-ranking-row--link:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
    box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
}

.admin-click-card:focus-visible,
.admin-panel-link:focus-visible,
.admin-ranking-row--link:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--accent) 28%, white);
    outline-offset: 3px;
}

.admin-dashboard .coach-metric-card strong {
    color: var(--text-primary);
}

.admin-dashboard .coach-metric-card span {
    color: var(--text-secondary);
}

.admin-mini-card span {
    display: block;
    color: var(--text-muted);
    font-size: 13px;
}

.admin-mini-card strong {
    display: block;
    margin-top: 8px;
    color: var(--text-primary);
    font-size: 26px;
    line-height: 1.05;
}

.admin-ranking-panel {
    margin-top: 20px;
}

.admin-ranking-list {
    display: grid;
    gap: 10px;
}

.admin-ranking-row {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 16px;
    border: 1px solid var(--border);
    border-radius: 16px;
    background: color-mix(in srgb, var(--surface-2) 76%, transparent);
}

.admin-ranking-row span {
    color: var(--text-secondary);
}

.admin-ranking-row strong {
    color: var(--text-primary);
}

.admin-economy-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(280px, 0.7fr);
    gap: 20px;
    align-items: start;
    min-width: 0;
}

.admin-agreement-panel {
    display: grid;
    gap: 18px;
    min-width: 0;
}

.admin-agreement-head p,
.admin-empty,
.admin-empty-cell {
    color: var(--text-muted);
}

.admin-agreement-head p {
    margin: -4px 0 18px;
}

.admin-agreement-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.admin-agreement-summary-card {
    display: grid;
    gap: 8px;
    padding: 14px 16px;
    border: 1px solid color-mix(in srgb, var(--border) 84%, transparent);
    border-radius: 16px;
    background: color-mix(in srgb, var(--surface-2) 72%, transparent);
}

.admin-agreement-summary-card span {
    color: var(--text-secondary);
    font-size: 13px;
}

.admin-agreement-summary-card strong {
    color: var(--text-primary);
    font-size: 18px;
}

.admin-agreement-table-wrap {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    overflow-x: auto;
}

.admin-agreement-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 1020px;
}

.admin-agreement-table th,
.admin-agreement-table td {
    padding: 12px 10px;
    border-bottom: 1px solid var(--border);
    text-align: left;
    vertical-align: middle;
    white-space: nowrap;
}

.admin-agreement-table th {
    color: var(--text-muted);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.admin-share-form {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.admin-share-form input {
    width: 84px;
    padding: 8px 10px;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: var(--surface);
    color: var(--text-primary);
}

.admin-share-form button,
.admin-inline-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 12px;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: var(--surface-2);
    color: var(--text-primary);
    font-weight: 700;
    text-decoration: none;
}

.admin-share-form button {
    cursor: pointer;
}

.admin-empty-cell {
    text-align: center;
}

.admin-trends-panel {
    margin-top: 20px;
    padding: 20px 24px;
}

.admin-trends-grid {
    margin-top: 0;
}

.admin-trend-card {
    padding: 18px 18px 16px;
    border: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
    border-radius: 20px;
    background: color-mix(in srgb, var(--surface-2) 66%, transparent);
    box-shadow: none;
}

.admin-compact-chart {
    min-height: 180px;
}

.admin-compact-chart svg {
    display: block;
    width: 100%;
    height: auto;
}

@media (max-width: 1180px) {
    .admin-economy-grid,
    .admin-dashboard-mini-grid {
        grid-template-columns: 1fr;
    }

    .admin-agreement-summary {
        grid-template-columns: 1fr;
    }
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.tags-page {
    display: grid;
    gap: 22px;
    width: 100%;
}

.tags-hero {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 320px) auto;
    align-items: end;
    gap: 20px;
    min-height: 220px;
    padding: 28px;
    border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
    border-radius: 24px;
    overflow: hidden;
    background:
        linear-gradient(120deg, rgba(21, 56, 43, 0.88), rgba(18, 31, 41, 0.78)),
        url("https://images.unsplash.com/photo-1535131749006-b7f58c99034b?auto=format&fit=crop&w=1600&q=80");
    background-position: center;
    background-size: cover;
    box-shadow: var(--shadow-soft);
}

.tags-hero > * {
    position: relative;
    z-index: 1;
}

.tags-hero h1 {
    margin: 10px 0 0;
    color: #fff;
    font-size: 48px;
    line-height: 1;
    letter-spacing: 0;
}

.tags-hero p {
    max-width: 620px;
    margin: 14px 0 0;
    color: rgba(248, 251, 247, 0.78);
    font-size: 16px;
    line-height: 1.6;
}

.tags-hero-card {
    display: grid;
    gap: 8px;
    padding: 20px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 18px;
    background: rgba(9, 18, 27, 0.58);
    color: #fff;
    backdrop-filter: blur(18px);
}

.tags-hero-card span {
    color: rgba(248, 251, 247, 0.72);
    font-size: 13px;
    font-weight: 800;
}

.tags-hero-card strong {
    font-size: 42px;
    line-height: 1;
}

.tags-hero-card p {
    margin: 0;
    color: rgba(248, 251, 247, 0.68);
    font-size: 13px;
}

.tags-hero-action {
    align-self: start;
    background: rgba(255, 255, 255, 0.9);
    color: #0b1720;
}

.tags-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    min-width: 0;
    margin-bottom: 24px;
}

.tags-header > div {
    min-width: 0;
}

.tags-header .admin-row-actions,
.tags-header [class$="-actions"] {
    flex: 0 1 auto;
}

.tags-header h1,
.tag-form-page h1 {
    margin: 0;
    color: #d9dee7;
    font-size: 24px;
    font-weight: 750;
}

.tag-new-button,
.primary-action {
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 46px;
    padding: 0 20px;
    border: 0;
    border-radius: 12px;
    background: #22b864;
    color: #031108;
    cursor: pointer;
    font-size: 15px;
    font-weight: 750;
    text-decoration: none;
}

.tag-new-button span:first-child {
    font-size: 24px;
    font-weight: 400;
    line-height: 1;
}

.tag-search-form {
    position: relative;
    margin-bottom: 0;
}

.tag-search-form + .admin-list,
.tag-search-form + .tag-list,
.tag-search-form + .recipe-list {
    margin-top: 20px;
}

.module-filter-tabs a {
    background: var(--surface);
    transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.group-program-name {
    display: block;
    margin-bottom: 12px;
    color: var(--text-primary);
    font-size: 28px;
    font-weight: 800;
    letter-spacing: -0.03em;
}

.groups-member-pool-scroll {
    max-height: 980px;
    padding-right: 6px;
    overflow-y: auto;
}

.groups-member-pool-scroll::-webkit-scrollbar {
    width: 10px;
}

.groups-member-pool-scroll::-webkit-scrollbar-thumb {
    border: 2px solid transparent;
    border-radius: 999px;
    background: var(--surface-3);
    background-clip: padding-box;
}

.active-groups-panel {
    align-self: start;
    position: sticky;
    top: 18px;
}

.active-groups-list {
    display: grid;
}

.active-group-card {
    display: grid;
    border: 1px solid var(--border);
    color: inherit;
    text-decoration: none;
    cursor: pointer;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.active-group-card:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--accent) 42%, var(--border));
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--accent) 13%, transparent), transparent 56%),
        var(--surface-2);
}

.active-group-card:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--accent) 32%, white);
    outline-offset: 3px;
    border-color: color-mix(in srgb, var(--accent) 42%, var(--border));
}

.active-group-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.active-group-meta {
    display: flex;
    flex-wrap: wrap;
}

.active-group-footer {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    border-top: 1px solid var(--border);
    color: var(--text-muted);
    font-size: 13px;
}

.active-group-footer strong {
    color: var(--text-primary);
}

.active-group-footer-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.active-group-footer-actions form {
    margin: 0;
}

.panel-disclosure {
    overflow: hidden;
}

.panel-disclosure-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    cursor: pointer;
    list-style: none;
}

.panel-disclosure-summary::-webkit-details-marker {
    display: none;
}

.panel-disclosure-copy {
    display: grid;
    gap: 6px;
}

.panel-disclosure-copy strong {
    color: var(--text-primary);
    font-size: 22px;
}

.panel-disclosure-copy small {
    color: var(--text-muted);
    font-size: 14px;
    line-height: 1.5;
}

.panel-disclosure-action {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--accent);
    font-size: 14px;
    font-weight: 700;
    white-space: nowrap;
}

.panel-disclosure-action::before {
    content: "";
    width: 10px;
    height: 10px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg);
    transition: transform 0.18s ease;
}

.panel-disclosure[open] .panel-disclosure-action::before {
    transform: rotate(225deg);
}

.panel-disclosure-body {
    margin-top: 18px;
}

.groups-quick-create-form {
    display: grid;
    gap: 18px;
}

.groups-logic-redirect-note {
    margin: 0;
    color: var(--text-muted);
    line-height: 1.6;
}

.groups-quick-create-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.group-bulk-assign-form {
    display: grid;
    gap: 16px;
}

.group-bulk-toolbar {
    display: flex;
    align-items: center;
    border: 1px solid var(--border);
}

.group-member-filter-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) repeat(2, minmax(132px, 0.48fr)) auto;
    gap: 12px;
    align-items: end;
}

.group-member-filter-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    align-self: end;
}

.group-member-filter-grid .form-field {
    margin: 0;
}

.group-member-filter-grid .form-field--inline-placeholder {
    gap: 0;
}

.group-member-filter-grid .form-field input[type="search"],
.group-member-filter-grid .form-field input[type="number"] {
    min-height: 48px;
    border-radius: 18px;
    padding: 0 18px;
    border-color: var(--border);
    background: color-mix(in srgb, var(--surface-2) 88%, #000 12%);
    color: var(--text-primary);
    font-weight: 650;
}

.group-member-filter-grid .form-field input::placeholder {
    color: var(--text-muted);
    opacity: 1;
}

.group-member-filter-grid .form-field input:hover {
    border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
    background: color-mix(in srgb, var(--surface-2) 94%, var(--accent) 6%);
}

.group-member-filter-grid .form-field input:focus {
    border-color: color-mix(in srgb, var(--accent) 64%, var(--border));
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent);
}

.group-member-filter-actions .secondary-action,
.group-member-filter-actions .ghost-action,
.group-bulk-toolbar .secondary-action,
.group-bulk-toolbar .smooth-select select {
    min-height: 48px;
    border-radius: 18px;
    padding: 0 18px;
    font-weight: 750;
}

.group-member-filter-actions .ghost-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--surface-2) 72%, transparent);
    color: var(--text-muted);
    text-decoration: none;
    transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.group-member-filter-actions .ghost-action:hover {
    border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
    color: var(--text-primary);
    background: color-mix(in srgb, var(--surface-2) 90%, var(--accent) 10%);
}

.group-select-all {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--text-primary);
    font-weight: 700;
}

.group-select-all input {
    width: 18px;
    height: 18px;
    accent-color: var(--accent);
}

.group-bulk-toolbar .smooth-select {
    flex: 1 1 240px;
}

.group-bulk-toolbar .secondary-action {
    flex-shrink: 0;
}

.selectable-member-card {
    position: relative;
    transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease;
}

.selectable-member-card:hover {
    border-color: color-mix(in srgb, var(--accent) 34%, var(--border));
    background: color-mix(in srgb, var(--surface-2) 92%, var(--accent) 8%);
}

.selectable-member-card:has(.member-select-checkbox:checked) {
    border-color: color-mix(in srgb, var(--accent) 62%, var(--border));
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 14%, transparent), var(--surface-2) 62%);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 10%, transparent);
}

.member-select-control {
    position: absolute;
    top: 22px;
    right: 22px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--text-muted);
    font-size: 12px;
    font-weight: 800;
    cursor: pointer;
}

.member-select-checkbox {
    width: 22px;
    height: 22px;
    accent-color: var(--accent);
    cursor: pointer;
}

.group-member-form .smooth-select {
    min-width: 220px;
    flex: 1 1 220px;
}

.smooth-select {
    position: relative;
}

.smooth-select::after {
    content: "";
    position: absolute;
    right: 16px;
    top: 50%;
    width: 9px;
    height: 9px;
    border-right: 2px solid var(--accent);
    border-bottom: 2px solid var(--accent);
    pointer-events: none;
    transform: translateY(-64%) rotate(45deg);
}

.smooth-select select,
.group-member-form select {
    width: 100%;
    min-height: 46px;
    padding: 0 44px 0 16px;
    border: 1px solid var(--border);
    border-radius: 16px;
    appearance: none;
    background: color-mix(in srgb, var(--surface-2) 88%, #000 12%);
    color: var(--text-primary);
    font: inherit;
    font-weight: 750;
    outline: none;
    transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}

.smooth-select select:hover,
.group-member-form select:hover {
    border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
    background: color-mix(in srgb, var(--surface-2) 94%, var(--accent) 6%);
}

.smooth-select select:focus,
.group-member-form select:focus {
    border-color: color-mix(in srgb, var(--accent) 64%, var(--border));
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent);
}

.smooth-select option,
.group-member-form option {
    background: #132230;
    color: #f5fbff;
}

.groups-member-segments {
    margin-top: 10px;
}

.module-filter-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 0 0 18px;
}

.module-filter-tabs a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 16px;
    border: 1px solid #202936;
    border-radius: 999px;
    color: var(--text-muted);
    font-size: 14px;
    font-weight: 750;
    text-decoration: none;
}

.module-filter-tabs a.is-active {
    border-color: var(--accent);
    color: var(--text-main);
    background: rgba(46, 204, 113, 0.12);
}

.groups-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.groups-section-head h2 {
    margin: 0 0 6px;
}

.groups-section-head p {
    margin: 0;
    color: var(--text-muted);
}

.groups-program-grid,
.groups-member-pool {
    display: grid;
    gap: 16px;
}

.member-card-compact {
    display: grid;
    gap: 16px;
}

.group-member-form {
    flex-wrap: wrap;
}

.group-member-form select {
    min-width: 220px;
    flex: 1 1 220px;
}

.groups-head-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.groups-member-list {
    display: grid;
    gap: 12px;
    margin-top: 16px;
}

.groups-member-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    padding: 14px 16px;
    border: 1px solid var(--border, #2e4052);
    border-radius: 14px;
    background: var(--surface-2, #152330);
}

.groups-member-row p {
    margin: 4px 0 0;
    color: var(--text-muted);
}

.groups-member-actions {
    display: grid;
    gap: 10px;
    justify-items: end;
}

.tag-search-form input {
    width: 100%;
    height: 58px;
    padding: 0 20px 0 52px;
    border: 1px solid var(--border);
    border-radius: 18px;
    outline: none;
    background: var(--surface);
    color: var(--text-primary);
    font-size: 16px;
    box-shadow: var(--shadow-soft);
}

.tag-search-form input::placeholder {
    color: #7d8796;
}

.tag-search-form input:focus {
    border-color: color-mix(in srgb, var(--accent) 52%, var(--border));
}

.tag-search-icon {
    position: absolute;
    top: 50%;
    left: 18px;
    width: 22px;
    height: 22px;
    transform: translateY(-50%);
    fill: none;
    stroke: #7d8796;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
}

.payment-filter-form {
    display: grid;
    grid-template-columns: minmax(220px, 1.5fr) minmax(180px, 1fr) auto;
    gap: 12px;
    align-items: end;
    min-width: 0;
    margin-bottom: 18px;
    padding: 14px;
    border: 1px solid #202936;
    border-radius: 12px;
    background: #10151d;
}

.payment-filter-form .form-field {
    margin: 0;
}

.payment-filter-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
    min-width: 0;
}

.free-access-page {
    max-width: 1180px;
}

.payment-access-page {
    max-width: 1180px;
}

.payment-access-filter {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 0.8fr) minmax(0, 0.8fr) auto;
    padding: 14px;
    border-color: color-mix(in srgb, var(--border) 88%, var(--accent));
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--accent) 7%, transparent), transparent 42%),
        var(--surface);
    box-shadow: var(--shadow-soft);
}

.payment-access-search-control {
    position: relative;
}

.payment-access-filter .payment-access-search-control svg {
    position: absolute;
    top: 50%;
    left: 16px;
    width: 20px;
    height: 20px;
    transform: translateY(-50%);
    fill: none;
    stroke: var(--text-muted);
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
}

.payment-access-filter .payment-access-search-control input[type="search"] {
    width: 100%;
    min-height: 44px;
    padding-left: 46px;
}

.free-access-filter {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 0.8fr) minmax(0, 0.8fr) auto;
    padding: 14px;
    border-color: color-mix(in srgb, var(--border) 88%, var(--accent));
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--accent) 7%, transparent), transparent 42%),
        var(--surface);
    box-shadow: var(--shadow-soft);
}

.free-access-search-control {
    position: relative;
}

.free-access-filter .free-access-search-control svg {
    position: absolute;
    top: 50%;
    left: 16px;
    width: 20px;
    height: 20px;
    transform: translateY(-50%);
    fill: none;
    stroke: var(--text-muted);
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
}

.free-access-filter .free-access-search-control input[type="search"] {
    width: 100%;
    min-height: 44px;
    padding-left: 46px;
}

.free-access-page .dashboard-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    min-width: 0;
}

.free-access-page .metric-card {
    gap: 8px;
    min-height: 78px;
    padding: 14px 16px;
    border-radius: 12px;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--surface-2) 52%, transparent), transparent 70%),
        var(--surface);
}

.free-access-list {
    gap: 12px;
}

.free-access-row {
    --free-access-status-color: var(--accent);
    --free-access-status-bg: var(--accent-soft);
    align-items: flex-start;
    position: relative;
    padding: 20px 22px;
    overflow: hidden;
    border-radius: 14px;
    background: var(--surface);
    box-shadow: inset 4px 0 0 var(--free-access-status-color);
}

.free-access-row--over-limit,
.free-access-row--no-payment {
    --free-access-status-color: var(--danger);
    --free-access-status-bg: color-mix(in srgb, var(--danger) 13%, transparent);
}

.free-access-row--expiring {
    --free-access-status-color: var(--warning);
    --free-access-status-bg: color-mix(in srgb, var(--warning) 15%, transparent);
}

.free-access-row--active-trial {
    --free-access-status-color: var(--success);
    --free-access-status-bg: color-mix(in srgb, var(--success) 14%, transparent);
}

.free-access-row--zero-price {
    --free-access-status-color: var(--accent-strong);
    --free-access-status-bg: color-mix(in srgb, var(--accent) 12%, transparent);
}

.free-access-row .admin-row-main {
    flex: 1 1 auto;
    width: 100%;
    gap: 16px;
}

.free-access-member-line {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.free-access-member-identity {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.free-access-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 44px;
    width: 44px;
    height: 44px;
    border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--border));
    border-radius: 12px;
    background: color-mix(in srgb, var(--accent-soft) 86%, var(--surface));
    color: var(--accent-strong);
    font-size: 15px;
    font-weight: 850;
}

.free-access-member-copy {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.admin-row-main .free-access-member-copy strong {
    font-size: 17px;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.admin-row-main .free-access-member-copy span {
    overflow-wrap: anywhere;
}

.free-access-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    min-height: 32px;
    padding: 0 11px;
    border: 1px solid color-mix(in srgb, var(--free-access-status-color) 54%, transparent);
    border-radius: 999px;
    background: var(--free-access-status-bg);
    color: var(--free-access-status-color);
    font-size: 12px;
    font-weight: 850;
    line-height: 1;
    white-space: nowrap;
}

.free-access-detail-grid {
    display: grid;
    grid-template-columns: minmax(220px, 1.2fr) minmax(140px, 0.65fr) minmax(140px, 0.65fr) minmax(220px, 1fr);
    gap: 16px 18px;
    padding-top: 16px;
    border-top: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
}

.free-access-detail {
    display: grid;
    align-content: start;
    gap: 4px;
    min-width: 0;
}

.admin-row-main .free-access-detail span {
    color: var(--text-muted);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0;
    text-transform: uppercase;
}

.admin-row-main .free-access-detail strong {
    color: var(--text-primary);
    font-size: 15px;
    line-height: 1.3;
    overflow-wrap: anywhere;
}

.free-access-detail small {
    color: var(--text-muted);
    font-size: 13px;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.free-access-payment-state {
    font-weight: 750;
}

.free-access-payment-state--has-payment {
    color: var(--success);
}

.free-access-payment-state--missing-payment {
    color: var(--danger);
}

.free-access-row .admin-row-actions {
    align-content: flex-start;
    gap: 8px;
    min-width: 188px;
}

.free-access-row .secondary-action,
.free-access-row .danger-action {
    min-height: 36px;
}

.free-access-row-form {
    margin: 0;
}

.tag-list {
    display: grid;
    gap: 0;
    overflow: hidden;
    border: 1px solid #eceee8;
    border-radius: 0;
    background: #ffffff;
    box-shadow: none;
}

.tag-list-head {
    display: grid;
    grid-template-columns: minmax(280px, 1.5fr) minmax(150px, 0.8fr) minmax(150px, 0.8fr) 104px;
    align-items: center;
    min-height: 60px;
    padding: 0 24px 0 54px;
    border-bottom: 1px solid #eceee8;
    color: #75827b;
    font-size: 13px;
    font-weight: 800;
}

.tag-row {
    display: grid;
    grid-template-columns: minmax(280px, 1.5fr) minmax(150px, 0.8fr) minmax(150px, 0.8fr) 104px;
    align-items: center;
    gap: 0;
    min-height: 82px;
    padding: 14px 24px 14px 54px;
    border: 0;
    border-bottom: 1px solid #eceee8;
    border-radius: 0;
    background: #ffffff;
    box-shadow: none;
    transition: background-color 0.18s ease;
}

.tag-row:hover {
    background: #fbfcf9;
}

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

.tag-row-main,
.tag-row-actions,
.tag-row-copy {
    display: flex;
    align-items: center;
}

.tag-row-main {
    flex: 1 1 auto;
    min-width: 0;
    gap: 14px;
}

.tag-row-preview {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border: 0;
    border-radius: 16px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--tag-row-color, #d7ddd8) 16%, #eef1f6), #e4e0dc);
    box-shadow: none;
    flex: 0 0 auto;
}

.tag-row-icon,
.icon-button svg {
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
}

.tag-row-icon {
    position: absolute;
    top: 10px;
    left: 10px;
    width: 18px;
    height: 18px;
    color: color-mix(in srgb, var(--accent) 60%, var(--text-muted));
    opacity: 0.9;
}

.tag-color-dot {
    width: 18px;
    height: 18px;
    border-radius: 999px;
    box-shadow: 0 0 0 6px rgba(255, 255, 255, 0.48);
    flex: 0 0 auto;
}

.tag-color-dot-image {
    border-radius: 16px;
    object-fit: cover;
}

.tag-row-copy {
    min-width: 0;
    display: grid;
    gap: 4px;
    align-items: center;
}

.tag-row-copy-head {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px 12px;
    width: 100%;
}

.tag-row-copy strong {
    color: #20322b;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.2;
}

.tag-row-copy span {
    color: #7d8781;
    font-size: 13px;
    line-height: 1.3;
}

.tag-row-usage,
.tag-row-module {
    color: #213044;
    font-size: 14px;
}

.tag-row-usage {
    display: inline-flex;
    width: fit-content;
    min-height: 30px;
    align-items: center;
    padding: 0 10px;
    border-radius: 999px;
    background: #fff1e7;
    color: #d97917;
    font-size: 12px;
    font-weight: 800;
}

.tag-row-actions {
    justify-content: flex-end;
    gap: 8px;
    flex: 0 0 auto;
}

.tag-row-availability {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--accent) 14%, white);
    color: var(--accent);
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0.01em;
}

.library-tag-overview {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    margin-bottom: 1rem;
}

.library-tag-usage-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.library-tag-usage-list span {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-2) 76%, white);
    color: var(--text-muted);
    font-size: 0.84rem;
    font-weight: 700;
    padding: 0 0.8rem;
}

.icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    border: 1px solid color-mix(in srgb, var(--border) 92%, white);
    background: color-mix(in srgb, var(--surface) 96%, white);
    border-radius: 14px;
    color: var(--text-muted);
    cursor: pointer;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.icon-button:hover {
    transform: translateY(-1px);
    background: var(--surface-2);
    border-color: color-mix(in srgb, var(--accent) 26%, var(--border));
    color: var(--text-primary);
}

.icon-button.danger {
    color: #ef4444;
}

.icon-button svg {
    width: 30px;
    height: 30px;
}

.tag-form-panel {
    border: 1px solid var(--border);
    border-radius: 20px;
    background: var(--surface);
}

.ui-empty-state {
    border: 1px dashed var(--border);
    border-radius: 12px;
    background: color-mix(in srgb, var(--surface) 84%, transparent);
    padding: 18px 20px;
    color: #7d8796;
    font-size: 14px;
    line-height: 1.45;
}

.simple-pagination {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 14px;
}

.simple-pagination a,
.secondary-action {
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid #2ecc71;
    border-radius: 9px;
    color: #2ecc71;
    text-decoration: none;
    font-size: 13px;
    font-weight: 700;
}

.simple-pagination a {
    min-width: 34px;
}

.simple-pagination svg {
    width: 14px;
    height: 14px;
}

.tag-form-page {
    max-width: 760px;
}

.tag-form-page h1 {
    margin-bottom: 18px;
}

.tag-form-panel {
    padding: 18px;
}

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

.form-field {
    display: grid;
    gap: 8px;
}

.form-field label {
    color: #d9dee7;
    font-weight: 700;
}

.form-field input[type="text"] {
    width: 100%;
    box-sizing: border-box;
    min-height: 50px;
    padding: 0 16px;
    border: 1px solid #202936;
    border-radius: 12px;
    outline: none;
    background: #151a22;
    color: #e5e7eb;
    font-size: 15px;
}

.form-field input[type="text"]:focus {
    border-color: #2ecc71;
}

.color-choice-list {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.color-choice {
    position: relative;
    display: inline-flex;
}

.color-choice input {
    position: absolute;
    opacity: 0;
}

.color-choice span {
    display: block;
    width: 34px;
    height: 34px;
    border: 2px solid transparent;
    border-radius: 999px;
    background: var(--tag-choice-color);
    cursor: pointer;
}

.color-choice input:checked + span {
    border-color: #fff;
    box-shadow: 0 0 0 2px rgba(46, 204, 113, 0.35);
}

.form-actions-row {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    margin-top: 20px;
}

.form-errors {
    margin-bottom: 18px;
    padding: 14px 16px;
    border: 1px solid rgba(239, 68, 68, 0.35);
    border-radius: 12px;
    background: rgba(239, 68, 68, 0.12);
    color: #fecaca;
}

.admin-page {
    width: 100%;
    min-width: 0;
    max-width: 1240px;
}

.admin-page > h1 {
    margin: 0 0 24px;
    color: #d9dee7;
    font-size: 24px;
}

.page-subtitle {
    margin: 6px 0 0;
    color: #7d8796;
    font-size: 14px;
}

.admin-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.admin-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    min-height: 82px;
    padding: 18px 22px;
    border: 1px solid #202936;
    border-radius: 16px;
    background: #10151d;
}

.admin-row-main {
    display: grid;
    gap: 8px;
    min-width: 0;
}

.admin-row-main strong {
    color: #d9dee7;
    font-size: 18px;
}

.admin-row-main span {
    color: #7d8796;
    font-size: 14px;
}

.admin-row.package-provider-missing-row {
    border-color: color-mix(in srgb, var(--danger) 72%, var(--border));
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--danger) 18%, transparent), transparent 56%),
        var(--surface);
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--danger) 20%, transparent),
        0 18px 42px color-mix(in srgb, var(--danger) 18%, transparent);
}

.admin-row-main .package-provider-status {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    min-height: 32px;
    padding: 6px 11px;
    border: 1px solid currentColor;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 800;
    line-height: 1;
}

.admin-row-main .package-provider-status--ready {
    color: var(--success);
    background: color-mix(in srgb, var(--success) 12%, transparent);
}

.admin-row-main .package-provider-status--missing {
    color: var(--danger);
    background: color-mix(in srgb, var(--danger) 16%, transparent);
    text-transform: uppercase;
}

.package-provider-status__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: var(--danger);
    color: var(--accent-contrast);
    font-size: 12px;
    font-weight: 900;
}

.admin-row-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    flex-wrap: wrap;
}

.admin-payments-results-scroll {
    max-height: 520px;
    overflow-y: auto;
    padding-right: 6px;
}

.admin-payments-results-scroll::-webkit-scrollbar {
    width: 10px;
}

.admin-payments-results-scroll::-webkit-scrollbar-thumb {
    border: 2px solid transparent;
    border-radius: 999px;
    background: var(--surface-3);
    background-clip: padding-box;
}

.row-menu {
    position: relative;
}

.row-menu summary {
    list-style: none;
}

.row-menu summary::-webkit-details-marker {
    display: none;
}

.row-menu[open] .row-menu-trigger {
    border-color: #2ecc71;
    color: #fff;
}

.row-menu-panel {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    z-index: 5;
    display: grid;
    gap: 6px;
    min-width: 190px;
    padding: 8px;
    border: 1px solid #202936;
    border-radius: 14px;
    background: #111827;
    box-shadow: 0 18px 44px rgba(3, 7, 10, 0.38);
}

.row-menu-link {
    display: flex;
    align-items: center;
    min-height: 38px;
    padding: 0 12px;
    border-radius: 10px;
    text-decoration: none;
    font-size: 14px;
}

.row-menu-link:hover {
    color: #fff;
}

.danger-action {
    border-color: #ef4444;
    color: #ef4444;
    background: transparent;
    cursor: pointer;
    font-size: 14px;
}

.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    margin-bottom: 18px;
}

.metric-card,
.detail-panel {
    border: 1px solid #202936;
    border-radius: 18px;
    background: #10151d;
}

.metric-card {
    display: grid;
    gap: 8px;
    min-height: 76px;
    padding: 14px 16px;
}

.metric-card span,
.detail-list dt {
    color: #7d8796;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
}

.metric-card strong {
    color: #d9dee7;
    font-size: 22px;
    overflow-wrap: anywhere;
}

.detail-panel {
    padding: 22px;
}

.admin-user-show-page .detail-panel + .detail-panel {
    margin-top: 20px;
}

.detail-panel h2,
.admin-form-grid h2 {
    margin: 0 0 18px;
    color: #d9dee7;
    font-size: 16px;
}

.detail-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px 28px;
    margin: 0;
}

.detail-list div {
    display: grid;
    gap: 6px;
}

.detail-list dd {
    margin: 0;
    color: #d9dee7;
    font-size: 15px;
}

.organization-form-panel {
    max-width: 1100px;
}

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

.admin-form-grid section {
    display: grid;
    align-content: start;
    gap: 16px;
}

.form-field input[type="date"],
.form-field input[type="datetime-local"],
.form-field input[type="email"],
.form-field input[type="file"],
.form-field input[type="number"],
.form-field input[type="password"],
.form-field input[type="search"],
.form-field input[type="text"],
.form-field select,
.form-field textarea {
    width: 100%;
    box-sizing: border-box;
    min-height: 44px;
    padding: 0 14px;
    border: 1px solid #202936;
    border-radius: 10px;
    outline: none;
    background: #151a22;
    color: #e5e7eb;
    font-size: 15px;
}

.form-field textarea {
    min-height: 120px;
    padding-top: 10px;
    resize: vertical;
}

.form-field input[type="file"] {
    padding: 12px 16px;
}

.form-field input:disabled {
    opacity: 0.7;
}

.form-field input[type="email"]:focus,
.form-field input[type="file"]:focus,
.form-field input[type="number"]:focus,
.form-field input[type="password"]:focus,
.form-field input[type="search"]:focus,
.form-field input[type="text"]:focus,
.form-field select:focus,
.form-field textarea:focus {
    border-color: #2ecc71;
}

.checkbox-field {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #d9dee7;
    font-weight: 700;
}

.checkbox-field input {
    width: 18px;
    height: 18px;
}

.profile-page {
    display: grid;
    gap: 24px;
}

.profile-page-header {
    display: flex;
    justify-content: space-between;
    align-items: start;
    gap: 20px;
}

.profile-page-header h1 {
    margin: 0;
    color: #173f31;
    font-size: 66px;
    line-height: 0.95;
    letter-spacing: -0.04em;
    font-weight: 600;
}

.profile-save-button {
    min-height: 52px;
    padding: 0 22px;
    border: 0;
    border-radius: 14px;
    background: linear-gradient(135deg, #0c4c37 0%, #15593e 100%);
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    box-shadow: 0 18px 34px -24px rgba(12, 76, 55, 0.6);
    cursor: pointer;
}

.profile-panel {
    border: 1px solid #d8e1ef;
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 250, 255, 0.98) 100%);
    box-shadow: 0 28px 60px -40px rgba(26, 44, 74, 0.3);
}

.profile-picture-preview-image,
.profile-picture-preview-fallback {
    width: 164px;
    height: 164px;
    border-radius: 999px;
}

.profile-picture-preview-image {
    display: block;
    object-fit: cover;
    border: 4px solid rgba(255, 255, 255, 0.9);
    box-shadow: 0 22px 46px -28px rgba(19, 63, 49, 0.45);
}

.profile-picture-preview-fallback {
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.8), transparent 38%),
        linear-gradient(135deg, #0f4f3a 0%, #175b43 100%);
    color: #fff;
    font-size: 46px;
    font-weight: 600;
    letter-spacing: 0.08em;
    box-shadow: 0 22px 46px -28px rgba(19, 63, 49, 0.45);
}

.profile-picture-preview-fallback {
    align-content: center;
    gap: 6px;
    text-align: center;
}

.profile-picture-preview-fallback small {
    width: 90px;
    color: rgba(255, 255, 255, 0.9);
    font-size: 12px;
    line-height: 1.3;
    letter-spacing: 0;
}

.profile-chip.soft {
    background: #f5f8fc;
}

.profile-panel {
    padding: 24px;
    display: grid;
    gap: 20px;
}

.profile-setting-value {
    display: flex;
    justify-content: flex-end;
}

.profile-setting-value {
    color: #5f6c65;
    font-weight: 700;
}

.profile-picture-preview {
    display: flex;
    justify-content: center;
    padding: 8px 0 4px;
}

html:not([data-theme="dark"]) .profile-panel {
    border-color: #d9e3f0;
    background: linear-gradient(180deg, #ffffff 0%, #f7f9fc 100%);
}

html:not([data-theme="dark"]) .profile-page-header h1 {
    color: #173f31;
}

@media (max-width: 720px) {
    .profile-page-header,
    .profile-panel {
        grid-template-columns: 1fr;
    }

    .profile-page-header {
        flex-direction: column;
        align-items: stretch;
    }

    .profile-save-button,
    .profile-save-row .secondary-action,
    .profile-save-row .primary-action,
    .profile-picture-actions .primary-action {
        width: 100%;
        justify-content: center;
    }

    .profile-page-header h1 {
        font-size: 48px;
    }

    .profile-setting-value {
        justify-content: flex-start;
    }
}

.profile-page--reference {
    position: relative;
}

.profile-page--reference::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.28;
    background-image:
        radial-gradient(circle at 24px 24px, rgba(0, 0, 0, 0.03) 1.2px, transparent 1.3px),
        radial-gradient(circle at 0 0, transparent 16px, rgba(0, 0, 0, 0.02) 16.2px, transparent 17px);
    background-size: 44px 44px, 120px 120px;
}

.profile-page--reference > * {
    position: relative;
    z-index: 1;
}

.profile-page--reference .page-subtitle {
    margin-top: 8px;
}

.profile-page--reference .profile-settings-form,
.profile-page--reference .profile-bottom-grid {
    display: grid;
    gap: 24px;
}

.profile-page--reference .profile-top-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(380px, 0.9fr);
    gap: 24px;
}

.profile-page--reference .profile-bottom-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.profile-page--reference .profile-panel--soft {
    min-height: 320px;
}

.profile-page--reference .profile-panel--stacked {
    gap: 0;
}

.profile-page--reference .profile-card-title {
    margin-bottom: 18px;
}

.profile-page--reference .profile-card-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background: #f3f4eb;
    color: #6f8577;
    flex: 0 0 auto;
}

.profile-page--reference .profile-card-icon svg {
    width: 20px;
    height: 20px;
}

.profile-page--reference .profile-inline-field input,
.profile-page--reference .profile-setting-control input,
.profile-page--reference .profile-setting-control select {
    width: 100%;
    min-height: 40px;
    border: 1px solid #dfe3db;
    border-radius: 12px;
    background: #fff;
    color: #2d3b35;
    box-sizing: border-box;
    padding: 0 14px;
    font-size: 15px;
}

.profile-page--reference .profile-inline-field input[readonly] {
    color: #637069;
    background: #fbfbf8;
}

.profile-page--reference .profile-picture-stage {
    padding: 8px 0 0;
}

.profile-page--reference .profile-setting-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(180px, 0.9fr);
    gap: 18px;
    align-items: center;
    padding: 18px 0;
    border-top: 1px solid #ecece6;
}

.profile-page--reference .profile-setting-row:first-of-type {
    padding-top: 0;
    border-top: 0;
}

.profile-page--reference .profile-setting-row strong {
    color: #22322b;
    font-size: 16px;
    font-weight: 600;
}

.profile-page--reference .profile-setting-row p {
    margin: 6px 0 0;
    color: #8a938d;
    font-size: 14px;
}

.profile-page--reference .profile-setting-control,
.profile-page--reference .profile-setting-value {
    justify-content: flex-end;
}

.profile-page--reference .profile-setting-value {
    color: #4f5d56;
    font-size: 14px;
    font-weight: 700;
    text-align: right;
}

.profile-page--reference .profile-setting-row--stacked {
    align-items: start;
}

.profile-page--reference .profile-upload-actions {
    align-items: center;
}

.profile-page--reference .profile-picture-upload-form--inline {
    margin-top: 6px;
}

.profile-page--reference .profile-upload-button {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    border-radius: 12px;
    font-weight: 700;
    cursor: pointer;
}

.profile-page--reference .profile-upload-button--secondary {
    background: #fff;
    color: #44514b;
    border: 1px solid #d8ddd4;
}

.profile-page--reference .profile-picture-upload-form .secondary-action {
    min-height: 44px;
}

@media (max-width: 1100px) {
    .profile-page--reference .profile-top-grid,
    .profile-page--reference .profile-bottom-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {

    .profile-page--reference .profile-inline-field,
    .profile-page--reference .profile-setting-row {
        grid-template-columns: 1fr;
    }

    .profile-page--reference .profile-setting-value,
    .profile-page--reference .profile-setting-control {
        justify-content: flex-start;
        text-align: left;
    }

    .profile-page--reference .profile-save-button {
        width: 100%;
    }
}

.content-surface:has(.profile-page--reference) {
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.content-surface:has(.profile-page--reference)::before {
    display: none;
}

.profile-page--reference {
    --profile-ink: #17385f;
    --profile-muted: #536b89;
    --profile-line: #d9e3f0;
    --profile-panel: #ffffff;
    --profile-panel-soft: #f8fbff;
    --profile-blue: #315d9a;
    --profile-green: #0b6b4b;
    gap: 26px;
    min-height: calc(100vh - 60px);
    padding: 12px 18px 28px;
    background: #ffffff;
}

.profile-settings-anchor {
    margin: 0;
}

.profile-page--reference::before {
    display: none;
}

.profile-page--reference .profile-page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.profile-page--reference .profile-page-header h1 {
    margin: 0;
    color: var(--profile-ink);
    font-family: Georgia, "Times New Roman", serif;
    font-size: 46px;
    line-height: 1.02;
    letter-spacing: 0;
    font-weight: 700;
}

.profile-page--reference .page-subtitle {
    margin: 8px 0 0;
    color: var(--profile-muted);
    font-size: 15px;
    line-height: 1.45;
}

.profile-page--reference .profile-save-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 52px;
    padding: 0 22px;
    border: 0;
    border-radius: 8px;
    background: linear-gradient(135deg, #006044 0%, #0b7654 100%);
    color: #ffffff;
    font-size: 15px;
    font-weight: 800;
    box-shadow: 0 16px 30px rgba(5, 91, 66, 0.16);
}

.profile-page--reference .profile-save-button svg,
.profile-page--reference .profile-upload-button svg,
.profile-page--reference .profile-status-pill svg,
.profile-overview-check svg {
    width: 18px;
    height: 18px;
    flex: 0 0 auto;
}

.profile-dashboard-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
    grid-template-areas:
        "personal picture"
        "security preferences"
        "security overview";
    gap: 18px 24px;
    align-items: start;
}

.profile-page--reference .profile-panel {
    display: grid;
    gap: 20px;
    padding: 22px;
    border: 1px solid var(--profile-line);
    border-radius: 16px;
    background: linear-gradient(180deg, #ffffff 0%, var(--profile-panel-soft) 100%);
    box-shadow: 0 18px 44px rgba(31, 45, 61, 0.06);
}

.profile-panel--personal {
    grid-area: personal;
}

.profile-panel--picture {
    grid-area: picture;
}

.profile-panel--security {
    grid-area: security;
}

.profile-panel--preferences {
    grid-area: preferences;
}

.profile-panel--overview {
    grid-area: overview;
}

.profile-page--reference .profile-card-title {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin: 0;
}

.profile-page--reference .profile-card-title h2 {
    margin: 0;
    color: var(--profile-ink);
    font-family: Georgia, "Times New Roman", serif;
    font-size: 22px;
    line-height: 1.15;
    letter-spacing: 0;
    font-weight: 700;
}

.profile-page--reference .profile-card-title p {
    margin: 8px 0 0;
    color: var(--profile-muted);
    font-size: 14px;
    line-height: 1.4;
}

.profile-page--reference .profile-card-icon,
.profile-list-icon,
.profile-preference-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: #eef4fc;
    color: var(--profile-blue);
}

.profile-card-icon--green,
.profile-list-icon--success {
    background: #edf8ef;
    color: #18834f;
}

.profile-page--reference .profile-card-icon svg,
.profile-list-icon svg,
.profile-preference-icon svg {
    width: 22px;
    height: 22px;
}

.profile-page--reference .profile-field-list {
    display: grid;
    gap: 18px;
    padding-top: 8px;
}

.profile-page--reference .profile-inline-field {
    display: grid;
    grid-template-columns: 110px minmax(0, 1fr);
    align-items: center;
    gap: 18px;
}

.profile-page--reference .profile-inline-field label {
    color: var(--profile-ink);
    font-size: 15px;
    font-weight: 800;
}

.profile-page--reference .profile-readonly-label {
    color: var(--profile-ink);
    font-size: 15px;
    font-weight: 800;
}

.profile-page--reference .profile-readonly-value {
    display: flex;
    align-items: center;
    min-height: 48px;
    padding: 0 16px;
    border: 1px solid var(--profile-line);
    border-radius: 10px;
    background: var(--profile-panel-soft);
    color: var(--profile-ink);
    box-sizing: border-box;
    font-size: 15px;
    font-weight: 650;
}

.profile-page--reference input,
.profile-page--reference select {
    width: 100%;
    min-height: 48px;
    padding: 0 16px;
    border: 1px solid var(--profile-line);
    border-radius: 10px;
    background: #ffffff;
    color: var(--profile-ink);
    box-sizing: border-box;
    font: inherit;
    font-size: 15px;
    font-weight: 650;
}

.profile-page--reference select {
    appearance: auto;
}

.profile-page--reference input:focus,
.profile-page--reference select:focus {
    border-color: color-mix(in srgb, var(--profile-blue) 56%, var(--profile-line));
    box-shadow: 0 0 0 4px rgba(49, 93, 154, 0.08);
    outline: none;
}

.profile-page--reference select:disabled {
    color: var(--profile-ink);
    opacity: 1;
    background: #ffffff;
}

.profile-page--reference .profile-picture-stage {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 170px;
    padding-top: 8px;
}

.profile-page--reference .profile-picture-preview-image,
.profile-page--reference .profile-picture-preview-fallback {
    width: 140px;
    height: 140px;
    border-radius: 999px;
}

.profile-page--reference .profile-picture-preview-image {
    display: block;
    object-fit: cover;
    border: 4px solid #ffffff;
    box-shadow: 0 18px 36px rgba(6, 65, 48, 0.22);
}

.profile-page--reference .profile-picture-preview-fallback {
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at 34% 24%, rgba(255, 255, 255, 0.16), transparent 36%),
        linear-gradient(135deg, #006044 0%, #0b7654 100%);
    color: #ffffff;
    font-family: Georgia, "Times New Roman", serif;
    font-size: 56px;
    font-weight: 700;
    line-height: 1;
    box-shadow: 0 18px 36px rgba(6, 65, 48, 0.22);
}

.profile-page--reference .profile-picture-upload-form--inline {
    display: grid;
    justify-items: center;
    gap: 14px;
    margin: 0;
}

.profile-page--reference .profile-upload-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 14px;
}

.profile-page--reference .profile-upload-button,
.profile-picture-submit {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 48px;
    padding: 0 18px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 800;
    cursor: pointer;
}

.profile-page--reference .profile-upload-button {
    border: 0;
    background: linear-gradient(135deg, #006044 0%, #0b7654 100%);
    color: #ffffff;
    overflow: hidden;
}

.profile-page--reference .profile-upload-button input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}

.profile-page--reference .profile-upload-button--secondary,
.profile-picture-submit {
    border: 1px solid var(--profile-blue);
    background: #ffffff;
    color: var(--profile-ink);
}

.profile-picture-submit {
    min-height: 40px;
    padding: 0 14px;
}

.profile-page--reference .profile-picture-upload-form--inline .form-hint {
    margin: 0;
    color: var(--profile-muted);
    font-size: 13px;
    text-align: center;
}

.profile-list-card,
.profile-preference-list,
.profile-overview-strip {
    display: grid;
    overflow: hidden;
    border: 1px solid var(--profile-line);
    border-radius: 12px;
    background: #ffffff;
}

.profile-list-row,
.profile-preference-row,
.profile-overview-item {
    display: grid;
    align-items: center;
    gap: 14px;
    min-width: 0;
    min-height: 74px;
    padding: 12px;
}

.profile-list-row {
    grid-template-columns: 48px minmax(0, 1fr) minmax(140px, auto);
}

.profile-preference-row {
    grid-template-columns: 34px minmax(110px, 0.55fr) minmax(180px, 1fr);
}

.profile-list-row + .profile-list-row,
.profile-preference-row + .profile-preference-row,
.profile-overview-item + .profile-overview-item {
    border-top: 1px solid var(--profile-line);
}

.profile-list-row strong,
.profile-preference-row strong,
.profile-overview-item strong {
    display: block;
    color: var(--profile-ink);
    font-size: 15px;
    font-weight: 800;
}

.profile-list-row p,
.profile-overview-item p {
    margin: 4px 0 0;
    color: var(--profile-muted);
    font-size: 14px;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.profile-list-row input {
    min-height: 40px;
}

.profile-password-details {
    justify-self: end;
    display: grid;
    gap: 10px;
}

.profile-password-details summary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0 16px;
    border: 1px solid var(--profile-line);
    border-radius: 10px;
    background: #ffffff;
    color: var(--profile-ink);
    font-size: 14px;
    font-weight: 800;
    cursor: pointer;
    list-style: none;
}

.profile-password-details summary::-webkit-details-marker {
    display: none;
}

.profile-password-details input {
    min-width: 240px;
}

.profile-row-chevron,
.profile-setting-value {
    justify-self: end;
    color: var(--profile-muted);
    font-size: 14px;
    font-weight: 700;
    text-align: right;
}

.profile-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    background: #edf8ef;
    color: #18834f;
    font-size: 14px;
    font-weight: 800;
    white-space: nowrap;
}

.profile-preference-icon {
    width: 28px;
    height: 28px;
    border-radius: 8px;
    background: transparent;
    color: var(--profile-blue);
}

.profile-preference-icon svg {
    width: 21px;
    height: 21px;
}

.profile-overview-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.profile-overview-item {
    grid-template-columns: 48px minmax(0, 1fr) auto;
}

.profile-overview-item + .profile-overview-item {
    border-top: 0;
    border-left: 1px solid var(--profile-line);
}

.profile-overview-check {
    display: grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: #edf8ef;
    color: #18834f;
}

html[data-theme="dark"] .profile-page--reference {
    --profile-ink: #e6edf4;
    --profile-muted: #9fb1c5;
    --profile-line: #2c4054;
    --profile-panel-soft: #172434;
    --profile-blue: #93b6e8;
    background: #0f1720;
}

html[data-theme="dark"] .profile-page--reference .profile-panel,
html[data-theme="dark"] .profile-list-card,
html[data-theme="dark"] .profile-preference-list,
html[data-theme="dark"] .profile-overview-strip,
html[data-theme="dark"] .profile-page--reference input,
html[data-theme="dark"] .profile-page--reference select,
html[data-theme="dark"] .profile-page--reference select:disabled,
html[data-theme="dark"] .profile-page--reference .profile-readonly-value {
    background: #16212c;
}

html[data-theme="dark"] .profile-page--reference .profile-upload-button--secondary,
html[data-theme="dark"] .profile-picture-submit {
    background: #16212c;
    color: var(--profile-ink);
}

@media (max-width: 1240px) {
    .profile-dashboard-grid {
        grid-template-columns: 1fr;
        grid-template-areas:
            "personal"
            "picture"
            "security"
            "preferences"
            "overview";
    }

    .profile-overview-strip {
        grid-template-columns: 1fr;
    }

    .profile-overview-item + .profile-overview-item {
        border-top: 1px solid var(--profile-line);
        border-left: 0;
    }
}

@media (max-width: 720px) {
    .profile-page--reference {
        padding: 8px 0 20px;
    }

    .profile-page--reference .profile-page-header {
        flex-direction: column;
        align-items: stretch;
    }

    .profile-page--reference .profile-page-header h1 {
        font-size: 38px;
    }

    .profile-page--reference .profile-inline-field,
    .profile-list-row,
    .profile-preference-row,
    .profile-overview-item {
        grid-template-columns: 1fr;
    }

    .profile-row-chevron,
    .profile-setting-value,
    .profile-password-details {
        justify-self: start;
        text-align: left;
    }

    .profile-password-details,
    .profile-password-details input {
        width: 100%;
    }

    .profile-page--reference .profile-save-button,
    .profile-page--reference .profile-upload-button,
    .profile-picture-submit {
        width: 100%;
    }

    .profile-page--reference .profile-upload-actions {
        width: 100%;
    }
}

.members-page--reference {
    gap: 18px;
}

.members-page--reference .coach-panel {
    border-radius: 24px;
    border: 1px solid #e6e6de;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 24px 52px -40px rgba(34, 51, 43, 0.18);
}

.members-summary-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    padding: 16px;
}

.members-summary-card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 8px 14px;
    border-right: 1px solid #ecece6;
}

.members-summary-card:last-child {
    border-right: 0;
}

.members-summary-card > div {
    display: grid;
    gap: 4px;
}

.members-summary-card span:last-child,
.members-summary-card > div > span {
    color: #7f8983;
    font-size: 14px;
}

.members-summary-card strong {
    color: #173f31;
    font-size: 24px;
    line-height: 1;
}

.members-summary-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 16px;
}

.members-summary-icon svg {
    width: 22px;
    height: 22px;
}

.members-summary-icon.is-blue { background: #eef4ff; color: #3f7dd9; }
.members-summary-icon.is-green { background: #eef8f0; color: #24a148; }
.members-summary-icon.is-amber { background: #fff3e8; color: #f08a24; }
.members-summary-icon.is-mint { background: #edf8f0; color: #259c4b; }

.members-filter-shell {
    padding: 16px;
}

.members-reference-filter-form,
.members-reference-filter-top {
    display: grid;
    gap: 14px;
}

.members-reference-filter-top {
    grid-template-columns: minmax(260px, 1.2fr) minmax(0, 2fr) auto;
    align-items: end;
}

.members-reference-search input,
.members-reference-filter-row select {
    width: 100%;
    min-height: 52px;
    padding: 0 16px;
    border: 1px solid #e1e4dc;
    border-radius: 14px;
    background: #fff;
    color: #2b3933;
    box-sizing: border-box;
    font: inherit;
}

.members-reference-filter-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.members-reference-filter-row label {
    display: grid;
    gap: 6px;
}

.members-reference-filter-row span {
    color: #7c8781;
    font-size: 12px;
    font-weight: 700;
}

.members-reference-filter-actions {
    display: flex;
    gap: 10px;
    align-items: center;
}

.members-status-tabs {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.members-status-tab {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid #e2e5dd;
    border-radius: 999px;
    background: #fff;
    color: #405049;
    text-decoration: none;
    font-weight: 700;
}

.members-status-tab strong {
    padding: 2px 8px;
    border-radius: 999px;
    background: #f3f4ef;
    font-size: 13px;
}

.members-status-tab.is-active {
    background: linear-gradient(135deg, #0d4d37 0%, #155b42 100%);
    color: #fff;
    border-color: transparent;
}

.members-status-tab.is-active strong {
    background: rgba(255, 255, 255, 0.14);
}

.members-results-toolbar--reference {
    margin-bottom: 8px;
    padding-bottom: 14px;
}

.members-table-shell {
    overflow-x: auto;
}

.members-reference-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 1160px;
}

.members-reference-table th,
.members-reference-table td {
    padding: 14px 12px;
    border-top: 1px solid #eceee8;
    text-align: left;
    vertical-align: middle;
}

.members-reference-table thead th {
    border-top: 0;
    color: #7a857f;
    font-size: 13px;
    font-weight: 700;
}

.members-reference-table tbody tr:hover {
    background: #fbfcf9;
}

.members-table-member {
    display: flex;
    align-items: center;
    gap: 12px;
}

.members-table-member__link {
    display: grid;
    gap: 2px;
    color: inherit;
    text-decoration: none;
}

.members-table-member__link:hover strong {
    color: #17633f;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.members-table-member strong {
    display: block;
    color: #20322b;
}

.members-table-member span {
    color: #7d8781;
    font-size: 13px;
}

.members-table-select {
    width: 32px;
}

.members-status-pill {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}

.members-status-pill.is-active { background: #edf8ef; color: #2b8a46; }
.members-status-pill.is-frozen { background: #eef1f6; color: #687483; }
.members-status-pill.is-ended { background: #f5f1ee; color: #8d6f61; }
.members-status-pill.is-attention { background: #fff1e7; color: #d97917; }

.members-progress-cell {
    display: flex;
    align-items: center;
    gap: 10px;
}

.members-progress-bar {
    width: 84px;
    height: 8px;
    border-radius: 999px;
    background: #edf0ea;
    overflow: hidden;
}

.members-progress-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
}

.members-progress-bar .is-good { background: linear-gradient(90deg, #2d9b47, #238a3f); }
.members-progress-bar .is-mid { background: linear-gradient(90deg, #f0a43a, #e08a22); }
.members-progress-bar .is-low { background: linear-gradient(90deg, #d8dbd5, #c7cbc3); }

.members-last-active {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}

.members-last-active.is-fresh {
    background: #edf8ef;
    color: #2b8a46;
}

.members-last-active.is-attention {
    background: #fff4e8;
    color: #d97917;
}

.members-table-actions {
    text-align: right;
}

@media (max-width: 1100px) {
    .members-summary-strip,
    .members-reference-filter-top,
    .members-reference-filter-row {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 720px) {
    .members-summary-strip,
    .members-reference-filter-top,
    .members-reference-filter-row {
        grid-template-columns: 1fr;
    }

    .members-summary-card {
        border-right: 0;
        border-bottom: 1px solid #ecece6;
    }

    .members-summary-card:last-child {
        border-bottom: 0;
    }

    .members-reference-filter-actions {
        flex-wrap: wrap;
    }
}

.chat-index-empty {
    padding: 28px;
    border: 1px dashed #d6dfd8;
    border-radius: 22px;
    color: #6a7c8b;
    background: rgba(255, 255, 255, 0.75);
}

.chat-create-panel {
    display: grid;
    gap: 24px;
}

.chat-create-type-switch {
    display: inline-flex;
    gap: 6px;
    padding: 5px;
    margin: 0 0 22px;
    border: 1px solid #d7e2d9;
    border-radius: 18px;
    background: #f3f7f4;
}

.chat-create-type {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px;
    border-radius: 14px;
    color: #536678;
    font-weight: 800;
    text-decoration: none;
}

.chat-create-type.is-active {
    background: #fff;
    color: #102f29;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.chat-member-results {
    display: grid;
    gap: 10px;
    margin-top: 16px;
    max-height: 420px;
    overflow-y: auto;
    padding-right: 6px;
    overscroll-behavior: contain;
}

.chat-member-results::-webkit-scrollbar {
    width: 8px;
}

.chat-member-results::-webkit-scrollbar-track {
    background: transparent;
}

.chat-member-results::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: #c9d8cb;
}

.chat-member-result {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px;
    border: 1px solid #dce7de;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.88);
    cursor: pointer;
}

.chat-member-result:has(input:checked) {
    border-color: #13553d;
    background: #eff8f1;
    box-shadow: 0 14px 28px rgba(19, 85, 61, 0.1);
}

.chat-member-result input {
    width: 18px;
    height: 18px;
    margin: 0;
    accent-color: #13553d;
}

.chat-member-result__avatar {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, #dfe9dd, #cfdccf);
    color: #214333;
    font-weight: 900;
}

.chat-member-result__copy {
    min-width: 0;
    display: grid;
    gap: 3px;
}

.chat-member-result__copy strong {
    color: #102f29;
}

.chat-member-result__copy span {
    color: #647688;
    font-size: 14px;
}

.chat-row-link .admin-row:hover {
    border-color: #2ecc71;
}

.chat-unread-meta {
    display: block;
    margin-top: 6px;
    color: #7ee2a8;
    font-size: 13px;
}

.chat-page {
    width: 100%;
}

.chat-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
}

.chat-thread {
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: 360px;
    margin-bottom: 20px;
    padding: 20px;
    border: 1px solid #202936;
    border-radius: 18px;
    background: #10151d;
}

.chat-message {
    max-width: 780px;
    padding: 14px 16px;
    border: 1px solid #202936;
    border-radius: 16px;
    background: #151a22;
}

.chat-message.own {
    align-self: flex-end;
    border-color: rgba(46, 204, 113, 0.35);
    background: rgba(46, 204, 113, 0.12);
}

.chat-message-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 8px;
}

.chat-message-meta strong {
    color: #d9dee7;
}

.chat-message-author {
    color: #d9dee7;
    font-weight: 700;
    text-decoration: none;
}

.chat-message-author:hover,
.chat-message-author:focus-visible {
    color: #9fc5ff;
    text-decoration: underline;
}

.chat-message-meta span {
    color: #7d8796;
    font-size: 13px;
}

.chat-message p {
    margin: 0;
    color: #e5e7eb;
    line-height: 1.5;
    white-space: pre-wrap;
}

.chat-compose {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 12px;
    align-items: end;
    padding: 18px;
    border: 1px solid #202936;
    border-radius: 18px;
    background: #10151d;
}

.chat-compose textarea {
    min-height: 72px;
}

.workouts-page {
    width: 100%;
}

.workout-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.recipe-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.workout-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    min-height: 80px;
    padding: 18px 22px;
    border: 1px solid #202936;
    border-radius: 16px;
    background: #10151d;
}

.recipe-row {
    display: grid;
    grid-template-columns: 132px minmax(0, 1fr) auto;
    gap: 22px;
    align-items: center;
    padding: 18px 22px;
    border: 1px solid #202936;
    border-radius: 16px;
    background: #10151d;
}

.workout-row-main {
    min-width: 0;
}

.recipe-row-main {
    min-width: 0;
}

.workout-row-main h2 {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0 0 8px;
    color: #d9dee7;
    font-size: 18px;
}

.recipe-row-main h2 {
    margin: 0 0 8px;
    color: #d9dee7;
    font-size: 18px;
}

.workout-row-main p {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin: 0;
    color: #7d8796;
    font-size: 15px;
}

.recipe-row-main p {
    margin: 0;
    color: #7d8796;
    font-size: 15px;
}

.recipe-row-media {
    width: 132px;
}

.recipe-thumbnail,
.recipe-detail-image {
    width: 100%;
    border: 1px solid #202936;
    border-radius: 16px;
    background: #03070a;
    object-fit: cover;
}

.recipe-thumbnail {
    aspect-ratio: 4 / 3;
}

.visibility-icon.hidden {
    color: #7d8796;
    font-size: 15px;
}

.icon-button.success {
    color: #22c55e;
}

.program-board-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.program-week-switcher {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.secondary-action.is-active {
    background: rgba(46, 204, 113, 0.12);
    color: #fff;
}

.program-board {
    display: grid;
    grid-template-columns: repeat(7, minmax(230px, 1fr));
    gap: 16px;
    overflow-x: auto;
    padding-bottom: 6px;
}

.program-day-column {
    display: grid;
    gap: 14px;
    min-width: 230px;
}

.program-day-heading {
    color: #d9dee7;
    font-size: 15px;
    font-weight: 800;
}

.program-section {
    display: grid;
    gap: 10px;
    padding: 14px;
    border: 1px solid #202936;
    border-radius: 16px;
    background: #0d131c;
}

.program-card {
    --program-card-color: #22c55e;
    display: grid;
    gap: 14px;
    padding: 14px 14px 14px 18px;
    border: 1px solid rgba(255, 255, 255, 0.04);
    border-radius: 14px;
    background: #151a22;
    box-shadow: inset 4px 0 0 var(--program-card-color);
}

.program-card-image {
    overflow: hidden;
    border-radius: 14px;
    aspect-ratio: 16 / 9;
    background: rgba(255, 255, 255, 0.08);
}

.program-card-copy {
    display: grid;
    gap: 6px;
}

.program-card-copy strong {
    color: #e5e7eb;
    font-size: 15px;
}

.program-card-copy span {
    color: #8a94a6;
    font-size: 13px;
    line-height: 1.5;
}

.program-card-emoji {
    margin-right: 8px;
}

.program-card-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.program-card-actions form {
    margin: 0;
}

.program-empty-slot {
    padding: 12px;
    border: 1px dashed #202936;
    border-radius: 12px;
    color: #607082;
    font-size: 13px;
    text-align: center;
}

.workout-form-panel {
    display: grid;
    gap: 22px;
    width: 100%;
    box-sizing: border-box;
    padding: 24px;
    border: 1px solid #202936;
    border-radius: 18px;
    background: #10151d;
}

.workout-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

.full-width {
    width: 100%;
}

.workout-tag-list {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.workout-chip {
    --chip-color: #2ecc71;
    position: relative;
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    cursor: pointer;
    overflow: hidden;
}

.workout-chip input {
    position: absolute;
    opacity: 0;
}

.workout-chip span,
.workout-chip.active {
    display: inline-flex;
    align-items: center;
}

.workout-chip input:checked + span,
.workout-chip.active {
    background: var(--chip-color);
    color: #07110b;
}

.toggle-field {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    color: #7d8796;
    font-size: 15px;
}

.toggle-field input {
    position: absolute;
    opacity: 0;
}

.toggle-slider {
    position: relative;
    display: inline-block;
    width: 64px;
    height: 34px;
    border-radius: 999px;
    background: #151a22;
}

.toggle-slider::after {
    content: "";
    position: absolute;
    top: 4px;
    left: 4px;
    width: 26px;
    height: 26px;
    border-radius: 999px;
    transition: transform 0.2s ease;
}

.toggle-field input:checked + .toggle-slider {
    background: #22c55e;
}

.toggle-field input:checked + .toggle-slider::after {
    transform: translateX(30px);
}

.full-submit {
    width: 100%;
}

.workout-description {
    margin: 0 0 20px;
    color: #d9dee7;
    white-space: pre-wrap;
}

.form-hint {
    margin: 0;
    color: #7d8796;
    font-size: 13px;
}

.form-hint-heading {
    display: block;
    font-weight: 700;
}

.workout-detail-stack {
    display: grid;
    gap: 20px;
}

.workout-detail-header {
    align-items: flex-start;
}

.workout-detail-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

.workout-detail-actions form {
    margin: 0;
}

.workout-detail-actions .danger-action {
    border-color: color-mix(in srgb, var(--danger) 64%, white 36%);
    background: color-mix(in srgb, var(--danger) 7%, white 93%);
    color: var(--danger);
}

.workout-detail-actions .danger-action:hover {
    background: color-mix(in srgb, var(--danger) 13%, white 87%);
}

.recipe-detail-stack,
.recipe-image-field {
    display: grid;
    gap: 20px;
}

.workout-thumbnail-field {
    display: grid;
    gap: 14px;
}

.workout-thumbnail-field__body {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}

.workout-thumbnail-preview {
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    width: 220px;
    aspect-ratio: 16 / 9;
    border: 1px solid #dce5f0;
    border-radius: 18px;
    background: #eef4ff;
}

.workout-thumbnail-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.workout-thumbnail-preview__empty {
    padding: 18px;
    color: var(--text-muted);
    font-size: 14px;
    text-align: center;
}

.workout-thumbnail-field--inline .workout-thumbnail-field__inline {
    display: grid;
    grid-template-columns: 88px minmax(0, 1fr) auto;
    gap: 16px;
    align-items: center;
}

.workout-thumbnail-field--inline .workout-thumbnail-preview {
    width: 88px;
    height: 60px;
    aspect-ratio: auto;
    flex: 0 0 88px;
    border-radius: 14px;
    background: #f1f5f9;
}

.workout-thumbnail-field--inline .workout-thumbnail-preview__empty {
    width: 100%;
    height: 100%;
    padding: 0;
    position: relative;
    color: transparent;
}

.workout-thumbnail-field--inline .workout-thumbnail-preview__empty::before,
.workout-thumbnail-field--inline .workout-thumbnail-preview__empty::after {
    content: "";
    position: absolute;
    inset: 50% auto auto 50%;
    transform: translate(-50%, -50%);
    border-radius: 999px;
}

.workout-thumbnail-field--inline .workout-thumbnail-preview__empty::before {
    width: 28px;
    height: 28px;
    border: 1px dashed #c7d2e0;
}

.workout-thumbnail-field--inline .workout-thumbnail-preview__empty::after {
    width: 10px;
    height: 10px;
    background: #cbd5e1;
}

.workout-thumbnail-field--inline .workout-thumbnail-inline-copy {
    display: grid;
    gap: 6px;
    min-width: 0;
    align-content: center;
}

.workout-thumbnail-field--inline .workout-thumbnail-inline-copy strong,
.workout-thumbnail-field--inline .workout-thumbnail-inline-copy span {
    display: block;
    margin: 0;
}

.workout-thumbnail-field--inline .workout-thumbnail-inline-copy span {
    line-height: 1.45;
}

.workout-thumbnail-field--inline .workout-thumbnail-inline-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.workout-thumbnail-inputs {
    display: grid;
    gap: 12px;
}

@media (max-width: 900px) {
    .workout-thumbnail-field__body {
        grid-template-columns: 1fr;
    }

    .workout-thumbnail-preview {
        width: 100%;
        max-width: 320px;
    }
}

.workout-video-player {
    display: block;
    width: 100%;
    height: 100%;
    border: 1px solid #202936;
    border-radius: 16px;
    background: #03070a;
    object-fit: cover;
}

.workout-video-frame {
    width: min(100%, 720px);
    height: 405px;
    overflow: hidden;
    border-radius: 18px;
}

@media (max-width: 820px) {
    .workout-video-frame {
        width: 100%;
        height: auto;
        aspect-ratio: 16 / 9;
    }
}

.sidebar-toggle-checkbox,
.sidebar-toggle-button,
.sidebar-backdrop {
    display: none;
}

@media (max-width: 820px) {
    body.app-body {
        overflow-x: hidden;
    }

    .app-shell {
        display: block;
    }

    .sidebar {
        position: fixed;
        inset: 0 auto 0 0;
        z-index: 20;
        transform: translateX(-100%);
        transition: transform 0.2s ease;
    }

    .sidebar-toggle-checkbox:checked ~ .sidebar {
        transform: translateX(0);
    }

    .sidebar-toggle-button {
        position: fixed;
        top: 16px;
        left: 16px;
        z-index: 30;
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 5px;
        width: 44px;
        height: 44px;
        border: 1px solid #1f2a44;
        border-radius: 10px;
        cursor: pointer;
    }

    .sidebar-toggle-button span {
        display: block;
        width: 18px;
        height: 2px;
        margin: 0 auto;
        border-radius: 999px;
    }

    .sidebar-backdrop {
        position: fixed;
        inset: 0;
        z-index: 10;
        background: rgba(0, 0, 0, 0.55);
    }

    .sidebar-toggle-checkbox:checked ~ .sidebar-backdrop {
        display: block;
    }

    .coach-dashboard-header {
        margin: -84px -20px 28px;
    }

    .coach-chart-grid,
.coach-pie-grid {
        grid-template-columns: 1fr;
    }

    .coach-pie-wrap {
        grid-template-columns: 1fr;
    }

    .coach-pie-labels {
        justify-items: center;
    }

    .tags-header {
        align-items: stretch;
        flex-direction: column;
    }

    .tag-new-button,
    .primary-action {
        width: 100%;
    }

    .tag-search-form input {
        height: 52px;
        font-size: 16px;
    }

    .payment-filter-form {
        grid-template-columns: 1fr;
    }

    .payment-filter-actions {
        justify-content: stretch;
    }

    .payment-filter-actions .secondary-action {
        width: 100%;
    }

    .tag-list-head {
        display: none;
    }

    .tag-row {
        grid-template-columns: 1fr;
        align-items: flex-start;
        gap: 12px;
        min-height: 0;
        padding: 18px;
    }

    .tag-row-main {
        width: 100%;
        align-items: flex-start;
    }

    .tag-row-preview {
        width: 64px;
        height: 64px;
        border-radius: 20px;
    }

    .tag-row-actions {
        width: 100%;
        align-self: flex-end;
        justify-content: flex-start;
    }

    .tag-row-copy strong {
        font-size: 18px;
    }

    .tag-row-availability,
    .library-tag-usage-list span {
        font-size: 13px;
    }

    .form-actions-row {
        flex-direction: column-reverse;
    }

    .admin-row {
        align-items: stretch;
        flex-direction: column;
    }

    .admin-row-actions {
        justify-content: flex-start;
    }

    .row-menu {
        width: 100%;
    }

    .row-menu-panel {
        left: 0;
        right: auto;
        min-width: min(100%, 220px);
    }

    .dashboard-grid,
    .detail-list,
    .admin-form-grid {
        grid-template-columns: 1fr;
    }

    .coach-dashboard .coach-secondary-grid,
    .admin-dashboard-mini-grid,
    .admin-agreement-summary {
        grid-template-columns: 1fr;
    }

    .program-board-header {
        flex-direction: column;
    }

    .program-board {
        grid-template-columns: 1fr;
        overflow: visible;
    }

    .program-day-column {
        min-width: 0;
    }

    .chat-compose {
        grid-template-columns: 1fr;
    }

    .workout-row {
        align-items: flex-start;
        flex-direction: column;
    }

    .recipe-row {
        grid-template-columns: 1fr;
    }

    .recipe-row-media {
        width: 100%;
    }

        .workout-form-grid {
        grid-template-columns: 1fr;
    }
}

body,
body.app-body,
.content {
    background: linear-gradient(180deg, var(--page-bg) 0%, var(--page-bg-elevated) 100%);
    color: var(--text-primary);
    transition: background 0.2s ease, color 0.2s ease;
}

.app-shell {
    box-sizing: border-box;
    gap: 14px;
    padding: 14px;
}

.logo-icon {
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-strong) 100%);
    box-shadow: var(--shadow-soft);
}

.logo p,
.sidebar-subtitle,
.sidebar-meta,
.nav-section-title,
.coach-metric-card span,
.page-subtitle,
.admin-row-main span,
.metric-card span,
.detail-list dt,
.detail-list dd,
.form-hint,
.tag-row-copy span,
.workout-row-main p,
.recipe-row-main p,
.chat-message-meta span,
.tag-search-form input::placeholder,
.remember-field,
.forgot,
.language-switch a {
    color: var(--text-muted);
}

.logo h1,
.sidebar-title,
.coach-dashboard-header h1,
.coach-panel h2,
.admin-page > h1,
.tags-header h1,
.tag-form-page h1,
.admin-row-main strong,
.metric-card strong,
.detail-panel h2,
.admin-form-grid h2,
.workout-row-main h2,
.recipe-row-main h2,
.chat-message-meta strong,
.chat-message p,
.workout-description,
.form-field label,
.checkbox-field {
    color: var(--text-primary);
}

.login-form input,
.organization-card,
.ui-empty-state,
.coach-metric-card,
.coach-panel,
.tag-form-panel,
.admin-row,
.metric-card,
.detail-panel,
.chat-thread,
.chat-message,
.chat-compose,
.workout-row,
.recipe-row,
.workout-form-panel,
.form-field input[type="date"],
.form-field input[type="datetime-local"],
.form-field input[type="email"],
.form-field input[type="file"],
.form-field input[type="number"],
.form-field input[type="password"],
.form-field input[type="search"],
.form-field input[type="text"],
.form-field select,
.form-field textarea,
.tag-search-form input,
.row-menu-panel,
.toggle-slider,
.workout-chip,
.recipe-thumbnail,
.recipe-detail-image {
    border-color: var(--border);
    background: var(--surface);
    color: var(--text-primary);
}

.sidebar {
    min-height: calc(100vh - 28px);
    height: calc(100vh - 28px);
    border: 1px solid var(--border);
    border-radius: 18px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 88%, white 12%) 0%, color-mix(in srgb, var(--surface-2) 86%, white 14%) 100%);
    box-shadow: 0 18px 44px rgba(17, 24, 39, 0.08);
}

.sidebar-header,
.sidebar-footer {
    border-color: var(--border);
}

@media (max-width: 820px) {
    .app-shell {
        gap: 0;
        padding: 0;
    }

    .sidebar {
        min-height: 100vh;
        height: 100vh;
        border-width: 0 1px 0 0;
        border-radius: 0 18px 18px 0;
    }
}

.nav-item-link:hover,
.nav-item-link.active,
.row-menu[open] .row-menu-trigger,
.tag-search-form input:focus,
.form-field input[type="email"]:focus,
.form-field input[type="file"]:focus,
.form-field input[type="number"]:focus,
.form-field input[type="password"]:focus,
.form-field input[type="search"]:focus,
.form-field input[type="text"]:focus,
.form-field select:focus,
.form-field textarea:focus,
.form-field input[type="text"]:focus {
    border-color: var(--accent);
    color: var(--text-primary);
}

.status-message,
.coach-dashboard-badge,
.chat-message.own {
    background: var(--accent-soft);
}

.login-form button,
.role-btn,
.tag-new-button,
.primary-action,
.logout-link:hover,
.toggle-field input:checked + .toggle-slider,
.workout-chip input:checked + span,
.workout-chip.active {
    background: var(--accent);
    color: var(--accent-contrast);
}

.role-btn.secondary,
.logout-link,
.simple-pagination a,
.secondary-action {
    border-color: var(--accent);
    color: var(--accent);
}

.logout-link,
.theme-toggle {
    background: transparent;
}

.error,
.icon-button.danger,
.danger-action,
.form-errors {
    color: var(--danger);
}

.success,
.coach-metric-icon.green,
.icon-button.success {
    color: var(--success);
}

.coach-metric-icon.orange,
.chart-line.orange {
    color: var(--warning);
    stroke: var(--warning);
}

.coach-metric-icon.red,
.chart-line.red {
    color: var(--danger);
    stroke: var(--danger);
}

.coach-metric-icon.green,
.chart-line.green,
.dashboard-placeholder .page-kicker,
.language-switch a.active {
    color: var(--accent);
    stroke: var(--accent);
}

.chart-axis {
    stroke: var(--border-strong);
}

.coach-line-chart text {
    fill: var(--text-muted);
}

.coach-dashboard-header {
    background: var(--header-bg);
    border-bottom-color: var(--border);
}

.coach-pie {
    border-color: color-mix(in srgb, var(--text-primary) 26%, transparent);
}

.row-menu-link {
    color: var(--text-primary);
}

.row-menu-link:hover {
    background: var(--surface-2);
}

.ui-empty-state,
.tag-form-panel,
.coach-metric-card,
.coach-panel,
.admin-row,
.metric-card,
.detail-panel,
.chat-thread,
.chat-compose,
.workout-row,
.recipe-row,
.workout-form-panel,
.organization-card {
    box-shadow: var(--shadow-soft);
}

.toggle-slider::after {
    background: var(--surface-3);
}

.checkbox-field input {
    accent-color: var(--accent);
}

.login-form .remember-field input {
    accent-color: var(--accent);
}

.icon-button,
.tag-row-icon,
.tag-search-icon,
.visibility-icon.hidden {
    color: var(--text-muted);
    stroke: var(--text-muted);
}

.theme-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    margin-bottom: 12px;
    padding: 11px 12px;
    border: 1px solid var(--border);
    border-radius: 10px;
    color: var(--text-primary);
    cursor: pointer;
    font-size: 14px;
    font-weight: 700;
}

.theme-toggle:hover {
    border-color: var(--accent);
    background: var(--accent-soft);
}

.theme-toggle-value {
    color: var(--accent);
}

@media (max-width: 820px) {
    .sidebar-toggle-button {
        border-color: var(--border);
        background: var(--surface);
    }

    .sidebar-toggle-button span {
        background: var(--text-primary);
    }
}

.coach-dashboard-header {
    align-items: center;
    gap: 16px;
    margin-bottom: 20px;
    padding: 22px 28px;
    border-radius: 0 0 28px 28px;
}

.coach-dashboard-header h1 {
    font-size: 34px;
    letter-spacing: -0.03em;
}

.coach-dashboard-badge {
    min-height: 30px;
    padding: 0 14px;
    border-radius: 999px;
    font-size: 11px;
    letter-spacing: 0.12em;
}

.coach-section-header h2 {
    margin: 10px 0 0;
    color: var(--text-primary);
    font-size: 28px;
    line-height: 1.05;
    letter-spacing: -0.03em;
}

.coach-secondary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 26px;
}

.coach-metric-card {
    min-height: 0;
    border-radius: 24px;
    gap: 10px;
}

.coach-metric-card-secondary {
    padding: 18px 20px;
}

.coach-metric-card strong {
    font-size: 32px;
    letter-spacing: -0.03em;
}

.coach-metric-card span {
    font-size: 14px;
    line-height: 1.4;
}

.coach-section-header {
    margin: 0 0 18px;
}

.coach-chart-grid,
.coach-pie-grid {
    gap: 20px;
}

.coach-chart-grid {
    margin-bottom: 26px;
}

.coach-panel {
    padding: 24px 24px 20px;
    border-radius: 28px;
}

.coach-panel h2 {
    margin-bottom: 14px;
    font-size: 24px;
    letter-spacing: -0.02em;
}

.coach-line-chart {
    min-height: 200px;
}

.coach-dashboard {
    display: grid;
    gap: 24px;
}

.coach-dashboard .coach-dashboard-header {
    position: relative;
    min-height: 178px;
    align-items: flex-end;
    margin: -32px -32px 0;
    padding: 28px 32px;
    border-radius: 0 0 30px 30px;
    overflow: hidden;
    background:
        linear-gradient(115deg, rgba(13, 35, 29, 0.9), rgba(14, 24, 34, 0.72)),
        url("https://images.unsplash.com/photo-1535131749006-b7f58c99034b?auto=format&fit=crop&w=1800&q=80");
    background-position: center;
    background-size: cover;
    border-bottom: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
}

.coach-dashboard--economy .coach-dashboard-header {
    background:
        linear-gradient(115deg, rgba(38, 45, 30, 0.88), rgba(14, 24, 34, 0.74)),
        url("https://images.unsplash.com/photo-1587174486073-ae5e5cff23aa?auto=format&fit=crop&w=1800&q=80");
    background-position: center;
    background-size: cover;
}

.coach-dashboard--statistics .coach-dashboard-header {
    background:
        linear-gradient(115deg, rgba(22, 42, 41, 0.9), rgba(16, 28, 40, 0.76)),
        url("https://images.unsplash.com/photo-1516321318423-f06f85e504b3?auto=format&fit=crop&w=1800&q=80");
    background-position: center;
    background-size: cover;
}

.coach-dashboard .coach-dashboard-header::after {
    content: "";
    position: absolute;
    inset: auto 32px 0;
    height: 1px;
    background: rgba(255, 255, 255, 0.18);
}

.coach-dashboard .coach-dashboard-badge {
    position: relative;
    z-index: 1;
    background: rgba(255, 255, 255, 0.14);
    color: #bdf2c8;
    backdrop-filter: blur(14px);
    letter-spacing: 0;
}

.coach-dashboard .coach-dashboard-header h1 {
    position: relative;
    z-index: 1;
    color: #f8fbf7;
    font-size: 56px;
    line-height: 1;
    letter-spacing: 0;
}

.coach-dashboard .coach-overview-grid {
    grid-template-columns: minmax(0, 1.45fr) minmax(340px, 0.85fr);
    gap: 22px;
    margin-bottom: 0;
}

.coach-dashboard .coach-hero-panel,
.coach-dashboard .coach-focus-panel,
.coach-dashboard .coach-panel {
    position: relative;
    overflow: hidden;
    border-color: color-mix(in srgb, var(--border) 82%, transparent);
    border-radius: 24px;
    background:
        linear-gradient(145deg, color-mix(in srgb, var(--surface) 92%, transparent), color-mix(in srgb, var(--surface-2) 82%, transparent));
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.18);
}

.coach-dashboard .coach-hero-panel::before,
.coach-dashboard .coach-focus-panel::before,
.coach-dashboard .coach-panel::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.07), transparent 38%);
}

.coach-dashboard .coach-hero-panel {
    grid-template-columns: minmax(0, 0.9fr) minmax(340px, 1.1fr);
    align-items: end;
    min-height: 420px;
    padding: 28px;
    background:
        linear-gradient(120deg, rgba(20, 45, 36, 0.9), rgba(18, 31, 41, 0.72)),
        url("https://images.unsplash.com/photo-1593111774240-d529f12cf4bb?auto=format&fit=crop&w=1500&q=80");
    background-position: center;
    background-size: cover;
    color: #f8fbf7;
}

.coach-dashboard .coach-hero-copy,
.coach-dashboard .coach-primary-grid,
.coach-dashboard .coach-focus-heading,
.coach-dashboard .coach-focus-list,
.coach-dashboard .coach-panel > * {
    position: relative;
    z-index: 1;
}

.coach-dashboard .coach-hero-copy h2,
.coach-dashboard .coach-focus-heading h2,
.coach-dashboard .coach-section-header h2 {
    margin-top: 8px;
    letter-spacing: 0;
}

.coach-dashboard .coach-hero-copy h2 {
    color: #fff;
    font-size: 40px;
    line-height: 1.04;
}

.coach-dashboard .coach-hero-copy p {
    max-width: 560px;
    color: rgba(248, 251, 247, 0.78);
    font-size: 16px;
}

.coach-dashboard .coach-section-kicker {
    background: rgba(255, 255, 255, 0.14);
    color: #bdf2c8;
    letter-spacing: 0;
    backdrop-filter: blur(14px);
}

.coach-dashboard .coach-focus-heading .coach-section-kicker,
.coach-dashboard .coach-section-header .coach-section-kicker {
    background: var(--accent-soft);
    color: var(--accent);
}

.coach-dashboard .coach-primary-grid {
    align-self: stretch;
    grid-template-columns: 1fr;
    align-content: start;
}

.coach-dashboard .coach-metric-card {
    border-radius: 18px;
    border-color: color-mix(in srgb, var(--border) 82%, transparent);
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.coach-dashboard .coach-metric-card-link {
    color: inherit;
    text-decoration: none;
    cursor: pointer;
}

.coach-dashboard .coach-hero-panel .coach-metric-card {
    background: rgba(9, 18, 27, 0.54);
    border-color: rgba(255, 255, 255, 0.16);
    color: #fff;
    backdrop-filter: blur(18px);
    min-height: 138px;
}

.coach-dashboard .coach-metric-card:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--accent) 42%, var(--border));
}

.coach-dashboard .coach-metric-card-link:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--accent) 26%, white);
    outline-offset: 3px;
}

.coach-dashboard .coach-metric-card strong {
    letter-spacing: 0;
}

.coach-dashboard .coach-hero-panel .coach-metric-card span {
    color: rgba(248, 251, 247, 0.72);
}

.coach-dashboard .coach-secondary-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 0;
}

.coach-dashboard .coach-metric-card-secondary {
    min-height: 132px;
    background:
        linear-gradient(145deg, color-mix(in srgb, var(--surface) 92%, transparent), color-mix(in srgb, var(--surface-2) 88%, transparent));
}

.coach-dashboard .coach-focus-panel {
    display: grid;
    align-content: end;
    min-height: 420px;
    padding: 24px;
}

.coach-dashboard .coach-focus-item {
    border-color: var(--border);
    background: color-mix(in srgb, var(--surface-2) 88%, transparent);
    transition: transform 0.18s ease, border-color 0.18s ease;
}

.coach-dashboard .coach-focus-list {
    margin-top: 20px;
}

.coach-dashboard .coach-focus-item-lead {
    padding: 22px 20px;
    border-radius: 20px;
}

.coach-dashboard .coach-focus-item:hover {
    transform: translateY(-2px);
}

.coach-dashboard .coach-priority-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.coach-dashboard .coach-priority-panel {
    position: relative;
    overflow: hidden;
    padding: 22px;
    border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
    border-radius: 22px;
    background:
        linear-gradient(145deg, color-mix(in srgb, var(--surface) 96%, transparent), color-mix(in srgb, var(--surface-2) 88%, transparent));
    box-shadow: 0 20px 48px rgba(0, 0, 0, 0.14);
}

.coach-dashboard .coach-priority-panel::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.06), transparent 40%);
}

.coach-dashboard .coach-priority-heading,
.coach-dashboard .coach-priority-list {
    position: relative;
    z-index: 1;
}

.coach-dashboard .coach-priority-heading p {
    margin-top: 8px;
    color: var(--text-secondary);
}

.coach-dashboard .coach-priority-list {
    display: grid;
    gap: 12px;
    margin-top: 18px;
}

.coach-dashboard .coach-priority-item {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    padding: 16px;
    border: 1px solid color-mix(in srgb, var(--border) 86%, transparent);
    border-radius: 18px;
    background: color-mix(in srgb, var(--surface-2) 72%, transparent);
}

.coach-dashboard .coach-priority-item.warning {
    border-color: color-mix(in srgb, var(--warning) 40%, var(--border));
}

.coach-dashboard .coach-priority-item.danger {
    border-color: color-mix(in srgb, var(--danger) 44%, var(--border));
}

.coach-dashboard .coach-priority-item.accent {
    border-color: color-mix(in srgb, var(--accent) 44%, var(--border));
}

.coach-dashboard .coach-priority-item.success {
    border-color: color-mix(in srgb, var(--success) 40%, var(--border));
}

.coach-dashboard .coach-priority-copy {
    display: grid;
    gap: 6px;
}

.coach-dashboard .coach-priority-copy strong {
    letter-spacing: 0;
}

.coach-dashboard .coach-priority-copy p,
.coach-dashboard .coach-priority-copy span {
    margin: 0;
    color: var(--text-secondary);
}

.coach-dashboard .coach-priority-item .secondary-action {
    flex-shrink: 0;
}

.coach-dashboard .coach-section-header {
    margin: 6px 0 -4px;
}

.coach-dashboard--overview .coach-priority-grid {
    gap: 14px;
}

.coach-dashboard--overview .coach-priority-panel {
    padding: 15px;
    border-radius: 18px;
}

.coach-dashboard--overview .coach-priority-heading h2 {
    font-size: 18px;
    line-height: 1.12;
}

.coach-dashboard--overview .coach-priority-heading p {
    margin-top: 8px;
    font-size: 13px;
    line-height: 1.55;
}

.coach-dashboard--overview .coach-priority-list {
    gap: 10px;
}

.coach-dashboard--overview .coach-priority-item {
    gap: 10px;
    padding: 11px 12px;
    border-radius: 14px;
}

.coach-dashboard--overview .coach-priority-copy {
    gap: 4px;
}

.coach-dashboard--overview .coach-priority-copy strong {
    font-size: 13px;
    line-height: 1.3;
}

.coach-dashboard--overview .coach-priority-copy p,
.coach-dashboard--overview .coach-priority-copy span {
    font-size: 12px;
    line-height: 1.45;
}

.coach-dashboard--overview .coach-priority-item .secondary-action {
    min-height: 30px;
    padding: 0 12px;
    border-radius: 9px;
    font-size: 12px;
}

.coach-dashboard--overview .coach-section-kicker {
    min-height: 20px;
    padding: 0 9px;
    font-size: 9px;
}

.coach-dashboard--overview .coach-overview-grid {
    gap: 16px;
}

.coach-dashboard--overview .coach-hero-panel,
.coach-dashboard--overview .coach-focus-panel {
    border-radius: 18px;
}

.coach-dashboard--overview .coach-hero-panel {
    min-height: 278px;
    padding: 18px;
    gap: 16px;
}

.coach-dashboard--overview .coach-focus-panel {
    min-height: 278px;
    padding: 17px;
}

.coach-dashboard--overview .coach-hero-copy h2 {
    font-size: 28px;
    line-height: 1.04;
}

.coach-dashboard--overview .coach-focus-heading h2 {
    font-size: 22px;
    line-height: 1.06;
}

.coach-dashboard--overview .coach-hero-copy p,
.coach-dashboard--overview .coach-focus-item p {
    margin-top: 8px;
    font-size: 13px;
    line-height: 1.55;
}

.coach-dashboard--overview .coach-primary-grid,
.coach-dashboard--overview .coach-secondary-grid {
    gap: 12px;
}

.coach-dashboard--overview .coach-hero-panel .coach-metric-card {
    min-height: 92px;
}

.coach-dashboard--overview .coach-metric-card {
    border-radius: 15px;
    gap: 6px;
}

.coach-dashboard--overview .coach-metric-card-primary {
    padding: 15px;
}

.coach-dashboard--overview .coach-metric-card-secondary {
    min-height: 88px;
    padding: 14px 15px;
}

.coach-dashboard--overview .coach-metric-icon {
    width: 22px;
    height: 22px;
}

.coach-dashboard--overview .coach-metric-card strong {
    font-size: 24px;
    line-height: 1;
}

.coach-dashboard--overview .coach-metric-card span {
    font-size: 12px;
    line-height: 1.35;
}

.coach-dashboard--overview .coach-focus-list {
    margin-top: 14px;
    gap: 10px;
}

.coach-dashboard--overview .coach-focus-item {
    padding: 14px 14px 13px;
    border-radius: 16px;
}

.coach-dashboard--overview .coach-focus-item-lead {
    padding: 16px 15px;
    border-radius: 16px;
}

.coach-dashboard--overview .coach-focus-item strong {
    font-size: 14px;
    line-height: 1.3;
}

.coach-dashboard--overview .coach-section-header {
    margin: 2px 0 -6px;
}

.coach-dashboard--overview .coach-section-header h2 {
    font-size: 18px;
    line-height: 1.1;
}

.coach-dashboard--overview .coach-chart-grid,
.coach-dashboard--overview .coach-pie-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
    gap: 14px;
}

.coach-dashboard--overview .coach-chart-grid {
    margin-bottom: 14px;
}

.coach-dashboard--overview .coach-pie-grid {
    margin-bottom: 8px;
}

.coach-dashboard--overview .coach-panel {
    padding: 16px 16px 14px;
    border-radius: 18px;
}

.coach-dashboard--overview .coach-panel h2 {
    margin-bottom: 10px;
    font-size: 16px;
    line-height: 1.15;
}

.coach-dashboard--overview .coach-line-chart {
    min-height: 158px;
}

.coach-dashboard--overview .coach-line-chart text {
    font-size: 10px;
}

.coach-dashboard--overview .chart-tooltip text {
    font-size: 10px;
}

.coach-dashboard--overview .chart-tooltip .chart-tooltip-value {
    font-size: 11px;
}

.coach-dashboard--overview .coach-pie-wrap {
    grid-template-columns: minmax(120px, 168px) 1fr;
    gap: 18px;
    min-height: 170px;
}

.coach-dashboard--overview .coach-pie {
    width: min(150px, 100%);
}

.coach-dashboard--overview .coach-pie-labels {
    gap: 10px;
}

.coach-dashboard--overview .coach-pie-labels span {
    font-size: 14px;
    line-height: 1.35;
}

.coach-dashboard--overview .coach-pie-legend {
    gap: 12px;
    margin-top: 4px;
}

.coach-dashboard--overview .coach-pie-legend span {
    gap: 6px;
    font-size: 12px;
}

.coach-dashboard--overview .coach-pie-legend span::before {
    width: 14px;
    height: 10px;
}

.coach-dashboard--overview .coach-group-empty {
    font-size: 13px;
    line-height: 1.45;
}

html:not([data-theme="dark"]) .coach-dashboard--overview .coach-priority-panel,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-focus-panel,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-panel,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-metric-card-secondary {
    background:
        linear-gradient(
            145deg,
            color-mix(in srgb, var(--surface) 97%, white 3%),
            color-mix(in srgb, var(--surface-2) 92%, white 8%)
        );
}

html:not([data-theme="dark"]) .coach-dashboard--overview .coach-section-kicker {
    background: color-mix(in srgb, var(--accent-soft) 82%, white 18%);
    color: #45627b;
}

html:not([data-theme="dark"]) .coach-dashboard--overview .coach-priority-heading h2,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-focus-heading h2,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-section-header h2,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-priority-copy strong,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-focus-item strong,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-metric-card strong {
    color: #223547;
}

html:not([data-theme="dark"]) .coach-dashboard--overview .coach-priority-heading p,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-priority-copy p,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-priority-copy span,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-focus-item p,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-metric-card span,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-group-empty {
    color: #587186;
}

html:not([data-theme="dark"]) .coach-dashboard--overview .coach-priority-item,
html:not([data-theme="dark"]) .coach-dashboard--overview .coach-focus-item {
    background: color-mix(in srgb, var(--surface) 94%, white 6%);
}

html:not([data-theme="dark"]) .coach-dashboard--overview .coach-hero-panel .coach-metric-card {
    background: rgba(13, 26, 35, 0.72);
    border-color: rgba(255, 255, 255, 0.18);
}

html:not([data-theme="dark"]) .coach-dashboard--overview .coach-hero-panel .coach-metric-card strong {
    color: #f8fbf7;
}

html:not([data-theme="dark"]) .coach-dashboard--overview .coach-hero-panel .coach-metric-card span {
    color: rgba(248, 251, 247, 0.84);
}

@media (max-width: 900px) {
    .coach-dashboard--overview .coach-chart-grid,
    .coach-dashboard--overview .coach-pie-grid {
        grid-template-columns: 1fr;
    }

    .coach-dashboard--overview .coach-pie-wrap {
        grid-template-columns: 1fr;
        justify-items: center;
    }

    .coach-dashboard--overview .coach-pie-labels {
        justify-items: center;
        text-align: center;
    }
}

.coach-dashboard .coach-chart-grid,
.coach-dashboard .coach-pie-grid {
    gap: 20px;
}

.coach-dashboard .coach-chart-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-bottom: 0;
}

.coach-dashboard .coach-panel {
    padding: 24px;
}

.coach-dashboard .coach-panel h2 {
    letter-spacing: 0;
}

.coach-dashboard .chart-line {
    stroke-width: 4;
}

.coach-dashboard .chart-axis {
    stroke: color-mix(in srgb, var(--border-strong) 76%, transparent);
}

.coach-dashboard .chart-point-marker {
    r: 5;
}

.coach-dashboard--landing {
    gap: 22px;
}

.coach-dashboard--landing .coach-dashboard-header {
    min-height: 134px;
    align-items: flex-end;
    justify-content: flex-start;
    margin: -32px -32px 0;
    padding: 28px 28px 24px;
    border-radius: 0 0 26px 26px;
    background:
        linear-gradient(110deg, rgba(16, 42, 33, 0.78), rgba(31, 42, 24, 0.42)),
        url("https://images.unsplash.com/photo-1510162305289-9d8f8f09f457?auto=format&fit=crop&w=1800&q=80");
    background-position: center;
    background-size: cover;
}

.coach-dashboard--landing .coach-dashboard-header::after {
    inset: auto 28px 0;
}

.coach-dashboard--landing .coach-dashboard-badge {
    min-height: 34px;
    padding: 0 14px;
    background: rgba(14, 46, 37, 0.68);
    color: #eff8ef;
    border: 1px solid rgba(255, 255, 255, 0.14);
}

.coach-dashboard--landing .coach-dashboard-header h1 {
    font-size: clamp(36px, 5vw, 60px);
    font-family: Georgia, "Times New Roman", serif;
    font-weight: 700;
}

.coach-priority-grid--landing {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
    gap: 18px;
}

.coach-priority-panel--landing {
    border-radius: 24px;
    border: 1px solid color-mix(in srgb, var(--border) 82%, white);
    background: color-mix(in srgb, var(--surface) 96%, white 4%);
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.06);
}

.coach-priority-panel--landing .coach-priority-heading {
    margin-bottom: 14px;
}

.coach-priority-panel--landing .coach-priority-heading h2 {
    font-size: 16px;
}

.coach-priority-panel--landing .coach-priority-item {
    display: grid;
    grid-template-columns: 1fr;
    align-items: start;
    justify-content: stretch;
    min-height: 0;
    padding: 14px 16px;
    border-radius: 18px;
    background: color-mix(in srgb, var(--surface-2) 72%, white);
}

.coach-priority-panel--landing .coach-priority-item .secondary-action {
    justify-self: start;
    margin-top: 6px;
    max-width: 100%;
    white-space: normal;
}

.coach-priority-panel--landing .coach-priority-copy strong {
    font-size: 14px;
}

.coach-overview-spotlight {
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(360px, 0.88fr);
    gap: 16px;
}

.coach-spotlight-card,
.coach-followup-card {
    border: 1px solid color-mix(in srgb, var(--border) 84%, transparent);
    border-radius: 26px;
    background:
        linear-gradient(
            135deg,
            color-mix(in srgb, var(--surface) 98%, var(--accent) 2%),
            color-mix(in srgb, var(--surface-2) 94%, var(--accent) 6%)
        );
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.07);
}

.coach-spotlight-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 16px;
    overflow: hidden;
    min-height: 0;
    padding: 22px;
    background:
        linear-gradient(
            135deg,
            color-mix(in srgb, var(--surface) 98%, var(--accent) 2%),
            color-mix(in srgb, var(--surface-2) 96%, var(--accent) 4%)
        );
}

.coach-spotlight-copy {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    gap: 10px;
    padding: 0;
    min-height: 0;
}

.coach-section-kicker {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.78);
    color: #3f5a4f;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.coach-spotlight-copy h2 {
    margin: 0;
    color: var(--text-primary);
    font-size: clamp(26px, 3vw, 34px);
    line-height: 1.08;
    letter-spacing: 0;
}

.coach-spotlight-copy p {
    margin: 0;
    max-width: 480px;
    color: var(--text-secondary);
    font-size: 15px;
    line-height: 1.6;
}

.coach-spotlight-meta {
    display: flex;
    align-items: baseline;
    gap: 10px;
    margin-top: 2px;
    color: var(--text-muted);
    font-size: 13px;
}

.coach-spotlight-meta strong {
    color: var(--text-primary);
    font-size: 14px;
}

.coach-spotlight-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    padding: 0;
    border-left: 0;
    background: transparent;
}

.coach-spotlight-metric {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    padding: 14px;
    border-radius: 15px;
    border: 1px solid color-mix(in srgb, var(--border) 76%, transparent);
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    color: var(--text-primary);
    box-shadow: none;
}

.coach-spotlight-metric-link {
    text-decoration: none;
    cursor: pointer;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.coach-spotlight-metric-link:hover,
.coach-spotlight-metric-link:focus-visible {
    border-color: color-mix(in srgb, var(--accent) 54%, var(--border));
    box-shadow: 0 16px 30px rgba(15, 23, 42, 0.12);
    transform: translateY(-1px);
}

.coach-spotlight-metric-link:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--accent) 30%, transparent);
    outline-offset: 3px;
}

.coach-spotlight-metric .coach-metric-icon {
    width: 24px;
    height: 24px;
    flex: 0 0 auto;
}

.coach-spotlight-metric-copy {
    display: grid;
    gap: 4px;
}

.coach-spotlight-metric-copy strong {
    color: var(--text-primary);
    font-size: 24px;
    line-height: 1;
}

.coach-spotlight-metric-copy span {
    color: var(--text-muted);
    font-size: 13px;
}

.coach-followup-card {
    display: grid;
    align-content: start;
    gap: 14px;
    padding: 22px;
}

.coach-followup-head h2 {
    margin: 0 0 6px;
    color: var(--text-primary);
    font-size: 20px;
    line-height: 1.15;
}

.coach-followup-head p {
    margin: 0;
    color: var(--text-muted);
    font-size: 14px;
    line-height: 1.5;
}

.coach-followup-list {
    display: grid;
    gap: 10px;
}

.coach-followup-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    min-width: 0;
    padding: 14px;
    border: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
    border-radius: 15px;
    background: color-mix(in srgb, var(--surface) 94%, transparent);
}

.coach-followup-item-copy {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.coach-followup-item-copy strong {
    color: var(--text-primary);
    font-size: 15px;
}

.coach-followup-item-copy p {
    margin: 0;
    color: var(--text-muted);
    font-size: 13px;
    line-height: 1.45;
}

.coach-followup-item-meta {
    display: flex;
    justify-content: flex-end;
    width: 150px;
    min-width: 0;
}

.coach-followup-link {
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 36px;
    padding: 0 14px;
    border-radius: 10px;
    border: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
    background: color-mix(in srgb, var(--surface) 92%, transparent);
    color: var(--text-primary);
    font-size: 13px;
    font-weight: 700;
    line-height: 1.15;
    text-align: center;
    text-decoration: none;
}

.coach-secondary-grid--landing {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.coach-metric-card-summary {
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 0;
    padding: 18px 20px;
    border-radius: 22px;
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.05);
}

.coach-metric-card-summary .coach-metric-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: color-mix(in srgb, var(--surface-2) 76%, white);
}

.coach-metric-card-summary-copy {
    display: grid;
    gap: 4px;
}

.coach-metric-card-summary strong {
    font-size: 18px;
}

.coach-metric-card-summary span {
    font-size: 13px;
}

.coach-section-header--landing {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin: 6px 0 0;
}

.coach-section-header--landing h2 {
    margin: 0 0 6px;
}

.coach-section-header--landing p {
    margin: 0;
    color: var(--text-muted);
    font-size: 14px;
}

.coach-section-period {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--accent) 16%, white);
    color: var(--accent);
    font-size: 12px;
    font-weight: 800;
}

.coach-chart-grid--landing,
.coach-pie-grid--landing {
    gap: 18px;
}

.coach-panel--chart {
    padding: 22px 22px 18px;
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.06);
}

.coach-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

.coach-panel-head h2 {
    margin: 0;
}

@media (max-width: 1180px) {
    .tags-hero {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .tags-hero-action {
        justify-self: start;
    }

    .coach-priority-grid,
.coach-secondary-grid,
.coach-chart-grid,
.coach-pie-grid {
        grid-template-columns: 1fr;
    }

    .coach-priority-grid--landing,
    .coach-overview-spotlight,
    .coach-secondary-grid--landing {
        grid-template-columns: 1fr;
    }

    .coach-spotlight-card {
        grid-template-columns: 1fr;
    }

    .coach-spotlight-metrics {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 10px;
        padding: 0;
        border-left: 0;
        border-top: 0;
        background: transparent;
    }
}

@media (max-width: 820px) {
    .tags-hero {
        min-height: 0;
        padding: 20px;
        border-radius: 20px;
    }

    .tags-hero h1 {
        font-size: 34px;
    }

    .tags-hero-action {
        width: 100%;
    }

    .coach-dashboard-header {
        padding: 84px 20px 20px;
        border-radius: 0 0 22px 22px;
    }

    .coach-dashboard-header h1 {
        font-size: 30px;
    }

    .coach-panel {
        padding: 20px;
        border-radius: 24px;
    }

    .coach-section-header h2 {
        font-size: 24px;
    }

    .groups-member-row {
        flex-direction: column;
    }

    .groups-member-actions {
        width: 100%;
        justify-items: stretch;
    }

    .group-member-form {
        width: 100%;
    }

    .coach-metric-card strong {
        font-size: 28px;
    }

    .coach-dashboard--landing .coach-dashboard-header {
        margin: -20px -20px 0;
        padding: 22px 20px 20px;
        min-height: 120px;
    }

    .coach-dashboard--landing .coach-dashboard-header h1 {
        font-size: 36px;
    }

    .coach-followup-card {
        padding: 20px;
    }

    .coach-spotlight-card {
        padding: 20px;
    }

    .coach-followup-item,
    .coach-metric-card-summary {
        align-items: flex-start;
        flex-direction: column;
    }

    .coach-followup-item {
        grid-template-columns: 1fr;
    }

    .coach-followup-item-meta {
        justify-content: flex-start;
        width: auto;
    }

    .coach-followup-link {
        width: auto;
        max-width: none;
    }
}

@media (max-width: 640px) {
    .coach-spotlight-metrics {
        grid-template-columns: 1fr;
    }
}

.flow-page-header {
    margin-bottom: 24px;
}

.group-detail-header-main {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
    width: 100%;
}

.group-name-edit-form {
    display: flex;
    align-items: end;
    gap: 8px;
    flex-wrap: wrap;
}

.group-name-edit-field {
    display: grid;
    gap: 6px;
    min-width: 180px;
}

.group-name-edit-field span {
    color: rgba(248, 251, 247, 0.8);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.group-name-edit-field input,
.group-name-edit-field select {
    min-height: 38px;
    padding: 0 12px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 12px;
    background: rgba(9, 18, 27, 0.18);
    color: #f8fbf7;
    font-size: 14px;
}

.group-name-edit-field input::placeholder {
    color: rgba(248, 251, 247, 0.5);
}

.group-name-edit-form .secondary-action {
    min-height: 38px;
    padding: 0 14px;
}

html:not([data-theme="dark"]) .flow-page-header .dashboard-subtitle {
    color: #4f667b;
}

html:not([data-theme="dark"]) .flow-page-header .group-name-edit-field span {
    color: #5c7488;
}

html:not([data-theme="dark"]) .flow-page-header .group-name-edit-field input,
html:not([data-theme="dark"]) .flow-page-header .group-name-edit-field select {
    min-height: 40px;
    border-color: color-mix(in srgb, var(--border) 90%, white 10%);
    border-radius: 14px;
    background: color-mix(in srgb, var(--surface) 90%, white 10%);
    color: #223547;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

html:not([data-theme="dark"]) .flow-page-header .group-name-edit-field input::placeholder {
    color: #7a8d9e;
}

html:not([data-theme="dark"]) .flow-page-header .group-name-edit-field input:hover,
html:not([data-theme="dark"]) .flow-page-header .group-name-edit-field select:hover {
    border-color: color-mix(in srgb, var(--accent) 42%, var(--border));
    background: color-mix(in srgb, var(--surface) 86%, var(--accent-soft) 14%);
}

html:not([data-theme="dark"]) .flow-page-header .group-name-edit-field input:focus,
html:not([data-theme="dark"]) .flow-page-header .group-name-edit-field select:focus {
    outline: none;
    border-color: color-mix(in srgb, var(--accent) 62%, var(--border));
    box-shadow:
        0 0 0 4px color-mix(in srgb, var(--accent) 12%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

html:not([data-theme="dark"]) .flow-page-header .group-name-edit-form .secondary-action {
    min-height: 40px;
    border-color: color-mix(in srgb, var(--accent) 34%, var(--border));
    background: color-mix(in srgb, var(--surface) 92%, white 8%);
    color: #33506b;
}

html:not([data-theme="dark"]) .flow-page-header .group-name-edit-form .secondary-action:hover {
    background: color-mix(in srgb, var(--accent-soft) 72%, white 28%);
    color: #223547;
}

.dashboard-subtitle {
    margin: 8px 0 0;
    color: var(--text-muted);
    font-size: 15px;
    line-height: 1.7;
}

.flow-page-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(320px, 0.82fr);
    gap: 22px;
    align-items: start;
}

.flow-page-main {
    display: grid;
    gap: 22px;
}

.tag-flow-hero,
.flow-library-panel,
.member-card,
.member-profile-card {
    border: 1px solid var(--border);
    border-radius: 30px;
    background: var(--surface);
    box-shadow: var(--shadow-soft);
}

.tag-flow-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    padding: 26px 28px;
}

.tag-flow-hero h2,
.member-section-head h2 {
    margin: 10px 0 0;
    font-size: 28px;
    letter-spacing: -0.03em;
}

.tag-flow-hero p,
.flow-library-head p,
.member-detail-note p {
    margin: 10px 0 0;
    color: var(--text-muted);
    line-height: 1.7;
}

.flow-library-meta strong,
.member-detail-note strong {
    display: block;
    color: var(--text-primary);
}

.flow-board {
    display: grid;
    grid-template-columns: repeat(4, minmax(220px, 1fr));
    gap: 14px;
    overflow-x: auto;
    padding-bottom: 4px;
}

.flow-week-column {
    display: grid;
    gap: 12px;
    min-width: 220px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 24px;
    background: var(--surface);
    box-shadow: var(--shadow-soft);
}

.flow-week-column.is-active {
    border-color: color-mix(in srgb, var(--accent) 28%, var(--border));
    box-shadow: 0 26px 60px rgba(17, 24, 39, 0.12);
}

.flow-week-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.flow-week-head h3,
.member-card h2,
.member-profile-card h2 {
    margin: 0;
    font-size: 22px;
    letter-spacing: -0.03em;
}

.flow-week-head p,
.member-card-head p,
.member-detail-facts span {
    margin: 6px 0 0;
    color: var(--text-muted);
    font-size: 14px;
    line-height: 1.6;
}

.flow-week-focus,
.member-secondary-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 14px;
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--text-primary);
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
    transition: 0.18s ease;
}

.flow-week-focus:hover,
.member-secondary-link:hover {
    border-color: var(--accent);
    color: var(--accent);
    background: var(--accent-soft);
}

.app-recipes-shell,
.app-recipe-detail {
    display: grid;
    gap: 20px;
}

.app-recipes-hero,
.app-recipes-empty,
.app-recipe-detail-copy,
.app-recipe-card {
    border: 1px solid var(--border);
    border-radius: 24px;
    background: linear-gradient(180deg, var(--surface), var(--page-bg-elevated));
    box-shadow: var(--shadow-soft);
}

.app-recipes-hero,
.app-recipes-empty,
.app-recipe-detail-copy {
    padding: 24px;
}

.app-recipes-hero h1,
.app-recipes-empty h2,
.app-recipe-card h2 {
    margin: 0;
    color: var(--text-primary);
}

.app-recipes-hero p,
.app-recipes-empty p,
.app-recipe-card p,
.app-recipe-detail-copy {
    color: var(--text-secondary);
}

.app-recipes-hero p:last-child,
.app-recipes-empty p,
.app-recipe-card p {
    margin: 10px 0 0;
}

.app-recipes-search {
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: var(--shadow-soft);
}

.app-recipes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 20px;
}

.app-recipe-card {
    overflow: hidden;
}

.app-recipe-card-media {
    display: block;
    background: var(--surface-3);
}

.app-recipe-card-media .recipe-thumbnail {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    border: 0;
    border-radius: 0;
}

.app-recipe-card-body {
    display: grid;
    gap: 18px;
    padding: 20px;
}

.app-recipe-detail-image {
    width: 100%;
    max-height: 480px;
    border: 1px solid var(--border);
    border-radius: 24px;
    background: var(--surface);
    box-shadow: var(--shadow-soft);
    object-fit: cover;
}

.app-recipe-detail-copy {
    font-size: 16px;
    line-height: 1.8;
    white-space: normal;
}

.resource-category-admin-card p,
.resource-row-category,
.resource-detail-summary {
    color: #8a94a6;
}

.resources-admin-actions,
.resource-detail-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.resource-section-heading {
    margin: 0;
    color: #8a94a6;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.resource-category-admin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 18px;
}

.resource-category-admin-card,
.resource-article-card {
    border: 1px solid #202936;
    border-radius: 22px;
    background: #141b26;
}

.resource-category-admin-card {
    display: grid;
    gap: 14px;
    padding: 18px;
}

.resource-category-admin-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.resource-category-pill {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border: 1px solid color-mix(in srgb, var(--resource-accent) 32%, transparent);
    border-radius: 18px;
    background: color-mix(in srgb, var(--resource-surface) 86%, #0f1620 14%);
}

.resource-category-pill strong,
.resource-category-card strong,
.resource-article-title-row h2,
.resource-article-copy span,
.resource-detail-kicker {
    color: #f2f5f8;
}

.resource-category-pill span:last-child,
.resource-category-card span,
.resource-article-copy p,
.resource-article-copy span {
    color: #8691a7;
}

.resource-category-pill-icon,
.resource-row-media,
.resource-article-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
}

.resource-category-pill-icon {
    width: 48px;
    height: 48px;
    background: rgba(255, 255, 255, 0.08);
    font-size: 26px;
}

.resource-category-icon-svg {
    display: block;
    width: 32px;
    height: 32px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.resource-article-icon .resource-category-icon-svg,
.resource-category-pill-icon .resource-category-icon-svg {
    width: 28px;
    height: 28px;
}

.resource-detail-kicker .resource-category-icon-svg {
    width: 18px;
    height: 18px;
}

.resource-row {
    align-items: center;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 16px;
}

.resource-row-media {
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    border: 1px solid rgba(135, 157, 185, 0.22);
    background: rgba(255, 255, 255, 0.06);
    color: #9ec5ff;
    font-size: 18px;
    font-weight: 800;
    box-shadow: none;
}

.resource-row-media .resource-category-icon-svg {
    width: 22px;
    height: 22px;
}

.resource-row-category {
    display: inline-flex;
    margin-top: 10px;
    font-size: 13px;
}

.resource-category-form-grid {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.resource-category-form-shell {
    display: grid;
    gap: 24px;
}

.resource-category-page {
    display: grid;
    gap: 22px;
}

.resource-category-page__header {
    display: grid;
    gap: 12px;
}

.resource-category-page__header h1 {
    margin: 0;
    color: var(--text-primary);
    font-size: clamp(34px, 4.6vw, 54px);
    letter-spacing: -0.05em;
}

.resource-category-page__header .dashboard-subtitle {
    max-width: 760px;
    margin: 0;
    color: var(--text-secondary);
}

.resource-category-form-shell--refined {
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.resource-category-editor {
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) minmax(280px, 0.7fr);
    gap: 22px;
    align-items: start;
}

.resource-category-editor-main {
    display: grid;
    gap: 20px;
}

.resource-form-section,
.resource-category-preview-panel {
    padding: 22px;
    border: 1px solid #233041;
    border-radius: 24px;
    background: linear-gradient(180deg, #18222e, #141c26);
}

.resource-form-section {
    display: grid;
    gap: 18px;
}

.resource-form-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.resource-form-section-head h2,
.resource-category-preview-panel h2 {
    margin: 0 0 6px;
    color: #f4f7fb;
    font-size: 24px;
}

.resource-form-section-head p,
.resource-category-preview-panel p {
    margin: 0;
    color: #98a8bb;
    line-height: 1.6;
}

.resource-color-choice-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 12px;
}

.resource-color-choice {
    position: relative;
    display: block;
}

.resource-color-choice input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.resource-color-choice-card {
    display: grid;
    gap: 10px;
    padding: 14px;
    border: 1px solid #202936;
    border-radius: 18px;
    background: #151c25;
    cursor: pointer;
    transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.resource-color-choice-card:hover {
    transform: translateY(-1px);
    border-color: #39506b;
    box-shadow: 0 12px 30px rgba(5, 10, 16, 0.18);
}

.resource-color-choice-swatch {
    display: block;
    width: 100%;
    height: 54px;
    border-radius: 14px;
    background: var(--resource-choice-color);
}

.resource-color-choice-card.is-surface .resource-color-choice-swatch {
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
}

.resource-color-choice-meta {
    color: #d9dee7;
    font-size: 14px;
    font-weight: 700;
}

.resource-color-choice input:checked + .resource-color-choice-card {
    border-color: #8fb4d6;
    box-shadow: 0 0 0 4px rgba(143, 180, 214, 0.16);
}

.resource-category-preview-panel {
    position: sticky;
    top: 18px;
    display: grid;
    gap: 16px;
}

.resource-category-form-shell--refined .resource-form-section,
.resource-category-form-shell--refined .resource-category-preview-panel {
    padding: 24px;
    border-radius: 28px;
}

.resource-category-form-shell--refined .resource-form-section-head h2 {
    font-size: 20px;
    letter-spacing: -0.03em;
}

.resource-category-form-shell--refined .form-actions-row {
    margin-top: 0;
    padding-top: 18px;
    border-top: 1px solid var(--border);
}

.app-resources-shell,
.app-resource-detail {
    display: grid;
    gap: 24px;
}

.app-resources-header {
    display: grid;
    gap: 8px;
    max-width: 760px;
}

.app-resources-header h1 {
    margin: 0;
    color: #162336;
    font-size: clamp(36px, 4vw, 56px);
    line-height: 1.02;
    font-family: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
    font-weight: 700;
}

.app-resources-header p {
    margin: 0;
    color: #5b6f88;
    line-height: 1.65;
}

.resource-category-card {
    display: grid;
    gap: 14px;
    min-height: 180px;
    padding: 28px;
    border: 1px solid #273140;
    border-radius: 28px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--resource-surface) 96%, #131b24 4%), #161d28);
    text-decoration: none;
    transition: transform 0.18s ease, border-color 0.18s ease;
}

.resource-category-card.is-featured {
    grid-column: 1 / -1;
    min-height: 280px;
    align-content: start;
    padding: 40px 48px;
    border-color: color-mix(in srgb, var(--resource-accent) 36%, #273140 64%);
}

.resource-category-card.is-selected,
.resource-category-card:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--resource-accent) 45%, #273140 55%);
}

.resource-category-card-icon {
    font-size: 44px;
}

.resource-category-card strong {
    font-size: clamp(26px, 3vw, 38px);
}

.resource-category-card:not(.is-featured) strong {
    font-size: 28px;
}

.resource-category-card-cta {
    margin-top: auto;
    color: var(--resource-accent) !important;
    font-size: 16px;
    font-weight: 700;
}

.app-resources-search {
    background: #141b26;
    border: 1px solid #273140;
    box-shadow: none;
}

.resource-filter-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.resource-filter-row--secondary {
    margin-top: -10px;
}

.resource-filter-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 20px;
    border: 1px solid #d6dfeb;
    border-radius: 999px;
    background: #f3f6fa;
    color: #4d6179;
    font-size: 15px;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
}

.resource-filter-chip.is-active,
.resource-filter-chip:hover {
    border-color: #203044;
    background: #203044;
    color: #f6f9fc;
}

.resource-article-card {
    overflow: hidden;
}

.resource-article-card--featured {
    border-color: rgba(46, 204, 113, 0.3);
    box-shadow: inset 0 0 0 1px rgba(46, 204, 113, 0.08);
}

.resource-article-card.is-unseen {
    border-color: rgba(46, 204, 113, 0.34);
    box-shadow: inset 0 0 0 1px rgba(46, 204, 113, 0.1);
}

.resource-article-link {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 18px;
    padding: 22px 24px;
    text-decoration: none;
}

.resource-article-icon {
    width: 48px;
    height: 48px;
    background: rgba(255, 255, 255, 0.05);
    font-size: 28px;
}

.resource-article-copy {
    display: grid;
    gap: 8px;
    min-width: 0;
}

.resource-article-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.resource-article-title-row h2 {
    margin: 0;
    font-size: clamp(24px, 2.8vw, 30px);
}

.resource-article-copy p {
    margin: 0;
    font-size: clamp(18px, 2.5vw, 22px);
    line-height: 1.5;
}

.resource-article-copy span {
    font-size: 14px;
}

.resource-inline-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.resource-inline-tag,
.resource-featured-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
}

.resource-inline-tag {
    border: 1px solid rgba(128, 151, 181, 0.28);
    background: rgba(255, 255, 255, 0.05);
    color: #d4deea;
}

.resource-featured-badge {
    border: 1px solid rgba(46, 204, 113, 0.25);
    background: rgba(46, 204, 113, 0.16);
    color: #8ee0ae;
}

.resource-inline-tags + .resource-inline-tags {
    margin-top: 0;
}

.resource-row .recipe-row-main {
    gap: 10px;
}

.resource-tag-picker {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.resource-tag-option {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--surface-2);
    cursor: pointer;
}

.resource-tag-option input {
    margin: 0;
}

.resource-bookmark-indicator {
    color: #f4d35e;
    font-size: 20px;
}

.resource-storyboard {
    display: grid;
    gap: 18px;
}

.library-resource-category-modal-layout {
    display: grid;
    grid-template-columns: minmax(320px, 0.9fr) minmax(0, 1.1fr);
    gap: 22px;
    align-items: start;
}

.library-resource-category-modal-list {
    display: grid;
    gap: 16px;
}

.library-resource-category-form {
    gap: 18px;
}

.resource-support-grid,
.resource-article-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.resource-article-grid {
    margin-top: 4px;
}

.resource-article-card--hero,
.resource-article-card--support,
.resource-article-card--library {
    position: relative;
    border-color: color-mix(in srgb, var(--resource-card-accent, #4f7cff) 20%, #202936 80%);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--resource-card-surface, #1d2734) 86%, #141b26 14%), #141b26),
        linear-gradient(135deg, color-mix(in srgb, var(--resource-card-accent, #4f7cff) 14%, transparent), transparent 58%);
}

.resource-article-card--hero::before,
.resource-article-card--support::before,
.resource-article-card--library::before {
    content: '';
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: linear-gradient(180deg, var(--resource-card-accent, #4f7cff), transparent);
    opacity: 0.9;
}

.resource-article-link--hero,
.resource-article-link--support,
.resource-article-link--library {
    grid-template-columns: 1fr;
    gap: 14px;
    padding-left: 26px;
}

.resource-article-cover {
    overflow: hidden;
    border-radius: 20px;
    border: 1px solid color-mix(in srgb, var(--resource-card-accent, #4f7cff) 24%, rgba(255, 255, 255, 0.08));
    background: rgba(255, 255, 255, 0.04);
}

.resource-article-cover img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.resource-article-cover--hero {
    height: clamp(220px, 28vw, 320px);
}

.resource-article-cover--support,
.resource-article-cover--library {
    height: clamp(150px, 19vw, 190px);
}

.resource-article-kicker {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.resource-article-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    color: #9aa7ba;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.resource-article-link--hero .resource-article-icon,
.resource-article-link--support .resource-article-icon,
.resource-article-link--library .resource-article-icon {
    background: color-mix(in srgb, var(--resource-card-accent, #4f7cff) 18%, rgba(255, 255, 255, 0.03));
}

.resource-article-card--hero .resource-article-title-row h2 {
    font-size: clamp(30px, 4vw, 42px);
}

.resource-article-card--hero .resource-article-copy p {
    font-size: clamp(18px, 2vw, 21px);
    max-width: 58ch;
}

.resource-article-card--support .resource-article-title-row h2,
.resource-article-card--library .resource-article-title-row h2 {
    font-size: clamp(22px, 2.2vw, 28px);
}

.resource-article-card--support .resource-article-copy p,
.resource-article-card--library .resource-article-copy p {
    font-size: 16px;
    line-height: 1.65;
}

.app-resources-hero {
    display: grid;
    gap: 14px;
    padding: 24px;
    border: 1px solid color-mix(in srgb, var(--resource-accent) 24%, #273140 76%);
    border-radius: 24px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--resource-surface) 92%, #131b24 8%), #141b26);
}

.resource-detail-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.app-resources-hero h1 {
    margin: 0;
    color: #f2f5f8;
    font-size: clamp(30px, 5vw, 44px);
}

.app-resources-hero p {
    margin: 0;
    color: #b3bfd1;
    font-size: 18px;
    line-height: 1.6;
}

.resource-detail-cover {
    margin: 18px 0 0;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 22px;
    background: var(--surface-2);
}

.resource-detail-cover img {
    display: block;
    width: 100%;
    height: clamp(220px, 30vw, 340px);
    object-fit: cover;
}

.resource-detail-cover--admin {
    margin-bottom: 18px;
}

.resource-row-media.has-image {
    padding: 0;
    overflow: hidden;
}

.resource-row-media.has-image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.resource-detail-summary {
    margin-top: 0;
    margin-bottom: 18px;
    font-size: 18px;
}

html:not([data-theme="dark"]) .resource-article-card--hero,
html:not([data-theme="dark"]) .resource-article-card--support,
html:not([data-theme="dark"]) .resource-article-card--library {
    border-color: color-mix(in srgb, var(--resource-card-accent, #4f7cff) 18%, #d3dde8 82%);
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--surface) 92%, white 8%),
            color-mix(in srgb, var(--surface-2) 88%, white 12%)
        ),
        linear-gradient(
            135deg,
            color-mix(in srgb, var(--resource-card-accent, #4f7cff) 8%, transparent),
            transparent 62%
        );
    box-shadow: 0 18px 40px rgba(154, 170, 188, 0.14);
}

html:not([data-theme="dark"]) .resource-article-card--hero::before,
html:not([data-theme="dark"]) .resource-article-card--support::before,
html:not([data-theme="dark"]) .resource-article-card--library::before {
    opacity: 0.55;
}

html:not([data-theme="dark"]) .resource-article-meta,
html:not([data-theme="dark"]) .resource-article-copy p {
    color: #5d7085;
}

html:not([data-theme="dark"]) .resource-article-title-row h2,
html:not([data-theme="dark"]) .resource-article-copy strong,
html:not([data-theme="dark"]) .resource-article-kicker {
    color: #203244;
}

html:not([data-theme="dark"]) .resource-inline-tag {
    border-color: rgba(110, 130, 154, 0.22);
    background: rgba(255, 255, 255, 0.72);
    color: #51667d;
}

html:not([data-theme="dark"]) .resource-featured-badge {
    border-color: rgba(46, 204, 113, 0.22);
    background: rgba(46, 204, 113, 0.12);
    color: #2e7d57;
}

html:not([data-theme="dark"]) .resources-admin-page .resource-category-admin-card,
html:not([data-theme="dark"]) .resources-admin-page .resource-article-card {
    border-color: #d9e3ee;
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--surface) 95%, white 5%),
            color-mix(in srgb, var(--surface-2) 92%, white 8%)
        );
    box-shadow: 0 16px 36px rgba(160, 176, 194, 0.12);
}

html:not([data-theme="dark"]) .resources-admin-page .resource-category-admin-card {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(245, 249, 253, 0.96)),
        var(--surface);
    box-shadow: 0 16px 34px rgba(154, 170, 188, 0.12);
}

html:not([data-theme="dark"]) .resources-admin-page .resource-category-pill {
    border-color: color-mix(in srgb, var(--resource-accent, #4f7cff) 12%, #d7e3ef 88%);
    background: #fdfefe;
    box-shadow: none;
}

html:not([data-theme="dark"]) .resources-admin-page .resource-category-pill-icon {
    background: color-mix(in srgb, var(--resource-accent, #4f7cff) 10%, white 90%);
    color: #26405a;
}

html:not([data-theme="dark"]) .resources-admin-page .resource-category-pill strong,
html:not([data-theme="dark"]) .resources-admin-page .resource-row h2 {
    color: #223547;
}

html:not([data-theme="dark"]) .resources-admin-page .resource-category-pill span:last-child,
html:not([data-theme="dark"]) .resources-admin-page .resource-category-admin-card p,
html:not([data-theme="dark"]) .resources-admin-page .resource-row p,
html:not([data-theme="dark"]) .resources-admin-page .resource-row-category {
    color: #60758b;
}

html:not([data-theme="dark"]) .resources-admin-page .resource-category-pill div,
html:not([data-theme="dark"]) .resources-admin-page .resource-category-pill div span,
html:not([data-theme="dark"]) .resources-admin-page .resource-category-pill div strong {
    color: #223547;
}

html:not([data-theme="dark"]) .resources-admin-page .resource-category-pill div span:last-child {
    color: #6b7d91;
}

html:not([data-theme="dark"]) .resources-admin-page .resource-category-admin-card p {
    color: #566b80;
}

html:not([data-theme="dark"]) .resources-admin-page .resource-category-pill-icon,
html:not([data-theme="dark"]) .resources-admin-page .resource-row-media {
    background: color-mix(in srgb, var(--surface-2) 82%, white 18%);
}

html:not([data-theme="dark"]) .resource-row-media {
    border-color: #d7e4f1;
    background: #f3f8fc;
    color: #315c7d;
}

html:not([data-theme="dark"]) .resource-category-page__header .coach-dashboard-badge {
    background: #ffffff;
    color: #496680;
    border-color: #d7e4f1;
    box-shadow: 0 8px 18px rgba(154, 170, 188, 0.12);
}

html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-form-section,
html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-category-preview-panel {
    border-color: #d9e3ee;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(247, 250, 253, 0.97)),
        var(--surface);
    box-shadow: 0 18px 34px rgba(154, 170, 188, 0.12);
}

html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-form-section-head h2,
html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-category-preview-panel h2 {
    color: #223547;
}

html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-form-section-head p,
html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-category-preview-panel p {
    color: #61758a;
}

html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-color-choice-card {
    border-color: #d7e2ee;
    background: #ffffff;
    box-shadow: 0 10px 22px rgba(154, 170, 188, 0.08);
}

html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-color-choice-meta {
    color: #26405a;
}

html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-color-choice-card.is-surface .resource-color-choice-swatch {
    box-shadow: inset 0 0 0 1px rgba(38, 64, 90, 0.08);
}

html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-category-preview-panel {
    background:
        linear-gradient(180deg, rgba(248, 251, 255, 0.98), rgba(242, 247, 252, 0.96)),
        var(--surface);
}

html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-category-card.is-featured {
    box-shadow: 0 18px 34px rgba(15, 76, 58, 0.18);
}

html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-category-card strong {
    color: #f8fbff;
}

html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-category-card span {
    color: rgba(240, 246, 252, 0.88);
}

html:not([data-theme="dark"]) .resource-category-form-shell--refined .resource-category-card-cta {
    color: color-mix(in srgb, var(--resource-accent) 88%, white 12%) !important;
}

@media (max-width: 900px) {

    .resource-category-card.is-featured {
        grid-column: auto;
        min-height: 220px;
        padding: 28px;
    }

    .resource-support-grid,
    .resource-article-grid {
        grid-template-columns: 1fr;
    }

    .library-resource-category-modal-layout {
        grid-template-columns: 1fr;
    }

    .resource-article-cover--hero {
        height: 220px;
    }

    .resource-article-cover--support,
    .resource-article-cover--library,
    .resource-detail-cover img {
        height: 180px;
    }
}

@media (max-width: 640px) {
    .resource-article-link {
        grid-template-columns: 1fr;
    }

    .resource-article-icon {
        width: 44px;
        height: 44px;
    }

    .resource-filter-chip {
        min-height: 44px;
        padding: 0 16px;
        font-size: 14px;
    }

    .resource-article-cover--hero {
        height: 180px;
    }

    .resource-article-cover--support,
    .resource-article-cover--library,
    .resource-detail-cover img {
        height: 160px;
    }
}

.flow-section-card {
    display: grid;
    gap: 8px;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: var(--surface-2);
}

.flow-section-card.is-target,
.tag-flow-section.is-target {
    border-color: color-mix(in srgb, var(--accent) 24%, var(--border));
    background: color-mix(in srgb, var(--accent-soft) 52%, var(--surface) 48%);
}

.flow-section-head,
.member-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.flow-section-head strong {
    color: var(--text-primary);
    font-size: 15px;
}

.flow-add-link,
.flow-library-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0 14px;
    border: 0;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 68%, #ffffff));
    color: #fff;
    font-size: 13px;
    font-weight: 800;
    text-decoration: none;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
    box-shadow: 0 14px 30px rgba(79, 109, 138, 0.24);
}

.flow-add-link {
    width: 40px;
    padding: 0;
    font-size: 20px;
    line-height: 1;
}

.flow-add-link:hover,
.flow-library-action:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 34px rgba(79, 109, 138, 0.28);
}

.flow-section-list {
    display: grid;
    gap: 10px;
}

.flow-stage-board {
    display: grid;
    grid-template-columns: repeat(4, minmax(260px, 1fr));
    gap: 18px;
    overflow-x: auto;
    padding-bottom: 4px;
}

.flow-stage-column {
    display: grid;
    gap: 12px;
    min-width: 220px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 24px;
    background: var(--surface);
    box-shadow: var(--shadow-soft);
}

.flow-item-card {
    display: grid;
    grid-template-columns: 10px minmax(0, 1fr);
    gap: 10px;
    padding: 12px 12px 12px 10px;
    border-radius: 16px;
    background: var(--surface);
    border: 1px solid var(--border);
}

.flow-item-marker {
    border-radius: 999px;
    background: linear-gradient(180deg, var(--accent), color-mix(in srgb, var(--warning) 65%, var(--accent)));
}

.flow-item-card {
    cursor: pointer;
}

.flow-item-card.is-dragging {
    opacity: 0.55;
}

.flow-item-card-type-exercise .flow-item-marker {
    background: linear-gradient(180deg, #87b0d5, #4f6d8a);
}

.flow-item-card-type-headline .flow-item-marker {
    background: linear-gradient(180deg, #d9c3a5, #b68553);
}

.flow-item-card-type-video .flow-item-marker {
    background: linear-gradient(180deg, #b0c6d6, #7c97ad);
}

.flow-item-card-type-text .flow-item-marker {
    background: linear-gradient(180deg, #cab5a4, #937b67);
}

.flow-item-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 6px;
}

.flow-item-type,
.flow-item-duration {
    color: var(--text-muted);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.flow-item-video,
.flow-item-hint {
    display: block;
    margin-top: 8px;
    color: var(--text-muted);
    font-size: 12px;
    line-height: 1.5;
}

.flow-item-copy strong {
    display: block;
    color: var(--text-primary);
    line-height: 1.45;
}

.flow-item-copy p,
.flow-library-card-copy p {
    margin: 4px 0 0;
    color: var(--text-muted);
    font-size: 13px;
    line-height: 1.55;
}

.flow-item-empty,
.flow-library-empty,
.members-empty {
    padding: 14px 16px;
    border: 1px dashed var(--border);
    border-radius: 18px;
    color: var(--text-muted);
    font-size: 13px;
    line-height: 1.6;
    background: var(--surface);
}

.flow-library-panel {
    position: sticky;
    top: 22px;
    display: grid;
    gap: 16px;
    padding: 20px;
}

.flow-library-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.flow-library-head h2 {
    margin: 10px 0 0;
    font-size: 24px;
    letter-spacing: -0.03em;
}

.flow-library-manage-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
}

.flow-library-target {
    display: grid;
    gap: 10px;
}

.flow-library-target-item {
    padding: 14px 16px;
    border-radius: 18px;
    background: var(--surface-2);
    border: 1px solid var(--border);
}

.flow-library-target-item span {
    display: block;
    color: var(--text-muted);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.flow-library-target-item strong {
    display: block;
    margin-top: 6px;
    color: var(--text-primary);
}

.flow-library-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.flow-library-tab {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--surface-2);
    color: var(--text-muted);
    text-decoration: none;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
}

.flow-library-tab.active {
    border-color: color-mix(in srgb, var(--accent) 35%, var(--border));
    background: color-mix(in srgb, var(--accent) 20%, var(--surface-2));
    color: var(--text-primary);
}

.flow-library-meta,
.member-detail-note {
    padding: 16px 18px;
    border-radius: 20px;
    border: 1px solid var(--border);
    background: var(--surface-2);
}

.flow-library-list {
    display: grid;
    gap: 12px;
}

.flow-library-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 14px;
    border-radius: 18px;
    background: var(--surface-2);
    border: 1px solid var(--border);
}

.flow-library-card-copy strong {
    display: block;
    color: var(--text-primary);
}

.flow-library-footnote {
    color: var(--text-muted);
    font-size: 13px;
    line-height: 1.6;
}

.startup-builder {
    display: grid;
    gap: 16px;
}

.flow-builder-filter-button {
    border: 1px solid #d8e1ec;
    cursor: pointer;
}

.flow-builder-filter-button {
    min-height: 42px;
    padding: 0 14px;
    border-radius: 12px;
    font-size: 14px;
    font-weight: 600;
}

.flow-builder-filter-button {
    background: #fff;
    color: #334155;
}

.flow-app-preview-page {
    display: grid;
    gap: 22px;
}

.flow-app-preview-toolbar {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
}

.flow-app-preview-toolbar h1 {
    margin: 0;
    font-size: clamp(34px, 5vw, 58px);
    letter-spacing: -0.04em;
}

.flow-app-preview-toolbar p {
    max-width: 680px;
    margin: 8px 0 0;
    color: var(--text-secondary);
}

.flow-app-preview-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
}

.flow-app-preview-tab {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 18px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--surface);
    color: var(--text-secondary);
    text-decoration: none;
    font-weight: 800;
}

.flow-app-preview-tab.is-active {
    border-color: color-mix(in srgb, var(--accent) 42%, var(--border));
    background: color-mix(in srgb, var(--accent-soft) 75%, #fff);
    color: var(--accent);
}

.flow-app-preview-shell {
    display: grid;
    gap: 24px;
    padding: 24px;
    border: 1px solid var(--border);
    border-radius: 28px;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(247, 243, 235, 0.84));
    box-shadow: var(--shadow-soft);
}

.flow-app-preview-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.85fr);
    gap: 24px;
    min-height: 240px;
    padding: 28px;
    border-radius: 24px;
    background:
        linear-gradient(105deg, rgba(12, 55, 38, 0.92), rgba(15, 29, 39, 0.76)),
        url("https://images.unsplash.com/photo-1535131749006-b7f58c99034b?auto=format&fit=crop&w=1800&q=80");
    background-position: center;
    background-size: cover;
    color: #fff;
    overflow: hidden;
}

.flow-app-preview-app-label,
.flow-app-preview-section-head span,
.flow-app-preview-session-top span,
.flow-app-preview-detail-list span,
.flow-app-preview-test-card span {
    display: inline-flex;
    color: color-mix(in srgb, var(--accent) 70%, #6fc185);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.flow-app-preview-hero .flow-app-preview-app-label {
    color: #c9f5d2;
}

.flow-app-preview-hero h2 {
    max-width: 760px;
    margin: 8px 0 0;
    font-size: clamp(38px, 5vw, 64px);
    line-height: 1;
    letter-spacing: -0.05em;
}

.flow-app-preview-hero p,
.flow-app-preview-next p {
    max-width: 620px;
    color: rgba(255, 255, 255, 0.78);
}

.flow-app-preview-chips,
.flow-app-preview-row-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

.flow-app-preview-chips {
    margin-top: 20px;
}

.flow-app-preview-chips span,
.flow-app-preview-row-meta span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 11px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 850;
}

.flow-app-preview-chips span {
    background: rgba(255, 255, 255, 0.14);
    color: #fff;
}

.flow-app-preview-row-meta span {
    background: color-mix(in srgb, var(--accent-soft) 82%, #fff);
    color: color-mix(in srgb, var(--accent) 76%, #1b2f25);
}

.flow-app-preview-next {
    align-self: center;
    display: grid;
    gap: 12px;
    padding: 24px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 20px;
    background: rgba(10, 19, 28, 0.72);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.24);
    backdrop-filter: blur(18px);
}

.flow-app-preview-next span,
.flow-app-preview-next small {
    color: rgba(255, 255, 255, 0.72);
    font-size: 13px;
    font-weight: 800;
}

.flow-app-preview-next strong {
    font-size: 24px;
    line-height: 1.16;
}

.flow-app-preview-progress {
    display: block;
    width: 100%;
    height: 8px;
    overflow: hidden;
    border: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.16);
    appearance: none;
}

.flow-app-preview-progress--light {
    background: color-mix(in srgb, var(--accent-soft) 70%, #e8eee5);
}

.flow-app-preview-progress::-webkit-progress-bar {
    border-radius: inherit;
    background: transparent;
}

.flow-app-preview-progress::-webkit-progress-value {
    border-radius: inherit;
    background: linear-gradient(90deg, #78c783, #e6c464);
}

.flow-app-preview-progress::-moz-progress-bar {
    border-radius: inherit;
    background: linear-gradient(90deg, #78c783, #e6c464);
}

.flow-app-preview-grid,
.flow-app-preview-session {
    display: grid;
    grid-template-columns: minmax(320px, 0.88fr) minmax(0, 1.12fr);
    gap: 24px;
}

.flow-app-preview-panel,
.flow-app-preview-session-card,
.flow-app-preview-phone-list {
    border: 1px solid var(--border);
    border-radius: 24px;
    background: var(--surface);
    box-shadow: var(--shadow-soft);
}

.flow-app-preview-panel,
.flow-app-preview-session-card {
    padding: 24px;
}

.flow-app-preview-section-head,
.flow-app-preview-session-top,
.flow-app-preview-phone-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.flow-app-preview-section-head h2,
.flow-app-preview-session-top h2 {
    margin: 6px 0 0;
    font-size: clamp(28px, 3vw, 42px);
    line-height: 1.05;
    letter-spacing: -0.04em;
}

.flow-app-preview-section-head strong {
    color: var(--text-secondary);
    font-size: 18px;
}

.flow-app-preview-muted {
    color: var(--text-secondary);
}

.flow-app-preview-timeline {
    display: grid;
    gap: 14px;
    margin-top: 22px;
}

.flow-app-preview-row {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) 34px;
    align-items: center;
    gap: 16px;
    padding: 16px;
    border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
    border-radius: 18px;
    background: color-mix(in srgb, var(--surface) 86%, #f7fbf2);
    color: inherit;
    text-decoration: none;
}

.flow-app-preview-row.is-current,
.flow-app-preview-row:hover {
    border-color: color-mix(in srgb, var(--accent) 42%, var(--border));
    background: linear-gradient(135deg, rgba(240, 249, 236, 0.96), rgba(255, 255, 255, 0.98));
}

.flow-app-preview-step,
.flow-app-preview-detail-icon {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--accent);
    color: #fff;
    font-weight: 900;
}

.flow-app-preview-row-copy {
    display: grid;
    gap: 6px;
}

.flow-app-preview-row-copy strong {
    font-size: 18px;
}

.flow-app-preview-row-copy small,
.flow-app-preview-detail-card small,
.flow-app-preview-phone-list a strong + span {
    color: var(--text-secondary);
}

.flow-app-preview-chevron {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: color-mix(in srgb, var(--accent-soft) 78%, #fff);
    color: var(--accent);
    font-size: 28px;
    line-height: 1;
}

.flow-app-preview-focus-card,
.flow-app-preview-detail-card,
.flow-app-preview-detail-list section,
.flow-app-preview-test-card {
    border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(249, 246, 239, 0.94));
}

.flow-app-preview-focus-card,
.flow-app-preview-detail-list section,
.flow-app-preview-test-card {
    padding: 20px;
}

.flow-app-preview-focus-card h3 {
    margin: 0;
    font-size: 24px;
}

.flow-app-preview-focus-card p,
.flow-app-preview-detail-list p,
.flow-app-preview-test-card p {
    color: var(--text-secondary);
}

.flow-app-preview-detail-card {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) 22px;
    align-items: center;
    gap: 16px;
    margin-top: 16px;
    padding: 16px;
    color: inherit;
    text-decoration: none;
}

.flow-app-preview-phone-list {
    align-self: start;
    display: grid;
    gap: 12px;
    padding: 18px;
}

.flow-app-preview-phone-head {
    padding: 0 4px 10px;
    border-bottom: 1px solid var(--border);
}

.flow-app-preview-phone-list a {
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr);
    align-items: center;
    gap: 12px;
    padding: 14px;
    border: 1px solid transparent;
    border-radius: 16px;
    color: inherit;
    text-decoration: none;
}

.flow-app-preview-phone-list a span {
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--accent-soft);
    color: var(--accent);
    font-weight: 900;
}

.flow-app-preview-phone-list a.is-active {
    border-color: color-mix(in srgb, var(--accent) 42%, var(--border));
    background: color-mix(in srgb, var(--accent-soft) 74%, #fff);
}

.flow-app-preview-session-card {
    display: grid;
    gap: 22px;
}

.flow-app-preview-session-top {
    align-items: flex-end;
}

.flow-app-preview-session-top p {
    max-width: 760px;
    color: var(--text-secondary);
}

.flow-app-preview-media {
    overflow: hidden;
    border-radius: 20px;
    background: #12231c;
}

.flow-app-preview-media img {
    display: block;
    width: 100%;
    max-height: 340px;
    object-fit: cover;
}

.flow-app-preview-detail-list {
    display: grid;
    gap: 14px;
}

.flow-app-preview-detail-list section p:last-child,
.flow-app-preview-test-card p:last-child {
    margin-bottom: 0;
}

.flow-app-preview-test-card {
    display: grid;
    gap: 16px;
}

.flow-app-preview-score {
    display: grid;
    grid-template-columns: 48px minmax(80px, 140px) 48px;
    align-items: center;
    gap: 10px;
}

.flow-app-preview-score button,
.flow-app-preview-score strong {
    min-height: 52px;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: #fff;
    color: var(--accent);
    font-size: 24px;
    font-weight: 900;
    text-align: center;
}

.flow-app-preview-score strong {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 44px;
}

.flow-app-preview-test-card textarea {
    min-height: 110px;
    resize: vertical;
}

@media (max-width: 1100px) {
    .flow-app-preview-toolbar,
    .flow-app-preview-hero,
    .flow-app-preview-grid,
    .flow-app-preview-session {
        grid-template-columns: 1fr;
    }

    .flow-app-preview-toolbar {
        align-items: flex-start;
    }

    .flow-app-preview-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 700px) {
    .flow-app-preview-shell {
        padding: 14px;
        border-radius: 20px;
    }

    .flow-app-preview-hero,
    .flow-app-preview-panel,
    .flow-app-preview-session-card {
        padding: 18px;
    }

    .flow-app-preview-row {
        grid-template-columns: 34px minmax(0, 1fr);
    }

    .flow-app-preview-chevron {
        display: none;
    }

    .flow-app-preview-session-top {
        display: grid;
    }
}

@media (max-width: 820px) {
    .coach-dashboard .coach-secondary-grid,
    .admin-dashboard-mini-grid {
        grid-template-columns: 1fr;
    }

    .coach-dashboard .coach-metric-card-secondary {
        min-height: 0;
    }
}

@media (max-width: 1200px) {

    .members-page .member-list-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.startup-library-panel .form-field {
    margin: 0;
}

.startup-section-card .flow-section-list {
    gap: 8px;
}

.startup-section-card .flow-item-empty {
    padding: 12px 14px;
    border-radius: 14px;
    font-size: 13px;
    line-height: 1.45;
}

.startup-section-card.is-target {
    border-color: color-mix(in srgb, var(--accent) 45%, var(--border));
    background: color-mix(in srgb, var(--accent) 10%, var(--surface-2));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 18%, transparent);
}

.startup-section-card.is-target .startup-section-count {
    background: color-mix(in srgb, var(--accent) 22%, var(--surface));
    color: var(--text-primary);
}

.startup-library-panel .flow-library-target {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.startup-library-panel .flow-library-target-item {
    padding: 12px 14px;
    border-radius: 16px;
}

.startup-library-panel .flow-library-tabs {
    gap: 8px;
}

.startup-library-panel .flow-library-tab {
    min-height: 38px;
    padding: 0 12px;
}

.startup-library-panel .flow-library-card {
    padding: 14px 16px;
    border-radius: 18px;
}

.startup-library-panel .flow-library-card-copy strong {
    line-height: 1.35;
}

.startup-library-panel .flow-library-card-copy p {
    margin-top: 6px;
    font-size: 13px;
    line-height: 1.45;
}

.flow-section-list.is-drop-target {
    outline: 1px dashed color-mix(in srgb, var(--accent) 42%, transparent);
    outline-offset: 6px;
}

.flow-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(7, 12, 18, 0.64);
    z-index: 60;
}

.flow-modal {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    z-index: 70;
}

.flow-modal[hidden],
.flow-modal-backdrop[hidden] {
    display: none !important;
}

body.flow-modal-open {
    overflow: hidden;
}

.flow-modal-card {
    width: min(680px, 100%);
    padding: 24px;
    border: 1px solid var(--border);
    border-radius: 28px;
    background: var(--surface);
    box-shadow: 0 30px 80px rgba(5, 10, 18, 0.32);
}

.flow-modal-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.flow-modal-head h2 {
    margin: 10px 0 0;
    font-size: 28px;
    letter-spacing: -0.03em;
}

.flow-modal-head p {
    margin: 10px 0 0;
    color: var(--text-muted);
    line-height: 1.7;
}

.flow-modal-close {
    width: 42px;
    height: 42px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--surface-2);
    color: var(--text-primary);
    font-size: 24px;
    cursor: pointer;
}

.flow-modal-form {
    display: grid;
    gap: 14px;
}

.flow-modal-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.member-detail-grid {
    display: grid;
    gap: 20px;
}

.members-page {
    display: grid;
    gap: 20px;
}

.members-filter-grid .form-field--inline-placeholder {
    gap: 0;
}

.tag-select {
    width: 100%;
    min-height: 48px;
    padding: 0 18px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: color-mix(in srgb, var(--surface-2) 88%, #000 12%);
    color: var(--text-primary);
    font: inherit;
    font-weight: 650;
}

.members-filter-search .flow-library-action,
.members-filter-actions .member-secondary-link {
    min-height: 48px;
    padding: 0 18px;
    border-radius: 18px;
    font-weight: 750;
}

.members-filter-actions .member-secondary-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--surface-2) 72%, transparent);
    color: var(--text-muted);
    text-decoration: none;
    transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.members-filter-actions .member-secondary-link:hover {
    border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
    color: var(--text-primary);
    background: color-mix(in srgb, var(--surface-2) 90%, var(--accent) 10%);
}

.members-results-panel {
    max-height: calc(100vh - 290px);
    overflow-y: auto;
    padding: 16px;
    scrollbar-gutter: stable;
}

.members-results-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
    padding: 2px 2px 10px;
    position: sticky;
    top: 0;
    z-index: 2;
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    backdrop-filter: blur(10px);
}

.members-results-bulk-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.members-selection-count {
    color: var(--text-muted);
    font-size: 13px;
    font-weight: 750;
}

.members-select-all {
    margin: 0;
}

.members-results-panel::-webkit-scrollbar {
    width: 10px;
}

.members-results-panel::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: color-mix(in srgb, var(--accent) 28%, transparent);
}

.members-results-panel::-webkit-scrollbar-track {
    background: transparent;
}

.members-page .members-grid.members-list-view {
    grid-template-columns: 1fr;
    gap: 16px;
}

.member-card {
    display: grid;
    gap: 16px;
    padding: 22px;
    align-content: start;
}

.members-page .member-list-row {
    position: relative;
    gap: 0;
    padding: 18px 22px;
}

.members-page .member-list-row-main {
    display: grid;
    grid-template-columns: minmax(240px, 1.15fr) minmax(560px, 1.7fr) auto;
    gap: 16px;
    align-items: center;
}

.member-card-head {
    display: flex;
    align-items: center;
    gap: 14px;
}

.member-card-head > div:last-child {
    min-width: 0;
}

.member-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 18px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 24%, transparent), color-mix(in srgb, var(--warning) 18%, transparent));
    color: var(--text-primary);
    font-size: 18px;
    font-weight: 800;
}

.member-avatar.large {
    width: 64px;
    height: 64px;
    border-radius: 22px;
    font-size: 22px;
}

.member-detail-facts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.members-page .member-list-overview {
    align-self: start;
    justify-content: flex-start;
}

.members-page .member-list-stats div {
    min-height: 88px;
}

.member-detail-facts div {
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid var(--border);
    background: var(--surface-2);
}

.members-page .member-list-actions {
    justify-content: flex-end;
    align-self: center;
    flex-wrap: nowrap;
    gap: 10px;
}

.members-results-panel.is-selection-mode .member-select-control--members {
    opacity: 1;
    pointer-events: auto;
}

.members-page .member-list-tags {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
}

.tag-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.tag-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    background: var(--accent-soft);
    color: var(--accent);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.02em;
}

.tag-chip-removable {
    border: 0;
    cursor: pointer;
}

.tag-remove-form,
.tag-add-form {
    margin: 0;
}

.tag-add-form {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 18px;
}

.member-detail-grid {
    grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.85fr);
    align-items: start;
}

.member-detail-main,
.member-detail-side {
    display: grid;
    gap: 20px;
}

.member-profile-card {
    padding: 24px;
}

.member-section-head p {
    margin: 8px 0 0;
    max-width: 360px;
}

@media (max-width: 1280px) {
    .flow-page-shell,
.member-detail-grid,
.flow-stage-board {
        grid-template-columns: 1fr;
    }

    .flow-library-panel {
        position: static;
    }

    .members-page .member-list-row-main {
        grid-template-columns: minmax(0, 1fr);
    }

    .members-page .member-list-actions {
        justify-content: flex-start;
        flex-wrap: wrap;
    }
}

@media (max-width: 820px) {
    .tag-flow-hero,
.flow-library-panel,
.member-card,
.member-profile-card {
        padding: 20px;
        border-radius: 24px;
    }

    .tag-flow-hero,
.flow-library-head,
.flow-library-card,
.tag-add-form,
.flow-modal-grid {
        flex-direction: column;
        align-items: stretch;
    }

    .members-page .member-list-stats {
        grid-template-columns: 1fr;
    }

    .tag-flow-hero h2,
.flow-library-head h2,
.member-section-head h2 {
        font-size: 24px;
    }

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

    .members-page .member-list-row {
        padding: 18px;
    }

    .members-page .member-list-tags {
        margin-top: 14px;
        padding-top: 14px;
    }

    .flow-modal-grid {
        display: grid;
        grid-template-columns: 1fr;
    }
}

.module-option-grid {
    display: grid;
    gap: 16px;
}

.module-option-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 14px;
}

.module-option-card {
    display: grid;
    gap: 12px;
    padding: 18px;
    border: 1px solid var(--border);
    border-radius: 22px;
    background: var(--surface-2);
}

.module-option-card {
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
    cursor: pointer;
}

.module-option-card input {
    margin-top: 4px;
}

.module-option-copy strong {
    display: block;
    color: var(--text-primary);
    font-size: 16px;
}

.module-option-copy span {
    color: var(--text-muted);
    line-height: 1.6;
}

.module-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.module-chip {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: var(--accent-soft);
    color: var(--accent);
    font-size: 12px;
    font-weight: 800;
}

.segment-chip {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--warning) 12%, var(--surface-2));
    color: var(--text-primary);
    border: 1px solid var(--border);
    font-size: 12px;
    font-weight: 700;
}

.module-chip-muted {
    background: var(--surface-2);
    color: var(--text-muted);
    border: 1px solid var(--border);
}

.customer-admin-page {
    display: grid;
    gap: 20px;
}

.customer-admin-header,
.customer-admin-toolbar,
.customer-admin-card,
.customer-admin-card-main,
.customer-admin-card-actions {
    display: flex;
}

.customer-admin-header {
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.customer-admin-header h1 {
    margin: 0;
    color: var(--text-primary);
    font-size: clamp(28px, 4vw, 42px);
    line-height: 1.05;
}

.customer-admin-header p {
    margin: 8px 0 0;
    color: var(--text-muted);
    line-height: 1.5;
}

.customer-admin-primary,
.customer-admin-secondary {
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 850;
    text-decoration: none;
    white-space: nowrap;
}

.customer-admin-primary {
    border: 1px solid color-mix(in srgb, var(--accent) 38%, transparent);
    background: linear-gradient(135deg, var(--accent), var(--accent-strong));
    color: #ffffff;
    box-shadow: 0 16px 28px color-mix(in srgb, var(--accent) 18%, transparent);
}

.customer-admin-secondary {
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--text-secondary);
}

.customer-admin-primary svg,
.customer-admin-secondary svg,
.customer-admin-meta svg {
    width: 16px;
    height: 16px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.customer-admin-overview {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

.customer-admin-kpis {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.customer-admin-kpi,
.customer-admin-module-overview,
.customer-admin-shell,
.customer-admin-card {
    border: 1px solid color-mix(in srgb, var(--border) 86%, white 14%);
    border-radius: 16px;
    background: color-mix(in srgb, var(--surface) 96%, white 4%);
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.055);
}

.customer-admin-kpi {
    display: grid;
    gap: 6px;
    min-height: 120px;
    padding: 16px;
    align-content: start;
}

.customer-admin-kpi--primary {
    border-color: color-mix(in srgb, var(--accent) 30%, var(--border));
    background: linear-gradient(180deg, color-mix(in srgb, var(--accent-soft) 54%, white 46%), #ffffff);
}

.customer-admin-kpi span,
.customer-admin-module-overview h2 {
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.customer-admin-kpi strong {
    color: var(--text-primary);
    font-size: 34px;
    line-height: 1;
    font-weight: 950;
}

.customer-admin-kpi p,
.customer-admin-module-overview p {
    margin: 0;
    color: var(--text-muted);
    font-size: 13px;
    line-height: 1.35;
}

.customer-admin-module-overview {
    display: grid;
    gap: 16px;
    padding: 16px;
}

.customer-admin-module-overview h2 {
    margin: 0;
}

.customer-admin-module-bars,
.customer-admin-module-bar {
    display: grid;
    gap: 10px;
}

.customer-admin-module-bar > div {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 800;
}

.customer-admin-module-bar strong {
    color: var(--text-primary);
    font-size: 13px;
}

.customer-admin-module-track {
    overflow: hidden;
    display: block;
    height: 8px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-3) 76%, white 24%);
}

.customer-admin-module-track span {
    display: block;
    height: 100%;
    min-width: 4px;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--accent), var(--accent-strong));
}

.admin-module-distribution-panel {
    grid-area: modules;
    min-height: 0;
    display: grid;
    align-content: start;
    gap: 18px;
}

.admin-module-distribution-panel h2 {
    margin: 0;
    color: var(--text-primary);
    font-size: 26px;
    line-height: 1.1;
    letter-spacing: 0;
}

.admin-module-distribution-panel p {
    margin: 6px 0 0;
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.4;
}

.admin-module-distribution-panel .customer-admin-module-bars {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 24px;
    row-gap: 14px;
}

.admin-module-distribution-row {
    color: inherit;
    text-decoration: none;
}

.admin-module-distribution-row:hover > div span,
.admin-module-distribution-row:focus-visible > div span {
    color: var(--accent-strong);
}

.admin-module-distribution-row:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--accent) 24%, white);
    outline-offset: 4px;
    border-radius: 12px;
}

.customer-admin-shell {
    display: grid;
    gap: 14px;
    padding: 16px;
}

.customer-admin-toolbar {
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.customer-admin-search {
    position: relative;
    flex: 1 1 20rem;
}

.customer-admin-search svg {
    position: absolute;
    left: 14px;
    top: 50%;
    width: 18px;
    height: 18px;
    transform: translateY(-50%);
    fill: none;
    stroke: var(--text-muted);
    stroke-width: 2;
}

.customer-admin-search input {
    width: 100%;
    min-height: 44px;
    padding-left: 44px;
    border-radius: 10px;
}

.customer-admin-segments {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.customer-admin-segments a,
.customer-admin-count {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 0 12px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--surface-2);
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 850;
    text-decoration: none;
}

.customer-admin-segments a.is-active {
    border-color: color-mix(in srgb, var(--accent) 34%, var(--border));
    background: var(--accent-soft);
    color: var(--accent);
}

.customer-admin-list {
    display: grid;
    gap: 12px;
}

.customer-admin-card {
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 16px;
}

.customer-admin-card-main {
    align-items: flex-start;
    gap: 14px;
    min-width: 0;
}

.customer-admin-icon {
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: color-mix(in srgb, var(--accent-soft) 60%, white 40%);
    color: var(--accent);
}

.customer-admin-icon-golf {
    background: color-mix(in srgb, #dcfce7 70%, white 30%);
    color: #1f7a43;
}

.customer-admin-icon-recovery {
    background: color-mix(in srgb, #ccfbf1 70%, white 30%);
    color: #0f766e;
}

.customer-admin-icon svg {
    width: 22px;
    height: 22px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.customer-admin-card-copy {
    display: grid;
    gap: 10px;
    min-width: 0;
}

.customer-admin-card-copy > strong {
    overflow: hidden;
    color: var(--text-primary);
    font-size: 18px;
    line-height: 1.2;
    text-overflow: ellipsis;
}

.customer-admin-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    color: var(--text-muted);
    font-size: 13px;
}

.customer-admin-meta span,
.customer-admin-card-stats span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.customer-admin-card-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.customer-admin-card-stats span {
    min-height: 28px;
    padding: 0 10px;
    border: 1px solid color-mix(in srgb, var(--border) 84%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-2) 74%, white 26%);
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 800;
}

.customer-admin-card-actions {
    position: relative;
    flex: 0 0 auto;
    align-items: center;
    gap: 10px;
}

.customer-admin-menu {
    position: relative;
}

.customer-admin-menu summary {
    list-style: none;
    cursor: pointer;
}

.customer-admin-menu summary::-webkit-details-marker {
    display: none;
}

.customer-admin-menu .row-menu-panel {
    right: 0;
    border-color: color-mix(in srgb, var(--border) 86%, white 14%);
    background: var(--surface);
    box-shadow: 0 18px 38px rgba(15, 23, 42, 0.14);
}

.customer-admin-menu-label {
    padding: 8px 10px 2px;
    color: var(--text-muted);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.customer-admin-menu .row-menu-link {
    color: var(--text-secondary);
    font-weight: 800;
}

.customer-admin-menu .row-menu-link:hover {
    background: var(--surface-2);
    color: var(--text-primary);
}

.customer-detail-page {
    gap: 16px;
}

.customer-detail-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.customer-detail-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--text-muted);
    font-size: 13px;
    font-weight: 800;
}

.customer-detail-breadcrumb a {
    color: var(--accent);
    text-decoration: none;
}

.customer-detail-title {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 10px;
}

.customer-detail-title h1 {
    margin: 0;
    color: var(--text-primary);
    font-size: clamp(28px, 4vw, 42px);
    line-height: 1.05;
}

.customer-detail-header p {
    margin: 8px 0 0;
    color: var(--text-muted);
}

.customer-detail-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

.customer-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 0 10px;
    border: 1px solid color-mix(in srgb, #22c55e 28%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, #dcfce7 82%, white 18%);
    color: #15803d;
    font-size: 12px;
    font-weight: 900;
    white-space: nowrap;
}

.customer-status-pill-muted {
    border-color: color-mix(in srgb, var(--border) 90%, transparent);
    background: var(--surface-2);
    color: var(--text-muted);
}

.customer-detail-tabs {
    display: flex;
    align-items: center;
    gap: 0;
    overflow-x: auto;
    padding: 0 14px;
    border: 1px solid color-mix(in srgb, var(--border) 86%, white 14%);
    border-radius: 8px;
    background: var(--surface);
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.045);
}

.customer-detail-tabs a {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 28px;
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 850;
    text-decoration: none;
    white-space: nowrap;
}

.customer-detail-tabs a::after {
    content: "";
    position: absolute;
    right: 16px;
    bottom: 0;
    left: 16px;
    height: 2px;
    border-radius: 999px 999px 0 0;
    background: transparent;
}

.customer-detail-tabs a.is-active {
    color: var(--text-primary);
}

.customer-detail-tabs a.is-active::after {
    background: var(--accent);
}

.customer-detail-panel,
.customer-detail-summary .customer-detail-metric,
.customer-detail-contact > div,
.customer-detail-module-card {
    border: 1px solid color-mix(in srgb, var(--border) 86%, white 14%);
    border-radius: 10px;
    background: var(--surface);
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.045);
}

.customer-detail-panel {
    display: grid;
    gap: 16px;
    padding: 18px;
}

.customer-detail-panel h2 {
    margin: 0;
    color: var(--text-primary);
    font-size: 18px;
    line-height: 1.2;
}

.customer-detail-panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.customer-detail-panel-head > div {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.customer-detail-panel-head p {
    margin: 0;
    color: var(--text-muted);
    font-size: 13px;
    line-height: 1.45;
}

.customer-detail-summary {
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.customer-detail-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.customer-detail-metric {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    min-height: 86px;
    padding: 14px;
}

.customer-detail-metric div {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.customer-detail-metric span:not(.customer-admin-icon),
.customer-detail-contact p,
.customer-detail-list dt,
.detail-list dt {
    color: var(--text-secondary);
    font-size: 12px;
    line-height: 1.25;
    font-weight: 800;
}

.customer-detail-metric strong {
    color: var(--text-primary);
    font-size: 22px;
    line-height: 1;
    font-weight: 950;
}

.customer-detail-contact {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.customer-detail-contact > div {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    min-height: 86px;
    padding: 14px;
}

.customer-detail-contact p {
    display: grid;
    gap: 5px;
    margin: 0;
}

.customer-detail-contact strong {
    overflow: hidden;
    color: var(--text-primary);
    font-size: 15px;
    line-height: 1.2;
    text-overflow: ellipsis;
}

.customer-detail-overview-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(20rem, 0.95fr);
    gap: 16px;
    align-items: start;
}

.customer-detail-side-stack {
    display: grid;
    gap: 16px;
}

.customer-detail-module-grid {
    display: grid;
    gap: 14px;
}

.customer-detail-module-card {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr);
    gap: 14px;
    padding: 16px;
    box-shadow: none;
}

.customer-detail-module-card > div {
    display: grid;
    gap: 10px;
    min-width: 0;
}

.customer-detail-module-head {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.customer-detail-module-head strong {
    color: var(--text-primary);
    font-size: 17px;
    line-height: 1.2;
}

.customer-detail-module-card p {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.45;
}

.customer-detail-module-card ul {
    display: grid;
    gap: 5px;
    margin: 0 0 2px 18px;
    padding: 0;
    color: var(--text-primary);
    font-size: 13px;
    line-height: 1.35;
}

.customer-detail-module-card .customer-admin-secondary,
.customer-detail-empty .customer-admin-secondary {
    width: fit-content;
    min-height: 34px;
    padding-inline: 14px;
    border-radius: 8px;
}

.customer-detail-empty {
    display: grid;
    justify-items: center;
    gap: 12px;
    min-height: 190px;
    align-content: center;
    text-align: center;
}

.customer-detail-empty > div {
    display: grid;
    justify-items: center;
    gap: 8px;
}

.customer-detail-empty strong {
    color: var(--text-primary);
}

.customer-detail-empty p {
    max-width: 36ch;
    margin: 0;
    color: var(--text-muted);
    font-size: 13px;
    line-height: 1.45;
}

.customer-detail-list,
.detail-list {
    display: grid;
    gap: 0;
    margin: 0;
}

.customer-detail-list div,
.detail-list div {
    display: grid;
    grid-template-columns: minmax(8rem, 0.75fr) minmax(0, 1fr);
    gap: 14px;
    padding: 9px 0;
    border-bottom: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
}

.customer-detail-list div:last-child,
.detail-list div:last-child {
    border-bottom: 0;
}

.customer-detail-list dt,
.customer-detail-list dd,
.detail-list dt,
.detail-list dd {
    margin: 0;
}

.customer-detail-list dd,
.detail-list dd {
    overflow-wrap: anywhere;
    color: var(--text-primary);
    font-size: 13px;
    font-weight: 750;
}

.customer-detail-two-column,
.customer-detail-content-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.customer-detail-content-link {
    display: grid;
    gap: 8px;
    min-height: 88px;
    padding: 16px;
    border: 1px solid color-mix(in srgb, var(--border) 86%, white 14%);
    border-radius: 10px;
    background: var(--surface);
    color: var(--text-secondary);
    text-decoration: none;
}

.customer-detail-content-link strong {
    color: var(--text-primary);
    font-size: 24px;
}

.organization-account-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.organization-account-stats span {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 10px;
    border: 1px solid color-mix(in srgb, var(--border) 84%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-2) 74%, white 26%);
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 850;
}

.organization-account-list {
    display: grid;
    gap: 10px;
}

.organization-account-list--compact {
    max-height: 360px;
    overflow: auto;
    padding-right: 2px;
}

.organization-account-row {
    display: grid;
    grid-template-columns: minmax(14rem, 1.35fr) minmax(10rem, 0.85fr) minmax(8rem, 0.65fr) auto;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
    border-radius: 10px;
    background: color-mix(in srgb, var(--surface-2) 58%, var(--surface) 42%);
}

.organization-account-list--compact .organization-account-row {
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
}

.organization-account-identity {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    min-width: 0;
}

.organization-account-avatar {
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 10px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 22%, transparent), color-mix(in srgb, var(--warning) 14%, transparent));
    color: var(--text-primary);
    font-size: 15px;
    font-weight: 900;
    letter-spacing: 0;
}

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

.organization-account-identity > span:last-child,
.organization-account-meta {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.organization-account-identity strong,
.organization-account-meta strong {
    overflow: hidden;
    color: var(--text-primary);
    font-size: 14px;
    line-height: 1.2;
    text-overflow: ellipsis;
}

.organization-account-identity small,
.organization-account-meta span {
    overflow: hidden;
    color: var(--text-muted);
    font-size: 12px;
    line-height: 1.25;
    text-overflow: ellipsis;
}

.organization-account-roles {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.organization-account-actions {
    display: flex;
    justify-content: flex-end;
}

.organization-audit-scroll {
    max-height: 620px;
    overflow-y: auto;
    padding-right: 4px;
}

.organization-audit-list {
    display: grid;
    gap: 10px;
}

.organization-audit-row {
    display: grid;
    grid-template-columns: minmax(8rem, 0.32fr) minmax(0, 1fr);
    gap: 14px;
    align-items: start;
    padding: 14px;
    border: 1px solid color-mix(in srgb, var(--border) 84%, transparent);
    border-radius: 10px;
    background: color-mix(in srgb, var(--surface-2) 58%, var(--surface) 42%);
}

.organization-audit-event {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    min-height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--accent) 10%, var(--surface));
    color: var(--accent);
    font-size: 12px;
    font-weight: 850;
    white-space: nowrap;
}

.organization-audit-event-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: currentColor;
}

.organization-audit-main {
    display: grid;
    gap: 7px;
    min-width: 0;
}

.organization-audit-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.organization-audit-head strong {
    min-width: 0;
    overflow-wrap: anywhere;
    color: var(--text-primary);
    font-size: 14px;
    line-height: 1.25;
}

.organization-audit-head time,
.organization-audit-meta {
    color: var(--text-muted);
    font-size: 12px;
    line-height: 1.3;
}

.organization-audit-head time {
    flex: 0 0 auto;
    white-space: nowrap;
}

.organization-audit-meta,
.organization-audit-changes {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.organization-audit-meta span {
    display: inline-flex;
    align-items: center;
}

.organization-audit-meta span + span::before {
    content: "/";
    margin-right: 6px;
    color: var(--border-strong);
}

.organization-audit-changes {
    margin-top: 3px;
}

.organization-audit-changes span {
    min-width: 0;
    max-width: 100%;
    padding: 5px 8px;
    border-radius: 8px;
    background: var(--surface);
    color: var(--text-secondary);
    font-size: 12px;
    line-height: 1.35;
    font-weight: 750;
    overflow-wrap: anywhere;
}

.audit-toolbar {
    display: flex;
    align-items: end;
    gap: 12px;
    flex-wrap: wrap;
}

.audit-filter-field {
    display: grid;
    gap: 6px;
    flex: 1 1 18rem;
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 850;
}

.audit-filter-field-compact {
    flex-basis: 12rem;
}

.audit-scroll-panel {
    max-height: 520px;
    overflow: auto;
}

.audit-timeline {
    display: grid;
    gap: 12px;
}

.audit-item {
    display: grid;
    grid-template-columns: 12px minmax(0, 1fr);
    gap: 10px;
}

.audit-dot {
    width: 10px;
    height: 10px;
    margin-top: 16px;
    border-radius: 999px;
    background: var(--accent);
}

.audit-card {
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--surface-2);
}

.audit-card-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
}

.audit-card p {
    margin: 6px 0 0;
    color: var(--text-muted);
}

.audit-change-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 10px;
}

.audit-change-list span {
    padding: 4px 8px;
    border-radius: 999px;
    background: var(--surface);
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 800;
}

@media (max-width: 1180px) {
    .customer-admin-overview {
        grid-template-columns: 1fr;
    }

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

    .customer-detail-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

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

@media (max-width: 760px) {
    .customer-admin-header,
    .customer-admin-card {
        display: grid;
    }

    .customer-admin-header .customer-admin-primary,
    .customer-admin-card-actions,
    .customer-admin-card-actions .customer-admin-primary,
    .customer-admin-card-actions .customer-admin-menu,
    .customer-admin-card-actions .customer-admin-secondary {
        width: 100%;
    }

    .customer-admin-kpis {
        grid-template-columns: 1fr;
    }

    .customer-detail-header,
    .customer-detail-actions,
    .customer-detail-contact,
    .customer-detail-metrics,
    .customer-detail-two-column,
    .customer-detail-content-grid {
        grid-template-columns: 1fr;
    }

    .customer-detail-header,
    .customer-detail-actions {
        display: grid;
    }

    .customer-detail-panel-head,
    .organization-account-actions {
        display: grid;
        justify-content: stretch;
    }

    .customer-detail-actions .customer-admin-primary,
    .customer-detail-actions .customer-admin-secondary,
    .customer-detail-actions .customer-admin-menu,
    .customer-detail-actions summary,
    .customer-detail-panel-head .customer-admin-secondary,
    .organization-account-actions .customer-admin-secondary {
        width: 100%;
    }

    .customer-detail-tabs a {
        padding: 0 18px;
    }

    .customer-detail-module-card {
        grid-template-columns: 1fr;
    }

    .customer-detail-list div,
    .detail-list div {
        grid-template-columns: 1fr;
        gap: 4px;
    }

    .organization-account-row {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .organization-audit-row {
        grid-template-columns: 1fr;
    }

    .organization-audit-head {
        display: grid;
        gap: 4px;
    }

    .organization-audit-head time {
        white-space: normal;
    }
}

.staff-layout {
    display: grid;
    gap: 20px;
}

.tags-header.compact {
    margin-bottom: 16px;
}

.staff-row-card {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    padding: 18px;
    border: 1px solid var(--border);
    border-radius: 22px;
    background: var(--surface-2);
}

.staff-inline-form {
    flex: 1 1 auto;
}

.staff-inline-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.staff-inline-actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 14px;
}

.segments-page,
.segment-summary-grid,
.segment-summary-list {
    display: grid;
    gap: 20px;
}

.segment-summary-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-bottom: 20px;
}

.segment-summary-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 16px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: var(--surface-2);
}

.segment-summary-item strong {
    color: var(--text-primary);
}

.segment-summary-item span {
    color: var(--accent);
    font-size: 18px;
    font-weight: 800;
}

.groups-page,
.groups-hero-grid,
.groups-layout {
    display: grid;
    gap: 20px;
}

.groups-hero-grid,
.groups-layout {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.group-summary-grid {
    grid-template-columns: minmax(320px, 0.95fr) minmax(0, 1.45fr);
    align-items: start;
}

.group-summary-card {
    display: grid;
    gap: 14px;
}

.group-card {
    display: grid;
    gap: 16px;
    padding: 20px;
    border: 1px solid var(--border);
    border-radius: 24px;
    background: var(--surface-2);
}

.group-detail-page {
    gap: 20px;
}

.groups-detail-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.audit-timeline {
    display: grid;
    gap: 14px;
    margin-top: 18px;
}

.audit-item {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    gap: 14px;
}

.audit-dot {
    width: 12px;
    height: 12px;
    margin-top: 18px;
    border-radius: 999px;
    background: var(--accent);
    box-shadow: 0 0 0 6px var(--accent-soft);
}

.audit-card {
    padding: 16px 18px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: var(--surface-2);
}

.audit-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.audit-card-head strong {
    color: var(--text-primary);
}

.audit-card-head span,
.audit-card p,
.audit-change-list span {
    color: var(--text-muted);
}

.audit-card p {
    margin: 6px 0 0;
}

.audit-change-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.audit-change-list span {
    display: inline-flex;
    min-height: 28px;
    align-items: center;
    padding: 0 10px;
    border-radius: 999px;
    background: var(--surface);
    font-size: 12px;
    font-weight: 700;
}

.audit-toolbar {
    display: grid;
    grid-template-columns: minmax(0, 1.7fr) minmax(220px, .7fr) auto;
    gap: 14px;
    align-items: end;
}

.audit-filter-field {
    display: grid;
    gap: 8px;
}

.audit-filter-field span {
    color: var(--text-muted);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.audit-filter-field-compact {
    max-width: 280px;
}

.audit-scroll-panel {
    max-height: 780px;
    padding-right: 6px;
    overflow-y: auto;
}

.audit-scroll-panel::-webkit-scrollbar {
    width: 10px;
}

.audit-scroll-panel::-webkit-scrollbar-thumb {
    border: 2px solid transparent;
    border-radius: 999px;
    background: var(--surface-3);
    background-clip: padding-box;
}

@media (max-width: 760px) {
    .audit-toolbar {
        grid-template-columns: 1fr;
    }

    .audit-filter-field-compact {
        max-width: none;
    }

    .audit-toolbar button {
        width: 100%;
    }
}

.group-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.group-card-head strong {
    color: var(--text-primary);
}

.groups-member-link {
    color: inherit;
    text-decoration: none;
}

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

.group-card-head p {
    margin: 6px 0 0;
    color: var(--text-muted);
    line-height: 1.6;
}

@media (max-width: 820px) {
    .group-summary-grid {
        grid-template-columns: 1fr;
    }

    .resource-category-editor {
        grid-template-columns: 1fr;
    }

    .resource-category-preview-panel {
        position: static;
    }

    .module-option-grid {
        grid-template-columns: 1fr;
    }

    .staff-row-card {
        flex-direction: column;
        align-items: stretch;
    }

    .staff-inline-grid {
        grid-template-columns: 1fr;
    }

    .segment-summary-grid {
        grid-template-columns: 1fr;
    }

    .groups-hero-grid,
.groups-layout {
        grid-template-columns: 1fr;
    }

    .group-card-head {
        flex-direction: column;
        align-items: stretch;
    }

    .group-bulk-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .group-bulk-toolbar-copy,
    .group-member-form {
        min-width: 0;
    }

    .group-member-form {
        grid-template-columns: 1fr;
    }

    .group-member-filter-grid {
        grid-template-columns: 1fr;
    }

    .group-member-filter-actions {
        justify-content: stretch;
    }

    .group-member-filter-actions > * {
        width: 100%;
    }

    .active-groups-panel {
        position: static;
    }
}

.member-hero {
    border: 1px solid color-mix(in srgb, var(--border) 76%, transparent);
    border-radius: 24px;
}

.member-hero-copy {
    display: flex;
    flex-direction: column;
}

.member-kicker {
    margin: 0 0 8px;
    color: color-mix(in srgb, var(--accent) 70%, #77c58a);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.member-hero .member-kicker {
    color: #bdf2c8;
}

.member-hero h1,
.member-section h2,
.member-group-panel h2,
.member-self-evaluation h2 {
    margin: 0;
    letter-spacing: 0;
}

.member-hero-meta,
.member-session-meta,
.member-session-topline {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.member-hero-meta span,
.member-session-meta span,
.member-session-topline span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
}

.member-hero-meta span,
.member-session-meta span {
    background: rgba(255, 255, 255, 0.14);
    color: #fff;
}

.member-next-card {
    align-self: end;
    display: grid;
    gap: 12px;
    padding: 22px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 18px;
    background: rgba(10, 19, 28, 0.68);
    box-shadow: 0 22px 50px rgba(0, 0, 0, 0.26);
    backdrop-filter: blur(18px);
}

.member-sessions-focus-link,
.member-sessions-next-card-link,
.member-sessions-detail-link {
    display: block;
    color: inherit;
    text-decoration: none;
}

.member-next-card-link:hover .member-next-card,
.member-sessions-focus-link:hover .member-sessions-focus-card,
.member-sessions-next-card-link:hover .member-sessions-next-card,
.member-sessions-detail-link:hover .member-sessions-detail-card {
    transform: translateY(-1px);
    box-shadow: 0 18px 38px rgba(22, 33, 28, 0.1);
}

.member-card-label,
.member-next-card small,
.member-section-head span {
    color: var(--text-muted);
    font-size: 13px;
    font-weight: 700;
}

.member-next-card .member-card-label,
.member-next-card small {
    color: rgba(248, 251, 247, 0.72);
}

.member-next-card strong {
    font-size: 24px;
    line-height: 1.15;
}

.member-next-card p {
    margin: 0;
    color: rgba(248, 251, 247, 0.76);
    font-size: 14px;
}

.member-progress {
    height: 8px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.16);
}

.member-progress span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #79d58a, #f1c36a);
}

.member-section,
.member-self-evaluation,
.member-group-panel {
    border: 1px solid var(--border);
    border-radius: 22px;
    background: var(--surface);
    box-shadow: var(--shadow-soft);
}

.member-section,
.member-self-evaluation {
    padding: 24px;
}

.member-section-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 20px;
}

.member-section h2,
.member-group-panel h2,
.member-self-evaluation h2 {
    font-size: 26px;
}

.member-program-flow {
    display: grid;
    gap: 18px;
}

.member-day-block {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 16px;
}

.member-day-marker {
    display: flex;
    justify-content: center;
    position: relative;
}

.member-day-marker::after {
    content: "";
    position: absolute;
    top: 42px;
    bottom: -18px;
    width: 2px;
    background: var(--border);
}

.member-day-block:last-child .member-day-marker::after {
    display: none;
}

.member-day-marker span {
    position: relative;
    z-index: 1;
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: color-mix(in srgb, var(--accent) 18%, var(--surface));
    color: var(--accent);
    font-weight: 900;
}

.member-day-content h3 {
    margin: 6px 0 12px;
    font-size: 18px;
}

.member-session-list {
    display: grid;
    gap: 12px;
}

.member-session-card {
    display: grid;
    grid-template-columns: 128px minmax(0, 1fr);
    min-height: 132px;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: var(--surface-2);
}

.member-session-thumb {
    display: grid;
    place-items: center;
    min-height: 132px;
    background:
        radial-gradient(circle at 72% 18%, rgba(255, 255, 255, 0.34), transparent 24%),
        linear-gradient(145deg, color-mix(in srgb, var(--session-accent) 72%, #183029), #17222d 72%);
    color: #fff;
    font-size: 34px;
}

.member-session-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.member-session-copy {
    display: grid;
    align-content: center;
    gap: 8px;
    padding: 16px 18px;
}

.member-session-topline span {
    background: color-mix(in srgb, var(--session-accent) 16%, var(--surface));
    color: var(--text-secondary);
}

.member-session-copy h4 {
    margin: 0;
    font-size: 19px;
}

.member-session-copy p {
    margin: 0;
    color: var(--text-secondary);
}

.member-session-copy small {
    color: var(--text-muted);
    font-weight: 700;
}

.member-empty {
    padding: 22px;
    border: 1px dashed var(--border-strong);
    border-radius: 18px;
    background: var(--surface-2);
}

.member-grid-section {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

.member-group-panel {
    display: grid;
    align-content: start;
    gap: 12px;
    min-height: 220px;
    padding: 24px;
}

.member-group-panel.soft {
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--warning) 12%, var(--surface)), var(--surface));
}

.member-group-panel p,
.member-self-evaluation p {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.65;
}

.member-home--messages {
    gap: 26px;
}

.member-hero--messages {
    min-height: 282px;
    padding: 36px;
    background:
        linear-gradient(110deg, rgba(13, 53, 41, 0.82), rgba(17, 34, 41, 0.56)),
        url("https://images.unsplash.com/photo-1535131749006-b7f58c99034b?auto=format&fit=crop&w=1800&q=80");
    background-position: center;
    background-size: cover;
}

.member-hero--messages .member-hero-copy {
    justify-content: flex-end;
}

.member-hero--messages h1 {
    max-width: 760px;
    font-size: clamp(52px, 5vw, 74px);
    line-height: 0.98;
    font-family: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
    font-weight: 700;
}

.member-hero-meta--messages span {
    gap: 8px;
    padding-inline: 14px;
    background: rgba(255, 255, 255, 0.16);
    backdrop-filter: blur(10px);
}

.member-grid-section--messages {
    align-items: start;
}

.member-grid-section--messages.member-grid-section--single {
    grid-template-columns: minmax(0, 1fr);
}

.member-group-panel--messages {
    gap: 18px;
    padding: 28px;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, white 4%), color-mix(in srgb, var(--surface-2) 94%, white 6%));
}

.member-group-panel--messages h2 {
    font-size: clamp(30px, 2.6vw, 46px);
    line-height: 1.06;
    font-family: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
    font-weight: 700;
}

.member-message-list {
    display: grid;
    gap: 14px;
    margin-top: 4px;
}

.member-message-card {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    padding: 18px;
    border: 1px solid #dbe5ef;
    border-radius: 22px;
    background: #fff;
    color: inherit;
    text-decoration: none;
    box-shadow: 0 14px 28px rgba(158, 176, 192, 0.10);
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.member-message-card:hover,
.member-message-card:focus-visible,
.member-article-hero-card:hover,
.member-article-hero-card:focus-visible,
.member-support-article-card:hover,
.member-support-article-card:focus-visible {
    transform: translateY(-2px);
    border-color: #c8d7e7;
    box-shadow: 0 22px 36px rgba(158, 176, 192, 0.16);
    outline: none;
}

.member-message-card__icon {
    width: 82px;
    height: 82px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 20px;
    font-size: 36px;
    font-weight: 800;
    color: #2b5b49;
    background:
        linear-gradient(180deg, #eef5eb, #e5efe3);
}

.member-message-card__icon--direct {
    color: #2a5faa;
    background:
        linear-gradient(180deg, #eef4ff, #e4ecfb);
}

.member-message-card__body {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.member-message-card__topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.member-message-card__type,
.member-message-card__tag,
.member-message-card__time {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 14px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 800;
}

.member-message-card__type {
    background: #edf5ea;
    color: #305d4b;
}

.member-message-card__tag {
    background: #f0f4fb;
    color: #577198;
}

.member-message-card__time {
    padding-inline: 0;
    background: transparent;
    color: #64748b;
}

.member-message-card__body h4 {
    margin: 0;
    font-size: 24px;
    line-height: 1.1;
    color: #203246;
}

.member-message-card__sender {
    font-size: 15px;
    font-weight: 700;
    color: #617289;
}

.member-message-card__body p {
    margin: 0;
    color: #506173;
    line-height: 1.6;
}

.member-message-card__status {
    width: 14px;
    height: 14px;
    border-radius: 999px;
    background: #2f6d3a;
    box-shadow: 0 0 0 6px rgba(47, 109, 58, 0.10);
}

.member-message-card__status--soft {
    background: #7aa7e7;
    box-shadow: 0 0 0 6px rgba(122, 167, 231, 0.12);
}

.member-primary-action--messages {
    width: 100%;
    min-height: 62px;
    justify-content: space-between;
    padding: 0 24px;
    margin-top: 10px;
    border-radius: 18px;
    background: linear-gradient(135deg, #2e5d3e, #244b30);
    box-shadow: 0 18px 28px rgba(36, 75, 48, 0.18);
}

.member-group-panel--articles {
    gap: 20px;
}

.member-sessions-page {
    gap: 28px;
}

.member-sessions-top {
    display: grid;
}

.member-sessions-top__hero,
.member-sessions-focus-card,
.member-sessions-panel {
    border: 1px solid var(--border);
    border-radius: 24px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 97%, white 3%), color-mix(in srgb, var(--surface-2) 96%, white 4%));
    box-shadow: var(--shadow-soft);
}

.member-sessions-top__hero {
    display: grid;
}

.member-sessions-top__hero h1 {
    margin: 0;
    font-size: clamp(38px, 4vw, 58px);
    line-height: 0.98;
}

.member-sessions-top__hero p {
    margin: 0;
    max-width: 760px;
    color: var(--text-secondary);
}

.member-sessions-top__meta,
.member-sessions-detail-tags,
.member-sessions-timeline-item__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.member-sessions-top__meta span,
.member-sessions-detail-tags span,
.member-sessions-timeline-item__meta span,
.member-sessions-complete-pill {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: #eef4ec;
    color: #496850;
    font-size: 12px;
    font-weight: 800;
}

.member-sessions-focus-card {
    display: grid;
    align-content: start;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.member-sessions-focus-card h2 {
    margin: 0;
}

.member-sessions-focus-card p {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.65;
}

.member-sessions-focus-card__progressline {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin-top: 10px;
    color: var(--text-secondary);
    font-size: 14px;
}

.member-sessions-focus-card__progressline strong {
    color: var(--text-primary);
}

.member-progress--sessions,
.member-progress--soft {
    height: 9px;
    background: #e4eadf;
}

.member-progress--sessions span,
.member-progress--soft span {
    background: linear-gradient(90deg, #6aa46f, #b9d08e);
}

.member-sessions-layout {
    display: grid;
    grid-template-columns: minmax(320px, 0.9fr) minmax(0, 1.15fr);
    gap: 20px;
    align-items: start;
}

.member-sessions-panel {
    display: grid;
    gap: 18px;
    padding: 24px;
}

.member-sessions-panel__head {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: flex-start;
}

.member-sessions-panel__head h2 {
    margin: 4px 0 0;
    font-size: clamp(28px, 2.4vw, 42px);
    line-height: 1.05;
}

.member-sessions-panel__head > span {
    color: var(--text-secondary);
    font-weight: 800;
}

.member-sessions-panel__intro {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.65;
}

.member-sessions-timeline {
    display: grid;
    gap: 12px;
}

.member-sessions-timeline-link {
    color: inherit;
    text-decoration: none;
}

.member-sessions-timeline-item {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 12px;
}

.member-sessions-timeline-item__rail {
    position: relative;
    display: grid;
    justify-items: center;
}

.member-sessions-timeline-item__index {
    position: relative;
    z-index: 1;
    display: grid;
    place-items: center;
    width: 32px;
    height: 32px;
    border-radius: 999px;
    background: #eef1ea;
    color: #556169;
    font-size: 13px;
    font-weight: 900;
}

.member-sessions-timeline-item.is-completed .member-sessions-timeline-item__index,
.member-sessions-timeline-item.is-active .member-sessions-timeline-item__index {
    background: #44724f;
    color: #fff;
}

.member-sessions-timeline-item__line {
    position: absolute;
    top: 34px;
    bottom: -14px;
    width: 2px;
    border-radius: 999px;
}

.member-sessions-timeline-item__card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 18px;
    border: 1px solid #dce4d8;
    border-radius: 18px;
    background: #fff;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.member-sessions-timeline-link:hover .member-sessions-timeline-item__card,
.member-sessions-timeline-item.is-active .member-sessions-timeline-item__card {
    border-color: #b8ceb3;
    box-shadow: 0 18px 36px rgba(30, 48, 38, 0.08);
    transform: translateY(-1px);
}

.member-sessions-timeline-item__body {
    display: grid;
    gap: 8px;
}

.member-sessions-timeline-item__body h3 {
    margin: 0;
    font-size: 22px;
}

.member-sessions-timeline-item__body p {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.55;
}

.member-sessions-timeline-item__status {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    background: #f3f6f1;
    color: #456c4d;
    font-size: 18px;
    font-weight: 900;
}

.member-sessions-next-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    padding: 18px;
    border: 1px solid #dce4d8;
    border-radius: 18px;
    background: linear-gradient(135deg, #f6fbf4, #eef5ea);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.member-sessions-next-card__icon {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: #44724f;
    color: #fff;
    font-size: 18px;
}

.member-sessions-next-card small,
.member-sessions-next-card strong,
.member-sessions-next-card p {
    display: block;
}

.member-sessions-next-card small {
    margin-bottom: 4px;
    color: var(--text-muted);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.member-sessions-next-card strong {
    font-size: 18px;
}

.member-sessions-next-card p {
    margin: 4px 0 0;
    color: var(--text-secondary);
}

.member-sessions-panel--detail {
    gap: 22px;
}

.member-sessions-panel__head--detail {
    align-items: center;
}

.member-sessions-detail-hero {
    display: grid;
    grid-template-columns: minmax(260px, 1.05fr) minmax(240px, 0.95fr);
    gap: 18px;
}

.member-sessions-detail-hero--compact {
    grid-template-columns: 1fr;
}

.member-sessions-detail-copy,
.member-sessions-detail-card {
    border: 1px solid #dce4d8;
    border-radius: 20px;
    background: #fff;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.member-sessions-detail-copy {
    display: grid;
    gap: 12px;
    align-content: start;
    padding: 22px;
}

.member-sessions-detail-copy--full {
    min-height: 0;
}

.member-sessions-detail-copy h3,
.member-sessions-detail-card__body h3 {
    margin: 0;
    font-size: 20px;
}

.member-sessions-detail-copy p,
.member-sessions-detail-card__body p,
.member-sessions-detail-card__body li {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.65;
}

.member-primary-action--sessions {
    justify-self: start;
}

.member-workout-page {
    gap: 18px;
}

.member-workout-back {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--text-primary);
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
}

.member-workout-hero {
    display: grid;
    align-items: center;
    border: 1px solid var(--border);
    border-radius: 22px;
    background:
        radial-gradient(circle at 72% 22%, rgba(255, 255, 255, 0.72), transparent 28%),
        linear-gradient(135deg, #ffffff 0%, #f8fbf6 44%, #ecf3e7 100%);
    box-shadow: var(--shadow-soft);
}

.member-workout-hero__icon,
.member-workout-hero__art {
    border-radius: 18px;
}

.member-workout-hero__icon {
    display: grid;
    place-items: center;
    overflow: hidden;
    background:
        radial-gradient(circle at 68% 22%, rgba(255, 255, 255, 0.25), transparent 28%),
        linear-gradient(145deg, #21513a, #1b2834 78%);
    color: #fff;
    font-weight: 700;
}

.member-workout-hero__icon.has-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.member-workout-hero__copy {
    display: grid;
    min-width: 0;
}

.member-workout-hero__copy h1 {
    margin: 0;
}

.member-workout-hero__copy p {
    margin: 0;
    color: var(--text-secondary);
}

.member-workout-hero__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.member-workout-hero__meta span {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: #eff4eb;
    color: #496850;
    font-size: 12px;
    font-weight: 700;
}

.member-workout-hero__art {
    background:
        radial-gradient(circle at 88% 26%, rgba(126, 160, 115, 0.42), transparent 18%),
        radial-gradient(circle at 72% 82%, rgba(82, 126, 75, 0.3), transparent 24%),
        linear-gradient(180deg, rgba(248, 251, 247, 0.9), rgba(233, 241, 227, 0.92));
    position: relative;
    overflow: hidden;
}

.member-workout-hero__art::before,
.member-workout-hero__art::after {
    content: "";
    position: absolute;
    inset: auto;
    border-radius: 999px 999px 0 0;
}

.member-workout-hero__art::before {
    left: -8%;
    right: 28%;
    bottom: -18px;
    height: 58px;
    background: rgba(153, 177, 133, 0.32);
}

.member-workout-hero__art::after {
    left: 40%;
    right: -10%;
    bottom: -16px;
    height: 72px;
    background: rgba(133, 160, 118, 0.26);
}

.member-workout-section,
.member-workout-followup-card {
    border: 1px solid var(--border);
    border-radius: 22px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 97%, white 3%), color-mix(in srgb, var(--surface-2) 95%, white 5%));
    box-shadow: var(--shadow-soft);
}

.member-workout-section {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr);
    gap: 14px;
    padding: 18px;
}

.member-workout-section__icon {
    display: grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border-radius: 999px;
    background: #f0f4ed;
    color: #4a6a50;
    font-size: 16px;
}

.member-workout-section__body {
    display: grid;
    gap: 14px;
}

.member-workout-section__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.member-workout-video-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

.member-video-favorite-action {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 14px;
    border: 1px solid #d5dfd2;
    border-radius: 999px;
    background: #fff;
    color: #385b42;
    font: inherit;
    font-size: 13px;
    font-weight: 800;
    cursor: pointer;
    transition: 0.18s ease;
}

.member-video-favorite-action:hover {
    border-color: #78966f;
    background: #f2f7ef;
}

.member-video-favorite-action.is-active {
    border-color: #f0cf65;
    background: #fff7d6;
    color: #7a5b12;
}

.member-workout-section__body h2,
.member-workout-followup-card h2 {
    margin: 0;
    font-size: 26px;
}

.member-workout-section__body h3 {
    margin: 0;
    font-size: 20px;
}

.member-workout-section__body p,
.member-workout-followup-card p,
.member-workout-mini-panel p,
.member-workout-fact-card p,
.member-workout-task-card__summary p {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.65;
}

.member-workout-media-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.72fr);
    gap: 18px;
    align-items: start;
}

.member-workout-video-card,
.member-workout-fact-card,
.member-workout-task-card,
.member-workout-mini-panel {
    border: 1px solid #dce4d8;
    border-radius: 18px;
    background: #fff;
}

.member-workout-video-card {
    overflow: hidden;
}

.member-workout-video-card .workout-video-player {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #111;
}

.member-workout-facts {
    display: grid;
    gap: 12px;
}

.member-workout-fact-card {
    display: grid;
    gap: 8px;
    padding: 16px;
}

.member-workout-fact-card strong,
.member-workout-mini-panel strong {
    color: var(--text-primary);
    font-size: 14px;
}

.member-workout-task-list {
    display: grid;
    gap: 14px;
}

.member-workout-task-card {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.8fr);
    gap: 0;
    overflow: hidden;
}

.member-workout-task-card__summary {
    display: grid;
    gap: 12px;
    padding: 18px;
}

.member-workout-task-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.member-workout-task-card__meta span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: #eff4eb;
    color: #496850;
    font-size: 12px;
    font-weight: 700;
}

.member-workout-task-card__summary h3 {
    margin: 0;
    font-size: 28px;
    line-height: 1.06;
}

.member-workout-task-card__insights {
    display: grid;
    gap: 1px;
    padding: 12px;
    background: #edf2ea;
}

.member-workout-mini-panel {
    display: grid;
    gap: 8px;
    padding: 16px;
}

.member-workout-mini-panel--challenge {
    background: linear-gradient(135deg, #f7fbf2, #ffffff);
}

.member-workout-followup-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.member-workout-followup-card {
    display: grid;
    gap: 10px;
    padding: 18px;
}

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

.member-primary-action--workout {
    min-width: 240px;
    justify-content: center;
}

.member-workout-complete-state {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 999px;
    background: #ecf5ea;
    color: #456c4d;
    font-weight: 700;
}

.member-workout-complete-note,
.workout-completion-preview__note {
    margin: 0;
    padding: 0.95rem 1.15rem;
    border-radius: 16px;
    border: 1px solid rgba(121, 142, 169, 0.25);
    background: rgba(245, 248, 252, 0.9);
    color: #5b6f88;
    font-weight: 600;
}

.app-video-favorites-shell {
    display: grid;
    gap: 20px;
}

.app-video-favorites-hero,
.app-video-favorites-empty,
.app-video-favorite-card {
    border: 1px solid var(--border);
    border-radius: 22px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 97%, white 3%), color-mix(in srgb, var(--surface-2) 95%, white 5%));
    box-shadow: var(--shadow-soft);
}

.app-video-favorites-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    padding: 24px;
    overflow: hidden;
}

.app-video-favorites-hero__copy {
    display: grid;
    gap: 8px;
}

.app-video-favorites-hero__copy h1,
.app-video-favorites-empty h2,
.app-video-favorite-card__copy h2 {
    margin: 0;
    color: var(--text-primary);
}

.app-video-favorites-hero__copy h1 {
    font-size: 2.25rem;
    line-height: 1.08;
}

.app-video-favorites-hero__copy p:last-child,
.app-video-favorites-empty p,
.app-video-favorite-card__copy p {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.6;
}

.app-video-favorites-hero__stat {
    min-width: 132px;
    display: grid;
    justify-items: center;
    gap: 6px;
    padding: 18px 20px;
    border: 1px solid #dce8d8;
    border-radius: 18px;
    background: #f7fbf3;
}

.app-video-favorites-hero__stat span {
    color: #5f755d;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.app-video-favorites-hero__stat strong {
    color: #2f4e37;
    font-size: 2rem;
    line-height: 1;
}

.app-video-favorites-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
    gap: 18px;
}

.app-video-favorite-card {
    overflow: hidden;
}

.app-video-favorite-card__media {
    min-height: 190px;
    position: relative;
    display: grid;
    place-items: center;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: linear-gradient(145deg, #203947, #284d35);
    color: #fff;
    text-decoration: none;
    font-size: 2.4rem;
    font-weight: 900;
}

.app-video-favorite-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.app-video-favorite-card__play {
    position: absolute;
    right: 14px;
    bottom: 14px;
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    color: #203244;
    font-size: 16px;
    box-shadow: 0 10px 22px rgba(22, 34, 47, 0.2);
}

.app-video-favorite-card__body {
    display: grid;
    gap: 14px;
    padding: 18px;
}

.app-video-favorite-card__meta,
.app-video-favorite-card__tags,
.app-video-favorite-card__actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

.app-video-favorite-card__meta span,
.app-video-favorite-card__tags span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: #eff4eb;
    color: #496850;
    font-size: 12px;
    font-weight: 800;
}

.app-video-favorite-card__copy {
    display: grid;
    gap: 8px;
}

.app-video-favorite-card__copy h2 {
    font-size: 1.35rem;
    line-height: 1.15;
}

.app-video-favorite-card__actions {
    justify-content: space-between;
}

.app-video-favorites-empty {
    display: grid;
    justify-items: start;
    gap: 12px;
    padding: 24px;
}

.member-sessions-detail-stack {
    display: grid;
    gap: 14px;
}

.member-sessions-detail-card {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr);
    gap: 16px;
    align-items: start;
    padding: 18px;
}

.member-sessions-detail-card__icon {
    display: grid;
    place-items: center;
    width: 40px;
    height: 40px;
    border-radius: 999px;
    background: #44724f;
    color: #fff;
    font-size: 18px;
    font-weight: 900;
}

.member-sessions-detail-card__body {
    display: grid;
    gap: 8px;
}

.member-sessions-detail-card__body ul {
    margin: 0;
    padding-left: 18px;
    display: grid;
    gap: 6px;
}

.member-article-hero-card {
    display: grid;
    grid-template-columns: minmax(240px, 0.95fr) minmax(0, 1.2fr) auto;
    gap: 22px;
    align-items: center;
    padding: 12px;
    border: 1px solid #dbe5ef;
    border-radius: 24px;
    background: #fff;
    color: inherit;
    text-decoration: none;
    box-shadow: 0 14px 28px rgba(158, 176, 192, 0.10);
}

.member-article-hero-card__media {
    min-height: 220px;
    border-radius: 18px;
    overflow: hidden;
    background: linear-gradient(145deg, #214334, #17262e);
}

.member-article-hero-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.member-article-hero-card__placeholder {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 220px;
    background:
        radial-gradient(circle at 72% 18%, rgba(255, 255, 255, 0.24), transparent 24%),
        linear-gradient(145deg, #6e8f56, #2d473b 68%);
}

.member-article-hero-card__body {
    display: grid;
    gap: 12px;
}

.member-article-hero-card__body h4 {
    margin: 0;
    font-size: clamp(30px, 2.7vw, 48px);
    line-height: 1.08;
    color: #203246;
    font-family: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
}

.member-article-hero-card__body p {
    margin: 0;
    color: #5d7085;
    line-height: 1.65;
}

.member-article-hero-card__arrow {
    width: 52px;
    height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid #d7e2ee;
    color: #203246;
    font-size: 24px;
}

.member-article-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.member-support-article-card {
    display: grid;
    gap: 16px;
    padding: 18px;
    border: 1px solid #dbe5ef;
    border-radius: 20px;
    background: #fff;
    color: inherit;
    text-decoration: none;
    box-shadow: 0 14px 28px rgba(158, 176, 192, 0.08);
}

.member-support-article-card__icon {
    width: 66px;
    height: 66px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
    background: linear-gradient(180deg, #eef5eb, #e7f0e4);
    color: #2f6d3a;
    font-size: 28px;
}

.member-support-article-card__body {
    display: grid;
    gap: 8px;
}

.member-support-article-card__category {
    color: #6f82a0;
    font-size: 14px;
    font-weight: 700;
}

.member-support-article-card__body h4 {
    margin: 0;
    font-size: 17px;
    line-height: 1.45;
    color: #203246;
}

.member-support-article-card__body p {
    margin: 0;
    color: #5d7085;
    line-height: 1.55;
}

.member-support-article-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: #6d7f94;
    font-size: 14px;
    font-weight: 700;
}

.member-library-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding-top: 4px;
    color: #2f5f45;
    text-decoration: none;
    font-weight: 800;
}

.member-library-link:hover,
.member-library-link:focus-visible {
    color: #214736;
    outline: none;
}

.member-home--development {
    gap: 26px;
}

.member-hero--development {
    min-height: 300px;
    padding: 36px;
    background:
        linear-gradient(110deg, rgba(12, 56, 41, 0.82), rgba(23, 34, 41, 0.52)),
        url("https://images.unsplash.com/photo-1535131749006-b7f58c99034b?auto=format&fit=crop&w=1800&q=80");
    background-position: center;
    background-size: cover;
}

.member-hero--development h1 {
    max-width: 720px;
    font-size: clamp(56px, 5vw, 78px);
    line-height: 0.96;
    font-family: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
    font-weight: 700;
}

.member-hero-meta--development span {
    gap: 8px;
    padding-inline: 14px;
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(10px);
}

.member-grid-section--development {
    align-items: start;
}

.member-grid-section--development.member-grid-section--single {
    grid-template-columns: 1fr;
}

.member-group-panel--development {
    gap: 18px;
    padding: 28px;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, white 4%), color-mix(in srgb, var(--surface-2) 94%, white 6%));
}

.member-group-panel--development h2 {
    font-size: clamp(32px, 2.6vw, 48px);
    line-height: 1.06;
    font-family: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
    font-weight: 700;
}

.member-development-feature-card {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.72fr);
    gap: 18px;
    padding: 28px;
    margin-top: 4px;
    border: 1px solid #dbe5ef;
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 14px 28px rgba(158, 176, 192, 0.10);
}

.member-development-feature-card__main {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}

.member-development-feature-card__icon {
    width: 84px;
    height: 84px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: linear-gradient(180deg, #edf5ea, #e4efe2);
    color: #2f6d3a;
    font-size: 36px;
}

.member-development-feature-card__copy {
    display: grid;
    gap: 8px;
}

.member-development-feature-card__copy h3 {
    margin: 0;
    font-size: 28px;
    color: #203246;
    font-family: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
}

.member-development-feature-card__copy p,
.member-development-feature-card__summary span,
.member-development-feature-card__summary strong {
    margin: 0;
    color: #506173;
    line-height: 1.6;
}

.member-development-feature-card__chart {
    display: grid;
    gap: 10px;
    padding: 18px;
    border: 1px solid #dbe5ef;
    border-radius: 18px;
    background: linear-gradient(180deg, #fff, #fbfdff);
}

.member-development-feature-card__chart strong {
    color: #203246;
}

.member-test-page {
    gap: 26px;
}

.member-hero--test-submit {
    min-height: 340px;
    padding: 28px;
    background:
        linear-gradient(110deg, rgba(10, 56, 40, 0.78), rgba(18, 31, 41, 0.58)),
        url("https://images.unsplash.com/photo-1535131749006-b7f58c99034b?auto=format&fit=crop&w=1800&q=80");
    background-position: center;
    background-size: cover;
}

.member-next-card--test-submit {
    align-self: center;
    background: rgba(14, 24, 32, 0.84);
}

.member-section--test-submit {
    padding: 26px;
}

.member-section-head--test-submit {
    margin-bottom: 18px;
}

.member-test-submit-layout {
    display: grid;
    grid-template-columns: minmax(240px, 0.34fr) minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}

.member-test-submit-side {
    display: grid;
    gap: 16px;
}

.member-test-submit-info-card,
.member-test-submit-detail-card,
.member-test-submit-explainer {
    border: 1px solid #dce4d8;
    border-radius: 18px;
    background: #fff;
    box-shadow: var(--shadow-soft);
}

.member-test-submit-info-card,
.member-test-submit-detail-card {
    padding: 18px;
}

.member-test-submit-info-card {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr);
    gap: 14px;
}

.member-test-submit-info-card__icon {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    background: #eef5ea;
    color: #44724f;
    font-size: 18px;
    font-weight: 900;
}

.member-test-submit-info-card__body,
.member-test-submit-detail-card {
    display: grid;
    gap: 8px;
}

.member-test-submit-info-card__body h3,
.member-test-submit-detail-card h3,
.member-test-submit-panel h3,
.member-test-submit-explainer h4 {
    margin: 0;
}

.member-test-submit-info-card__body p,
.member-test-submit-detail-card li,
.member-test-submit-explainer p,
.member-test-submit-help {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.65;
}

.member-test-submit-score {
    color: #2f6846;
    font-size: 34px;
    font-weight: 800;
    letter-spacing: -0.03em;
}

.member-test-submit-detail-card ul {
    margin: 0;
    padding-left: 18px;
    display: grid;
    gap: 10px;
}

.member-test-submit-panel {
    padding: 22px;
}

.member-test-submit-form {
    display: grid;
    gap: 18px;
}

.member-test-submit-panel__head h3 {
    font-size: clamp(28px, 2.4vw, 42px);
    line-height: 1.08;
}

.member-test-submit-main {
    display: grid;
    grid-template-columns: minmax(260px, 0.72fr) auto minmax(220px, 0.55fr);
    gap: 20px;
    align-items: center;
}

.member-test-submit-counter {
    display: grid;
    grid-template-columns: 64px minmax(0, 1fr) 64px;
    align-items: center;
    min-height: 94px;
    border: 1px solid #dce4d8;
    border-radius: 18px;
    background: #fff;
    overflow: hidden;
}

.member-test-submit-counter__button {
    width: 100%;
    height: 100%;
    border: 0;
    background: transparent;
    color: #4c5d55;
    font-size: 34px;
    cursor: pointer;
}

.member-test-submit-counter__value {
    display: grid;
    place-items: center;
    padding: 8px 0;
}

.member-test-submit-counter__value input {
    width: 100%;
    border: 0;
    background: transparent;
    color: #2f6846;
    font-size: clamp(50px, 4vw, 72px);
    font-weight: 800;
    text-align: center;
    appearance: textfield;
    -moz-appearance: textfield;
}

.member-test-submit-counter__value input::-webkit-outer-spin-button,
.member-test-submit-counter__value input::-webkit-inner-spin-button {
    margin: 0;
    -webkit-appearance: none;
}

.member-test-submit-percent {
    display: grid;
    gap: 4px;
    justify-items: start;
}

.member-test-submit-percent strong {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: 0 14px;
    border-radius: 14px;
    background: #eef5ea;
    color: #44724f;
    font-size: 30px;
    font-weight: 800;
    line-height: 1;
}

.member-test-submit-percent span {
    color: var(--text-secondary);
    font-size: 14px;
}

.member-test-submit-explainer {
    padding: 18px;
}

.member-test-submit-reflection {
    display: grid;
    gap: 8px;
}

.member-test-submit-reflection span {
    font-size: 14px;
    font-weight: 700;
    color: var(--text-primary);
}

.member-test-submit-reflection textarea {
    min-height: 120px;
}

.member-test-submit-actions {
    display: flex;
    gap: 14px;
    justify-content: space-between;
    align-items: center;
}

.member-test-submit-actions__primary {
    min-width: 280px;
    justify-content: center;
}

.member-development-chart {
    position: relative;
    min-height: 132px;
    border-bottom: 2px solid #d7e1eb;
}

.member-development-chart__line {
    position: absolute;
    left: 0;
    right: 0;
    display: block;
    color: #7a8a9a;
    font-size: 13px;
}

.member-development-chart__line::after {
    content: "";
    position: absolute;
    left: 32px;
    right: 0;
    top: 50%;
    border-top: 1px dashed #d7e1eb;
}

.member-development-chart__line--top {
    top: 0;
}

.member-development-chart__line--mid {
    top: 50%;
    transform: translateY(-50%);
}

.member-development-chart__line--base {
    bottom: -10px;
}

.member-development-chart__point {
    position: absolute;
    width: 14px;
    height: 14px;
    border-radius: 999px;
    background: #2f6d3a;
    box-shadow: 0 0 0 6px rgba(47, 109, 58, 0.12);
}

.member-development-chart__point--latest {
    background: #7aa7e7;
    box-shadow: 0 0 0 6px rgba(122, 167, 231, 0.12);
}

.member-development-chart__labels {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: #64748b;
    font-size: 13px;
    font-weight: 700;
}

.member-development-feature-card__footer {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    padding-top: 6px;
    border-top: 1px solid #e7eef5;
}

.member-development-feature-card__summary {
    display: grid;
    gap: 4px;
}

.member-development-feature-card__summary strong {
    color: #203246;
    font-size: 17px;
}

.member-development-list {
    display: grid;
    gap: 12px;
}

.member-development-list-card {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
    padding: 18px 20px;
    border: 1px solid #dbe5ef;
    border-radius: 18px;
    background: #fff;
}

.member-development-list-card strong {
    display: block;
    margin-bottom: 4px;
    color: #203246;
}

.member-development-list-card p,
.member-development-list-card__meta span {
    margin: 0;
    color: #64748b;
}

.member-development-list-card__meta {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px 12px;
    font-size: 14px;
    font-weight: 700;
}

.member-library-link--development {
    margin-top: 4px;
}

.member-group-panel--development-side {
    gap: 20px;
}

.member-hcp-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: end;
}

.member-hcp-form__field {
    display: grid;
    gap: 10px;
}

.member-hcp-form__field span {
    color: #203246;
    font-size: 14px;
    font-weight: 700;
}

.member-hcp-form__field input {
    min-height: 54px;
    border: 1px solid #d5e0eb;
    border-radius: 14px;
    background: #fff;
}

.member-hcp-form .primary-action {
    min-height: 54px;
    padding-inline: 24px;
    border-radius: 14px;
}

.member-development-status-card {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
    padding: 26px;
    border: 1px solid #dbe5ef;
    border-radius: 22px;
    background: linear-gradient(180deg, #fff, #fbfdff);
    box-shadow: 0 14px 28px rgba(158, 176, 192, 0.08);
}

.member-development-status-card__icon {
    width: 74px;
    height: 74px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: linear-gradient(180deg, #edf5ea, #e4efe2);
    color: #2f6d3a;
    font-size: 30px;
}

.member-development-status-card__copy {
    display: grid;
    gap: 6px;
}

.member-development-status-card__kicker {
    color: #64748b;
    font-size: 14px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.member-development-status-card__copy strong {
    color: #9a6b11;
    font-size: 16px;
}

.member-development-status-card__copy h3 {
    margin: 0;
    color: #203246;
    font-size: 28px;
    font-family: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
}

.member-development-status-card__copy p {
    margin: 0;
    color: #5d7085;
    line-height: 1.6;
}

.member-primary-action {
    justify-self: start;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    margin-top: 8px;
    padding: 0 16px;
    border-radius: 12px;
    font-weight: 900;
    text-decoration: none;
}

.member-primary-action {
    background: var(--accent);
    color: var(--accent-contrast);
}

.member-self-evaluation {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(320px, 1.15fr);
    gap: 22px;
    align-items: stretch;
}

.member-evaluation-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.member-upload-card {
    display: grid;
    align-content: end;
    gap: 8px;
    min-height: 190px;
    padding: 18px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background:
        linear-gradient(145deg, rgba(23, 47, 38, 0.86), rgba(20, 31, 41, 0.82)),
        url("https://images.unsplash.com/photo-1593111774240-d529f12cf4bb?auto=format&fit=crop&w=900&q=80");
    background-position: center;
    background-size: cover;
    color: #fff;
    cursor: pointer;
}

.member-upload-card.current {
    background:
        linear-gradient(145deg, rgba(66, 45, 27, 0.82), rgba(20, 31, 41, 0.82)),
        url("https://images.unsplash.com/photo-1591491653056-8b8672d5872d?auto=format&fit=crop&w=900&q=80");
    background-position: center;
    background-size: cover;
}

.member-upload-card span {
    color: rgba(255, 255, 255, 0.72);
    font-weight: 800;
}

.member-upload-card strong {
    font-size: 21px;
}

.member-upload-card input {
    width: 100%;
    color: rgba(255, 255, 255, 0.84);
}

@media (max-width: 980px) {
    .member-hero,
    .member-self-evaluation,
    .member-grid-section {
        grid-template-columns: 1fr;
    }

    .member-sessions-top,
    .member-sessions-layout,
    .member-sessions-detail-hero,
    .member-workout-media-layout,
    .member-workout-task-card,
    .member-workout-followup-grid {
        grid-template-columns: 1fr;
    }

    .member-next-card {
        align-self: stretch;
    }

    .member-article-grid {
        grid-template-columns: 1fr;
    }

    .member-article-hero-card,
    .member-message-card,
    .member-development-feature-card,
    .member-hcp-form {
        grid-template-columns: 1fr;
    }

    .member-message-card__status {
        justify-self: start;
    }

    .member-development-feature-card__footer {
        grid-template-columns: 1fr;
    }

    .member-development-list-card {
        flex-direction: column;
        align-items: flex-start;
    }

    .member-development-list-card__meta {
        justify-content: flex-start;
    }
}

@media (max-width: 640px) {
    .content {
        padding: 18px;
    }

    .member-hero,
    .member-section,
    .member-self-evaluation,
    .member-group-panel {
        border-radius: 18px;
        padding: 18px;
    }

    .member-hero h1 {
        font-size: 36px;
    }

    .member-hero--messages {
        padding: 22px;
    }

    .member-hero--development {
        padding: 22px;
    }

    .member-article-hero-card__body h4 {
        font-size: 28px;
    }

    .member-group-panel--development h2 {
        font-size: 34px;
    }

    .member-section-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .member-day-block {
        grid-template-columns: 32px minmax(0, 1fr);
        gap: 12px;
    }

    .member-day-marker span {
        width: 32px;
        height: 32px;
        border-radius: 10px;
    }

    .member-day-marker::after {
        top: 32px;
    }

    .member-session-card,
    .member-evaluation-grid {
        grid-template-columns: 1fr;
    }

    .member-session-thumb {
        min-height: 150px;
    }

    .member-sessions-panel,
    .member-sessions-top__hero,
    .member-sessions-focus-card,
    .member-workout-hero,
    .member-workout-section,
    .member-workout-followup-card {
        padding: 20px;
        border-radius: 18px;
    }

    .member-sessions-timeline-item__card,
.member-sessions-next-card,
.member-sessions-detail-copy,
.member-sessions-detail-card,
.member-workout-video-card,
.member-workout-fact-card,
.member-workout-task-card,
.member-workout-mini-panel {
        border-radius: 16px;
    }

    .member-sessions-panel__head {
        flex-direction: column;
        align-items: flex-start;
    }

    .member-workout-hero {
        grid-template-columns: 1fr;
    }

    .app-video-favorites-hero,
    .member-workout-section__head {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .app-video-favorites-hero {
        display: grid;
    }

    .member-workout-section__head,
    .member-workout-video-actions,
    .app-video-favorite-card__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .member-workout-video-actions .member-secondary-link,
    .member-video-favorite-action,
    .app-video-favorite-card__actions .member-secondary-link {
        width: 100%;
    }

    .member-workout-hero__art {
        min-height: 72px;
    }

    .member-workout-section {
        grid-template-columns: 1fr;
    }

    .member-workout-footer {
        align-items: stretch;
        flex-direction: column;
    }

    .member-primary-action--workout,
    .member-workout-footer .secondary-action {
        width: 100%;
    }
}

.group-member-move-hint {
    margin-top: 10px;
    color: #64748b;
    font-size: 0.88rem;
    line-height: 1.5;
}

@media (min-width: 1280px) {

    .group-detail-page-web {
        gap: 24px;
    }

    .group-detail-page-web .group-summary-grid {
        grid-template-columns: minmax(300px, 0.9fr) minmax(0, 1.35fr);
        gap: 22px;
    }

    .group-detail-page-web .coach-panel,
    .group-detail-page-web .detail-panel {
        border-radius: 24px;
    }

    .group-detail-page-web .groups-member-list {
        gap: 14px;
    }

    .group-detail-page-web .groups-member-row {
        display: grid;
        grid-template-columns: minmax(0, 1.45fr) minmax(320px, 0.85fr);
        gap: 22px;
        align-items: start;
        padding: 18px 20px;
    }

    .group-detail-page-web .groups-member-actions {
        justify-items: stretch;
        align-content: start;
    }

    .group-detail-page-web .groups-member-actions > form,
    .group-detail-page-web .groups-member-actions > p {
        width: 100%;
        margin: 0;
    }

    .group-detail-page-web .groups-member-actions .group-member-form {
        display: grid;
        grid-template-columns: minmax(0, 1fr) 132px;
        gap: 10px;
        align-items: center;
    }

    .group-detail-page-web .group-member-form select {
        min-width: 0;
        width: 100%;
    }

    .group-detail-page-web .groups-member-actions .secondary-action,
    .group-detail-page-web .groups-member-actions .danger-action {
        width: 100%;
        justify-content: center;
    }

    .group-detail-page-web .groups-member-pool {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 18px;
    }

    .group-detail-page-web .member-card-compact {
        min-height: 100%;
        align-content: start;
    }
}

@media (min-width: 1500px) {

    .group-detail-page-web .groups-member-pool {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.tag-inline-image,
.tag-color-dot-image {
    width: 18px;
    height: 18px;
    border-radius: 999px;
    object-fit: cover;
    flex: 0 0 auto;
}

.tag-color-dot-image {
    width: 26px;
    height: 26px;
    box-shadow: 0 0 0 1px rgba(148, 163, 184, 0.24);
}

.workout-chip span,
.workout-chip.active {
    gap: 8px;
}

.tag-image-choice-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(108px, 1fr));
    gap: 10px;
}

.tag-image-choice {
    position: relative;
    display: block;
}

.tag-image-choice input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.tag-image-choice-card {
    display: grid;
    gap: 8px;
    min-height: 118px;
    padding: 10px;
    border: 1px solid var(--border, #dce5f0);
    border-radius: 16px;
    background: #fff;
    cursor: pointer;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
    align-content: start;
}

/* Flow builder web refresh overrides */

.app-body--blank {
    background: #f5f1e8;
}

.app-body--blank .flow-app-preview-page {
    min-height: 100vh;
    padding: 18px;
}

.tag-image-choice-card:hover {
    transform: translateY(-1px);
    border-color: #bfd2ea;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}

.tag-image-choice-card img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 12px;
    background: #f8fafc;
}

.tag-image-choice-card strong {
    color: var(--text-primary, #0f172a);
    font-size: 12px;
    line-height: 1.25;
}

.tag-image-choice-card small,
.form-field-hint {
    color: var(--text-muted, #64748b);
    font-size: 12px;
    line-height: 1.35;
}

.form-field-hint {
    margin: 0 0 8px;
}

.tag-image-choice-none {
    justify-content: center;
    text-align: center;
    background: linear-gradient(180deg, #ffffff, #f8fafc);
}

.tag-image-choice input:checked + .tag-image-choice-card {
    border-color: #8fb4d6;
    box-shadow: 0 0 0 4px rgba(143, 180, 214, 0.16);
}

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

.workout-video-picker {
    display: grid;
    gap: 12px;
}

.workout-video-picker__summary {
    display: grid;
    grid-template-columns: 88px minmax(0, 1fr) auto;
    gap: 16px;
    align-items: center;
    padding: 14px;
    border: 1px solid #dce5f0;
    border-radius: 18px;
    background: #fbfdff;
}

.workout-video-picker__thumb {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    width: 88px;
    aspect-ratio: 16 / 9;
    border-radius: 14px;
    background: #dfeaf9;
    color: #2b5fd9;
    font-size: 30px;
    font-weight: 800;
}

.workout-video-picker__play {
    width: 30px;
    height: 30px;
    font-size: 11px;
}

.workout-video-picker__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.workout-video-picker__copy {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.workout-video-picker__copy strong,
.workout-video-library-option__copy strong {
    font-size: 16px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.workout-video-picker__copy span,
.workout-video-library-option__copy span {
    color: var(--text-secondary);
    font-size: 14px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.workout-video-picker__actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.workout-video-library-modal__card {
    width: min(920px, 100%);
}

.workout-video-library-modal__toolbar {
    margin-bottom: 16px;
}

.workout-video-library-modal__toolbar input {
    width: 100%;
}

.workout-video-library-modal__list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    max-height: min(70vh, 760px);
    overflow: auto;
    padding-right: 4px;
}

.workout-video-library-option {
    display: grid;
    grid-template-columns: 120px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    width: 100%;
    padding: 12px;
    border: 1px solid #dce5f0;
    border-radius: 18px;
    background: #fbfdff;
    text-align: left;
    cursor: pointer;
}

.workout-video-library-option:hover {
    border-color: #b6c8e6;
    box-shadow: 0 14px 30px rgba(24, 41, 74, 0.08);
}

.workout-video-library-option__thumb {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    width: 120px;
    aspect-ratio: 16 / 9;
    border-radius: 14px;
    background: #dfeaf9;
    color: #2b5fd9;
    font-size: 34px;
    font-weight: 800;
}

.workout-video-library-option__thumb .workout-video-picker__play {
    width: 34px;
    height: 34px;
    font-size: 12px;
}

.workout-video-library-option__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.workout-video-library-option__copy {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.flow-workout-picker-modal__card {
    width: min(1080px, 100%);
    max-height: calc(100vh - 48px);
    overflow: auto;
}

.flow-workout-picker-toolbar {
    margin-bottom: 18px;
}

.flow-workout-picker-toolbar input {
    width: 100%;
}

.flow-workout-picker-section {
    display: grid;
    gap: 14px;
}

.flow-workout-picker-section + .flow-workout-picker-section {
    margin-top: 18px;
}

.flow-workout-picker-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.flow-workout-picker-section-head span {
    color: var(--text-muted);
    font-size: 14px;
}

.flow-workout-picker-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.flow-workout-picker-item {
    display: grid;
    grid-template-columns: 112px minmax(0, 1fr) auto;
    gap: 14px;
    align-items: center;
    padding: 14px;
    border: 1px solid #dce5f0;
    border-radius: 20px;
    background: #fbfdff;
}

.flow-workout-picker-thumb {
    overflow: hidden;
    width: 112px;
    aspect-ratio: 1;
    border-radius: 16px;
    background: #e9f0fb;
}

.flow-workout-picker-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.flow-workout-picker-copy {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.flow-workout-picker-copy span,
.flow-workout-picker-copy small {
    color: var(--text-muted);
}

.flow-workout-picker-copy h3,
.flow-workout-picker-copy p {
    margin: 0;
}

@media (max-width: 900px) {
    .workout-video-picker__summary {
        grid-template-columns: 88px minmax(0, 1fr);
    }

    .workout-video-picker__actions {
        grid-column: 1 / -1;
        justify-content: flex-start;
    }

    .workout-video-library-modal__list {
        grid-template-columns: 1fr;
    }

    .groups-quick-create-grid {
        grid-template-columns: 1fr;
    }

    .flow-workout-picker-grid {
        grid-template-columns: 1fr;
    }

    .flow-workout-picker-item {
        grid-template-columns: 96px minmax(0, 1fr);
    }
}

.active-group-delete-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 14px;
    border: 1px dashed rgba(239, 68, 68, 0.28);
    border-radius: 12px;
    background: transparent;
    color: #c62828;
    font-size: 13px;
    font-weight: 650;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.active-group-delete-button:hover {
    border-color: rgba(220, 38, 38, 0.42);
    background: rgba(239, 68, 68, 0.08);
    color: #a61b1b;
}

.group-flow-setup-form {
    display: grid;
    gap: 14px;
    margin-bottom: 22px;
    padding: 18px;
    border: 1px solid #dce5f0;
    border-radius: 22px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.group-flow-setup-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.group-flow-next-window {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 16px 18px;
    border: 1px solid #dce5f0;
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
}

.group-flow-next-window-copy {
    display: grid;
    gap: 4px;
}

.group-flow-next-window-copy strong {
    color: var(--text-primary);
    font-size: 15px;
}

.group-flow-next-window-copy p,
.group-flow-next-window-copy span {
    margin: 0;
    color: #6b7a90;
    line-height: 1.6;
}

.group-flow-next-window-copy span {
    font-size: 13px;
}

.group-flow-setup-field {
    display: grid;
    gap: 8px;
}

.group-flow-setup-field span {
    color: #51627a;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.group-flow-setup-field select,
.group-flow-setup-field input[type="date"] {
    width: 100%;
    min-height: 46px;
    padding: 12px 14px;
    border: 1px solid #d7e0eb;
    border-radius: 14px;
    background: #fff;
    color: #162235;
}

.group-flow-setup-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.group-flow-setup-actions p {
    margin: 0;
    color: #6b7a90;
}

.group-flow-manual-start {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin: -4px 0 22px;
    padding: 16px 18px;
    border: 1px solid #dce5f0;
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.group-flow-manual-start p {
    margin: 0;
    color: #6b7a90;
    line-height: 1.6;
}

.group-flow-board-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 20px;
}

.group-flow-board-summary-card {
    display: grid;
    gap: 6px;
    padding: 16px 18px;
    border: 1px solid #dce5f0;
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff 0%, #f7fafe 100%);
}

.group-flow-board-summary-card span {
    color: #6b7a90;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.group-flow-board {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(420px, 1fr);
    gap: 18px;
    overflow-x: auto;
    padding-bottom: 8px;
    scroll-snap-type: x proximity;
}

.group-flow-board-week {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
        "head"
        "goal"
        "sections"
        "add";
    gap: 16px;
    align-items: start;
    min-width: 0;
    padding: 20px;
    border: 1px solid #e8eef5;
    border-radius: 28px;
    background: linear-gradient(180deg, #ffffff 0%, #fcfdff 100%);
    box-shadow: 0 12px 28px rgba(148, 163, 184, 0.06);
    scroll-snap-align: start;
}

.group-flow-board-week.is-current {
    border-color: #9ee2b3;
    box-shadow: 0 14px 30px rgba(34, 197, 94, 0.08);
}

.group-flow-board-week.is-planned {
    background: linear-gradient(180deg, #ffffff 0%, #fbfcfe 100%);
}

.group-flow-board-week-head {
    grid-area: head;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.group-flow-board-week-head h3 {
    margin: 0 0 4px;
    font-size: 28px;
    line-height: 1;
}

.group-flow-board-week-head p {
    margin: 0;
    color: #6b7a90;
    font-size: 15px;
}

.group-flow-board-week-badge {
    padding: 8px 12px;
    border-radius: 999px;
    background: #e7f9ee;
    color: #15803d;
    font-size: 12px;
    font-weight: 700;
}

.group-flow-board-week-badge.is-muted {
    background: #eef2f7;
    color: #64748b;
}

.group-flow-board-goal-form {
    grid-area: goal;
    display: grid;
    gap: 12px;
    padding: 18px 18px 16px;
    border: 1px solid #edf2f7;
    border-radius: 24px;
    background: linear-gradient(180deg, #ffffff 0%, #fbfcfe 100%);
}

.group-flow-board-goal-form label {
    color: #51627a;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.group-flow-board-goal-form textarea {
    width: 100%;
    min-height: 46px;
    padding: 12px 14px;
    border: 1px solid #e2eaf3;
    border-radius: 14px;
    background: #fff;
    color: #162235;
}

.group-flow-board-goal-form textarea {
    font-family: "SF Pro Text", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
    font-size: 17px;
    line-height: 1.55;
    letter-spacing: -0.015em;
    resize: vertical;
}

.group-flow-board-sections {
    display: grid;
    grid-area: sections;
    grid-template-columns: 1fr;
    gap: 12px;
    align-content: start;
}

.group-flow-board-section {
    display: grid;
    gap: 12px;
    padding: 14px;
    border: 1px solid #edf2f7;
    border-radius: 20px;
    background: linear-gradient(180deg, #ffffff 0%, #fcfdff 100%);
}

.group-flow-board-section.is-empty {
    background: #fbfdff;
}

.group-flow-board-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 2px;
}

.group-flow-board-section-head strong {
    font-size: 15px;
    letter-spacing: -0.01em;
}

.group-flow-board-section-head span {
    color: #6b7a90;
    font-size: 12px;
    font-weight: 800;
    min-width: 24px;
    min-height: 24px;
    padding: 0 8px;
    border-radius: 999px;
    background: #f1f5f9;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.group-flow-board-item-list {
    display: grid;
    gap: 10px;
}

.group-flow-board-item,
.group-flow-board-empty {
    border: 1px solid #e7edf5;
    border-radius: 18px;
    background: #fff;
}

.group-flow-board-item {
    display: grid;
    grid-template-columns: 56px minmax(0, 1fr);
    gap: 12px 14px;
    padding: 14px;
    align-items: start;
    box-shadow: 0 6px 18px rgba(148, 163, 184, 0.04);
}

.group-flow-board-item-media {
    display: block;
    width: 56px;
    height: 56px;
}

.group-flow-board-item-media img,
.group-flow-board-item-thumb {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    object-fit: cover;
}

.group-flow-board-item-thumb {
    display: block;
    background: #dbeafe;
}

.group-flow-board-item-thumb.type-reflection {
    background: #ede9fe;
}

.group-flow-board-item-thumb.type-text {
    background: #fef3c7;
}

.group-flow-board-item-thumb.type-exercise {
    background: #dcfce7;
}

.group-flow-board-item-copy {
    display: grid;
    gap: 5px;
    min-width: 0;
}

.group-flow-board-item-copy span {
    color: #6b7a90;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.group-flow-board-item-copy strong {
    color: #162235;
    font-size: 20px;
    line-height: 1.2;
    letter-spacing: -0.02em;
}

.group-flow-board-item-copy p {
    margin: 0;
    color: #51627a;
    font-size: 14px;
    line-height: 1.5;
}

.group-flow-board-empty {
    padding: 16px;
    color: #6b7a90;
    border-style: dashed;
}

.app-body {
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--accent) 10%, transparent) 0, transparent 26%),
        radial-gradient(circle at top right, color-mix(in srgb, var(--surface-3) 76%, transparent) 0, transparent 22%),
        linear-gradient(180deg, var(--page-bg) 0%, var(--page-bg-elevated) 100%);
}

.content {
    display: grid;
    align-items: start;
    justify-items: center;
    min-height: calc(100vh - 28px);
    padding: 28px clamp(24px, 2vw, 40px) 36px;
}

.content-surface {
    box-sizing: border-box;
    position: relative;
    display: grid;
    gap: 18px;
    width: min(100%, 1680px);
    min-width: 0;
    max-width: 100%;
    padding: 22px;
    border: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
    border-radius: 20px;
    background: color-mix(in srgb, var(--surface) 72%, var(--page-bg) 28%);
    box-shadow:
        0 18px 42px rgba(15, 23, 42, 0.055),
        inset 0 1px 0 rgba(255, 255, 255, 0.48);
}

.content-surface::before {
    display: none;
}

.content-surface > * {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: none;
}

.status-message {
    box-sizing: border-box;
    min-width: 0;
    max-width: 100%;
    margin-bottom: 4px;
    padding: 14px 16px;
    border: 1px solid color-mix(in srgb, var(--accent) 24%, transparent);
    border-radius: 16px;
    background: color-mix(in srgb, var(--accent-soft) 78%, white 22%);
    color: var(--accent-strong);
    font-weight: 700;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.statistics-dashboard {
    display: grid;
    gap: 18px;
}

.statistics-hero,
.statistics-chart-card,
.statistics-followup-card,
.statistics-table-card,
.statistics-kpi-card {
    border: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
    background: color-mix(in srgb, var(--surface) 94%, white 6%);
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.06);
}

.statistics-hero,
.statistics-chart-card,
.statistics-followup-card,
.statistics-table-card {
    border-radius: 28px;
}

.statistics-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    padding: 8px 4px 14px;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.statistics-hero h1 {
    margin: 0;
    color: var(--text-primary);
    font-size: clamp(34px, 4vw, 48px);
    letter-spacing: -0.05em;
    line-height: 0.98;
}

.statistics-hero p {
    max-width: 760px;
    margin: 10px 0 0;
    color: var(--text-muted);
    font-size: 15px;
    line-height: 1.7;
}

.statistics-date-pill {
    display: inline-flex;
    align-items: center;
    min-height: 46px;
    padding: 0 16px;
    border: 1px solid color-mix(in srgb, var(--border) 84%, transparent);
    border-radius: 16px;
    background: color-mix(in srgb, var(--surface) 94%, transparent);
    color: var(--text-secondary);
    font-weight: 700;
    white-space: nowrap;
}

.statistics-kpi-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 16px;
}

.statistics-kpi-card {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 16px;
    align-items: start;
    border-radius: 22px;
}

.statistics-kpi-icon,
.statistics-followup-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 18px;
    background: color-mix(in srgb, var(--surface-2) 84%, white 16%);
    color: var(--accent);
}

.statistics-kpi-icon svg,
.statistics-followup-icon svg {
    width: 24px;
    height: 24px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.statistics-kpi-icon.green {
    color: #4b8f57;
}

.statistics-kpi-icon.orange,
.statistics-followup-icon.warning {
    color: #dd7d42;
}

.statistics-kpi-icon.blue,
.statistics-followup-icon.accent {
    color: #4d79c9;
}

.statistics-kpi-icon.purple,
.statistics-insight-icon.purple {
    color: #8a63c7;
}

.statistics-kpi-copy {
    display: grid;
    gap: 4px;
}

.statistics-kpi-copy span,
.statistics-card-head p,
.statistics-followup-copy small {
    color: var(--text-muted);
}

.statistics-kpi-copy span {
    font-size: 14px;
    line-height: 1.45;
}

.statistics-kpi-copy strong {
    color: var(--text-primary);
    font-size: 38px;
    line-height: 1;
    letter-spacing: -0.04em;
}

.statistics-kpi-copy small {
    color: #4b8f57;
    font-size: 13px;
    font-weight: 700;
}

.statistics-main-grid,
.statistics-dual-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(340px, 0.95fr);
    gap: 18px;
}

.statistics-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}

.statistics-card-head h2 {
    margin: 6px 0 0;
    color: var(--text-primary);
    font-size: 30px;
    letter-spacing: -0.04em;
}

.statistics-card-head p {
    margin: 8px 0 0;
    font-size: 14px;
    line-height: 1.6;
}

.statistics-card-eyebrow {
    color: var(--accent);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.statistics-chart-card,
.statistics-followup-card,
.statistics-table-card {
    padding: 22px 22px 20px;
}

.statistics-chart-wrap {
    min-height: 360px;
}

.statistics-line-chart {
    min-height: 100%;
}

.statistics-grid-line {
    stroke: color-mix(in srgb, var(--border) 60%, transparent);
    stroke-width: 1;
    stroke-dasharray: 4 6;
}

.statistics-followup-list {
    display: grid;
    gap: 10px;
}

.statistics-followup-item {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 14px;
    align-items: center;
    padding: 14px;
    border: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
    border-radius: 18px;
    background: color-mix(in srgb, var(--surface) 92%, white 8%);
    text-decoration: none;
}

.statistics-followup-copy {
    min-width: 0;
}

.statistics-followup-copy strong {
    display: block;
    color: var(--text-primary);
    font-size: 15px;
}

.statistics-followup-copy small {
    display: block;
    margin-top: 5px;
    font-size: 13px;
    line-height: 1.55;
}

.statistics-followup-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    height: 34px;
    padding: 0 10px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-2) 88%, white 12%);
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 800;
}

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

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

.statistics-table th,
.statistics-table td {
    padding: 13px 0;
    border-bottom: 1px solid color-mix(in srgb, var(--border) 74%, transparent);
    text-align: left;
    vertical-align: middle;
}

.statistics-table th {
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 800;
}

.statistics-table td {
    color: var(--text-primary);
    font-size: 14px;
}

.statistics-progress-cell {
    display: grid;
    gap: 8px;
    min-width: 120px;
}

.statistics-progress-track {
    display: block;
    width: 100%;
    height: 7px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-3) 80%, white 20%);
    overflow: hidden;
}

.statistics-progress-bar {
    display: block;
    height: 100%;
    border-radius: inherit;
}

.statistics-progress-bar.is-good {
    background: linear-gradient(90deg, #4b8f57, #72b16c);
}

.statistics-progress-bar.is-mid {
    background: linear-gradient(90deg, #d8a244, #f0ba61);
}

.statistics-progress-bar.is-low {
    background: linear-gradient(90deg, #d46852, #eb8a72);
}

.statistics-status {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-2) 88%, white 12%);
    font-size: 12px;
    font-weight: 800;
}

@media (max-width: 1280px) {
    .statistics-kpi-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 980px) {
    .statistics-main-grid,
.statistics-dual-grid,
.statistics-kpi-grid {
        grid-template-columns: 1fr;
    }

    .statistics-hero {
        flex-direction: column;
        align-items: stretch;
    }
}

@media (max-width: 820px) {
    .content {
        padding: 74px 16px 22px;
    }

    .content-surface {
        padding: 14px;
        border-radius: 16px;
    }

    .content-surface::before {
        display: none;
    }

    .statistics-chart-card,
.statistics-followup-card,
.statistics-table-card,
.statistics-kpi-card {
        border-radius: 20px;
    }

    .statistics-kpi-copy strong {
        font-size: 32px;
    }

    .statistics-card-head h2 {
        font-size: 24px;
    }
}

.statistics-dashboard--insight {
    gap: 14px;
}

.statistics-dashboard--insight .statistics-hero {
    align-items: center;
    padding: 0;
}

.statistics-dashboard--insight .statistics-hero h1 {
    font-size: 34px;
    letter-spacing: 0;
    line-height: 1.05;
}

.statistics-dashboard--insight .statistics-hero p {
    max-width: 820px;
    margin-top: 6px;
    font-size: 13px;
    line-height: 1.45;
}

.statistics-dashboard--insight .statistics-date-pill {
    min-height: 42px;
    padding: 0 18px;
    border-radius: 14px;
    font-size: 13px;
    text-decoration: none;
}

.statistics-dashboard--insight .statistics-kpi-grid {
    gap: 12px;
}

.statistics-dashboard--insight .statistics-kpi-card {
    position: relative;
    min-height: 150px;
    padding: 18px;
    border-radius: 16px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}

.statistics-dashboard--insight .statistics-kpi-icon,
.statistics-dashboard--insight .statistics-followup-icon {
    width: 42px;
    height: 42px;
    border-radius: 14px;
}

.statistics-dashboard--insight .statistics-kpi-icon svg,
.statistics-dashboard--insight .statistics-followup-icon svg {
    width: 21px;
    height: 21px;
}

.statistics-dashboard--insight .statistics-kpi-icon.orange,
.statistics-dashboard--insight .statistics-followup-icon.warning,
.statistics-dashboard--insight .statistics-followup-icon.orange {
    color: #dd7d42;
}

.statistics-dashboard--insight .statistics-followup-icon.purple {
    color: #8a63c7;
}

.statistics-dashboard--insight .statistics-kpi-copy {
    gap: 4px;
}

.statistics-dashboard--insight .statistics-kpi-copy span {
    font-size: 13px;
    font-weight: 800;
}

.statistics-dashboard--insight .statistics-kpi-copy strong {
    font-size: 31px;
    letter-spacing: 0;
}

.statistics-dashboard--insight .statistics-kpi-copy small {
    color: var(--text-secondary);
    font-size: 12px;
    line-height: 1.35;
}

.statistics-dashboard--insight .statistics-inline-link {
    min-height: 30px;
    margin-top: auto;
    padding: 0 14px;
    border-radius: 12px;
    font-size: 12px;
}

.statistics-dashboard--insight .statistics-main-grid {
    grid-template-columns: minmax(0, 1.42fr) minmax(360px, 0.78fr);
    gap: 12px;
}

.statistics-dashboard--insight .statistics-dual-grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 12px;
}

.statistics-dashboard--insight .statistics-chart-card,
.statistics-dashboard--insight .statistics-followup-card,
.statistics-dashboard--insight .statistics-table-card {
    padding: 18px;
    border-radius: 16px;
}

.statistics-dashboard--insight .statistics-card-head {
    gap: 12px;
    margin-bottom: 12px;
}

.statistics-dashboard--insight .statistics-card-head--inline {
    align-items: center;
}

.statistics-dashboard--insight .statistics-card-head h2 {
    margin-top: 4px;
    font-size: 22px;
    letter-spacing: 0;
}

.statistics-dashboard--insight .statistics-card-eyebrow {
    letter-spacing: 0.08em;
}

.statistics-range-tabs {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 3px;
    border: 1px solid color-mix(in srgb, var(--border) 74%, transparent);
    border-radius: 14px;
    background: color-mix(in srgb, var(--surface) 92%, white 8%);
}

.statistics-range-tabs a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 48px;
    min-height: 30px;
    border-radius: 11px;
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 800;
    text-decoration: none;
    transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.statistics-range-tabs a:hover,
.statistics-range-tabs a:focus-visible {
    color: var(--text-primary);
    outline: none;
}

.statistics-range-tabs a.is-active {
    background: color-mix(in srgb, var(--surface-2) 90%, white 10%);
    color: var(--text-primary);
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.06);
}

.statistics-chart-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 10px;
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 800;
}

.statistics-chart-legend span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.statistics-chart-legend i {
    display: inline-block;
    width: 18px;
    height: 3px;
    border-radius: 999px;
    background: #335e96;
}

.statistics-chart-legend .is-bar {
    width: 13px;
    height: 13px;
    border-radius: 4px;
    background: #e7dfd0;
}

.statistics-combo-chart svg {
    display: block;
    width: 100%;
    height: auto;
    overflow: visible;
}

.statistics-combo-chart text {
    fill: var(--text-muted);
    font-size: 11px;
}

.statistics-axis-label {
    fill: var(--text-secondary);
    font-size: 12px;
    font-weight: 800;
}

.statistics-axis-label--right,
.statistics-right-tick {
    text-anchor: start;
}

.statistics-combo-bar {
    fill: #e7dfd0;
}

.statistics-combo-line {
    fill: none;
    stroke: #335e96;
    stroke-width: 3.4;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.statistics-combo-marker {
    fill: #335e96;
    stroke: #fff;
    stroke-width: 2.4;
}

.statistics-chart-footer,
.statistics-table-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.statistics-chart-footer {
    margin-top: 10px;
    padding: 10px 12px;
    border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
    border-radius: 14px;
    background: color-mix(in srgb, var(--surface-2) 56%, white 44%);
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 800;
}

.statistics-chart-footer .statistics-inline-link {
    margin: 0;
}

.statistics-dashboard--insight .statistics-followup-list {
    gap: 8px;
}

.statistics-dashboard--insight .statistics-followup-item {
    gap: 12px;
    padding: 11px;
    border-radius: 14px;
    color: inherit;
}

.statistics-dashboard--insight .statistics-followup-copy strong {
    font-size: 13px;
}

.statistics-dashboard--insight .statistics-followup-copy small {
    margin-top: 3px;
    font-size: 12px;
    line-height: 1.35;
}

.statistics-dashboard--insight .statistics-followup-count {
    min-width: 32px;
    height: 30px;
    font-size: 12px;
}

.statistics-table-link {
    margin-top: 12px;
    color: var(--accent-strong);
    font-size: 12px;
    font-weight: 850;
    text-decoration: none;
}

.statistics-table-link:hover {
    color: var(--text-primary);
}

.statistics-table--compact th,
.statistics-table--compact td {
    padding: 9px 0;
    font-size: 12px;
}

.statistics-table--compact th {
    font-size: 11px;
}

.statistics-table--compact .statistics-progress-cell {
    display: grid;
    grid-template-columns: minmax(82px, 1fr) auto;
    align-items: center;
    gap: 10px;
    min-width: 130px;
}

.statistics-status-pill {
    min-height: 24px;
}

.statistics-status-pill.is-good {
    background: rgba(75, 143, 87, 0.12);
    color: #3d7b4c;
}

.statistics-status-pill.is-focus {
    background: rgba(221, 125, 66, 0.13);
    color: #b86128;
}

.statistics-status-pill.is-critical {
    background: rgba(212, 104, 82, 0.13);
    color: #c63f36;
}

.statistics-kpi-grid--tests {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.statistics-kpi-card--link {
    color: inherit;
    text-decoration: none;
}

.statistics-card-arrow {
    position: absolute;
    top: 50%;
    right: 18px;
    color: var(--accent-strong);
    font-size: 26px;
    line-height: 1;
    transform: translateY(-50%);
}

@media (max-width: 1280px) {
    .statistics-dashboard--insight .statistics-kpi-grid,
    .statistics-dashboard--insight .statistics-kpi-grid--tests {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .statistics-dashboard--insight .statistics-main-grid,
    .statistics-dashboard--insight .statistics-dual-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .statistics-dashboard--insight .statistics-kpi-grid,
    .statistics-dashboard--insight .statistics-kpi-grid--tests {
        grid-template-columns: 1fr;
    }

    .statistics-dashboard--insight .statistics-hero,
    .statistics-dashboard--insight .statistics-card-head--inline,
    .statistics-chart-footer {
        align-items: stretch;
        flex-direction: column;
    }

    .statistics-range-tabs {
        width: 100%;
        justify-content: space-between;
    }
}

.statistics-inline-link {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 30px;
    margin-top: 4px;
    padding: 0 10px;
    border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--border));
    border-radius: 999px;
    background: color-mix(in srgb, var(--accent-soft) 72%, transparent);
    color: var(--accent-strong);
    font-size: 12px;
    font-weight: 800;
    text-decoration: none;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.statistics-inline-link:hover {
    border-color: color-mix(in srgb, var(--accent) 44%, var(--border));
    background: color-mix(in srgb, var(--accent-soft) 100%, var(--surface) 18%);
    color: var(--text-primary);
}

@media (max-width: 980px) {
    .group-summary-grid {
        grid-template-columns: 1fr;
    }

    .group-detail-header-main,
    .group-name-edit-form {
        align-items: stretch;
        flex-direction: column;
    }

    .group-name-edit-field {
        min-width: 0;
        width: 100%;
    }
}

.group-flow-board-empty-large {
    padding: 28px;
    text-align: center;
}

@media (max-width: 1100px) {
    .group-flow-setup-grid,
    .group-flow-board-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 720px) {
    .group-flow-setup-grid,
    .group-flow-board-summary {
        grid-template-columns: 1fr;
    }

    .group-flow-setup-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .group-flow-next-window,
    .group-flow-manual-start {
        align-items: stretch;
        flex-direction: column;
    }

    .group-flow-board {
        grid-auto-columns: minmax(320px, 92vw);
    }

    .group-flow-board-week {
        padding: 18px;
    }

    .group-flow-board-sections {
        grid-template-columns: 1fr;
    }
}

.coach-surface--hero,
.coach-surface--task,
.coach-surface--secondary,
.statistics-surface--task,
.statistics-surface--data {
    position: relative;
    overflow: hidden;
}

.coach-surface--hero {
    padding: 28px;
    border-radius: 30px;
}

.coach-surface--task {
    padding: 24px;
    border-color: color-mix(in srgb, var(--accent) 28%, var(--border));
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--accent) 10%, transparent), transparent 46%),
        var(--surface);
}

.coach-surface--secondary {
    padding: 20px;
    border-radius: 22px;
    background: color-mix(in srgb, var(--surface-2) 88%, transparent);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.coach-surface--secondary h2,
.coach-surface--task h2 {
    margin-bottom: 12px;
}

.detail-panel--workspace {
    padding: 26px;
    border-radius: 26px;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface) 92%, transparent), color-mix(in srgb, var(--surface-2) 82%, transparent));
}

.detail-panel--secondary {
    padding: 20px;
    background: color-mix(in srgb, var(--surface-2) 88%, transparent);
}

.statistics-kpi-grid {
    gap: 14px;
}

.statistics-kpi-card {
    box-shadow: none;
}

.statistics-kpi-card {
    padding: 16px 18px;
    background: color-mix(in srgb, var(--surface-2) 58%, white 42%);
}

.statistics-surface--task {
    border-color: color-mix(in srgb, var(--accent) 22%, var(--border));
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--accent) 10%, transparent), transparent 54%),
        color-mix(in srgb, var(--surface) 95%, white 5%);
}

.statistics-surface--data {
    padding: 24px;
    border-radius: 28px;
    background: color-mix(in srgb, var(--surface) 97%, white 3%);
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.08);
}

.statistics-surface--data .statistics-card-head h2,
.detail-panel--workspace h2 {
    font-size: 26px;
    letter-spacing: -0.03em;
}

.statistics-surface--secondary .statistics-card-head h2,
.detail-panel--secondary h2 {
    font-size: 22px;
}

.groups-page {
    gap: 24px;
}

.groups-hero-grid .coach-surface--hero {
    min-height: 220px;
    align-content: end;
}

.groups-hero-grid .coach-surface--secondary {
    align-content: start;
}

.groups-logic-create-redirect {
    display: grid;
    gap: 16px;
}

.groups-logic-actions {
    display: flex;
    justify-content: flex-end;
}

.group-bulk-toolbar {
    padding: 14px;
    border-radius: 22px;
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--accent) 7%, transparent), transparent 52%),
        color-mix(in srgb, var(--surface-2) 74%, transparent);
}

.groups-layout {
    align-items: start;
}

.detail-panel.detail-panel--workspace.active-groups-panel,
.detail-panel.detail-panel--secondary {
    padding: 26px;
    border: 1px solid color-mix(in srgb, var(--border) 88%, white 12%);
    border-radius: 28px;
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--accent-soft) 18%, transparent), transparent 28%),
        linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, white 2%), color-mix(in srgb, var(--surface-2) 96%, white 4%));
    box-shadow: 0 18px 38px rgba(15, 23, 42, 0.05);
}

.groups-section-head {
    margin-bottom: 20px;
}

.groups-section-head h2 {
    font-size: 28px;
    letter-spacing: -0.03em;
}

.groups-section-head p {
    max-width: 54ch;
    line-height: 1.6;
}

.groups-quick-create-panel .panel-disclosure-summary {
    min-height: 76px;
    padding: 18px 20px;
    border-radius: 18px;
    background: color-mix(in srgb, var(--surface) 90%, white 10%);
}

.groups-quick-create-panel .panel-disclosure-body {
    padding: 0 12px 12px;
}

.active-groups-list {
    gap: 16px;
}

.active-group-card {
    gap: 16px;
    padding: 22px;
    border-radius: 20px;
    border-color: color-mix(in srgb, var(--border) 86%, white 14%);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, white 2%), color-mix(in srgb, var(--surface-2) 96%, white 4%));
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

.active-group-copy strong {
    font-size: 24px;
    letter-spacing: -0.03em;
}

.active-group-copy p {
    font-size: 14px;
}

.active-group-count {
    min-width: 36px;
    height: 36px;
    border-radius: 12px;
    background: color-mix(in srgb, var(--surface-3) 76%, white 24%);
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 800;
}

.active-group-meta {
    gap: 10px;
}

.active-group-meta .segment-chip,
.groups-member-stats .segment-chip {
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-3) 72%, white 28%);
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 700;
}

.active-group-footer {
    align-items: center;
    padding-top: 14px;
}

.active-group-member-total {
    color: var(--text-muted);
    font-size: 13px;
    font-weight: 700;
}

.active-group-open-button {
    min-height: 40px;
    padding: 0 16px;
    border-radius: 12px;
    border-color: color-mix(in srgb, var(--border) 82%, white 18%);
    background: color-mix(in srgb, var(--surface) 96%, white 4%);
    box-shadow: none;
}

.groups-member-pool-controls {
    display: grid;
    gap: 14px;
    margin-bottom: 18px;
}

.group-member-filter-form,
.group-bulk-toolbar {
    margin: 0;
    padding: 14px;
    border: 1px solid color-mix(in srgb, var(--border) 86%, white 14%);
    border-radius: 20px;
    background: color-mix(in srgb, var(--surface) 97%, white 3%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

.group-member-filter-form {
    margin-bottom: 0;
}

.group-bulk-toolbar {
    gap: 14px;
}

.group-bulk-toolbar-copy {
    display: grid;
    gap: 2px;
    min-width: 150px;
}

.group-bulk-toolbar-copy strong {
    color: var(--text-primary);
    font-size: 14px;
}

.group-bulk-toolbar-copy span {
    color: var(--text-muted);
    font-size: 12px;
}

.groups-member-pool {
    gap: 18px;
}

.member-card-compact.selectable-member-card {
    gap: 18px;
    padding: 22px;
    border: 1px solid color-mix(in srgb, var(--border) 84%, white 16%);
    border-radius: 22px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 98%, white 2%), color-mix(in srgb, var(--surface-2) 96%, white 4%));
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

.member-card-compact .member-card-head {
    align-items: center;
    gap: 14px;
}

.member-card-compact .member-card-head h2 {
    margin: 0;
    font-size: 25px;
    letter-spacing: -0.03em;
}

.member-card-compact .member-card-head p {
    margin: 4px 0 0;
    color: var(--text-muted);
}

.member-card-compact .member-avatar {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-3) 74%, white 26%);
    color: var(--text-primary);
    font-size: 18px;
}

.group-member-assignment {
    display: grid;
    gap: 10px;
    margin-top: 2px;
}

.group-member-assignment-label {
    color: var(--text-muted);
    font-size: 12px;
    font-weight: 700;
}

.group-member-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
}

.group-member-form .secondary-action {
    min-height: 46px;
    padding: 0 16px;
    border-radius: 12px;
}

html:not([data-theme="dark"]) .detail-panel.detail-panel--workspace.active-groups-panel,
html:not([data-theme="dark"]) .detail-panel.detail-panel--secondary {
    border-color: #e3e8ee;
    background:
        radial-gradient(circle at top right, rgba(105, 156, 118, 0.07), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.05);
}

html:not([data-theme="dark"]) .group-member-filter-form,
html:not([data-theme="dark"]) .group-bulk-toolbar,
html:not([data-theme="dark"]) .member-card-compact.selectable-member-card,
html:not([data-theme="dark"]) .active-group-card {
    border-color: #e4e9ef;
    background: linear-gradient(180deg, #ffffff 0%, #fbfcfe 100%);
}

html:not([data-theme="dark"]) .active-group-count,
html:not([data-theme="dark"]) .active-group-meta .segment-chip,
html:not([data-theme="dark"]) .groups-member-stats .segment-chip,
html:not([data-theme="dark"]) .member-card-compact .member-avatar {
    background: #f1f4f7;
    color: #57697c;
}

html:not([data-theme="dark"]) .group-member-filter-grid .form-field input[type="search"],
html:not([data-theme="dark"]) .group-member-filter-grid .form-field input[type="number"],
html:not([data-theme="dark"]) .group-bulk-toolbar .smooth-select select,
html:not([data-theme="dark"]) .group-member-form select {
    border-color: #e1e6ec;
    background: #ffffff;
    color: #223547;
}

html:not([data-theme="dark"]) .group-member-form option,
html:not([data-theme="dark"]) .smooth-select option {
    background: #ffffff;
    color: #223547;
}

@media (max-width: 980px) {
    .coach-surface--hero,
.statistics-surface--data,
.detail-panel--workspace {
        padding: 22px;
    }
}

.chart-line.blue {
    color: #4d79c9;
    stroke: #4d79c9;
}

.chart-line.purple {
    color: #8a63c7;
    stroke: #8a63c7;
}

.primary-button,
.secondary-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 44px;
    padding: 0 18px;
    border-radius: 16px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.primary-button {
    border: 1px solid color-mix(in srgb, var(--accent) 24%, transparent);
    background: var(--accent);
    color: #fff;
}

.secondary-button {
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--surface-2) 82%, white 18%);
    color: var(--text-primary);
}

.admin-overview-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(320px, 0.72fr);
    grid-template-areas:
        "stats stats largest"
        "modules modules payment";
    gap: 20px;
    align-items: stretch;
}

.admin-overview-focus {
    grid-area: stats;
    min-height: 0;
    display: grid;
}

.admin-overview-head {
    display: grid;
    gap: 18px;
    align-content: start;
}

.admin-overview-head p {
    margin: 10px 0 0;
    color: var(--text-secondary);
    max-width: 56ch;
}

.admin-overview-cta {
    align-self: start;
    width: 100%;
}

.admin-largest-organizations-panel {
    grid-area: largest;
}

.admin-payment-status-panel {
    grid-area: payment;
}

.admin-overview-grid > .admin-ranking-panel {
    margin-top: 0;
}

.admin-statistics-page {
    gap: 16px;
}

.admin-statistics-page--revamp {
    gap: 16px;
}

.admin-statistics-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    min-height: 0;
    padding: 22px 24px;
    border: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
    border-radius: 20px;
    background:
        linear-gradient(135deg, rgba(18, 30, 42, 0.96), rgba(29, 43, 52, 0.92)),
        #17222e;
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.1);
}

.admin-statistics-hero__copy {
    display: grid;
    gap: 8px;
    max-width: 640px;
}

.admin-statistics-hero__copy .coach-dashboard-badge {
    justify-self: start;
    width: fit-content;
    min-height: 26px;
    padding: 0 12px;
}

.admin-statistics-hero__copy h1 {
    margin: 0;
    color: #f8fbf7;
    font-size: clamp(34px, 4vw, 44px);
    line-height: 1;
    letter-spacing: 0;
}

.admin-statistics-hero__copy p {
    margin: 0;
    color: rgba(248, 251, 247, 0.82);
    font-size: 14px;
    line-height: 1.55;
}

.admin-statistics-hero__actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 10px;
    flex: 0 0 auto;
}

.admin-statistics-hero__button {
    min-height: 40px;
    border-radius: 10px;
    padding: 0 14px;
}

.admin-statistics-spotlight-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}

.admin-statistics-card--spotlight {
    min-height: 0;
    padding: 14px;
    border-radius: 16px;
}

.admin-statistics-card--spotlight,
.admin-statistics-card--compact {
    box-sizing: border-box;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
}

.admin-statistics-page .statistics-kpi-icon {
    width: 40px;
    height: 40px;
    border-radius: 13px;
}

.admin-statistics-page .statistics-kpi-icon svg {
    width: 20px;
    height: 20px;
}

.admin-statistics-page .statistics-kpi-copy {
    min-width: 0;
    gap: 4px;
}

.admin-statistics-page .statistics-kpi-copy span {
    font-size: 13px;
    font-weight: 700;
    line-height: 1.35;
}

.admin-statistics-page .statistics-kpi-copy strong {
    font-size: clamp(28px, 3vw, 36px);
    line-height: 0.98;
    letter-spacing: 0;
    overflow-wrap: anywhere;
}

.admin-statistics-page .statistics-kpi-copy small {
    color: var(--text-secondary);
    font-size: 12px;
    line-height: 1.35;
    font-weight: 650;
}

.admin-statistics-card--spotlight.is-danger {
    border-color: color-mix(in srgb, var(--danger) 28%, var(--border));
}

.admin-statistics-overview-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    gap: 16px;
}

.admin-statistics-overview-grid .statistics-chart-wrap {
    min-height: 220px;
}

.admin-statistics-secondary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.admin-statistics-secondary-grid .statistics-chart-wrap {
    min-height: 190px;
}

.admin-statistics-keymetrics {
    display: grid;
    gap: 14px;
}

.admin-statistics-keymetrics__grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}

.admin-statistics-tables-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.admin-statistics-table-card {
    display: grid;
    gap: 16px;
}

.admin-statistics-table-wrap {
    overflow-x: auto;
}

.admin-statistics-table {
    width: 100%;
    border-collapse: collapse;
}

.admin-statistics-table th,
.admin-statistics-table td {
    padding: 12px 0;
    border-bottom: 1px solid color-mix(in srgb, var(--border) 66%, transparent);
    text-align: left;
}

.admin-statistics-table th {
    color: var(--text-muted);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.admin-statistics-table td {
    color: var(--text-primary);
    font-size: 14px;
}

.admin-statistics-table .is-value {
    text-align: right;
    font-weight: 700;
}

.admin-statistics-workspace {
    display: grid;
}

.admin-statistics-workspace__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.admin-statistics-workspace__head p {
    margin: 8px 0 0;
    color: var(--text-secondary);
}

.admin-statistics-card {
    min-height: 0;
}

.admin-statistics-page .statistics-chart-card {
    padding: 18px;
    border-radius: 16px;
}

.admin-statistics-page .statistics-card-head {
    margin-bottom: 10px;
}

.admin-statistics-page .statistics-card-head h2 {
    margin: 0;
    font-size: 22px;
    line-height: 1.12;
    letter-spacing: 0;
}

.admin-statistics-page .statistics-card-head p {
    margin-top: 6px;
    font-size: 13px;
    line-height: 1.45;
}

.admin-statistics-overview-charts .statistics-chart-card:first-child {
    grid-column: span 2;
}

.admin-statistics-summary-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 10px;
}

.admin-statistics-selection-pill {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: color-mix(in srgb, var(--surface-2) 78%, white 22%);
    color: var(--text-secondary);
    font-size: 14px;
    font-weight: 600;
}

.admin-statistics-card--compact {
    background: color-mix(in srgb, var(--surface-2) 70%, white 30%);
}

.admin-ranking-row span {
    display: grid;
    gap: 4px;
}

.admin-ranking-row span small {
    color: var(--text-muted);
}

.admin-stats-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
}

.admin-stats-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.52);
    backdrop-filter: blur(6px);
}

.admin-stats-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(1080px, calc(100vw - 32px));
    max-height: calc(100vh - 48px);
    margin: 24px auto;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    border: 1px solid var(--border);
    border-radius: 28px;
    background: var(--surface);
    box-shadow: 0 26px 70px rgba(15, 23, 42, 0.22);
    overflow: hidden;
}

.admin-stats-modal__header,
.admin-stats-modal__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 22px 24px;
    border-bottom: 1px solid var(--border);
}

.admin-stats-modal__header p {
    margin: 10px 0 0;
    color: var(--text-secondary);
    max-width: 60ch;
}

.admin-stats-modal__close {
    width: 42px;
    height: 42px;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: color-mix(in srgb, var(--surface-2) 82%, white 18%);
    color: var(--text-primary);
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
}

.admin-stats-modal__form {
    min-height: 0;
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
}

.admin-stats-modal__body {
    min-height: 0;
    overflow: auto;
    display: grid;
    gap: 22px;
    padding: 24px;
}

.admin-stats-modal__footer {
    border-top: 1px solid var(--border);
    border-bottom: 0;
}

.admin-stats-picker {
    display: grid;
    gap: 14px;
}

.admin-stats-picker__head {
    display: grid;
    gap: 6px;
}

.admin-stats-picker__head p {
    margin: 0;
    color: var(--text-secondary);
}

.admin-stats-picker__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.admin-stats-option {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 12px;
    align-items: start;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: color-mix(in srgb, var(--surface-2) 78%, white 22%);
    cursor: pointer;
}

.admin-stats-option input {
    margin-top: 3px;
}

.admin-stats-option span {
    display: grid;
    gap: 4px;
}

.admin-stats-option small {
    color: var(--text-muted);
    line-height: 1.45;
}

.admin-stats-modal-open {
    overflow: hidden;
}

html:not([data-theme="dark"]) .admin-statistics-page .statistics-chart-card,
html:not([data-theme="dark"]) .admin-statistics-page .statistics-kpi-card,
html:not([data-theme="dark"]) .admin-statistics-page .coach-panel,
html:not([data-theme="dark"]) .admin-statistics-page .admin-mini-card {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(246, 249, 253, 0.94)),
        var(--surface);
}

html:not([data-theme="dark"]) .admin-statistics-page .statistics-chart-card,
html:not([data-theme="dark"]) .admin-statistics-page .statistics-kpi-card,
html:not([data-theme="dark"]) .admin-statistics-page .coach-panel,
html:not([data-theme="dark"]) .admin-statistics-page .admin-mini-card,
html:not([data-theme="dark"]) .admin-stats-modal__dialog,
html:not([data-theme="dark"]) .admin-stats-option,
html:not([data-theme="dark"]) .admin-statistics-selection-pill,
html:not([data-theme="dark"]) .primary-button,
html:not([data-theme="dark"]) .secondary-button {
    border-color: color-mix(in srgb, var(--border) 80%, #d7e2ef);
}

html:not([data-theme="dark"]) .admin-statistics-page .coach-panel::before,
html:not([data-theme="dark"]) .admin-statistics-page .statistics-chart-card::before {
    opacity: 0.26;
}

html:not([data-theme="dark"]) .admin-statistics-hero {
    border-color: color-mix(in srgb, var(--border) 88%, #cfe0ed);
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(239, 246, 242, 0.88)),
        linear-gradient(135deg, color-mix(in srgb, var(--accent-soft) 58%, white 42%), color-mix(in srgb, #e7eef7 72%, white 28%));
    box-shadow:
        0 14px 30px rgba(79, 109, 138, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

html:not([data-theme="dark"]) .admin-statistics-hero__copy h1 {
    color: var(--text-primary);
}

html:not([data-theme="dark"]) .admin-statistics-hero__copy p {
    color: var(--text-secondary);
}

html:not([data-theme="dark"]) .admin-statistics-hero__copy .coach-dashboard-badge {
    background: color-mix(in srgb, var(--accent-soft) 72%, white 28%);
    color: var(--accent-strong);
    border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--border));
}

@media (max-width: 1180px) {
    .admin-statistics-spotlight-grid,
    .admin-statistics-keymetrics__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .admin-statistics-overview-grid,
.admin-statistics-secondary-grid,
.admin-statistics-tables-grid,
.admin-statistics-workspace__head,
.admin-overview-grid {
        grid-template-columns: 1fr;
    }

    .admin-overview-grid {
        grid-template-areas:
            "stats"
            "modules"
            "largest"
            "payment";
    }

    .admin-module-distribution-panel .customer-admin-module-bars {
        grid-template-columns: 1fr;
    }

    .admin-statistics-overview-charts .statistics-chart-card:first-child {
        grid-column: span 1;
    }
}

@media (max-width: 980px) {
    .admin-statistics-hero {
        align-items: stretch;
        flex-direction: column;
    }

    .admin-stats-modal__header,
.admin-stats-modal__footer {
        flex-direction: column;
        align-items: stretch;
    }

    .admin-stats-picker__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .admin-statistics-spotlight-grid,
    .admin-statistics-keymetrics__grid {
        grid-template-columns: 1fr;
    }

    .admin-statistics-hero {
        padding: 22px 20px;
        border-radius: 22px;
    }

    .admin-statistics-hero__actions {
        justify-content: flex-start;
    }
}

.statistics-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 9999px;
    padding: .35rem .75rem;
    font-size: .78rem;
    font-weight: 700;
    white-space: nowrap;
}

.statistics-status-pill.is-performing_well {
    background: #dcfce7;
    color: #166534;
}

.statistics-status-pill.is-building_data {
    background: #dbeafe;
    color: #1d4ed8;
}

.statistics-status-pill.is-needs_attention {
    background: #fef3c7;
    color: #92400e;
}

.statistics-status-pill.is-missing_data {
    background: #fee2e2;
    color: #b91c1c;
}

.workout-builder-form {
    gap: 28px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.workout-builder-hero {
    display: grid;
    gap: 10px;
}

.workout-builder-hero__copy h1 {
    margin: 0;
    color: var(--text-primary);
    font-size: clamp(36px, 4vw, 54px);
    line-height: 0.98;
    letter-spacing: -0.04em;
}

.workout-builder-org-chip {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 14px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--surface-2) 82%, white 18%);
    color: var(--accent);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.workout-builder-stepper {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    align-items: center;
}

.workout-builder-stepper__item {
    position: relative;
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
    color: var(--text-muted);
    text-decoration: none;
}

.workout-builder-stepper__item::after {
    content: "";
    flex: 1 1 auto;
    height: 1px;
    background: var(--border);
}

.workout-builder-stepper__item:last-child::after {
    display: none;
}

.workout-builder-stepper__item span:last-child {
    white-space: nowrap;
    font-size: 14px;
    font-weight: 600;
}

.workout-builder-stepper__index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 40px;
    width: 40px;
    height: 40px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--surface);
    color: var(--text-primary);
    font-size: 15px;
    font-weight: 800;
}

.workout-builder-stepper__item.is-active .workout-builder-stepper__index {
    border-color: var(--accent);
    background: var(--accent);
    color: var(--accent-contrast);
    box-shadow: 0 16px 28px rgba(15, 76, 58, 0.18);
}

.workout-form-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(320px, 0.52fr);
    gap: 28px;
    align-items: start;
}

.workout-form-main,
.workout-form-sidebar {
    display: grid;
    gap: 18px;
}

.workout-setup-section {
    padding: 22px 24px;
    border: 1px solid var(--border);
    border-radius: 26px;
    background: color-mix(in srgb, var(--surface) 92%, white 8%);
    box-shadow: 0 18px 46px rgba(15, 23, 42, 0.05);
}

.workout-section-heading {
    margin-bottom: 18px;
}

.workout-section-heading h2 {
    margin: 0;
    color: var(--text-primary);
    font-size: 31px;
    letter-spacing: -0.03em;
}

.workout-section-heading p {
    margin: 8px 0 0;
    color: var(--text-muted);
    font-size: 14px;
    line-height: 1.6;
}

.workout-choice-panel,
.workout-builder-row {
    border: 1px solid var(--border);
    border-radius: 20px;
    background: color-mix(in srgb, var(--surface-2) 82%, white 18%);
}

.workout-choice-panel {
    padding: 16px 18px;
}

.workout-choice-panel__head h3,
.workout-builder-row__identity h3 {
    margin: 0;
    color: var(--text-primary);
}

.workout-choice-panel__head p,
.workout-builder-row__identity p,
.workout-builder-row__status,
.workout-builder-row__empty {
    color: var(--text-muted);
}

.workout-chip {
    min-height: 38px;
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--text-secondary);
}

.workout-chip span,
.workout-chip.active {
    min-height: 38px;
    padding: 0 14px;
}

.workout-builder-row__summary {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 16px;
    align-items: center;
    padding: 16px 18px;
}

.workout-builder-row__identity {
    display: flex;
    align-items: center;
    gap: 14px;
}

.workout-builder-row__handle {
    color: var(--text-muted);
    font-size: 16px;
    line-height: 1;
}

.workout-builder-row__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 12px;
    background: var(--surface);
    border: 1px solid var(--border);
    font-weight: 700;
}

.workout-builder-row__button {
    min-width: 132px;
}

.workout-builder-row__body,
.workout-content-card__body {
    padding: 0 18px 18px;
}

.workout-step-card {
    border: 1px solid var(--border);
    border-radius: 18px;
    background: var(--surface);
    box-shadow: none;
}

.workout-step-card__head {
    padding: 14px 16px 0;
}

.workout-publish-toggle {
    margin-bottom: 16px;
    padding: 14px 16px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: var(--surface);
}

.workout-completion-callout {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 14px;
    padding: 16px 18px;
    border-radius: 18px;
    background: color-mix(in srgb, var(--accent-soft) 62%, white 38%);
    border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--border) 82%);
}

.workout-completion-callout__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: var(--surface);
    color: var(--accent);
    font-weight: 800;
}

.workout-form-actions--builder {
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-top: 20px;
}

.workout-form-actions__submit {
    display: flex;
    align-items: center;
    gap: 14px;
}

.workout-form-sidebar {
    position: sticky;
    top: 24px;
}

.workout-form-sidebar__section {
    padding: 22px;
}

.workout-phone-preview {
    padding: 6px 0 0;
}

.workout-phone-preview__device {
    max-width: 320px;
    margin: 0 auto;
    padding: 14px;
    border-radius: 42px;
    background: linear-gradient(180deg, #f6f4ef 0%, #fbfaf8 100%);
    border: 1px solid rgba(148, 163, 184, 0.24);
    box-shadow: 0 28px 46px rgba(15, 23, 42, 0.09);
}

.workout-phone-preview__screen {
    display: grid;
    gap: 16px;
    min-height: 620px;
    padding: 20px 18px 18px;
    border-radius: 30px;
    background: #fffdfa;
    border: 1px solid rgba(148, 163, 184, 0.2);
}

.workout-phone-preview__notch {
    width: 120px;
    height: 20px;
    margin: 0 auto 10px;
    border-radius: 999px;
    background: #111827;
}

.workout-phone-preview__status {
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: #0f172a;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: -0.02em;
}

.workout-phone-preview__status-icons {
    display: inline-flex;
    align-items: flex-end;
    gap: 3px;
}

.workout-phone-preview__status-icons i {
    display: block;
    width: 4px;
    border-radius: 999px;
    background: #0f172a;
}

.workout-phone-preview__status-icons i:nth-child(1) {
    height: 6px;
}

.workout-phone-preview__status-icons i:nth-child(2) {
    height: 9px;
}

.workout-phone-preview__status-icons i:nth-child(3) {
    width: 14px;
    height: 7px;
}

.workout-phone-preview__topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: #1f2937;
    font-size: 18px;
}

.workout-phone-preview__topbar strong {
    font-size: 14px;
}

.workout-phone-preview__hero {
    display: grid;
    gap: 10px;
}

.workout-phone-preview__hero strong {
    color: #111827;
    font-size: 18px;
}

.workout-phone-preview__hero p {
    margin: 0;
    color: #64748b;
    font-size: 14px;
}

.workout-phone-preview__eyebrow {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    color: #64748b;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.workout-phone-preview__media {
    overflow: hidden;
    border-radius: 18px;
    aspect-ratio: 16 / 9;
    background: linear-gradient(135deg, rgba(15, 76, 58, 0.16) 0%, rgba(214, 179, 94, 0.26) 100%);
}

.workout-phone-preview__media img,
.workout-phone-preview__media-fallback {
    width: 100%;
    height: 100%;
    display: block;
}

.workout-phone-preview__media img {
    object-fit: cover;
}

.workout-phone-preview__media-fallback {
    background:
        radial-gradient(circle at top left, rgba(255, 255, 255, 0.65), transparent 42%),
        linear-gradient(135deg, rgba(15, 76, 58, 0.85), rgba(214, 179, 94, 0.56));
}

.workout-phone-preview__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.workout-phone-preview__chips span {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 11px;
    border-radius: 999px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    color: #334155;
    font-size: 12px;
    font-weight: 600;
}

.workout-phone-preview__list {
    display: grid;
    gap: 0;
    border: 1px solid #e2e8f0;
    border-radius: 18px;
    overflow: hidden;
    background: #ffffff;
}

.workout-phone-preview__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 15px 14px;
    border-bottom: 1px solid #edf2f7;
}

.workout-phone-preview__item:last-child {
    border-bottom: 0;
}

.workout-phone-preview__item strong {
    color: #1f2937;
    font-size: 14px;
}

.workout-phone-preview__item p {
    margin: 4px 0 0;
    color: #64748b;
    font-size: 12px;
}

.workout-phone-preview__footer {
    margin-top: auto;
}

.workout-phone-preview__footer button {
    width: 100%;
    min-height: 46px;
    border: 0;
    border-radius: 999px;
    background: var(--accent);
    color: var(--accent-contrast);
    font-size: 15px;
    font-weight: 700;
}

.workout-preview-tip {
    display: grid;
    gap: 6px;
}

.workout-preview-tip strong {
    color: var(--text-primary);
}

.workout-builder-form--edit .workout-builder-stepper {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.workout-builder-form--edit .workout-form-layout {
    grid-template-columns: minmax(0, 1.65fr) minmax(340px, 0.65fr);
    align-items: start;
    gap: 32px;
}

.workout-builder-form--edit .workout-form-main {
    display: grid;
    gap: 24px;
}

.workout-builder-form--edit .workout-editor-card--reference {
    border-radius: 28px;
    border: 1px solid #dbe5eb;
    background: linear-gradient(180deg, #ffffff, #f9fbfb);
    box-shadow: 0 20px 45px rgba(15, 23, 42, 0.06);
    padding: 20px 24px;
}

.workout-reference-card {
    display: grid;
    gap: 20px;
}

.workout-reference-field {
    display: grid;
    gap: 8px;
}

.workout-reference-field label,
.workout-reference-meta-group > label,
.workout-reference-media-block > label,
.workout-reference-thumbnail-block > label {
    color: #0f172a;
    font-size: 14px;
    font-weight: 800;
}

.workout-reference-field input,
.workout-reference-field textarea {
    width: 100%;
    border: 1px solid #d6dfe7;
    border-radius: 12px;
    background: #ffffff;
    padding: 12px 16px;
    color: #0f172a;
    font-size: 15px;
    box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.02);
}

.workout-reference-field textarea {
    min-height: 74px;
    resize: vertical;
}

.workout-reference-media-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 180px;
    gap: 32px;
    align-items: start;
}

.workout-reference-media-block,
.workout-reference-thumbnail-block,
.workout-builder-form--edit .workout-form-sidebar__section {
    display: grid;
    gap: 10px;
}

.workout-reference-video-stage {
    position: relative;
    min-height: 190px;
    overflow: hidden;
    border-radius: 12px;
    border: 1px solid #d6dfe7;
    background: linear-gradient(180deg, #e2e8f0, #cbd5e1);
}

.workout-reference-video-stage img {
    width: 100%;
    height: 100%;
    min-height: 190px;
    object-fit: cover;
    display: block;
}

.workout-reference-video-stage__empty {
    display: grid;
    min-height: 190px;
    place-items: center;
    color: #475569;
    font-weight: 700;
}

.workout-reference-video-stage__play,
.workout-phone-preview__play {
    position: absolute;
    inset: 50% auto auto 50%;
    transform: translate(-50%, -50%);
    width: 64px;
    height: 64px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: rgba(15, 23, 42, 0.5);
    color: #ffffff;
    font-size: 20px;
    backdrop-filter: blur(6px);
}

.workout-reference-video-picker .workout-video-picker__summary {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    padding: 12px 14px;
    border: 1px solid #d6dfe7;
    border-radius: 14px;
    background: #ffffff;
}

.workout-reference-video-picker .workout-video-picker__thumb {
    width: 52px;
    height: 52px;
    border-radius: 12px;
}

.workout-reference-video-picker .workout-video-picker__actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.workout-reference-thumbnail-preview {
    width: 100%;
    height: 76px;
    overflow: hidden;
    border-radius: 12px;
    border: 1px solid #d6dfe7;
    background: #f1f5f9;
}

.workout-reference-thumbnail-preview img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.workout-reference-thumbnail-preview__empty {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    color: #64748b;
    font-size: 13px;
}

.workout-reference-thumbnail-button {
    display: grid;
    min-height: 132px;
    justify-items: center;
    align-content: center;
    gap: 4px;
    border: 1px dashed #c7d3df;
    border-radius: 14px;
    background: #f8fafc;
    color: #0f172a;
    padding: 18px;
    cursor: pointer;
}

.workout-reference-thumbnail-button strong {
    font-size: 15px;
}

.workout-reference-thumbnail-button small {
    color: #64748b;
    font-size: 13px;
}

.workout-reference-meta {
    display: grid;
    gap: 18px;
}

.workout-reference-meta-group {
    display: grid;
    gap: 10px;
}

.workout-reference-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.workout-reference-chip {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    border: 1px solid #d6dfe7;
    background: #ffffff;
    color: #0f172a;
    transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
}

.workout-reference-chip input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.workout-reference-chip span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 40px;
    padding: 0 18px;
    font-size: 14px;
    font-weight: 700;
}

.workout-reference-chip--level.is-active,
.workout-reference-chip--level:has(input:checked) {
    border-color: #10755b;
    background: linear-gradient(135deg, #10755b, #115e59);
    color: #ffffff;
    box-shadow: 0 12px 24px rgba(16, 117, 91, 0.18);
}

.workout-reference-chip--tag:has(input:checked) {
    border-color: color-mix(in srgb, var(--chip-color) 45%, white);
    background: color-mix(in srgb, var(--chip-color) 10%, white);
}

.workout-reference-duration-hint {
    margin-top: -4px;
}

.workout-builder-form--edit .workout-editor-footer--reference {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 0;
    border-top: 1px solid #e2e8f0;
    padding-top: 24px;
}

.workout-builder-form--edit .workout-publish-toggle--reference {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 0;
    padding: 0;
    border: 0;
    background: transparent;
}

.workout-builder-form--edit .workout-form-actions--reference {
    display: flex;
    align-items: center;
    gap: 16px;
    width: auto;
    margin-top: 0;
}

.workout-builder-form--edit .workout-form-actions__submit {
    display: flex;
    align-items: center;
    gap: 16px;
}

.workout-builder-form--edit .workout-form-actions--reference .secondary-action,
.workout-builder-form--edit .workout-form-actions--reference .primary-action {
    width: auto;
    min-width: 220px;
}

.workout-builder-form--edit .workout-form-sidebar__section {
    padding: 28px;
    border-radius: 28px;
    border: 1px solid #e2e8f0;
    background: linear-gradient(180deg, #ffffff, #f9fafb);
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.05);
}

.workout-builder-form--edit .workout-phone-preview__device {
    max-width: 360px;
    padding: 10px;
    border-radius: 46px;
    background:
        linear-gradient(145deg, #080b10, #1b1f26 46%, #050608),
        #111111;
    box-shadow: 0 28px 60px rgba(15, 23, 42, 0.2);
}

.workout-builder-form--edit .workout-phone-preview__screen {
    position: relative;
    align-content: start;
    gap: 18px;
    min-height: 610px;
    padding: 16px 18px 18px;
    overflow: hidden;
    border-radius: 34px;
    background:
        radial-gradient(circle at 50% -18%, rgba(47, 119, 85, 0.12), transparent 36%),
        linear-gradient(180deg, #ffffff 0%, #fbfaf6 62%, #f3efe7 100%);
}

.workout-builder-form--edit .workout-phone-preview__hero--reference {
    gap: 14px;
    padding-top: 66px;
}

.workout-builder-form--edit .workout-phone-preview__media--reference {
    position: relative;
    min-height: 158px;
    overflow: hidden;
    border-radius: 18px;
    background:
        radial-gradient(circle at 22% 20%, rgba(255, 255, 255, 0.5), transparent 32%),
        linear-gradient(135deg, #88a99a 0%, #6d8f6f 50%, #d7c586 100%);
    box-shadow: 0 18px 34px rgba(31, 41, 55, 0.12);
}

.workout-builder-form--edit .workout-phone-preview__media--reference img {
    width: 100%;
    height: 100%;
    min-height: 150px;
    display: block;
    object-fit: cover;
}

.workout-builder-form--edit .workout-phone-preview__hero--reference strong {
    color: #0f172a;
    font-size: 25px;
    line-height: 1.1;
    letter-spacing: -0.05em;
}

.workout-builder-form--edit .workout-phone-preview__hero--reference p {
    color: #26364a;
    font-size: 15px;
    line-height: 1.55;
}

.workout-builder-form--edit .workout-phone-preview__list,
.workout-builder-form--edit .workout-preview-tip {
    display: none;
}

.workout-builder-form--edit .workout-phone-preview__status {
    padding: 0 4px;
}

.workout-builder-form--edit .workout-phone-preview__topbar {
    min-height: 40px;
    padding: 0 2px;
    color: #0f172a;
    font-size: 18px;
}

.workout-builder-form--edit .workout-phone-preview__topbar strong {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.05);
    color: #0f172a;
    font-size: 12px;
    letter-spacing: 0.02em;
}

.workout-builder-form--edit .workout-phone-preview__eyebrow {
    margin-top: 2px;
}

.workout-builder-form--edit .workout-phone-preview__chips--reference {
    margin-top: 2px;
}

.workout-builder-form--edit .workout-phone-preview__chips--reference span {
    min-height: 28px;
    border-color: rgba(47, 119, 85, 0.16);
    background: rgba(47, 119, 85, 0.08);
    color: #244c38;
    font-size: 11px;
}

.workout-builder-form--edit .workout-phone-preview__footer {
    align-self: end;
    margin-top: 18px;
}

.workout-builder-form--edit .workout-phone-preview__footer button {
    width: 100%;
    min-height: 48px;
    border: 0;
    border-radius: 18px;
    background: linear-gradient(135deg, #17633f, #2c7a51);
    color: #ffffff;
    font-size: 14px;
    font-weight: 900;
    box-shadow: 0 18px 28px rgba(23, 99, 63, 0.24);
}

@media (max-width: 1100px) {
    .workout-builder-form--edit .workout-form-layout {
        grid-template-columns: 1fr;
    }

    .workout-reference-media-grid {
        grid-template-columns: 1fr;
    }

    .workout-builder-form--edit .workout-editor-footer--reference,
    .workout-builder-form--edit .workout-form-actions--reference,
    .workout-builder-form--edit .workout-form-actions__submit {
        flex-direction: column;
        align-items: stretch;
    }

    .workout-builder-form--edit .workout-form-actions--reference .secondary-action,
    .workout-builder-form--edit .workout-form-actions--reference .primary-action {
        width: 100%;
    }
}

.program-item-builder {
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    gap: 24px;
}

.program-item-builder__header h2 {
    margin: 0;
    color: var(--text-primary);
    font-size: clamp(34px, 4vw, 50px);
    letter-spacing: -0.04em;
}

.program-item-builder__header p {
    margin: 8px 0 0;
    color: var(--text-muted);
    font-size: 15px;
    line-height: 1.6;
}

.program-item-builder__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(300px, 0.85fr);
    gap: 18px;
    align-items: start;
}

.program-item-builder__main,
.program-item-builder__sidebar {
    display: grid;
    gap: 16px;
}

.program-item-builder__section,
.program-item-builder__preview-card {
    padding: 18px;
    border: 1px solid var(--border);
    border-radius: 20px;
    background: color-mix(in srgb, var(--surface) 92%, white 8%);
    box-shadow: var(--shadow-soft);
}

.program-item-builder__section-head {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 16px;
}

.program-item-builder__section-head h3,
.program-item-builder__preview-head h3 {
    margin: 0;
    color: var(--text-primary);
    font-size: 24px;
    letter-spacing: -0.03em;
}

.program-item-builder__section-head p,
.program-item-builder__preview-head p {
    margin: 6px 0 0;
    color: var(--text-muted);
    font-size: 14px;
    line-height: 1.6;
}

.program-branch-editor-summary__list {
    display: grid;
    gap: 10px;
}

.program-branch-editor-summary__add {
    justify-self: start;
    margin-top: 12px;
}

.program-branch-editor-summary__path,
.program-branch-editor-summary__rule {
    --program-branch-editor-color: #64748b;
    display: grid;
    gap: 5px;
    padding: 12px;
    border: 1px solid color-mix(in srgb, var(--program-branch-editor-color) 28%, var(--border));
    border-left: 4px solid var(--program-branch-editor-color);
    border-radius: 12px;
    background: color-mix(in srgb, var(--program-branch-editor-color) 8%, var(--surface));
    color: inherit;
    text-decoration: none;
}

.program-branch-editor-summary__path.is-progress {
    --program-branch-editor-color: #15803d;
}

.program-branch-editor-summary__path.is-caution {
    --program-branch-editor-color: #b45309;
}

.program-branch-editor-summary__path span,
.program-branch-editor-summary__rule span,
.program-branch-editor-summary__rule em {
    justify-self: start;
    max-width: 100%;
    padding: 5px 8px;
    border-radius: 999px;
    background: #fff;
    color: var(--program-branch-editor-color);
    font-size: 12px;
    font-style: normal;
    font-weight: 950;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.program-branch-editor-summary__path strong,
.program-branch-editor-summary__rule strong {
    color: var(--text-primary);
    font-size: 15px;
    font-weight: 950;
    line-height: 1.25;
}

.program-branch-editor-summary__path small,
.program-branch-editor-summary__rule small {
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 800;
    line-height: 1.35;
}

.program-item-builder__library-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 40px;
    width: 40px;
    height: 40px;
    border-radius: 14px;
    background: color-mix(in srgb, var(--surface-2) 80%, white 20%);
    color: var(--text-secondary);
    font-size: 18px;
    font-weight: 700;
}

.program-item-builder__library-grid,
.program-item-builder__visual-grid {
    display: grid;
    gap: 16px;
}

.program-item-builder__library-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.program-item-builder__visual-grid {
    grid-template-columns: minmax(0, 1fr) 140px minmax(0, 1fr);
    align-items: start;
}

.program-item-builder__fields {
    display: grid;
    gap: 18px;
}

.completion-field-list {
    display: grid;
    gap: 14px;
}

.completion-field-row {
    border: 1px solid var(--border);
    border-radius: 8px;
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 14px;
}

.completion-field-row .full-width {
    grid-column: 1 / -1;
}

.completion-field-row__required {
    align-items: end;
    display: flex;
}

.completion-field-row__required label {
    align-items: center;
    display: flex;
    gap: 8px;
}

.completion-field-row__remove {
    justify-self: start;
}

.program-item-builder__actions {
    display: flex;
    justify-content: flex-end;
}

.program-item-builder__actions .primary-action {
    min-width: 140px;
}

.program-item-builder__sidebar {
    position: sticky;
    top: 24px;
}

.program-item-builder__preview-head {
    margin-bottom: 16px;
}

.program-item-builder__preview-surface {
    display: grid;
    gap: 18px;
    padding: 18px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff 0%, #fbfbfa 100%);
}

.program-item-builder__preview-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

.program-item-builder__preview-row strong {
    color: var(--text-primary);
    font-size: 22px;
    letter-spacing: -0.03em;
}

.program-item-builder__preview-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    border: 1px solid color-mix(in srgb, var(--program-preview-accent, var(--accent)) 18%, var(--border) 82%);
    background: color-mix(in srgb, var(--program-preview-accent, var(--accent)) 8%, white 92%);
    color: var(--text-secondary);
    font-size: 14px;
    font-weight: 700;
}

.program-item-builder__preview-copy {
    display: grid;
    gap: 10px;
    color: var(--text-secondary);
    line-height: 1.65;
}

.program-item-builder__preview-copy p {
    margin: 0;
}

.program-item-builder__preview-meta {
    display: grid;
    gap: 8px;
    color: var(--text-muted);
    font-size: 13px;
}

@media (max-width: 1100px) {
    .program-item-builder__layout {
        grid-template-columns: 1fr;
    }

    .program-item-builder__sidebar {
        position: static;
    }
}

@media (max-width: 820px) {
    .program-item-builder__library-grid,
.program-item-builder__visual-grid {
        grid-template-columns: 1fr;
    }

    .completion-field-row {
        grid-template-columns: 1fr;
    }

    .program-item-builder__actions .primary-action {
        width: 100%;
    }
}

@media (max-width: 1180px) {
    .workout-form-layout {
        grid-template-columns: 1fr;
    }

    .workout-form-sidebar {
        position: static;
    }

    .workout-phone-preview__device {
        max-width: 360px;
    }
}

@media (max-width: 900px) {
    .workout-builder-stepper {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .workout-builder-stepper__item::after {
        display: none;
    }

    .workout-builder-row__summary,
    .workout-form-actions--builder {
        justify-items: stretch;
    }

    .workout-form-actions--builder {
        flex-direction: column;
        align-items: stretch;
    }

    .workout-form-actions__submit {
        flex-direction: column;
    }

    .workout-form-actions__submit .secondary-action,
    .workout-form-actions__submit .primary-action,
    .workout-form-actions--builder > .secondary-action {
        width: 100%;
    }
}

@media (max-width: 1024px) {
    .member-test-submit-layout,
    .member-test-submit-main {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .member-test-submit-counter {
        grid-template-columns: 58px minmax(0, 1fr) 58px;
    }

    .member-test-submit-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .member-test-submit-actions__primary {
        min-width: 0;
    }
}
.signup-form-admin-grid {
    align-items: start;
}

.signup-form-admin-grid [hidden] {
    display: none !important;
}

.signup-form-editor-page {
    --signup-editor-accent: #4f6d8a;
    --signup-editor-border: #d5dfeb;
    --signup-editor-muted: #66788b;
    max-width: 1360px;
}

.signup-form-editor {
    display: grid;
    gap: 18px;
}

.signup-form-editor__header {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 22px;
    border: 1px solid var(--signup-editor-border);
    border-radius: 8px;
    background: var(--surface);
    box-shadow: 0 14px 28px rgba(31, 45, 59, 0.08);
}

.signup-form-editor__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 8px;
    background: color-mix(in srgb, var(--signup-editor-accent) 14%, var(--surface));
    color: var(--signup-editor-accent);
    flex: 0 0 auto;
}

.signup-form-editor__icon svg,
.signup-editor-card__title svg,
.signup-slug-field svg {
    width: 22px;
    height: 22px;
}

.signup-form-editor__header h1,
.signup-editor-card h2 {
    margin: 0;
    color: var(--text-primary);
}

.signup-form-editor__header p {
    margin: 4px 0 0;
    color: var(--signup-editor-muted);
}

.signup-form-editor__tabs {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
    width: fit-content;
    padding: 6px;
    border: 1px solid var(--signup-editor-border);
    border-radius: 8px;
    background: var(--surface);
}

.signup-form-editor__tabs button {
    min-height: 40px;
    border: 0;
    border-radius: 6px;
    padding: 0 16px;
    background: transparent;
    color: var(--signup-editor-muted);
    font: inherit;
    font-weight: 750;
    cursor: pointer;
}

.signup-form-editor__tabs button:hover,
.signup-form-editor__tabs button:focus-visible {
    background: color-mix(in srgb, var(--signup-editor-accent) 10%, var(--surface));
    color: var(--signup-editor-accent);
    outline: none;
}

.signup-form-editor__tabs button.is-active {
    background: var(--signup-editor-accent);
    color: var(--accent-contrast);
}

.signup-form-editor__panel {
    display: none;
}

.signup-form-editor__panel.is-active {
    display: block;
}

.signup-form-editor__grid {
    display: grid;
    align-items: start;
    gap: 18px;
}

.signup-form-editor__grid--basic {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.82fr);
}

.signup-form-editor__grid--advanced {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.signup-form-editor__column,
.signup-settings-list,
.signup-editor-card {
    display: grid;
    gap: 16px;
}

.signup-editor-card {
    padding: 20px;
    border: 1px solid var(--signup-editor-border);
    border-radius: 8px;
    background: var(--surface);
    box-shadow: 0 14px 28px rgba(31, 45, 59, 0.07);
}

.signup-editor-card--advanced {
    align-content: start;
}

.signup-editor-card__title {
    display: flex;
    align-items: center;
    gap: 10px;
}

.signup-editor-card__title span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 8px;
    background: color-mix(in srgb, var(--signup-editor-accent) 12%, var(--surface));
    color: var(--signup-editor-accent);
}

.signup-form-editor__two,
.signup-color-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.signup-slug-field,
.signup-color-input {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
}

.signup-slug-field span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--signup-editor-muted);
    background: var(--surface-2);
}

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

.signup-color-input {
    grid-template-columns: 48px minmax(0, 1fr);
}

.signup-color-input input[type="color"] {
    width: 48px;
    min-height: 44px;
    padding: 4px;
    border-radius: 8px;
}

.signup-color-input span {
    min-width: 0;
    color: var(--signup-editor-muted);
    font-size: 0.9rem;
    overflow-wrap: anywhere;
}

.signup-toggle-row,
.signup-check-row {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin: 0;
    cursor: pointer;
}

.signup-check-row {
    padding: 12px;
    border: 1px solid var(--signup-editor-border);
    border-radius: 8px;
    background: color-mix(in srgb, var(--surface) 92%, var(--surface-2));
}

.signup-check-row--stacked span,
.signup-toggle-row span:last-child {
    display: grid;
    gap: 3px;
}

.signup-check-row small,
.signup-toggle-row small {
    color: var(--signup-editor-muted);
    line-height: 1.4;
}

.signup-toggle-row input,
.signup-check-row input {
    flex: 0 0 auto;
    margin-top: 3px;
}

.signup-toggle-row__switch {
    position: relative;
    width: 44px;
    height: 24px;
    border-radius: 999px;
    background: var(--border-strong);
    flex: 0 0 auto;
    transition: background 0.18s ease;
}

.signup-toggle-row__switch::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 2px 6px rgba(15, 23, 42, 0.18);
    transition: transform 0.18s ease;
}

.signup-toggle-row input {
    position: absolute;
    opacity: 0;
}

.signup-toggle-row input:checked + .signup-toggle-row__switch {
    background: var(--signup-editor-accent);
}

.signup-toggle-row input:checked + .signup-toggle-row__switch::after {
    transform: translateX(20px);
}

.signup-toggle-row input:focus-visible + .signup-toggle-row__switch {
    outline: 3px solid color-mix(in srgb, var(--signup-editor-accent) 24%, transparent);
    outline-offset: 2px;
}

.signup-form-editor textarea[data-autogrow] {
    overflow: hidden;
    resize: vertical;
}

.signup-form-editor .form-actions-row {
    padding: 12px;
    border: 1px solid var(--signup-editor-border);
    border-radius: 8px;
    background: var(--surface);
    box-shadow: 0 18px 40px rgba(31, 45, 59, 0.12);
}

.signup-package-selector,
.signup-package-list,
.signup-preview-fields {
    display: grid;
    gap: .75rem;
}

.signup-package-selector {
    max-height: 360px;
    overflow: auto;
    padding-right: .35rem;
}

.signup-package-option {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: .75rem;
    align-items: start;
    padding: .85rem;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: var(--surface);
}

.signup-package-option input {
    margin-top: .25rem;
}

.signup-package-option span,
.signup-package-item {
    display: grid;
    gap: .2rem;
}

.signup-package-option small,
.signup-package-item span {
    color: var(--text-muted);
}

.code-editor {
    min-height: 180px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: .9rem;
    line-height: 1.45;
}

@media (max-width: 980px) {
    .signup-form-editor__grid--basic,
    .signup-form-editor__grid--advanced,
    .signup-form-editor__two,
    .signup-color-grid {
        grid-template-columns: 1fr;
    }

    .signup-form-editor__header {
        align-items: flex-start;
    }
}

.signup-form-show-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.signup-package-item {
    padding: .9rem 1rem;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: var(--surface);
}

.signup-visual-preview {
    display: grid;
    gap: 1rem;
    padding: 1.25rem;
    border: 1px solid var(--border);
    border-radius: 16px;
    background: var(--signup-bg);
    color: var(--signup-text);
}

.signup-visual-preview h3 {
    margin: 0;
    color: var(--signup-text);
}

.signup-visual-preview p {
    margin: 0;
    color: color-mix(in srgb, var(--signup-text) 76%, transparent);
}

.signup-preview-fields span {
    display: block;
    padding: .75rem .85rem;
    border: 1px solid color-mix(in srgb, var(--signup-text) 18%, transparent);
    border-radius: 10px;
    color: color-mix(in srgb, var(--signup-text) 72%, transparent);
}

.signup-visual-preview__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 10px;
    padding: .85rem 1rem;
    background: var(--signup-theme);
    color: #fff;
    font-weight: 700;
    cursor: default;
}

.signup-embed-code {
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: var(--surface);
    overflow-x: auto;
}

.signup-language-links {
    display: grid;
    gap: 1rem;
}

.signup-language-link {
    display: grid;
    gap: .65rem;
    min-width: 0;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: var(--surface);
}

.signup-language-link h3 {
    margin: 0;
    color: var(--text);
    font-size: 1rem;
}

.signup-language-link-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    min-width: 0;
    color: var(--text-primary);
    font-weight: 750;
}

.signup-language-badge {
    flex: 0 0 auto;
    border-radius: 999px;
    padding: .25rem .55rem;
    background: color-mix(in srgb, var(--signup-admin-accent, var(--accent)) 14%, transparent);
    color: var(--signup-admin-accent, var(--accent));
    font-size: .75rem;
    font-weight: 750;
}

.signup-embed-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
}

.signup-embed-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .45rem;
    min-height: 38px;
    max-width: 100%;
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: .55rem .75rem;
    background: var(--surface-2);
    color: var(--text-primary);
    font: inherit;
    font-size: .9rem;
    font-weight: 700;
    line-height: 1.2;
    text-decoration: none;
    cursor: pointer;
}

.signup-embed-action-primary {
    border-color: color-mix(in srgb, var(--signup-admin-accent, var(--accent)) 45%, var(--border));
    background: color-mix(in srgb, var(--signup-admin-accent, var(--accent)) 12%, var(--surface));
    color: var(--signup-admin-accent, var(--accent));
}

.signup-embed-action svg,
.signup-embed-code-disclosure svg {
    flex: 0 0 auto;
    width: 16px;
    height: 16px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.signup-embed-code-disclosure {
    min-width: 0;
}

.signup-embed-code-disclosure summary {
    display: flex;
    align-items: center;
    gap: .65rem;
    min-width: 0;
    padding: .75rem;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--surface-2);
    color: var(--text-muted);
    cursor: pointer;
}

.signup-embed-code-disclosure summary::marker,
.signup-embed-code-disclosure summary::-webkit-details-marker {
    display: none;
}

.signup-embed-code-preview {
    min-width: 0;
    overflow-wrap: anywhere;
}

.signup-embed-code-preview-expanded {
    display: none;
    color: var(--text-primary);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: .82rem;
    line-height: 1.45;
}

.signup-embed-code-disclosure[open] .signup-embed-code-preview-expanded {
    display: block;
}

.signup-embed-code-disclosure[open] .signup-embed-code-preview-collapsed {
    display: none;
}

.signup-embed-code-disclosure[open] summary {
    align-items: flex-start;
}

.signup-provider-authenticated[hidden] {
    display: none !important;
}

.signup-provider-authenticated {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: .35rem .75rem;
    align-items: center;
    padding: .9rem 1rem;
    border: 1px solid color-mix(in srgb, var(--signup-theme) 24%, transparent);
    border-radius: 10px;
    background: color-mix(in srgb, var(--signup-theme) 8%, white);
}

.signup-provider-authenticated span {
    color: color-mix(in srgb, var(--signup-text) 68%, transparent);
    font-size: .9rem;
    font-weight: 700;
}

.signup-provider-authenticated strong {
    grid-column: 1;
    overflow-wrap: anywhere;
}

.signup-provider-authenticated button {
    grid-column: 2;
    grid-row: 1 / span 2;
    border: 1px solid color-mix(in srgb, var(--signup-theme) 26%, transparent);
    border-radius: 8px;
    padding: .55rem .75rem;
    background: #fff;
    color: var(--signup-theme);
    font-weight: 800;
    cursor: pointer;
}

.signup-provider-auth__divider {
    margin: 0;
    color: color-mix(in srgb, var(--signup-text) 70%, transparent);
    font-weight: 700;
}

.signup-provider-auth__divider {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 1rem;
    align-items: center;
    text-align: center;
}

.signup-provider-auth__divider::before,
.signup-provider-auth__divider::after {
    content: "";
    height: 1px;
    background: color-mix(in srgb, var(--signup-text) 18%, transparent);
}

.signup-provider-auth__buttons {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .5rem;
}

.signup-provider-auth__button {
    display: inline-flex;
    min-height: 44px;
    min-width: 0;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    border: 1px solid color-mix(in srgb, var(--signup-text) 14%, transparent);
    border-radius: 8px;
    padding: .75rem .8rem;
    background: #fff;
    color: var(--signup-text);
    font-weight: 800;
    cursor: pointer;
}

.signup-provider-auth__mark {
    display: inline-grid;
    flex: 0 0 auto;
    place-items: center;
    width: 1.35rem;
    height: 1.35rem;
    border-radius: 999px;
    font-weight: 900;
}

.signup-provider-auth__mark svg {
    width: 1.18rem;
    height: 1.18rem;
}

.signup-provider-auth__button:hover,
.signup-provider-auth__button:focus-visible,
.signup-provider-auth__button.is-selected {
    border-color: color-mix(in srgb, var(--signup-theme) 42%, transparent);
    outline: 0;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--signup-theme) 14%, transparent);
}

.signup-provider-auth__button--apple {
    background: #111;
    border-color: #111;
    color: #fff;
}

.signup-provider-auth__button--google {
    background: #fff;
    border-color: #dadce0;
    color: #3c4043;
}

.signup-provider-auth__button--vipps {
    background: #ff5b24;
    border-color: #ff5b24;
    color: #fff;
}

.signup-provider-auth__button--golfsmart {
    background: color-mix(in srgb, var(--signup-theme) 10%, white);
    color: var(--signup-theme);
}

@media (max-width: 980px) {
    .signup-form-show-grid,
    .signup-color-grid {
        grid-template-columns: 1fr;
    }

    .signup-provider-auth__buttons {
        grid-template-columns: 1fr;
    }
}

/* Coach groups board: card grid with a right-hand ungrouped-members drawer. */
.groups-member-drawer-toggle {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    opacity: 0;
    pointer-events: none;
}

.groups-layout:has(.groups-board-panel) {
    display: block;
}

.groups-board-panel {
    display: grid;
    gap: 1.25rem;
}

.groups-board-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
}

.groups-board-header h2 {
    margin: 0;
    color: rgb(15 23 42);
    font-size: 2rem;
    line-height: 1.1;
    letter-spacing: 0;
}

.groups-board-header p {
    margin: 0.45rem 0 0;
    color: rgb(71 85 105);
}

.groups-board-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.groups-member-drawer-open {
    gap: 0.55rem;
    cursor: pointer;
}

.groups-member-drawer-open span {
    display: inline-grid;
    place-items: center;
    min-width: 1.35rem;
    height: 1.35rem;
    border-radius: 999px;
    background: rgb(226 232 240);
    color: rgb(51 65 85);
    font-size: 0.75rem;
    font-weight: 800;
}

.groups-new-anchor {
    border: 0;
    text-decoration: none;
    cursor: pointer;
}

.active-group-chat-button {
    min-height: 42px;
    padding: 0 18px;
    border-color: rgb(20 83 45 / 0.34);
    color: rgb(20 83 45);
    background: rgb(240 253 244);
}

.active-group-chat-button:hover {
    border-color: rgb(20 83 45 / 0.5);
    background: rgb(220 252 231);
}

.active-group-status {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0 0.7rem;
    border: 1px solid rgb(187 247 208);
    border-radius: 8px;
    background: rgb(240 253 244);
    color: rgb(22 101 52);
    font-size: 0.78rem;
    font-weight: 800;
    white-space: nowrap;
}

.active-group-status.is-attention {
    border-color: rgb(253 230 138);
    background: rgb(254 249 195);
    color: rgb(146 64 14);
}

.groups-create-modal__card {
    width: min(980px, 100%);
    max-height: calc(100vh - 48px);
    overflow: auto;
}

.group-chat-modal__card {
    box-sizing: border-box;
    width: min(920px, 100%);
    max-height: calc(100vh - 48px);
    overflow-x: hidden;
    overflow-y: auto;
}

.group-chat-modal__card--compact {
    width: min(560px, 100%);
    padding: 1.65rem;
    border-radius: 18px;
}

.group-chat-modal__head {
    align-items: flex-start;
    margin-bottom: 1.2rem;
}

.group-chat-modal__head h2 {
    margin: 0;
    font-size: 1.35rem;
    line-height: 1.15;
    letter-spacing: 0;
}

.group-chat-modal__head .group-chat-modal__meta {
    margin: 0.3rem 0 0;
    color: rgb(71 85 105);
    font-size: 0.9rem;
    line-height: 1.35;
}

.group-chat-modal__close {
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    width: 2.55rem;
    height: 2.55rem;
    background: #ffffff;
    color: rgb(15 23 42);
    font-size: 1.45rem;
    line-height: 1;
}

.group-chat-modal__body {
    display: grid;
    gap: 0.75rem;
}

.group-chat-modal__body > *,
.group-chat-modal__start-form > * {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.group-chat-modal__body p {
    flex: 1 0 100%;
    margin: 0 0 0.35rem;
    color: rgb(71 85 105);
    line-height: 1.6;
}

.group-chat-modal__body form {
    margin: 0;
}

.group-chat-modal__empty {
    box-sizing: border-box;
    display: grid;
    grid-template-columns: 3rem minmax(0, 1fr);
    gap: 1rem;
    align-items: center;
    padding: 1.25rem;
    border: 1px solid rgb(226 232 240);
    border-radius: 8px;
    background: linear-gradient(135deg, rgb(248 250 252), rgb(241 245 249));
}

.group-chat-modal__empty-icon {
    position: relative;
    display: inline-grid;
    place-items: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 999px;
    background: rgb(226 232 240);
}

.group-chat-modal__empty-icon::before {
    content: "";
    width: 1.15rem;
    height: 0.85rem;
    border: 2px solid rgb(50 86 126);
    border-radius: 0.35rem;
    background:
        radial-gradient(circle, rgb(50 86 126) 0 1.5px, transparent 2px) 0.22rem 50% / 0.3rem 0.3rem no-repeat,
        radial-gradient(circle, rgb(50 86 126) 0 1.5px, transparent 2px) 0.48rem 50% / 0.3rem 0.3rem no-repeat,
        radial-gradient(circle, rgb(50 86 126) 0 1.5px, transparent 2px) 0.74rem 50% / 0.3rem 0.3rem no-repeat;
}

.group-chat-modal__empty-icon::after {
    content: "";
    position: absolute;
    left: 1.2rem;
    bottom: 0.84rem;
    width: 0.45rem;
    height: 0.45rem;
    border-left: 2px solid rgb(50 86 126);
    border-bottom: 2px solid rgb(50 86 126);
    background: rgb(226 232 240);
    transform: rotate(-18deg);
}

.group-chat-modal__empty-copy strong {
    display: block;
    color: rgb(30 41 59);
    font-size: 0.95rem;
    line-height: 1.25;
    font-weight: 900;
}

.group-chat-modal__empty-copy p,
.group-chat-modal__body .group-chat-modal__empty-copy p {
    margin: 0.35rem 0 0;
    color: rgb(71 85 105);
    font-size: 0.88rem;
    line-height: 1.45;
}

.group-chat-modal__start-form {
    display: grid;
}

.group-chat-modal__primary-action,
.group-chat-modal__secondary-action {
    box-sizing: border-box;
    display: flex;
    width: 100%;
    max-width: 100%;
    min-height: 2.75rem;
    padding-right: 1rem;
    padding-left: 1rem;
    border-radius: 8px;
    font-weight: 900;
}

.group-chat-modal__primary-action {
    justify-content: center;
    box-shadow: 0 12px 24px rgba(29, 78, 125, 0.18);
}

.group-chat-modal__secondary-action {
    justify-content: center;
}

.group-chat-modal__thread {
    width: 100%;
    min-height: 340px;
    max-height: 52vh;
    overflow-y: auto;
    margin: 0;
    background: rgb(248 250 252);
    border-color: rgb(203 213 225);
}

.group-chat-modal__compose {
    width: 100%;
    margin: 0;
    background: rgb(248 250 252);
    border-color: rgb(203 213 225);
}

.group-chat-modal__compose .form-field {
    margin: 0;
}

.groups-board-toolbar {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    flex-wrap: wrap;
}

.groups-board-search {
    min-width: min(100%, 18rem);
}

.groups-board-search input {
    width: 100%;
    min-height: 2.8rem;
    border: 1px solid rgb(203 213 225);
    border-radius: 9px;
    background: rgb(255 255 255);
    color: rgb(15 23 42);
    padding: 0 0.95rem;
}

.groups-board-filter-row {
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.groups-board-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(26rem, 1fr));
    gap: 0.85rem 1.15rem;
}

.groups-board-grid .active-groups-list {
    display: contents;
}

.groups-board-grid .groups-quick-create-panel,
.groups-board-grid .active-group-card {
    min-height: 0;
    border-radius: 8px;
}

.groups-board-grid .groups-quick-create-panel {
    order: -1;
}

.groups-board-grid .groups-quick-create-panel .panel-disclosure-summary {
    min-height: 10.5rem;
}

.groups-board-grid .active-group-card {
    display: grid;
    align-content: start;
    gap: 0.8rem;
    padding: 0.95rem 1rem 0.85rem;
    border-color: rgb(226 232 240);
    background: rgb(255 255 255);
    box-shadow: 0 10px 24px rgb(15 23 42 / 0.05);
}

.groups-board-grid .group-card-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 0.9rem;
}

.groups-board-grid .active-group-copy strong {
    display: block;
    color: rgb(30 41 59);
    font-size: 1.2rem;
    line-height: 1.12;
    letter-spacing: 0;
}

.groups-board-grid .active-group-copy p {
    margin-top: 0.25rem;
    color: rgb(71 85 105);
    font-size: 0.86rem;
    line-height: 1.25;
}

.groups-board-grid .active-group-copy .active-group-hcp {
    color: rgb(51 65 85);
    font-size: 1rem;
    line-height: 1.25;
}

.groups-board-grid .groups-head-actions {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
}

.groups-board-grid .active-group-status {
    min-height: 1.65rem;
    padding: 0 0.55rem;
    border-radius: 7px;
    font-size: 0.72rem;
}

.groups-board-grid .active-group-status::before {
    content: "";
    width: 0.72rem;
    height: 0.72rem;
    margin-right: 0.32rem;
    border-radius: 999px;
    background: currentColor;
    opacity: 0.58;
    mask: radial-gradient(circle at center, #000 42%, transparent 45%);
}

.groups-board-grid .active-group-status.is-attention::before {
    border-radius: 2px;
    mask: none;
}

.groups-board-grid .active-group-count {
    min-width: 3rem;
    min-height: 3rem;
    padding: 0.35rem 0.4rem;
    border: 1px solid rgb(226 232 240);
    border-radius: 8px;
    display: inline-grid;
    place-items: center;
    align-content: center;
    background: rgb(248 250 252);
    color: rgb(30 41 59);
    font-size: 0.9rem;
    font-weight: 800;
    line-height: 1;
}

.groups-board-grid .active-group-count::after {
    content: "medlemmer";
    display: block;
    color: rgb(100 116 139);
    font-size: 0.64rem;
    font-weight: 600;
}

.groups-board-grid .active-group-meta {
    gap: 0.45rem;
}

.groups-board-grid .active-group-meta .segment-chip {
    min-height: 1.55rem;
    padding: 0 0.58rem;
    border: 1px solid rgb(226 232 240);
    border-radius: 7px;
    background: rgb(248 250 252);
    color: rgb(71 85 105);
    font-size: 0.72rem;
    font-weight: 700;
}

.active-group-flow-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0;
    border-top: 1px solid rgb(226 232 240);
    border-bottom: 1px solid rgb(226 232 240);
}

.groups-board-grid .active-group-flow-row {
    margin-top: 0.1rem;
}

.active-group-flow-cell {
    display: grid;
    align-content: start;
    gap: 0.28rem;
    min-width: 0;
    padding: 0.72rem 0.85rem 0.72rem 0;
}

.active-group-flow-cell + .active-group-flow-cell {
    padding-left: 1rem;
    border-left: 1px solid rgb(226 232 240);
}

.active-group-flow-cell span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: rgb(71 85 105);
    font-size: 0.72rem;
    font-weight: 800;
}

.active-group-flow-cell span::before {
    content: "";
    width: 0.78rem;
    height: 0.78rem;
    border-radius: 999px;
    background: rgb(100 116 139 / 0.22);
    box-shadow: inset 0 0 0 2px rgb(100 116 139 / 0.5);
}

.active-group-flow-cell strong {
    color: rgb(30 41 59);
    font-size: 0.82rem;
    line-height: 1.25;
}

.active-group-flow-cell p {
    margin: 0;
    color: rgb(71 85 105);
    font-size: 0.76rem;
}

.groups-board-grid .active-group-footer {
    align-items: center;
    padding-top: 0.25rem;
    border-top: 0;
}

.groups-board-grid .active-group-member-total {
    color: rgb(71 85 105);
    font-size: 0.77rem;
    font-weight: 800;
}

.groups-board-grid .active-group-footer-actions {
    gap: 0.5rem;
}

.groups-board-grid .active-group-chat-button,
.groups-board-grid .active-group-open-button,
.groups-board-grid .active-group-delete-button {
    min-height: 2.1rem;
    padding: 0 0.85rem;
    border-radius: 7px;
    font-size: 0.76rem;
    font-weight: 800;
    box-shadow: none;
}

.groups-board-grid .active-group-chat-button::before,
.groups-board-grid .active-group-open-button::before,
.groups-board-grid .active-group-delete-button::before {
    margin-right: 0.42rem;
}

.groups-board-grid .active-group-chat-button::before {
    content: "◯";
}

.groups-board-grid .active-group-open-button::before {
    content: "⌁";
}

.groups-board-grid .active-group-delete-button::before {
    content: "⌫";
}

.groups-board-grid .active-group-open-button {
    background: rgb(248 250 252);
    color: rgb(51 65 85);
}

.groups-member-drawer-backdrop {
    position: fixed;
    inset: 0;
    z-index: 79;
    background: rgb(15 23 42 / 0.14);
    opacity: 0;
    pointer-events: none;
    transition: opacity 180ms ease;
}

.groups-member-drawer {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 80;
    width: min(30rem, calc(100vw - 1rem));
    height: 100vh;
    overflow-y: auto;
    transform: translateX(104%);
    transition: transform 220ms ease;
    border-left: 1px solid rgb(226 232 240);
    border-radius: 0;
    background: rgb(255 255 255);
    box-shadow: -24px 0 60px rgb(15 23 42 / 0.16);
}

.groups-member-drawer-toggle:checked ~ .groups-member-drawer-backdrop {
    opacity: 1;
    pointer-events: auto;
}

.groups-member-drawer-toggle:checked ~ .groups-member-drawer {
    transform: translateX(0);
}

.groups-member-drawer .groups-section-head {
    align-items: start;
    position: sticky;
    top: 0;
    z-index: 2;
    background: rgb(255 255 255);
    padding-bottom: 1rem;
}

.groups-member-drawer-close {
    display: inline-grid;
    place-items: center;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    color: rgb(71 85 105);
    cursor: pointer;
    font-size: 1.35rem;
    line-height: 1;
}

.groups-member-drawer-close:hover {
    background: rgb(241 245 249);
}

.groups-member-drawer .group-member-filter-grid,
.groups-member-drawer .group-bulk-toolbar {
    grid-template-columns: 1fr;
}

.groups-member-drawer .group-bulk-toolbar {
    align-items: stretch;
}

.groups-member-drawer .groups-member-pool {
    grid-template-columns: 1fr;
}

.groups-member-drawer .member-card-compact {
    border-radius: 12px;
}

@media (min-width: 1320px) {
    .groups-board-grid {
        grid-template-columns: repeat(2, minmax(22rem, 1fr));
    }

    .groups-board-grid .groups-quick-create-panel {
        grid-column: span 1;
    }
}

@media (max-width: 860px) {
    .groups-board-header,
    .groups-board-toolbar {
        align-items: stretch;
        display: grid;
    }

    .groups-board-grid {
        grid-template-columns: 1fr;
    }

    .active-group-flow-row {
        grid-template-columns: 1fr;
    }

    .active-group-flow-cell,
    .active-group-flow-cell + .active-group-flow-cell {
        padding: 0.85rem 0;
        border-left: 0;
    }

    .active-group-flow-cell + .active-group-flow-cell {
        border-top: 1px solid rgb(226 232 240);
    }
}

/* Coach member detail: reference-style operational layout using the current palette. */
.content-shell:has(.member-detail-page--reference) {
    max-width: 100%;
}

.member-detail-page--reference {
    --member-ref-border: #d7e2dc;
    --member-ref-ink: #13251c;
    --member-ref-muted: #5f7167;
    --member-ref-surface: #fffdf8;
    --member-ref-soft: #f6f3eb;
    --member-ref-green: #138a4e;
    --member-ref-green-soft: #dff4e8;
    --member-ref-warm: #d18a24;
    display: grid;
    gap: 1rem;
}

.member-detail-hero-v2,
.member-reference-card {
    border: 1px solid var(--member-ref-border);
    border-radius: 12px;
    background: linear-gradient(180deg, #fffefb, var(--member-ref-surface));
    box-shadow: 0 14px 34px rgb(19 37 28 / 0.07);
}

.member-detail-hero-v2 {
    display: grid;
    grid-template-columns: minmax(22rem, 0.78fr) minmax(0, 1.45fr);
    min-height: 7.25rem;
    overflow: hidden;
    padding: 0.9rem;
}

.member-detail-hero-v2__identity {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 1rem;
    align-items: center;
    padding: 0.15rem 0.3rem;
    position: relative;
    z-index: 2;
}

.member-detail-hero-v2__avatar {
    width: 4.9rem;
    height: 4.9rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    overflow: hidden;
    background: #f0eee7;
    border: 1px solid #e2ded4;
    color: var(--member-ref-ink);
    font-size: 1.6rem;
    font-weight: 800;
}

.member-detail-hero-v2__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.member-detail-hero-v2__copy {
    display: grid;
    gap: 0.34rem;
}

.member-detail-hero-v2__topline {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.member-detail-hero-v2__copy h1 {
    margin: 0;
    color: var(--member-ref-ink);
    font-size: 2.25rem;
    line-height: 1.05;
    letter-spacing: 0;
}

.member-detail-hero-v2__copy p {
    margin: 0;
    color: var(--member-ref-muted);
    font-size: 0.95rem;
}

.member-detail-hero-v2__banner {
    position: relative;
    min-height: 5.5rem;
    align-self: stretch;
    border-radius: 10px;
    overflow: hidden;
    background: linear-gradient(180deg, #faf8f1, #fffdf8);
}

.member-detail-hero-v2__sky,
.member-detail-hero-v2__hills,
.member-detail-hero-v2__flag {
    position: absolute;
}

.member-detail-hero-v2__sky {
    inset: 0;
    background:
        linear-gradient(180deg, rgb(255 253 248 / 0.96), rgb(255 253 248 / 0.68)),
        repeating-linear-gradient(0deg, rgb(215 226 220 / 0.22) 0 1px, transparent 1px 13px);
}

.member-detail-hero-v2__hills {
    left: -4%;
    right: -4%;
    bottom: -32%;
    height: 82%;
    background:
        radial-gradient(ellipse at 20% 100%, #dff4e8 0 23%, transparent 24%),
        radial-gradient(ellipse at 43% 100%, #bfe6cb 0 19%, transparent 20%),
        radial-gradient(ellipse at 65% 100%, #eadfba 0 20%, transparent 21%),
        radial-gradient(ellipse at 84% 100%, #cde8d5 0 24%, transparent 25%);
}

.member-detail-hero-v2__flag {
    right: 18%;
    bottom: 20%;
    width: 2px;
    height: 3rem;
    background: #708277;
}

.member-detail-hero-v2__flag::before {
    content: "";
    position: absolute;
    top: 0.2rem;
    left: 2px;
    width: 1.2rem;
    height: 0.78rem;
    background: linear-gradient(135deg, #708277, #a7b5ad);
    clip-path: polygon(0 0, 100% 18%, 74% 100%, 0 82%);
}

.member-reference-tabs {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
    margin-top: -0.35rem;
    padding: 0 0.25rem;
}

.member-reference-tab-input {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    opacity: 0;
    pointer-events: none;
}

.member-reference-tabs label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.2rem;
    border: 1px solid var(--member-ref-border);
    border-radius: 999px;
    background: #fffefb;
    color: var(--member-ref-ink);
    padding: 0.45rem 0.85rem;
    font-size: 0.82rem;
    font-weight: 800;
    text-decoration: none;
    box-shadow: 0 8px 20px rgb(19 37 28 / 0.05);
    cursor: pointer;
}

.member-reference-tabs label:hover {
    border-color: #b8cabe;
    background: var(--member-ref-green-soft);
    color: var(--member-ref-green);
}

#member-tab-overview:checked ~ .member-reference-tabs label[for="member-tab-overview"],
#member-tab-group:checked ~ .member-reference-tabs label[for="member-tab-group"],
#member-tab-tags:checked ~ .member-reference-tabs label[for="member-tab-tags"],
#member-tab-nutrition:checked ~ .member-reference-tabs label[for="member-tab-nutrition"],
#member-tab-recovery:checked ~ .member-reference-tabs label[for="member-tab-recovery"],
#member-tab-rounds:checked ~ .member-reference-tabs label[for="member-tab-rounds"],
#member-tab-tests:checked ~ .member-reference-tabs label[for="member-tab-tests"],
#member-tab-history:checked ~ .member-reference-tabs label[for="member-tab-history"] {
    border-color: #b8cabe;
    background: var(--member-ref-green-soft);
    color: var(--member-ref-green);
}

.member-reference-panels {
    display: grid;
}

.member-reference-panel {
    display: none;
    gap: 1rem;
}

#member-tab-overview:checked ~ .member-reference-panels .member-reference-panel--overview,
#member-tab-group:checked ~ .member-reference-panels .member-reference-panel--group,
#member-tab-tags:checked ~ .member-reference-panels .member-reference-panel--tags,
#member-tab-nutrition:checked ~ .member-reference-panels .member-reference-panel--nutrition,
#member-tab-recovery:checked ~ .member-reference-panels .member-reference-panel--recovery,
#member-tab-rounds:checked ~ .member-reference-panels .member-reference-panel--rounds,
#member-tab-tests:checked ~ .member-reference-panels .member-reference-panel--tests,
#member-tab-history:checked ~ .member-reference-panels .member-reference-panel--history {
    display: grid;
}

.member-reference-panel--overview {
    grid-template-columns: 1fr;
    align-items: start;
}

.member-reference-overview-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(24rem, 0.95fr);
    align-items: start;
    gap: 1rem;
}

.member-reference-column {
    display: grid;
    align-content: start;
    gap: 1rem;
}

.member-reference-card--overview-development {
    grid-column: 1 / -1;
}

.member-reference-card {
    display: grid;
    gap: 0.85rem;
    padding: 1rem;
    align-content: start;
}

.member-reference-card--wide {
    min-height: 18rem;
}

.member-reference-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.member-reference-card__head h2,
.member-reference-results h3,
.member-reference-chart-card h3 {
    margin: 0;
    color: var(--member-ref-ink);
    font-size: 1.05rem;
    line-height: 1.2;
    letter-spacing: 0;
}

.member-reference-card--overview .member-reference-card__head h2,
.member-reference-card--group .member-reference-card__head h2,
.member-reference-card--program .member-reference-card__head h2 {
    font-size: 1.35rem;
}

.member-reference-card__head p,
.member-reference-program__description p {
    margin: 0;
    color: var(--member-ref-muted);
    font-size: 0.86rem;
    line-height: 1.45;
}

.member-reference-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    border: 1px solid #e4e9e5;
    border-radius: 10px;
    overflow: hidden;
    background: #fffefb;
}

.member-reference-stats article {
    display: grid;
    gap: 0.18rem;
    min-height: 4.35rem;
    padding: 0.82rem 0.95rem;
    border-right: 1px solid #e4e9e5;
    border-bottom: 1px solid #e4e9e5;
}

.member-reference-stats article:nth-child(3n) {
    border-right: 0;
}

.member-reference-stats article:nth-last-child(-n + 3) {
    border-bottom: 0;
}

.member-reference-stats span,
.member-reference-contact dt,
.member-reference-note p,
.member-reference-results__row span,
.member-reference-program__result span {
    color: var(--member-ref-muted);
    font-size: 0.78rem;
}

.member-reference-stats strong,
.member-reference-contact dd,
.member-reference-results__row strong,
.member-reference-program__title strong {
    color: var(--member-ref-ink);
    font-size: 0.94rem;
    line-height: 1.25;
    margin: 0;
}

.member-reference-note {
    display: grid;
    gap: 0.28rem;
    padding: 0.82rem 0.95rem;
    border: 1px solid #e4e9e5;
    border-radius: 10px;
    background: var(--member-ref-soft);
}

.member-reference-note strong {
    color: var(--member-ref-green);
    font-size: 0.9rem;
}

.member-reference-contact {
    display: grid;
    border: 1px solid #e4e9e5;
    border-radius: 10px;
    overflow: hidden;
    background: #fffefb;
}

.member-reference-contact div {
    display: grid;
    gap: 0.18rem;
    padding: 0.82rem 0.95rem;
    border-bottom: 1px solid #e4e9e5;
}

.member-reference-contact div:last-child {
    border-bottom: 0;
}

.member-overview-development {
    display: grid;
    grid-template-columns: minmax(20rem, 0.85fr) minmax(18rem, 0.75fr) minmax(0, 1.1fr);
    gap: 0.85rem;
    align-items: stretch;
}

.member-overview-development__summary,
.member-overview-development__latest,
.member-overview-development__chart {
    display: grid;
    gap: 0.65rem;
    padding: 0.85rem;
    border: 1px solid #e4e9e5;
    border-radius: 10px;
    background: #fffefb;
}

.member-overview-development__summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.member-overview-development__summary article {
    display: grid;
    gap: 0.18rem;
    padding: 0.75rem;
    border-radius: 8px;
    background: var(--member-ref-soft);
}

.member-overview-development__summary span,
.member-overview-development__latest span {
    color: var(--member-ref-muted);
    font-size: 0.76rem;
}

.member-overview-development__summary strong,
.member-overview-development__latest strong {
    color: var(--member-ref-ink);
    font-size: 0.95rem;
}

.member-overview-development__latest h3,
.member-overview-development__chart h3 {
    margin: 0;
    color: var(--member-ref-ink);
    font-size: 1rem;
}

.member-overview-development__latest article {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.75rem;
    align-items: center;
    padding: 0.5rem 0;
    border-bottom: 1px solid #eef1ee;
}

.member-overview-development__latest article:last-child {
    border-bottom: 0;
}

.member-overview-development__latest article div {
    display: grid;
    gap: 0.12rem;
}

.member-overview-mini-chart {
    position: relative;
    min-height: 10rem;
}

.member-overview-mini-chart svg {
    width: 100%;
    height: 100%;
    overflow: visible;
}

.member-overview-mini-chart line {
    stroke: #e4e9e5;
    stroke-width: 0.8;
    vector-effect: non-scaling-stroke;
}

.member-overview-mini-chart polyline {
    fill: none;
    stroke: var(--line-color);
    stroke-width: 2.1;
    stroke-linecap: round;
    stroke-linejoin: round;
    vector-effect: non-scaling-stroke;
}

.member-overview-mini-chart circle {
    fill: var(--point-color);
    stroke: #fffefb;
    stroke-width: 1.15;
    vector-effect: non-scaling-stroke;
}

.member-reference-group-form,
.member-reference-tags-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.75rem;
    align-items: center;
}

.member-reference-development-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.85rem;
}

.member-reference-app-results,
.member-reference-results,
.member-reference-chart-card,
.member-reference-test-copies {
    display: grid;
    gap: 0.7rem;
    padding: 0.85rem;
    border: 1px solid #e4e9e5;
    border-radius: 10px;
    background: #fffefb;
}

.member-reference-app-results__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.member-reference-app-results__head h3 {
    margin: 0;
    color: var(--member-ref-ink);
    font-size: 1.05rem;
}

.member-reference-app-results__head span {
    color: var(--member-ref-muted);
    font-size: 0.78rem;
    font-weight: 800;
}

.member-reference-app-results__list {
    display: grid;
    gap: 0.5rem;
}

.member-reference-app-result {
    border: 1px solid #e4e9e5;
    border-radius: 9px;
    background: #fffdf8;
    overflow: hidden;
}

.member-reference-app-result summary {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.9rem;
    align-items: center;
    cursor: pointer;
    list-style: none;
    padding: 0.72rem 0.82rem;
}

.member-reference-app-result summary::-webkit-details-marker {
    display: none;
}

.member-reference-app-result summary span {
    display: grid;
    gap: 0.12rem;
}

.member-reference-app-result summary strong {
    color: var(--member-ref-ink);
    font-size: 0.92rem;
}

.member-reference-app-result summary small {
    color: var(--member-ref-muted);
    font-size: 0.74rem;
}

.member-reference-app-result__body {
    display: grid;
    gap: 0.65rem;
    padding: 0 0.82rem 0.82rem;
}

.member-reference-app-result__body dl {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.5rem;
    margin: 0;
}

.member-reference-app-result__body div {
    display: grid;
    gap: 0.12rem;
    padding: 0.55rem 0.65rem;
    border-radius: 8px;
    background: var(--member-ref-soft);
}

.member-reference-app-result__body dt {
    color: var(--member-ref-muted);
    font-size: 0.72rem;
}

.member-reference-app-result__body dd {
    margin: 0;
    color: var(--member-ref-ink);
    font-size: 0.82rem;
    font-weight: 800;
}

.member-reference-app-result__body p {
    margin: 0;
    color: var(--member-ref-muted);
    font-size: 0.82rem;
    line-height: 1.45;
}

.member-golf-round-holes {
    display: grid;
    gap: 6px;
    margin-top: 0.35rem;
    padding: 0;
    border-radius: 0;
    background: transparent;
}

.member-golf-round-filter {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: end;
    margin-bottom: 14px;
}

.member-golf-round-filter label {
    display: grid;
    gap: 6px;
    min-width: min(100%, 240px);
}

.member-golf-round-filter label span {
    color: var(--member-ref-muted);
    font-size: 0.78rem;
    font-weight: 800;
}

.member-golf-round.is-tournament {
    border-color: rgba(22, 101, 52, 0.22);
    background: linear-gradient(180deg, rgba(240, 253, 244, 0.74), #fff);
}

.member-golf-round.is-normal-round {
    border-color: rgba(37, 99, 235, 0.16);
}

.member-golf-round-type {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    background: rgba(37, 99, 235, 0.1);
    color: #1d4ed8;
    font-size: 0.7rem;
    font-weight: 900;
    line-height: 1;
}

.member-golf-round.is-tournament .member-golf-round-type {
    background: rgba(22, 101, 52, 0.12);
    color: #166534;
}

.member-golf-round-holes__head,
.member-golf-round-holes__row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    align-items: center;
}

.member-golf-round-holes__head {
    padding: 0;
    border-radius: 0;
    background: transparent;
    color: var(--member-ref-muted);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.member-golf-round-holes__row {
    padding: 8px 10px;
    border: 1px solid rgba(17, 24, 39, 0.08);
    border-radius: 8px;
    background: var(--member-ref-soft);
    color: var(--member-ref-ink);
    font-size: 0.9rem;
}

.member-reference-test-copies h3 {
    margin: 0;
    color: var(--member-ref-ink);
    font-size: 1.05rem;
}

.member-reference-test-copy-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.6rem;
}

.member-reference-test-copy-grid article {
    display: grid;
    gap: 0.2rem;
    padding: 0.75rem 0.8rem;
    border: 1px solid #e4e9e5;
    border-radius: 9px;
    background: var(--member-ref-soft);
}

.member-reference-test-copy-grid strong {
    color: var(--member-ref-ink);
}

.member-reference-test-copy-grid span,
.member-reference-test-copy-grid small {
    color: var(--member-ref-muted);
    font-size: 0.78rem;
}

.member-flow-history-list {
    display: grid;
    gap: 0.65rem;
}

.member-flow-history-row {
    display: grid;
    grid-template-columns: minmax(15rem, 1.25fr) repeat(4, minmax(7rem, 0.55fr)) minmax(18rem, 1.15fr);
    gap: 1rem;
    align-items: center;
    padding: 0.85rem 0.95rem;
    border: 1px solid #e4e9e5;
    border-radius: 10px;
    background: #fffefb;
}

.member-flow-history-row > div {
    display: grid;
    gap: 0.15rem;
}

.member-flow-history-row span,
.member-flow-history-row small {
    color: var(--member-ref-muted);
    font-size: 0.78rem;
}

.member-flow-history-row strong {
    color: var(--member-ref-ink);
    font-size: 0.94rem;
}

.member-flow-test-development {
    padding: 0.65rem 0.75rem;
    border-radius: 9px;
    background: var(--member-ref-soft);
}

.member-flow-test-development.is-positive {
    background: #e7f6ee;
}

.member-flow-test-development.is-negative {
    background: #fef2f2;
}

.member-flow-test-development > strong {
    color: var(--member-ref-ink);
}

.member-flow-test-development.is-positive > strong {
    color: var(--member-ref-green);
}

.member-flow-test-development.is-negative > strong {
    color: #b42318;
}

.member-flow-test-development__list {
    display: grid;
    gap: 0.35rem;
    margin-top: 0.45rem;
}

.member-flow-test-development__list > span {
    display: grid;
    gap: 0.08rem;
    color: var(--member-ref-ink);
    font-size: 0.78rem;
    font-weight: 800;
}

.member-flow-test-development__list > span.is-positive {
    color: var(--member-ref-green);
}

.member-flow-test-development__list > span.is-negative {
    color: #b42318;
}

.member-flow-test-development__list small {
    color: var(--member-ref-muted);
    font-weight: 600;
}

.member-reference-results__row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.75rem;
    align-items: center;
    min-height: 2.35rem;
    padding: 0.45rem 0;
    border-bottom: 1px solid #eef1ee;
}

.member-reference-results__row:last-child {
    border-bottom: 0;
}

.member-reference-chart-legend {
    display: flex;
    gap: 0.7rem;
    flex-wrap: wrap;
    color: var(--member-ref-muted);
    font-size: 0.74rem;
}

.member-reference-chart-legend span {
    display: inline-flex;
    align-items: center;
    gap: 0.34rem;
}

.member-reference-chart-legend i {
    width: 0.78rem;
    height: 0.14rem;
    border-radius: 999px;
    background: var(--chart-color);
}

.member-reference-chart {
    position: relative;
    min-height: 12.5rem;
    padding: 0.1rem 0 1rem 2rem;
}

.member-reference-chart__axis {
    position: absolute;
    left: 0;
    color: #9aaba1;
    font-size: 0.72rem;
}

.member-reference-chart__axis:nth-child(1) { top: 0; }
.member-reference-chart__axis:nth-child(2) { top: 25%; }
.member-reference-chart__axis:nth-child(3) { top: 50%; }
.member-reference-chart__axis:nth-child(4) { top: 75%; }
.member-reference-chart__axis:nth-child(5) { bottom: 0.15rem; }

.member-reference-chart svg {
    width: 100%;
    height: 100%;
    overflow: visible;
}

.member-reference-chart line {
    stroke: #e4e9e5;
    stroke-width: 0.8;
    vector-effect: non-scaling-stroke;
}

.member-reference-chart polyline {
    fill: none;
    stroke: var(--line-color);
    stroke-width: 2.1;
    stroke-linecap: round;
    stroke-linejoin: round;
    vector-effect: non-scaling-stroke;
}

.member-reference-chart circle {
    fill: var(--point-color);
    stroke: #fffefb;
    stroke-width: 1.15;
    vector-effect: non-scaling-stroke;
}

.member-reference-chart__labels {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.35rem;
    color: var(--member-ref-muted);
    font-size: 0.72rem;
    text-align: center;
}

.member-reference-program {
    display: grid;
}

.member-reference-program__row {
    display: grid;
    grid-template-columns: minmax(13rem, 0.9fr) minmax(0, 1.7fr) minmax(7rem, 0.45fr) auto;
    gap: 1rem;
    align-items: center;
    min-height: 2.75rem;
    padding: 0.55rem 0.1rem;
    border-bottom: 1px solid #e4e9e5;
}

.member-reference-program__row:last-child {
    border-bottom: 0;
}

.member-reference-program__row.is-test {
    background: linear-gradient(90deg, rgb(223 244 232 / 0.28), transparent 34%);
}

.member-reference-program__description p,
.member-reference-program__result span {
    font-size: 0.82rem;
}

.member-reference-program__actions {
    display: flex;
    justify-content: flex-end;
}

.member-detail-page--reference .tag-select {
    min-height: 2.35rem;
    border-radius: 8px;
}

.member-detail-page--reference .flow-library-action,
.member-detail-page--reference .secondary-action {
    min-height: 2.35rem;
    border-radius: 8px;
    padding: 0.55rem 0.9rem;
    font-size: 0.82rem;
    white-space: nowrap;
}

.member-detail-page--reference .tag-chip {
    border-radius: 999px;
}

@media (min-width: 1320px) {
    .member-reference-panel--tests .member-reference-development-grid {
        grid-template-columns: minmax(16rem, 0.95fr) minmax(0, 1.35fr);
    }

    .member-reference-panel--tests .member-reference-app-results {
        grid-column: 1 / -1;
    }

    .member-reference-panel--tests .member-reference-test-copies {
        grid-column: 1 / -1;
    }
}

@media (max-width: 1100px) {
    .member-detail-hero-v2,
    .member-reference-overview-grid,
    .member-overview-development,
    .member-reference-group-form,
    .member-reference-tags-form,
    .member-reference-program__row,
    .member-flow-history-row {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .member-detail-hero-v2__identity,
    .member-reference-stats,
    .member-overview-development__summary,
    .member-reference-chart__labels,
    .member-reference-test-copy-grid {
        grid-template-columns: 1fr;
    }

    .member-detail-hero-v2__banner {
        min-height: 4.5rem;
    }

    .member-reference-stats article {
        border-right: 0;
    }

    .member-reference-card__head {
        display: grid;
    }

    .member-reference-app-result summary,
    .member-reference-app-result__body dl {
        grid-template-columns: 1fr;
    }
}

/* Member homepage redesign */
.app-shell:has(.member-home) {
    gap: 12px;
    padding: 14px;
    background: #f5f7fa;
}

.app-shell:has(.member-home) .sidebar {
    width: 224px;
    flex-basis: 224px;
    min-height: calc(100vh - 28px);
    height: calc(100vh - 28px);
    overflow-x: hidden;
    padding: 16px;
    border: 0;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 16px 40px rgba(31, 45, 61, 0.08);
}

.app-shell:has(.member-home) .sidebar-header {
    gap: 12px;
    padding: 14px 0 22px;
}

.app-shell:has(.member-home) .sidebar-brand-logo {
    width: 128px;
    border-radius: 0;
}

.app-shell:has(.member-home) .sidebar-subtitle {
    color: #334963;
    font-size: 14px;
}

.app-shell:has(.member-home) .nav-section-title {
    display: none;
}

.app-shell:has(.member-home) .sidebar-nav {
    gap: 8px;
    padding: 22px 0;
}

.app-shell:has(.member-home) .nav-item-link {
    min-height: 46px;
    padding: 0 12px;
    border-radius: 8px;
    color: #25384f;
    font-size: 14px;
    font-weight: 700;
}

.app-shell:has(.member-home) .nav-item-link.active {
    background: #4f6f9d;
    color: #fff;
    box-shadow: none;
}

.app-shell:has(.member-home) .nav-item-link.active .nav-item-icon,
.app-shell:has(.member-home) .nav-item-link:hover .nav-item-icon {
    color: currentColor;
}

.app-shell:has(.member-home) .nav-item-icon {
    width: 22px;
    height: 22px;
}

.app-shell:has(.member-home) .nav-item-badge {
    min-width: 23px;
    background: #e8eef7;
    color: #4f6f9d;
}

.app-shell:has(.member-home) .sidebar-footer {
    gap: 14px;
    padding-top: 14px;
    border-top: 1px solid #e1e7ef;
}

.app-shell:has(.member-home) .sidebar-user-card {
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    padding: 8px;
    border: 1px solid #e1e7ef;
    border-radius: 10px;
    background: #fbfdff;
    color: inherit;
    text-decoration: none;
    transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}

.app-shell:has(.member-home) .sidebar-user-card:hover,
.app-shell:has(.member-home) .sidebar-user-card:focus-visible,
.app-shell:has(.member-home) .sidebar-user-card.active {
    border-color: color-mix(in srgb, #4f6f9d 42%, #e1e7ef);
    background: #f5f8fc;
    box-shadow: 0 10px 24px rgba(31, 45, 61, 0.08);
    outline: none;
}

.sidebar-user-avatar {
    display: grid;
    place-items: center;
    overflow: hidden;
    width: 40px;
    height: 40px;
    min-width: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, #e8d5c5, #f7f2ec);
    color: #31445c;
    font-weight: 900;
}

.sidebar-user-card strong,
.sidebar-user-card small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.sidebar-user-card strong {
    color: #25384f;
    font-size: 13px;
}

.sidebar-user-card small {
    margin-top: 2px;
    color: #66778b;
    font-size: 11px;
}

.app-shell:has(.member-home) .theme-toggle,
.app-shell:has(.member-home) .logout-link {
    min-height: 40px;
    border-radius: 8px;
}

.app-shell:has(.member-home) .sidebar-meta {
    display: none;
}

.app-shell--member {
    gap: 12px;
    padding: 14px;
    background: #f5f7fa;
}

.app-shell--member .sidebar {
    width: 224px;
    flex-basis: 224px;
    min-height: calc(100vh - 28px);
    height: calc(100vh - 28px);
    overflow-x: hidden;
    padding: 16px;
    border: 1px solid #e1e7ef;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 18px 42px rgba(31, 45, 61, 0.07);
}

.app-shell--member .sidebar-header {
    gap: 12px;
    padding: 14px 0 22px;
}

.app-shell--member .sidebar-brand-logo {
    width: 128px;
    border-radius: 0;
}

.app-shell--member .sidebar-subtitle {
    color: #334963;
    font-size: 14px;
}

.app-shell--member .nav-section-title {
    display: none;
}

.app-shell--member .sidebar-nav {
    gap: 8px;
    padding: 22px 0;
}

.app-shell--member .nav-item-link {
    min-height: 46px;
    padding: 0 12px;
    border-radius: 8px;
    color: #25384f;
    font-size: 14px;
    font-weight: 700;
}

.app-shell--member .nav-item-link.active {
    background: #4f6f9d;
    color: #fff;
    box-shadow: none;
}

.app-shell--member .nav-item-link.active .nav-item-icon,
.app-shell--member .nav-item-link:hover .nav-item-icon {
    color: currentColor;
}

.app-shell--member .nav-item-icon {
    width: 22px;
    height: 22px;
}

.app-shell--member .nav-item-badge {
    min-width: 23px;
    background: #e8eef7;
    color: #4f6f9d;
}

.app-shell--member .sidebar-footer {
    gap: 14px;
    padding-top: 14px;
    border-top: 1px solid #e1e7ef;
}

.app-shell--member .sidebar-user-card {
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    min-width: 0;
    padding: 9px;
    border: 1px solid #e1e7ef;
    border-radius: 12px;
    background: linear-gradient(180deg, #ffffff 0%, #f7f9fc 100%);
    color: inherit;
    text-decoration: none;
    transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}

.app-shell--member .sidebar-user-card:hover,
.app-shell--member .sidebar-user-card:focus-visible,
.app-shell--member .sidebar-user-card.active {
    border-color: color-mix(in srgb, #4f6f9d 42%, #e1e7ef);
    background: #f5f8fc;
    box-shadow: 0 10px 24px rgba(31, 45, 61, 0.08);
    outline: none;
}

.app-shell--member .sidebar-user-more {
    display: none;
}

.app-shell--member .theme-toggle,
.app-shell--member .logout-link {
    min-height: 40px;
    border-radius: 8px;
}

.app-shell--member .sidebar-meta {
    display: none;
}

.app-shell--member .content,
.app-shell:has(.member-home) .content {
    flex: 1;
    padding: 0;
}

.app-shell--member .content-surface,
.app-shell:has(.member-home) .content-surface {
    gap: 12px;
    min-height: calc(100vh - 28px);
    padding: 0;
    border-color: #e1e7ef;
    border-radius: 16px;
    background: transparent;
    box-shadow: none;
}

.app-shell--member .content-surface::before,
.app-shell:has(.member-home) .content-surface::before {
    display: none;
}

@media (max-width: 820px) {
    .app-shell--member {
        gap: 0;
        padding: 0;
    }

    .app-shell--member .sidebar {
        min-height: 100vh;
        height: 100vh;
        border-width: 0 1px 0 0;
        border-radius: 0 16px 16px 0;
    }

    .app-shell--member .content {
        padding: 74px 12px 16px;
    }

    .app-shell--member .content-surface {
        min-height: auto;
        border-radius: 16px;
    }
}

.member-home {
    display: grid;
    align-content: start;
    gap: 12px;
    color: var(--member-ink);
}

.member-hero,
.member-mobile-card,
.member-home .member-section,
.member-home .member-self-evaluation,
.member-home .member-group-panel {
    border: 1px solid var(--member-line);
    border-radius: 12px;
    background: var(--member-panel);
    box-shadow: 0 18px 42px rgba(31, 45, 61, 0.06);
}

.member-hero {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 372px;
    align-items: center;
    overflow: hidden;
    color: #fff;
    background:
        linear-gradient(90deg, rgba(13, 29, 45, 0.94), rgba(20, 34, 48, 0.70) 48%, rgba(17, 43, 39, 0.54)),
        var(--member-hero-image);
    background-position: center;
    background-size: cover;
}

.member-hero-copy {
    justify-content: center;
    max-width: 850px;
}

.member-hero h1 {
    max-width: 780px;
    margin: 0;
    color: #fff;
    font-weight: 900;
    letter-spacing: 0;
}

.member-hero p {
    max-width: 720px;
    margin: 12px 0 0;
    color: rgba(255, 255, 255, 0.88);
}

.member-hero-actions {
    display: flex;
    flex-wrap: wrap;
}

.member-hero-action {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    border-radius: 8px;
    color: #fff;
    font-weight: 800;
    text-decoration: none;
}

.member-hero-action.primary {
    background: #3f6fb8;
}

.member-hero-action.secondary {
    border: 1px solid rgba(255, 255, 255, 0.76);
    background: rgba(14, 26, 38, 0.36);
}

.member-icon svg,
.member-section-icon svg,
.member-next-step svg {
    display: block;
    width: 20px;
    height: 20px;
}

.member-icon svg path,
.member-section-icon svg path,
.member-next-step svg path {
    fill: none;
    stroke: currentColor;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.member-hero-meta {
    display: flex;
    flex-wrap: wrap;
}

.member-hero-meta span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
    color: rgba(255, 255, 255, 0.94);
    font-size: 13px;
    font-weight: 800;
}

.member-hero-meta .is-complete span {
    display: grid;
    place-items: center;
    width: 20px;
    height: 20px;
    min-height: 0;
    padding: 0;
    background: #75c850;
    color: #12301d;
}

.member-next-steps {
    display: grid;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 12px;
    background: rgba(35, 53, 73, 0.86);
    box-shadow: 0 22px 55px rgba(5, 12, 20, 0.24);
    backdrop-filter: blur(16px);
}

.member-next-steps__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: rgba(255, 255, 255, 0.82);
    font-weight: 800;
}

.member-next-steps__flag {
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: rgba(144, 179, 110, 0.24);
    color: #b1e66f;
}

.member-next-step {
    display: grid;
    align-items: center;
    gap: 12px;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    text-decoration: none;
}

.member-next-step__icon {
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
}

.member-next-step strong,
.member-next-step small {
    display: block;
}

.member-next-step small {
    margin-top: 2px;
    color: rgba(255, 255, 255, 0.72);
}

.member-next-step__arrow {
    color: rgba(255, 255, 255, 0.78);
    font-size: 30px;
    line-height: 1;
}

.member-dashboard-grid {
    display: grid;
    grid-template-columns: minmax(360px, 0.9fr) minmax(520px, 1.1fr);
    gap: 12px;
}

.member-mobile-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    padding: 24px 26px;
    background:
        linear-gradient(135deg, #132235, #254c39 58%, #376a48);
    color: #fff;
    box-shadow: 0 22px 54px rgba(19, 34, 53, 0.18);
}

.member-mobile-card__copy {
    display: grid;
    gap: 8px;
    max-width: 780px;
}

.member-mobile-card__copy .member-kicker {
    margin: 0;
    color: rgba(255, 255, 255, 0.72);
}

.member-mobile-card h2 {
    margin: 0;
    color: #fff;
    font-size: clamp(34px, 4vw, 54px);
    line-height: 1.1;
    letter-spacing: 0;
}

.member-mobile-card p {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
    font-size: 18px;
    line-height: 1.5;
}

.member-mobile-card__copy > strong {
    color: #d6f2b7;
    font-size: 16px;
    line-height: 1.4;
}

.member-mobile-card__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
}

.member-store-link {
    display: grid;
    min-width: 154px;
    min-height: 54px;
    justify-content: start;
    align-content: center;
    gap: 2px;
    padding: 10px 18px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.26);
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    text-decoration: none;
    box-shadow: 0 12px 24px rgba(7, 18, 30, 0.16);
    transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.member-store-link:not(.member-store-link--soon):hover,
.member-store-link:not(.member-store-link--soon):focus-visible {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, 0.18);
    box-shadow: 0 16px 28px rgba(19, 34, 53, 0.20);
    outline: none;
}

.member-store-link--soon {
    background: rgba(255, 255, 255, 0.18);
    cursor: default;
}

.member-store-link span {
    font-size: 11px;
    line-height: 1;
    color: rgba(255, 255, 255, 0.72);
    font-weight: 800;
    text-transform: uppercase;
}

.member-store-link strong {
    font-size: 18px;
    line-height: 1.05;
}

.member-home .member-week-card,
.member-home .member-progress-card,
.member-home .member-self-evaluation,
.member-home .member-profile-card,
.member-home .member-flow-details {
    padding: 20px;
}

.member-home .member-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin: 0 0 20px;
}

.member-section-title {
    display: inline-flex;
    align-items: center;
    gap: 12px;
}

.member-home .member-section h2,
.member-home .member-self-evaluation h2 {
    margin: 0;
    color: var(--member-ink);
    font-size: 19px;
    font-weight: 900;
    letter-spacing: 0;
}

.member-week-complete {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    align-items: center;
    gap: 20px;
    min-height: 154px;
    padding: 22px;
    border: 1px solid #d9e6dd;
    border-radius: 12px;
    background: linear-gradient(135deg, #fbfffc, #f5fbf8);
}

.member-week-check {
    display: grid;
    place-items: center;
    width: 70px;
    height: 70px;
    border: 3px solid #2f8743;
    border-radius: 999px;
    color: #2f8743;
    font-size: 38px;
}

.member-week-complete strong {
    display: block;
    max-width: 440px;
    color: var(--member-ink);
    font-size: 16px;
}

.member-week-complete p {
    margin: 10px 0 0;
    color: var(--member-muted);
    line-height: 1.45;
}

.member-week-complete a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 16px;
    color: #315d9a;
    font-weight: 800;
    text-decoration: none;
}

.member-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.member-stat-card {
    display: grid;
    align-content: center;
    min-height: 146px;
    padding: 16px;
    border: 1px solid var(--member-line);
    border-radius: 10px;
    background: #fff;
}

.member-stat-card span,
.member-stat-card small {
    color: #62758a;
    font-size: 12px;
}

.member-stat-card > strong {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 14px;
    color: #1d3048;
    font-size: 26px;
    line-height: 1.08;
}

.member-stat-card a {
    margin-top: 12px;
    color: #315d9a;
    font-weight: 800;
    text-decoration: none;
}

.member-stat-bar {
    height: 8px;
    margin-top: 12px;
    overflow: hidden;
    border-radius: 999px;
    background: #dce5ee;
}

.member-stat-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: #69ad4a;
}

.member-home .member-self-evaluation {
    grid-column: 1;
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
}

.member-swing-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.member-swing-step {
    position: relative;
    display: grid;
    gap: 8px;
}

.member-swing-step:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 12px;
    left: 28px;
    right: -18px;
    border-top: 2px dotted #aebbd0;
}

.member-swing-step span {
    position: relative;
    z-index: 1;
    display: grid;
    place-items: center;
    width: 26px;
    height: 26px;
    border-radius: 999px;
    background: #263b58;
    color: #fff;
    font-size: 12px;
    font-weight: 900;
}

.member-swing-step strong {
    color: #25384f;
    font-size: 12px;
    line-height: 1.2;
}

.member-home .member-evaluation-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.member-home .member-upload-card,
.member-compare-card {
    display: grid;
    align-content: end;
    min-height: 128px;
    padding: 14px;
    border: 1px solid var(--member-line);
    border-radius: 8px;
    overflow: hidden;
    color: #fff;
    text-decoration: none;
}

.member-home .member-upload-card {
    background:
        linear-gradient(145deg, rgba(21, 43, 36, 0.72), rgba(20, 31, 41, 0.45)),
        url("https://images.unsplash.com/photo-1593111774240-d529f12cf4bb?auto=format&fit=crop&w=900&q=80");
    background-position: center;
    background-size: cover;
}

.member-home .member-upload-card.current,
.member-compare-card {
    background:
        linear-gradient(145deg, rgba(22, 35, 45, 0.62), rgba(35, 43, 53, 0.56)),
        url("https://images.unsplash.com/photo-1535131749006-b7f58c99034b?auto=format&fit=crop&w=900&q=80");
    background-position: center;
    background-size: cover;
}

.member-home .member-upload-card span,
.member-compare-card span {
    color: rgba(255, 255, 255, 0.86);
    font-size: 12px;
    font-weight: 800;
}

.member-home .member-upload-card strong,
.member-compare-card strong {
    margin-top: 6px;
    font-size: 14px;
}

.member-home .member-upload-card input {
    margin-top: 8px;
    color: rgba(255, 255, 255, 0.86);
    font-size: 12px;
}

.member-home .member-upload-card input::file-selector-button {
    margin-right: 8px;
    border: 0;
    border-radius: 6px;
    background: #fff;
    color: #25384f;
    font-weight: 800;
}

.member-help-text {
    margin: 0;
    color: #687b90;
    font-size: 13px;
}

.member-profile-card {
    grid-column: 2;
}

.member-profile-list {
    display: grid;
    border: 1px solid var(--member-line);
    border-radius: 10px;
    overflow: hidden;
}

.member-profile-list div {
    display: grid;
    grid-template-columns: minmax(140px, 0.7fr) minmax(0, 1.3fr);
    gap: 18px;
    padding: 18px 20px;
    background: #fff;
}

.member-profile-list div + div {
    border-top: 1px solid var(--member-line);
}

.member-profile-list span {
    color: #4d6075;
}

.member-profile-list strong {
    justify-self: end;
    max-width: 480px;
    color: #274a83;
    text-align: right;
}

.member-flow-details .member-program-flow {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.member-flow-details--empty {
    padding-bottom: 18px;
}

.member-flow-details--empty .member-section-head {
    margin-bottom: 12px;
}

.member-flow-waiting {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    min-height: 78px;
    padding: 14px 18px;
    border: 1px dashed var(--member-line-strong);
    border-radius: 10px;
    background: #f8fbfd;
}

.member-flow-waiting__icon {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border: 1px solid #c8d8cc;
    border-radius: 999px;
    color: #2f8743;
    font-size: 22px;
    font-weight: 900;
}

.member-flow-waiting strong {
    display: block;
    color: var(--member-ink);
    font-size: 16px;
}

.member-flow-waiting p {
    margin: 4px 0 0;
    color: var(--member-muted);
    line-height: 1.45;
}

.member-flow-waiting a {
    color: #315d9a;
    font-weight: 800;
    text-decoration: none;
    white-space: nowrap;
}

.member-flow-details .member-day-block {
    display: block;
}

.member-flow-details .member-day-marker {
    display: none;
}

.member-flow-details .member-session-card {
    grid-template-columns: 1fr;
    min-height: 0;
    border-radius: 10px;
}

.member-flow-details .member-session-thumb {
    min-height: 118px;
}

@media (max-width: 1180px) {
    .member-hero,
    .member-dashboard-grid {
        grid-template-columns: 1fr;
    }

    .member-profile-card,
    .member-home .member-self-evaluation {
        grid-column: auto;
    }

    .member-stat-grid,
    .member-flow-details .member-program-flow {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 820px) {
    .member-hero {
        padding: 24px;
    }

    .member-next-steps,
    .member-week-complete,
    .member-flow-waiting,
    .member-home .member-evaluation-grid,
    .member-stat-grid,
    .member-swing-steps,
    .member-profile-list div,
    .member-flow-details .member-program-flow {
        grid-template-columns: 1fr;
    }

    .member-week-complete {
        justify-items: start;
    }

    .member-flow-waiting {
        grid-template-columns: 36px minmax(0, 1fr);
        align-items: center;
        gap: 10px 12px;
        min-height: 0;
        padding: 12px 14px;
    }

    .member-flow-waiting__icon {
        width: 36px;
        height: 36px;
        font-size: 19px;
    }

    .member-flow-waiting a {
        grid-column: 2;
        justify-self: start;
    }

    .member-swing-step:not(:last-child)::after {
        display: none;
    }
}

@media (min-width: 821px) and (max-width: 1350px) {
    .member-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .member-home .member-evaluation-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .member-compare-card {
        grid-column: 1 / -1;
        min-height: 96px;
    }

    .member-swing-step strong {
        font-size: 11px;
    }

    .member-stat-card {
        min-height: 118px;
    }

    .member-stat-card > strong {
        font-size: 22px;
    }

    .member-stat-card:not(:first-child) > strong {
        font-size: 18px;
    }
}

/* Shared member area theme */
.member-home {
    --member-panel: #ffffff;
    --member-panel-soft: #f8fbfd;
    --member-line: #e1e7ef;
    --member-line-strong: #cbd6e3;
    --member-ink: #25384f;
    --member-muted: #687b90;
    --member-blue: #416aa8;
    --member-blue-dark: #24446f;
    --member-green: #69ad4a;
    --member-green-soft: #edf8ef;
    --member-hero-image: url("https://images.unsplash.com/photo-1517836357463-d25dfeac3438?auto=format&fit=crop&w=1800&q=80");
}

.member-home--golf {
    --member-hero-image: url("https://images.unsplash.com/photo-1535131749006-b7f58c99034b?auto=format&fit=crop&w=1800&q=80");
}

.member-sessions-top__hero,
.member-workout-hero,
.member-hero--messages,
.member-hero--development,
.member-hero--test-submit {
    border: 1px solid var(--member-line);
    border-radius: 12px;
    color: #fff;
    background:
        linear-gradient(90deg, rgba(13, 29, 45, 0.94), rgba(20, 34, 48, 0.72) 50%, rgba(17, 43, 39, 0.56)),
        var(--member-hero-image);
    background-position: center;
    background-size: cover;
    box-shadow: 0 18px 42px rgba(31, 45, 61, 0.06);
}

.member-sessions-top__hero h1,
.member-sessions-top__hero p,
.member-workout-hero__copy h1,
.member-workout-hero__copy p,
.member-hero--messages h1,
.member-hero--messages p,
.member-hero--development h1,
.member-hero--development p,
.member-hero--test-submit h1,
.member-hero--test-submit p {
    color: #fff;
}

.member-sessions-top__meta span,
.member-workout-hero__meta span,
.member-sessions-detail-tags span,
.member-sessions-timeline-item__meta span,
.member-message-card__type,
.member-message-card__tag,
.member-development-feature-card__summary,
.member-test-meta-pill {
    background: rgba(65, 106, 168, 0.12);
    color: var(--member-blue-dark);
}

.member-sessions-top__hero .member-sessions-top__meta span,
.member-workout-hero__meta span,
.member-hero--messages .member-hero-meta span,
.member-hero--development .member-hero-meta span,
.member-hero--test-submit .member-hero-meta span {
    background: rgba(255, 255, 255, 0.16);
    color: rgba(255, 255, 255, 0.92);
}

.member-sessions-focus-card,
.member-sessions-panel,
.member-group-panel,
.member-message-card,
.member-support-article-card,
.member-article-hero-card,
.member-development-feature-card,
.member-development-list-card,
.member-hcp-form,
.member-development-status-card,
.member-sessions-detail-copy,
.member-sessions-detail-card,
.member-workout-section,
.member-workout-followup-card,
.member-workout-video-card,
.member-workout-fact-card,
.member-workout-task-card,
.member-workout-mini-panel,
.member-test-submit-info-card,
.member-test-submit-detail-card,
.member-test-submit-explainer,
.member-test-submit-panel {
    border: 1px solid var(--member-line);
    border-radius: 12px;
    background: var(--member-panel);
    box-shadow: 0 18px 42px rgba(31, 45, 61, 0.06);
}

.member-sessions-focus-card,
.member-sessions-next-card,
.member-development-feature-card,
.member-hcp-form,
.member-development-status-card,
.member-test-submit-info-card,
.member-test-submit-explainer {
    background: linear-gradient(180deg, #ffffff, var(--member-panel-soft));
}

.member-kicker,
.member-development-status-card__kicker,
.member-test-submit-info-card__body h3,
.member-test-submit-detail-card h3,
.member-test-submit-panel h3,
.member-sessions-panel__head > span {
    color: var(--member-blue-dark);
}

.member-development-chart__point,
.member-development-chart__point--latest {
    background: var(--member-green);
}

.member-sessions-focus-card__progressline span {
    background: transparent;
    color: var(--member-muted);
}

.member-sessions-complete-pill,
.member-workout-complete-state {
    background: var(--member-green-soft);
    color: #2f8743;
}

.member-sessions-timeline-item__index,
.member-sessions-timeline-item.is-completed .member-sessions-timeline-item__index,
.member-sessions-timeline-item.is-active .member-sessions-timeline-item__index,
.member-sessions-next-card__icon,
.member-sessions-detail-card__icon,
.member-workout-hero__icon,
.member-workout-section__icon,
.member-development-feature-card__icon,
.member-development-status-card__icon,
.member-message-card__icon,
.member-support-article-card__icon,
.member-test-submit-info-card__icon {
    background: var(--member-blue);
    color: #fff;
}

.member-message-card__icon--direct,
.member-support-article-card__category,
.member-workout-mini-panel--challenge,
.member-test-submit-counter__button {
    background: var(--member-green-soft);
    color: #2f8743;
}

.member-group-panel--messages,
.member-support-article-card {
    border-color: var(--member-line);
    background: var(--member-panel);
}

.member-development-feature-card__main,
.member-development-feature-card__copy,
.member-support-article-card__body {
    min-width: 0;
}

.member-development-feature-card__copy,
.member-support-article-card__body,
.member-group-panel--messages {
    overflow-wrap: anywhere;
}

.member-sessions-timeline-item__line {
    background: var(--member-line-strong);
}

.member-sessions-timeline-item__card,
.member-sessions-next-card,
.member-workout-task-card,
.member-workout-fact-card,
.member-workout-mini-panel,
.member-development-list-card {
    border-color: var(--member-line);
    background: var(--member-panel-soft);
}

.member-sessions-timeline-item.is-active .member-sessions-timeline-item__card,
.member-sessions-timeline-link:hover .member-sessions-timeline-item__card,
.member-message-card:hover,
.member-message-card:focus-visible,
.member-article-hero-card:hover,
.member-article-hero-card:focus-visible {
    border-color: color-mix(in srgb, var(--member-blue) 42%, var(--member-line));
    box-shadow: 0 18px 42px rgba(31, 45, 61, 0.11);
}

.member-hcp-form input,
.member-test-submit-reflection textarea {
    border-color: var(--member-line);
    background: #fff;
    color: var(--member-ink);
}

.member-hcp-form .primary-action,
.member-test-submit-actions__primary,
.member-workout-footer .primary-action,
.member-primary-action {
    background: var(--member-blue);
    color: #fff;
}

.member-workout-footer .secondary-action,
.member-test-submit-actions .secondary-action {
    border-color: var(--member-line-strong);
    color: var(--member-blue-dark);
}

/* Compact member headers */
.member-hero {
    min-height: 264px;
    gap: 22px;
    padding: 24px 34px;
}

.member-hero h1 {
    font-size: clamp(34px, 3.25vw, 46px);
    line-height: 1;
}

.member-hero p {
    margin-top: 8px;
    font-size: 15px;
}

.member-hero-actions {
    gap: 10px;
    margin-top: 18px;
}

.member-hero-action {
    min-height: 42px;
    padding: 0 18px;
}

.member-hero-meta {
    gap: 8px;
    margin-top: 18px;
}

.member-hero-meta span {
    min-height: 30px;
    padding: 0 12px;
}

.member-next-steps {
    gap: 8px;
    padding: 14px;
}

.member-next-steps__flag {
    width: 32px;
    height: 32px;
}

.member-next-step {
    grid-template-columns: 42px minmax(0, 1fr) auto;
    min-height: 50px;
    padding: 8px 12px 8px 10px;
}

.member-next-step__icon {
    width: 36px;
    height: 36px;
}

.member-next-step strong {
    font-size: 13px;
}

.member-next-step small {
    font-size: 11px;
}

.member-sessions-top {
    grid-template-columns: minmax(0, 0.95fr) minmax(300px, 0.68fr);
    gap: 12px;
    align-items: start;
}

.member-sessions-page {
    align-self: start;
    align-content: start;
}

.member-sessions-top__hero {
    box-sizing: border-box;
    align-content: start;
    gap: 10px;
    min-height: 0;
    height: 198px;
    max-height: 198px;
    padding: 20px 24px;
    overflow: hidden;
    background-position: center 42%;
}

.member-sessions-top__hero h1,
.member-hero--messages h1,
.member-hero--development h1,
.member-hero--test-submit h1 {
    font-size: clamp(32px, 3.2vw, 44px);
    line-height: 1;
}

.member-sessions-top__hero p,
.member-hero--messages p,
.member-hero--development p,
.member-hero--test-submit p {
    font-size: 15px;
    line-height: 1.45;
}

.member-sessions-top__meta {
    align-self: end;
    max-width: 100%;
    overflow: hidden;
}

.member-sessions-top__meta,
.member-sessions-detail-tags,
.member-workout-hero__meta,
.member-hero-meta--messages,
.member-hero-meta--development {
    gap: 8px;
}

.member-sessions-top__meta span,
.member-sessions-detail-tags span,
.member-sessions-timeline-item__meta span,
.member-sessions-complete-pill,
.member-workout-hero__meta span {
    min-height: 28px;
    padding: 0 10px;
}

.member-sessions-top__meta span {
    max-width: min(100%, 520px);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.member-sessions-focus-card {
    align-self: start;
    gap: 8px;
    padding: 18px 20px;
}

.member-upload-progression {
    display: grid;
    gap: 16px;
}

.member-upload-progression__item {
    display: grid;
    grid-template-columns: minmax(220px, 0.42fr) minmax(0, 1fr);
    gap: 16px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: color-mix(in srgb, var(--surface) 94%, var(--bg));
}

.member-upload-progression__media {
    overflow: hidden;
    border-radius: 12px;
    background: #0f172a;
    aspect-ratio: 16 / 10;
}

.member-upload-progression__media video,
.member-upload-progression__media img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
}

.member-upload-progression__copy {
    display: grid;
    gap: 12px;
    align-content: start;
}

.member-upload-progression__eyebrow {
    display: block;
    margin-bottom: 5px;
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.member-upload-progression__copy h3 {
    margin: 0;
    font-size: 18px;
}

.member-upload-progression__copy p,
.member-upload-progression__copy blockquote {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.45;
}

.member-upload-progression__copy dl {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin: 0;
}

.member-upload-progression__copy dt {
    color: var(--text-secondary);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.member-upload-progression__copy dd {
    margin: 2px 0 0;
    font-weight: 800;
}

.member-sessions-focus-card h2 {
    font-size: 22px;
}

.member-workout-hero {
    grid-template-columns: auto minmax(0, 1fr) minmax(140px, 0.45fr);
    gap: 14px;
    padding: 14px;
}

.member-workout-hero__icon {
    width: 64px;
    height: 64px;
    border-radius: 14px;
    font-size: 28px;
}

.member-workout-hero__copy {
    gap: 7px;
}

.member-workout-hero__copy h1 {
    font-size: clamp(30px, 3.1vw, 42px);
    line-height: 1;
}

.member-workout-hero__copy p {
    line-height: 1.45;
}

.member-workout-hero__art {
    min-height: 70px;
    border-radius: 14px;
}

.member-home--favorites {
    gap: 12px;
}

.member-home--messages .member-hero,
.member-home--development .member-hero,
.member-home--favorites .member-hero,
.member-hero--test-submit {
    grid-template-columns: minmax(0, 1fr);
    min-height: 0;
    gap: 10px;
    padding: 16px 20px;
}

.member-home--messages .member-hero-copy,
.member-home--development .member-hero-copy,
.member-home--favorites .member-hero-copy,
.member-hero--test-submit .member-hero-copy {
    max-width: 920px;
}

.member-home--messages .member-hero h1,
.member-home--development .member-hero h1,
.member-home--favorites .member-hero h1,
.member-hero--test-submit h1 {
    font-size: clamp(28px, 3vw, 38px);
}

.member-home--messages .member-hero p,
.member-home--development .member-hero p,
.member-home--favorites .member-hero p,
.member-hero--test-submit p {
    max-width: 720px;
    margin-top: 6px;
    font-size: 14px;
    line-height: 1.4;
}

.member-home--messages .member-hero-meta,
.member-home--development .member-hero-meta,
.member-home--favorites .member-hero-meta,
.member-hero--test-submit .member-hero-meta {
    margin-top: 10px;
}

.member-sessions-top__hero {
    height: auto;
    max-height: none;
    min-height: 0;
    padding: 16px 20px;
}

.member-sessions-top__hero h1 {
    font-size: clamp(28px, 3vw, 38px);
}

.member-workout-hero {
    min-height: 0;
    padding: 12px 14px;
}

.member-group-panel--favorites {
    gap: 18px;
}

.member-favorites-panel__head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
}

.member-favorites-panel__head .member-kicker {
    margin-bottom: 6px;
}

.member-favorites-panel__head h2,
.member-favorites-empty h3,
.member-favorite-card__copy h3 {
    margin: 0;
    color: var(--member-ink);
    letter-spacing: 0;
}

.member-favorites-panel__head > strong {
    display: grid;
    place-items: center;
    min-width: 58px;
    height: 46px;
    padding: 0 14px;
    border-radius: 10px;
    background: var(--member-green-soft);
    color: #2f8743;
    font-size: 24px;
    line-height: 1;
}

.member-favorites-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 12px;
}

.member-favorite-card {
    display: grid;
    overflow: hidden;
    border: 1px solid var(--member-line);
    border-radius: 12px;
    background: var(--member-panel-soft);
}

.member-favorite-card__media {
    position: relative;
    display: grid;
    place-items: center;
    min-height: 156px;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background:
        radial-gradient(circle at 72% 20%, rgba(255, 255, 255, 0.24), transparent 24%),
        linear-gradient(145deg, #263b58, #1f4f39);
    color: #fff;
    font-size: 36px;
    font-weight: 900;
    text-decoration: none;
}

.member-favorite-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.member-favorite-card__play {
    position: absolute;
    right: 12px;
    bottom: 12px;
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.94);
    color: var(--member-blue-dark);
    font-size: 14px;
    box-shadow: 0 14px 28px rgba(16, 31, 49, 0.18);
}

.member-favorite-card__body {
    display: grid;
    gap: 12px;
    padding: 16px;
}

.member-favorite-card__meta,
.member-favorite-card__tags,
.member-favorite-card__actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

.member-favorite-card__meta span,
.member-favorite-card__tags span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(65, 106, 168, 0.12);
    color: var(--member-blue-dark);
    font-size: 12px;
    font-weight: 800;
}

.member-favorite-card__copy {
    display: grid;
    gap: 6px;
}

.member-favorite-card__copy h3 {
    font-size: 19px;
    line-height: 1.18;
}

.member-favorite-card__copy p,
.member-favorites-empty p {
    margin: 0;
    color: var(--member-muted);
    line-height: 1.5;
}

.member-favorite-card__actions {
    justify-content: space-between;
    margin-top: 2px;
}

.member-favorites-empty {
    display: grid;
    justify-items: start;
    gap: 10px;
}

@media (max-width: 820px) {
    .member-favorites-panel__head,
    .member-favorite-card__actions {
        align-items: stretch;
        flex-direction: column;
    }

    .member-favorites-panel__head > strong,
    .member-favorite-card__actions .member-secondary-link,
    .member-favorite-card__actions .member-video-favorite-action {
        width: 100%;
    }
}

@media (max-width: 1180px) {
    .member-hero {
        min-height: 0;
    }

    .member-sessions-top__hero {
        min-height: 180px;
    }
}

@media (max-width: 820px) {
    .member-hero,
    .member-sessions-top__hero,
    .member-hero--messages,
    .member-hero--development,
    .member-hero--test-submit {
        padding: 20px;
    }

    .member-hero h1 {
        font-size: clamp(30px, 8vw, 38px);
    }

    .member-hero-actions {
        margin-top: 14px;
    }

    .member-hero-meta {
        margin-top: 14px;
    }

    .member-mobile-card {
        align-items: stretch;
        flex-direction: column;
    }

    .member-mobile-card__actions {
        justify-content: stretch;
    }

    .member-store-link {
        flex: 1 1 160px;
    }

    .member-next-steps {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 8px;
        padding: 12px;
    }

    .member-next-steps__head {
        grid-column: 1 / -1;
        min-height: 28px;
    }

    .member-next-step {
        grid-template-columns: 1fr;
        justify-items: start;
        align-content: start;
        min-height: 70px;
        padding: 8px;
    }

    .member-next-step__icon {
        width: 30px;
        height: 30px;
    }

    .member-next-step strong {
        font-size: 12px;
        line-height: 1.2;
    }

    .member-next-step small,
    .member-next-step__arrow {
        display: none;
    }

    .member-sessions-focus-card {
        gap: 6px;
        padding: 14px 16px;
    }

    .member-sessions-focus-card p {
        display: none;
    }

    .member-sessions-focus-card__progressline {
        margin-top: 2px;
    }
}

.member-home--messages .member-hero,
.member-home--development .member-hero,
.member-home--favorites .member-hero,
.member-hero--test-submit {
    grid-template-columns: minmax(0, 1fr);
    min-height: 0;
    padding: 16px 20px;
}

.member-sessions-page .member-sessions-top__hero {
    min-height: 0;
    height: auto;
    max-height: none;
    padding: 16px 20px;
}

@media (max-width: 700px) {
    .member-sessions-page .member-sessions-top {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 1180px) {
    .payment-access-filter,
    .free-access-filter {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .payment-access-search-field,
    .free-access-search-field {
        grid-column: 1 / -1;
    }

    .payment-access-filter .payment-filter-actions,
    .free-access-filter .payment-filter-actions {
        justify-content: flex-start;
    }

    .free-access-page .dashboard-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .free-access-row {
        align-items: stretch;
        flex-direction: column;
    }

    .free-access-detail-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .free-access-row .admin-row-actions {
        justify-content: flex-start;
        min-width: 0;
    }
}

@media (max-width: 700px) {
    .payment-access-filter,
    .free-access-filter {
        grid-template-columns: 1fr;
    }

    .free-access-page .dashboard-grid,
    .free-access-detail-grid {
        grid-template-columns: 1fr;
    }

    .free-access-row {
        padding: 18px;
    }

    .free-access-member-line {
        align-items: stretch;
        flex-direction: column;
        gap: 12px;
    }

    .free-access-status {
        width: fit-content;
    }

.free-access-row .secondary-action,
    .free-access-row .danger-action,
    .free-access-row-form {
        width: 100%;
    }
}

.member-session-log {
    display: grid;
    gap: 16px;
}

.member-session-log__exercise {
    border: 1px solid rgba(31, 41, 55, 0.12);
    border-radius: 8px;
    padding: 16px;
    background: rgba(255, 255, 255, 0.72);
}

.member-session-log__exercise h4 {
    margin: 0 0 12px;
    font-size: 1rem;
}

.member-session-result-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.member-session-result-summary span {
    border: 1px solid rgba(31, 41, 55, 0.12);
    border-radius: 999px;
    padding: 6px 10px;
    background: rgba(255, 255, 255, 0.8);
    color: var(--member-ink-soft, #475569);
    font-size: 0.85rem;
}

.nutrition-recipe-fields,
.nutrition-plan-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
}

.nutrition-recipe-panel {
    display: grid;
    gap: 16px;
    border: 1px solid rgba(31, 41, 55, 0.12);
    border-radius: 8px;
    padding: 18px;
    background: rgba(246, 242, 232, 0.58);
}

.nutrition-recipe-panel legend {
    padding: 0 8px;
    color: #24311f;
    font-weight: 800;
}

.nutrition-recipe-panel p {
    margin: 0;
    color: #5d6659;
}

.nutrition-chip-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 8px;
}

.nutrition-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid rgba(31, 41, 55, 0.12);
    border-radius: 999px;
    padding: 8px 12px;
    background: #fff;
    color: #24311f;
    font-weight: 700;
    font-size: 0.875rem;
}

.nutrition-chip--warn {
    background: rgba(255, 107, 107, 0.08);
}

.nutrition-plan-builder,
.nutrition-plan-form,
.nutrition-generated-plan,
.nutrition-plan-meals {
    display: grid;
    gap: 18px;
}

.nutrition-plan-builder {
    margin: 18px 0 24px;
}

.nutrition-plan-form,
.nutrition-generated-plan {
    border: 1px solid rgba(31, 41, 55, 0.12);
    border-radius: 8px;
    padding: 18px;
    background: rgba(255, 255, 255, 0.72);
}

.nutrition-plan-form__head,
.nutrition-generated-plan__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
}

.nutrition-plan-form__head h3,
.nutrition-generated-plan__head h3,
.nutrition-plan-meals h4 {
    margin: 0;
}

.nutrition-plan-targets,
.nutrition-plan-distribution-bar,
.nutrition-meal-distribution,
.nutrition-preference-panels,
.nutrition-recipe-card-grid {
    display: grid;
    gap: 12px;
}

.nutrition-plan-targets {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    align-items: center;
    border-radius: 8px;
    padding: 14px;
    background: #f6f2e8;
    color: #394535;
}

.nutrition-goal-guidance {
    display: grid;
    gap: 6px;
    border: 1px solid rgba(47, 81, 48, 0.18);
    border-radius: 8px;
    padding: 14px;
    background: #eef6e9;
    color: #2f5130;
}

.nutrition-goal-guidance span,
.nutrition-generated-plan__goal {
    margin: 0;
    color: #5d6659;
    line-height: 1.45;
}

.nutrition-meal-distribution {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.nutrition-meal-row {
    display: grid;
    grid-template-columns: 1fr 72px auto auto;
    align-items: center;
    gap: 10px;
    border-radius: 8px;
    padding: 12px;
    background: #f6f2e8;
}

.nutrition-meal-row input[type="number"] {
    min-width: 0;
}

.nutrition-distribution-status {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    border-radius: 8px;
    padding: 12px 14px;
    background: #eef6e9;
    color: #2f5130;
    font-weight: 700;
}

.nutrition-distribution-status.is-invalid {
    background: #fff3f3;
    color: #b42318;
}

.nutrition-distribution-status span {
    text-align: right;
    font-weight: 700;
}

.nutrition-preference-panels {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.nutrition-plan-distribution-bar {
    grid-auto-flow: column;
    grid-auto-columns: minmax(120px, 1fr);
    overflow-x: auto;
}

.nutrition-plan-distribution-bar > div {
    display: grid;
    gap: 8px;
    min-width: 130px;
    border-radius: 8px;
    padding: 14px;
    background: #dfe6cf;
}

.nutrition-plan-distribution-bar em {
    font-style: normal;
    font-size: 1.15rem;
}

.nutrition-plan-meals section {
    display: grid;
    gap: 10px;
}

.nutrition-plan-meals h4 {
    display: flex;
    justify-content: space-between;
    gap: 12px;
}

.nutrition-recipe-card-grid {
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}

.nutrition-recipe-card {
    display: grid;
    gap: 8px;
    border: 1px solid rgba(31, 41, 55, 0.12);
    border-radius: 8px;
    padding: 14px;
    background: #fff;
}

.recovery-status-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    border: 1px solid rgba(31, 41, 55, 0.12);
    border-radius: 8px;
    padding: 16px;
    background: #eef6e9;
    color: #2f5130;
}

.recovery-status-card > div {
    display: grid;
    gap: 4px;
}

.recovery-status-card span {
    color: #4c5f48;
    line-height: 1.45;
}

.recovery-status-card em {
    font-style: normal;
    font-size: 1.5rem;
    font-weight: 900;
    white-space: nowrap;
}

.recovery-status-card--watch {
    background: #fff7df;
    color: #745017;
}

.recovery-status-card--watch span {
    color: #7a612d;
}

.recovery-status-card--needs_attention {
    background: #fff3f3;
    color: #b42318;
}

.recovery-status-card--needs_attention span {
    color: #85423d;
}

.recovery-check-in-result--needs_attention summary {
    border-left: 4px solid #b42318;
}

.recovery-check-in-result--watch summary {
    border-left: 4px solid #c7902f;
}

.recovery-check-in-result--ready summary {
    border-left: 4px solid #2f5130;
}

@media (max-width: 640px) {
    .member-reference-panel--nutrition .member-reference-stats,
    .member-reference-panel--recovery .member-reference-stats,
    .nutrition-plan-grid,
    .nutrition-preference-panels,
    .nutrition-recipe-card-grid {
        grid-template-columns: 1fr;
    }

    .nutrition-plan-form__head,
    .nutrition-generated-plan__head,
    .nutrition-plan-meals h4 {
        flex-direction: column;
        align-items: stretch;
    }

    .nutrition-plan-distribution-bar {
        grid-auto-flow: row;
        grid-auto-columns: auto;
        overflow-x: visible;
    }

    .nutrition-plan-distribution-bar > div {
        min-width: 0;
    }

    .nutrition-meal-row {
        grid-template-columns: 1fr 64px auto auto;
    }

    .nutrition-distribution-status {
        align-items: stretch;
        flex-direction: column;
    }

    .nutrition-distribution-status span {
        text-align: left;
    }

    .recovery-status-card {
        align-items: stretch;
        flex-direction: column;
    }
}

.package-editor-page {
    --package-editor-accent: #0f9a93;
    --package-editor-accent-strong: #087f79;
    --package-editor-ink: #111935;
    --package-editor-muted: #65718a;
    --package-editor-border: #d9e0ea;
    --package-editor-soft: #f7fafc;
    --package-editor-danger: #ef4444;
    width: min(100%, 1360px);
    max-width: none;
    color: var(--package-editor-ink);
}

.package-editor-brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 36px;
    color: var(--package-editor-ink);
    font-size: 22px;
    font-weight: 900;
    line-height: 1;
}

.package-editor-brand__mark {
    display: grid;
    grid-template-columns: repeat(2, 11px);
    grid-template-rows: repeat(2, 11px);
    gap: 2px;
    transform: rotate(-38deg);
}

.package-editor-brand__mark span {
    display: block;
    border-radius: 4px;
    background: linear-gradient(135deg, #36c8bd, #0f8f89);
}

.package-editor-brand__mark span:nth-child(2),
.package-editor-brand__mark span:nth-child(3) {
    opacity: .78;
}

.package-editor-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 22px;
}

.package-editor-header h1 {
    margin: 0;
    color: var(--package-editor-ink);
    font-size: 28px;
    line-height: 1.08;
    letter-spacing: 0;
}

.package-editor-header p {
    margin: 8px 0 0;
    color: var(--package-editor-muted);
    font-size: 14px;
}

.package-editor-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 14px;
    flex-wrap: wrap;
}

.package-editor-actions form {
    margin: 0;
}

.package-editor-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    min-width: 120px;
    min-height: 44px;
    box-sizing: border-box;
    padding: 0 16px;
    border: 1px solid var(--package-editor-border);
    border-radius: 8px;
    background: #fff;
    color: var(--package-editor-ink);
    font: inherit;
    font-weight: 800;
    text-decoration: none;
    cursor: pointer;
    white-space: nowrap;
    transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease, background-color .16s ease;
}

.package-editor-button--compact {
    gap: 8px;
    min-width: 0;
    min-height: 40px;
    padding: 0 14px;
    font-size: 14px;
}

.package-editor-button.package-editor-button--compact svg {
    width: 16px;
    height: 16px;
}

.package-editor-button svg {
    width: 18px;
    height: 18px;
}

.package-editor-button:hover,
.package-editor-button:focus-visible {
    border-color: color-mix(in srgb, var(--package-editor-accent) 45%, var(--package-editor-border));
    box-shadow: 0 12px 28px rgba(15, 154, 147, .14);
    transform: translateY(-1px);
}

.package-editor-button--danger {
    color: var(--package-editor-danger);
}

.package-editor-button--primary {
    border-color: transparent;
    background: linear-gradient(135deg, var(--package-editor-accent), var(--package-editor-accent-strong));
    color: #fff;
    box-shadow: 0 12px 24px rgba(15, 154, 147, .24);
}

.package-editor-form {
    display: block;
}

.package-editor-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 430px);
    gap: 38px;
    align-items: start;
}

.package-editor-main,
.package-editor-side {
    display: grid;
    gap: 16px;
    min-width: 0;
}

.package-editor-card {
    display: grid;
    gap: 18px;
    box-sizing: border-box;
    padding: 20px;
    border: 1px solid var(--package-editor-border);
    border-radius: 8px;
    background: rgba(255, 255, 255, .9);
    box-shadow: 0 16px 44px rgba(17, 24, 39, .06);
}

.package-editor-card__title {
    display: flex;
    align-items: center;
    gap: 12px;
}

.package-editor-card__title--split {
    justify-content: space-between;
}

.package-editor-card__title--split > span {
    display: inline-flex;
    align-items: center;
    gap: 12px;
}

.package-editor-card__title svg {
    flex: 0 0 auto;
    width: 22px;
    height: 22px;
    color: var(--package-editor-ink);
}

.package-editor-card h2 {
    margin: 0;
    color: var(--package-editor-ink);
    font-size: 17px;
    line-height: 1.2;
}

.package-editor-card p {
    margin: 0;
    color: var(--package-editor-muted);
    line-height: 1.55;
}

.package-editor-fields {
    display: grid;
    gap: 18px;
}

.package-editor-fields--details {
    grid-template-columns: minmax(0, 1fr) minmax(220px, .58fr) auto;
    align-items: end;
}

.package-editor-fields--two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.package-editor-page .form-field {
    display: grid;
    gap: 8px;
}

.package-editor-page .form-field label,
.package-editor-switch > span:first-child {
    color: #27334a;
    font-size: 13px;
    font-weight: 700;
}

.package-editor-page .form-field input[type="number"],
.package-editor-page .form-field input[type="text"],
.package-editor-page .form-field textarea {
    width: 100%;
    min-height: 38px;
    box-sizing: border-box;
    border: 1px solid var(--package-editor-border);
    border-radius: 6px;
    background: #fff;
    color: var(--package-editor-ink);
    font: inherit;
    padding: 9px 12px;
    box-shadow: inset 0 1px 1px rgba(17, 24, 39, .03);
}

.package-editor-page .form-field textarea {
    min-height: 58px;
    resize: vertical;
}

.package-editor-switch {
    display: grid;
    grid-template-columns: auto auto;
    grid-template-areas:
        "label label"
        "track status";
    gap: 8px 8px;
    align-items: center;
    cursor: pointer;
}

.package-editor-switch > span:first-child {
    grid-area: label;
}

.package-editor-switch input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.package-editor-switch__track {
    grid-area: track;
    position: relative;
    width: 36px;
    height: 20px;
    border-radius: 999px;
    background: #c9d3df;
    transition: background-color .16s ease;
}

.package-editor-switch__track::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 14px;
    height: 14px;
    border-radius: 999px;
    background: #fff;
    box-shadow: 0 2px 6px rgba(17, 24, 39, .22);
    transition: transform .16s ease;
}

.package-editor-switch input:checked + .package-editor-switch__track {
    background: var(--package-editor-accent);
}

.package-editor-switch input:checked + .package-editor-switch__track::after {
    transform: translateX(16px);
}

.package-editor-switch strong {
    grid-area: status;
    color: var(--package-editor-ink);
    font-size: 14px;
}

.package-price-scope {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin: 0;
    padding: 0;
    border: 0;
}

.package-price-option {
    position: relative;
    display: grid;
    grid-template-columns: auto auto minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    min-height: 100px;
    box-sizing: border-box;
    padding: 18px 16px;
    border: 1px solid var(--package-editor-border);
    border-radius: 8px;
    background: #fff;
    cursor: pointer;
}

.package-price-option:has(input:checked) {
    border-color: var(--package-editor-accent);
    background: color-mix(in srgb, var(--package-editor-accent) 7%, white);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--package-editor-accent) 26%, transparent);
}

.package-price-option input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.package-price-option__radio {
    width: 15px;
    height: 15px;
    margin-top: 1px;
    border: 1px solid #aab6c5;
    border-radius: 999px;
    background: #fff;
}

.package-price-option input:checked + .package-price-option__radio {
    border-color: var(--package-editor-accent);
    box-shadow: inset 0 0 0 4px #fff;
    background: var(--package-editor-accent);
}

.package-price-option__icon {
    color: var(--package-editor-accent);
}

.package-price-option--keep .package-price-option__icon {
    color: #f59e0b;
}

.package-price-option--all .package-price-option__icon {
    color: #8b5cf6;
}

.package-price-option__icon svg {
    display: block;
    width: 20px;
    height: 20px;
}

.package-price-option strong,
.package-price-option small {
    display: block;
}

.package-price-option strong {
    color: var(--package-editor-ink);
    font-size: 13px;
    line-height: 1.25;
}

.package-price-option small {
    margin-top: 5px;
    color: var(--package-editor-muted);
    font-size: 12px;
    line-height: 1.42;
}

.package-editor-note,
.package-publishing-reminder {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 12px;
    border: 1px solid #bde4f3;
    border-radius: 6px;
    background: #f0f9ff;
    color: var(--package-editor-muted);
    font-size: 13px;
}

.package-editor-note svg,
.package-publishing-reminder svg {
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
    color: #2f8cc6;
}

.package-preview-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 11px;
    border: 1px solid #bae6c6;
    border-radius: 999px;
    background: #f0fdf4;
    color: #128450;
    font-size: 12px;
}

.package-preview-status.is-inactive {
    border-color: #e2e8f0;
    background: #f8fafc;
    color: #64748b;
}

.package-preview-status [aria-hidden="true"] {
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: currentColor;
}

.package-preview {
    position: relative;
    overflow: hidden;
    display: grid;
    gap: 20px;
    min-height: 290px;
    padding: 50px 24px 28px;
    border: 1px solid var(--package-editor-border);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(240, 253, 250, .96), rgba(255, 255, 255, .95)),
        #fff;
}

.package-preview::before,
.package-preview::after {
    content: "";
    position: absolute;
    pointer-events: none;
    background: rgba(15, 154, 147, .08);
}

.package-preview::before {
    right: -66px;
    top: -52px;
    width: 180px;
    height: 270px;
    transform: rotate(42deg);
}

.package-preview::after {
    right: -70px;
    bottom: -62px;
    width: 160px;
    height: 160px;
    border-radius: 50%;
}

.package-preview > * {
    position: relative;
    z-index: 1;
}

.package-preview h3 {
    margin: 0;
    color: var(--package-editor-ink);
    font-size: 30px;
    line-height: 1.08;
}

.package-preview > strong {
    color: var(--package-editor-accent-strong);
    font-size: 18px;
}

.package-preview p {
    display: flex;
    align-items: baseline;
    gap: 7px;
    margin: -8px 0 12px;
    color: var(--package-editor-muted);
}

.package-preview p b {
    color: var(--package-editor-accent-strong);
    font-size: 34px;
    line-height: 1;
}

.package-preview ul,
.package-publishing-list {
    display: grid;
    gap: 18px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.package-preview li {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--package-editor-ink);
}

.package-preview li svg {
    box-sizing: border-box;
    width: 18px;
    height: 18px;
    padding: 2px;
    border: 1px solid var(--package-editor-accent);
    border-radius: 999px;
    color: var(--package-editor-accent);
}

.package-publishing-list div {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr);
    gap: 12px;
}

.package-publishing-list svg {
    width: 22px;
    height: 22px;
    color: var(--package-editor-accent);
}

.package-publishing-list .is-keep svg {
    color: #f59e0b;
}

.package-publishing-list .is-all svg {
    color: #8b5cf6;
}

.package-publishing-list strong,
.package-publishing-list small {
    display: block;
}

.package-publishing-list strong {
    color: var(--package-editor-ink);
    font-size: 13px;
}

.package-publishing-list small {
    margin-top: 4px;
    color: var(--package-editor-muted);
    line-height: 1.45;
}

.package-publishing-reminder {
    margin-top: 12px;
    padding-top: 18px;
    border-width: 1px 0 0;
    border-color: var(--package-editor-border);
    border-radius: 0;
    background: transparent;
}

.package-show-page .package-editor-layout {
    grid-template-columns: minmax(0, 1fr) minmax(300px, 390px);
}

.package-show-hero {
    position: relative;
    overflow: hidden;
    grid-template-columns: minmax(0, 1fr) minmax(260px, .72fr);
    align-items: stretch;
    min-height: 230px;
    background:
        linear-gradient(135deg, rgba(240, 253, 250, .96), rgba(255, 255, 255, .96)),
        #fff;
}

.package-show-hero::after {
    content: "";
    position: absolute;
    right: -70px;
    top: -90px;
    width: 250px;
    height: 250px;
    border-radius: 50%;
    background: rgba(15, 154, 147, .1);
    pointer-events: none;
}

.package-show-hero > * {
    position: relative;
    z-index: 1;
}

.package-show-hero h2 {
    margin-top: 24px;
    font-size: 18px;
}

.package-show-hero p {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 8px;
}

.package-show-hero p b {
    color: var(--package-editor-accent-strong);
    font-size: 52px;
    line-height: .95;
}

.package-show-hero__stats {
    display: grid;
    gap: 12px;
}

.package-show-hero__stats article,
.package-show-price-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 15px 16px;
    border: 1px solid var(--package-editor-border);
    border-radius: 8px;
    background: #fff;
}

.package-show-hero__stats span,
.package-show-price-row span,
.package-show-detail-list dt {
    color: var(--package-editor-muted);
    font-size: 12px;
    font-weight: 700;
}

.package-show-hero__stats strong,
.package-show-price-row strong {
    display: block;
    margin-top: 4px;
    color: var(--package-editor-ink);
    font-size: 18px;
    line-height: 1.15;
}

.package-income-card > p {
    font-size: 13px;
}

.package-income-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.package-income-grid article {
    display: grid;
    gap: 6px;
    min-height: 118px;
    box-sizing: border-box;
    padding: 16px;
    border: 1px solid var(--package-editor-border);
    border-radius: 8px;
    background: #fff;
}

.package-income-grid article.is-positive {
    border-color: #bae6c6;
    background: #f0fdf4;
}

.package-income-grid article.is-negative {
    border-color: #fecaca;
    background: #fef2f2;
}

.package-income-grid span,
.package-income-mini dt,
.package-income-prices span {
    color: var(--package-editor-muted);
    font-size: 12px;
    font-weight: 700;
}

.package-income-grid strong {
    color: var(--package-editor-ink);
    font-size: 23px;
    line-height: 1.05;
}

.package-income-grid small {
    color: var(--package-editor-muted);
    font-size: 12px;
    line-height: 1.35;
}

.package-income-split {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.package-income-mini,
.package-income-prices {
    display: grid;
    gap: 12px;
    padding: 16px;
    border: 1px solid var(--package-editor-border);
    border-radius: 8px;
    background: var(--package-editor-soft);
}

.package-income-mini h3,
.package-income-prices h3 {
    margin: 0;
    color: var(--package-editor-ink);
    font-size: 14px;
}

.package-income-mini dl {
    display: grid;
    gap: 10px;
    margin: 0;
}

.package-income-mini dl div {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 14px;
}

.package-income-mini dt,
.package-income-mini dd {
    margin: 0;
}

.package-income-mini dd {
    color: var(--package-editor-ink);
    font-weight: 800;
    text-align: right;
}

.package-income-price-list {
    display: grid;
    gap: 8px;
}

.package-income-price-list article {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 12px 13px;
    border: 1px solid var(--package-editor-border);
    border-radius: 8px;
    background: #fff;
}

.package-income-price-list strong,
.package-income-price-list b {
    color: var(--package-editor-ink);
}

.package-income-price-list span {
    display: block;
    margin-top: 3px;
}

.package-show-price-list {
    display: grid;
    gap: 12px;
}

.package-show-price-row--missing {
    border-color: color-mix(in srgb, var(--package-editor-danger) 36%, var(--package-editor-border));
    background: color-mix(in srgb, var(--package-editor-danger) 4%, white);
}

.package-show-price-row .package-provider-status {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex: 0 0 auto;
    min-height: 30px;
    padding: 6px 10px;
    border: 1px solid currentColor;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
}

.package-show-price-row .package-provider-status--ready {
    color: #128450;
    background: #f0fdf4;
}

.package-show-price-row .package-provider-status--missing {
    color: var(--package-editor-danger);
    background: color-mix(in srgb, var(--package-editor-danger) 10%, white);
}

.package-show-terms > p {
    font-size: 12px;
}

.package-show-terms-panel {
    min-height: 18rem;
    max-height: 48rem;
    overflow: auto;
    padding: 18px;
    border: 1px solid var(--package-editor-border);
    border-radius: 8px;
    background: #fff;
}

.package-show-detail-list {
    display: grid;
    gap: 12px;
    margin: 0;
}

.package-show-detail-list div {
    display: grid;
    gap: 5px;
}

.package-show-detail-list dt,
.package-show-detail-list dd {
    margin: 0;
}

.package-show-detail-list dd {
    overflow-wrap: anywhere;
    color: var(--package-editor-ink);
    font-weight: 800;
}

.package-terms-section {
    --package-editor-accent: #0f9a93;
    --package-editor-accent-strong: #087f79;
    --package-editor-ink: #111935;
    --package-editor-muted: #65718a;
    --package-editor-border: #d9e0ea;
    --package-editor-soft: #f7fafc;
}

.package-terms-section > .package-editor-card__title svg {
    flex: 0 0 auto;
    width: 22px;
    height: 22px;
}

.package-terms-section > p {
    font-size: 12px;
}

.package-terms-tabs {
    display: flex;
    align-items: center;
    gap: 24px;
    flex-wrap: wrap;
    border-bottom: 1px solid var(--package-editor-border);
}

.package-terms-tabs button {
    position: relative;
    border: 0;
    background: transparent;
    color: var(--package-editor-muted);
    font: inherit;
    font-weight: 800;
    padding: 0 0 11px;
    cursor: pointer;
}

.package-terms-tabs button.is-active {
    color: var(--package-editor-accent-strong);
}

.package-terms-tabs button.is-active::after {
    content: "";
    position: absolute;
    inset: auto 0 -1px;
    height: 2px;
    background: var(--package-editor-accent);
}

.package-terms-editor {
    display: grid;
    grid-template-columns: 190px minmax(0, 1fr);
    gap: 20px;
}

.package-terms-import {
    display: grid;
    gap: 9px;
    align-content: start;
    padding: 16px 14px;
    border: 1px solid var(--package-editor-border);
    border-radius: 8px;
    background: var(--package-editor-soft);
}

.package-terms-import strong {
    color: var(--package-editor-ink);
}

.package-terms-import span,
.package-terms-import small,
.package-terms-richtext small {
    color: var(--package-editor-muted);
    font-size: 12px;
    line-height: 1.45;
}

.package-terms-file {
    display: block;
    margin-top: 12px;
    cursor: pointer;
}

.package-terms-file input {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    opacity: 0;
    pointer-events: none;
}

.package-terms-file span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    min-height: 54px;
    box-sizing: border-box;
    padding: 0 12px;
    border: 1px dashed var(--package-editor-accent);
    border-radius: 8px;
    background: #fff;
    color: var(--package-editor-accent-strong);
    font: inherit;
    font-weight: 800;
}

.package-terms-file:focus-within span,
.package-terms-file:hover span {
    border-color: var(--package-editor-accent-strong);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--package-editor-accent) 12%, transparent);
}

.package-terms-file svg {
    width: 18px;
    height: 18px;
}

.package-terms-richtext {
    display: grid;
    gap: 10px;
}

.package-terms-richtext label {
    color: var(--package-editor-ink);
    font-weight: 800;
}

.package-terms-toolbar {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
    align-content: flex-start;
}

.package-terms-toolbar button,
.package-terms-toolbar span {
    display: inline-grid;
    place-items: center;
    min-width: 32px;
    height: 32px;
    padding: 0 8px;
    border: 0;
    border-radius: 6px;
    background: #f1f5f9;
    color: var(--package-editor-ink);
    font: inherit;
    font-weight: 800;
    cursor: pointer;
}

.package-terms-toolbar button:hover,
.package-terms-toolbar button:focus-visible {
    outline: none;
    background: color-mix(in srgb, var(--package-editor-accent) 12%, #f1f5f9);
    color: var(--package-editor-accent-strong);
}

.package-terms-editor__surface {
    min-height: 24rem;
    border: 1px solid var(--package-editor-border);
    border-radius: 8px;
    background: #fff;
    padding: 16px;
    overflow: auto;
}

.package-terms-editor__surface--compact {
    min-height: 12rem;
    max-height: 22rem;
}

.package-terms-editor__surface:empty::before {
    content: attr(data-placeholder);
    color: var(--package-editor-muted);
}

.package-terms-editor__input {
    display: none;
}

.package-terms-content {
    overflow-wrap: anywhere;
}

.package-terms-content table {
    width: 100%;
    margin: 4px 0 16px;
    border-collapse: collapse;
    table-layout: fixed;
    font-size: 14px;
}

.package-terms-content td,
.package-terms-content th {
    padding: 11px 12px;
    border: 1px solid var(--package-editor-border, #d9e0ea);
    background: var(--package-editor-soft, #f7fafc);
    color: var(--package-editor-ink, #111935);
    vertical-align: top;
}

@media (max-width: 1180px) {
    .package-editor-layout {
        grid-template-columns: 1fr;
    }

    .package-editor-side {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 860px) {
    .package-editor-brand {
        margin-bottom: 22px;
    }

    .package-editor-header,
    .package-editor-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .package-editor-actions,
    .package-editor-actions form,
    .package-editor-button {
        width: 100%;
    }

    .package-editor-fields--details,
    .package-editor-fields--two,
    .package-price-scope,
    .package-show-hero,
    .package-income-grid,
    .package-income-split,
    .package-editor-side,
    .package-terms-editor {
        grid-template-columns: 1fr;
    }

    .package-editor-card {
        padding: 16px;
    }
}

/* Sign-up form builder refresh */
.signup-form-editor-page {
    --signup-builder-accent: #0f8f83;
    --signup-builder-accent-dark: #087669;
    --signup-builder-ink: #111827;
    --signup-builder-muted: #667085;
    --signup-builder-border: #dfe6ee;
    --signup-builder-soft: #eef9f7;
    max-width: none;
    padding: 0;
}

.signup-form-editor-page .signup-form-editor {
    display: block;
}

.signup-builder-frame {
    min-height: calc(100vh - 24px);
    padding: 36px 48px 52px;
    background: linear-gradient(180deg, #fbfcfd 0%, #f6f8fb 100%);
}

.signup-builder-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 26px;
}

.signup-builder-header h1 {
    margin: 0;
    color: var(--signup-builder-ink);
    font-size: 28px;
    line-height: 1.15;
    letter-spacing: 0;
}

.signup-builder-header p,
.signup-builder-card__title p {
    margin: 8px 0 0;
    color: var(--signup-builder-muted);
    font-size: 13px;
}

.signup-builder-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 14px;
    flex-wrap: wrap;
}

.signup-builder-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    min-height: 44px;
    padding: 0 22px;
    border: 1px solid var(--signup-builder-border);
    border-radius: 6px;
    background: #fff;
    color: var(--signup-builder-ink);
    font-weight: 800;
    text-decoration: none;
    cursor: pointer;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.signup-builder-button svg,
.signup-builder-card__title svg {
    width: 18px;
    height: 18px;
}

.signup-builder-button--primary {
    border-color: transparent;
    background: linear-gradient(135deg, var(--signup-builder-accent), var(--signup-builder-accent-dark));
    color: #fff;
}

.signup-builder-button:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

.signup-builder-tabs {
    display: flex;
    gap: 26px;
    margin: 0 -48px 20px;
    padding: 0 48px;
    border-bottom: 1px solid var(--signup-builder-border);
}

.signup-builder-tabs button {
    position: relative;
    min-height: 44px;
    border: 0;
    background: transparent;
    color: #596579;
    font-weight: 800;
    cursor: pointer;
}

.signup-builder-tabs button::after {
    position: absolute;
    right: 0;
    bottom: -1px;
    left: 0;
    height: 3px;
    border-radius: 999px 999px 0 0;
    background: transparent;
    content: "";
}

.signup-builder-tabs button.is-active {
    color: var(--signup-builder-accent-dark);
}

.signup-builder-tabs button.is-active::after {
    background: var(--signup-builder-accent);
}

.signup-builder-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.52fr);
    gap: 28px;
    align-items: start;
}

.signup-builder-layout--advanced {
    grid-template-columns: minmax(0, 1fr);
}

.signup-builder-main,
.signup-builder-side {
    display: grid;
    gap: 18px;
}

.signup-builder-side {
    position: sticky;
    top: 22px;
}

.signup-builder-card {
    display: grid;
    gap: 18px;
    padding: 22px;
    border: 1px solid var(--signup-builder-border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.055);
}

.signup-builder-card__title {
    display: flex;
    align-items: center;
    gap: 14px;
}

.signup-builder-card__title > span {
    display: inline-flex;
    width: 34px;
    height: 34px;
    align-items: center;
    justify-content: center;
    border-radius: 7px;
    background: var(--signup-builder-soft);
    color: var(--signup-builder-accent-dark);
    flex: 0 0 auto;
}

.signup-builder-card h2 {
    margin: 0;
    color: var(--signup-builder-ink);
    font-size: 16px;
    line-height: 1.25;
}

.signup-builder-fields {
    display: grid;
    gap: 18px;
}

.signup-builder-fields--two {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.signup-builder-fields--three {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr) minmax(150px, 0.38fr);
    align-items: start;
}

.signup-form-editor-page .form-field label,
.signup-builder-switch > span {
    color: #344054;
    font-size: 12px;
    font-weight: 800;
}

.signup-form-editor-page input[type="text"],
.signup-form-editor-page input[type="url"],
.signup-form-editor-page input[type="number"],
.signup-form-editor-page select,
.signup-form-editor-page textarea {
    width: 100%;
    border: 1px solid #cfd8e3;
    border-radius: 6px;
    background: #fff;
    color: var(--signup-builder-ink);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.signup-language-tabs {
    display: inline-flex;
    width: fit-content;
    gap: 8px;
    padding: 4px;
    border: 1px solid var(--signup-builder-border);
    border-radius: 8px;
    background: #f8fafc;
}

.signup-language-tabs button {
    min-height: 34px;
    padding: 0 14px;
    border: 0;
    border-radius: 6px;
    background: transparent;
    color: #566174;
    font-weight: 800;
    cursor: pointer;
}

.signup-language-tabs button.is-active {
    background: #fff;
    color: var(--signup-builder-accent-dark);
    box-shadow: 0 4px 14px rgba(15, 23, 42, 0.08);
}

.signup-language-panel {
    display: none;
}

.signup-language-panel.is-active {
    display: grid;
    gap: 18px;
}

.signup-chip-stack,
.signup-mini-preview__chips {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 9px;
}

.signup-chip-stack span {
    display: flex;
    min-height: 44px;
    align-items: center;
    padding: 0 12px;
    border: 1px solid var(--signup-builder-border);
    border-radius: 7px;
    background: #fbfdfd;
    color: #344054;
    font-size: 12px;
    font-weight: 800;
}

.signup-auth-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
}

.signup-auth-option {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid #98d3cc;
    border-radius: 7px;
    background: #fbfffe;
    color: var(--signup-builder-ink);
    cursor: default;
}

.signup-auth-option span {
    display: inline-flex;
    width: 16px;
    height: 16px;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    background: var(--signup-builder-accent);
    color: #fff;
    font-size: 11px;
    font-weight: 900;
}

.signup-builder-compact-select {
    max-width: 340px;
}

.signup-builder-switch {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 12px;
    align-items: center;
    min-height: 44px;
}

.signup-builder-switch input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.signup-builder-switch i {
    position: relative;
    display: inline-block;
    width: 42px;
    height: 24px;
    border-radius: 999px;
    background: #cbd5e1;
}

.signup-builder-switch i::after {
    position: absolute;
    top: 3px;
    left: 3px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 1px 4px rgba(15, 23, 42, 0.18);
    content: "";
    transition: transform 0.18s ease;
}

.signup-builder-switch input:checked + i {
    background: var(--signup-builder-accent);
}

.signup-builder-switch input:checked + i::after {
    transform: translateX(18px);
}

.signup-builder-switch--inline {
    grid-template-columns: auto auto;
    justify-content: start;
}

.signup-builder-switch-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, max-content));
    gap: 26px;
}

.signup-package-builder-grid {
    display: grid;
    grid-template-columns: minmax(220px, 0.7fr) minmax(190px, 0.6fr) minmax(180px, 0.52fr) minmax(260px, 1fr);
    gap: 18px;
    align-items: stretch;
}

.signup-selected-package {
    display: grid;
    align-content: center;
    gap: 4px;
    min-height: 74px;
    padding: 14px 16px;
    border: 1px solid var(--signup-builder-border);
    border-radius: 8px;
    background: linear-gradient(135deg, #fffdf5, #ffffff);
}

.signup-selected-package small,
.signup-package-meta span {
    color: var(--signup-builder-muted);
    font-size: 12px;
}

.signup-package-meta {
    display: grid;
    grid-template-columns: minmax(120px, 1fr) minmax(130px, 1fr);
    gap: 8px 16px;
    padding: 12px 0 0;
    border-top: 1px solid var(--signup-builder-border);
}

.signup-package-meta strong {
    color: var(--signup-builder-ink);
    font-size: 12px;
}

.signup-package-selector--builder {
    max-height: 220px;
}

.signup-mini-preview {
    display: grid;
    gap: 16px;
    padding: 26px;
    border: 1px solid var(--signup-builder-border);
    border-radius: 8px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--mini-accent) 8%, #fff) 0%, #fff 42%);
    color: var(--mini-text);
}

.signup-mini-preview__brand {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: 12px;
}

.signup-mini-preview h3 {
    max-width: 360px;
    margin: 6px auto 0;
    color: var(--mini-text);
    font-size: 26px;
    line-height: 1.08;
    text-align: center;
    letter-spacing: 0;
}

.signup-mini-preview > p {
    max-width: 360px;
    margin: -4px auto 0;
    color: #475467;
    font-size: 13px;
    line-height: 1.45;
    text-align: center;
}

.signup-mini-preview__chips span,
.signup-mini-preview__providers span {
    display: flex;
    min-height: 38px;
    align-items: center;
    justify-content: center;
    padding: 0 8px;
    border: 1px solid var(--signup-builder-border);
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.86);
    color: #344054;
    font-size: 10px;
    font-weight: 800;
    text-align: center;
}

.signup-mini-preview__divider {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 12px;
    align-items: center;
    color: #667085;
    font-size: 11px;
}

.signup-mini-preview__divider::before,
.signup-mini-preview__divider::after {
    height: 1px;
    background: var(--signup-builder-border);
    content: "";
}

.signup-mini-preview__providers {
    display: grid;
    gap: 8px;
}

.signup-mini-preview__package {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    padding: 16px;
    border: 1px solid var(--signup-builder-border);
    border-radius: 8px;
    background: #fff;
}

.signup-mini-preview__package div {
    display: grid;
    gap: 5px;
}

.signup-mini-preview__package small {
    color: #475467;
    font-size: 11px;
}

.signup-mini-preview__package em {
    padding: 5px 9px;
    border-radius: 999px;
    background: var(--signup-builder-soft);
    color: var(--signup-builder-accent-dark);
    font-size: 11px;
    font-style: normal;
    font-weight: 900;
    white-space: nowrap;
}

.signup-mini-preview button {
    min-height: 44px;
    border: 0;
    border-radius: 6px;
    background: linear-gradient(135deg, var(--mini-accent), color-mix(in srgb, var(--mini-accent) 70%, #064e45));
    color: #fff;
    font-size: 14px;
    font-weight: 900;
}

.signup-mini-preview footer {
    color: #667085;
    font-size: 11px;
    text-align: center;
}

.signup-summary-card ul {
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.signup-summary-card li {
    display: flex;
    align-items: center;
    gap: 10px;
    color: #475467;
    font-size: 13px;
}

.signup-summary-card li span {
    display: inline-flex;
    width: 18px;
    height: 18px;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--signup-builder-accent);
    color: #fff;
    font-size: 11px;
    font-weight: 900;
    flex: 0 0 auto;
}

@media (max-width: 1280px) {
    .signup-builder-frame {
        padding: 28px;
    }

    .signup-builder-tabs {
        margin-right: -28px;
        margin-left: -28px;
        padding-right: 28px;
        padding-left: 28px;
    }

    .signup-builder-layout,
    .signup-package-builder-grid {
        grid-template-columns: 1fr;
    }

    .signup-builder-side {
        position: static;
    }
}

@media (max-width: 820px) {
    .signup-builder-header,
    .signup-builder-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .signup-builder-button {
        width: 100%;
    }

    .signup-builder-fields--two,
    .signup-builder-fields--three,
    .signup-auth-grid,
    .signup-chip-stack,
    .signup-color-grid,
    .signup-mini-preview__chips {
        grid-template-columns: 1fr;
    }

    .signup-builder-switch-row {
        grid-template-columns: 1fr;
    }
}
