:root {
    --tp-navy: #102a43;
    --tp-blue: #176b87;
    --tp-mint: #64ccc5;
    --tp-bg: #f4f7fa;
    --tp-text: #243b53;
}

html { font-size: 16px; }
body {
    background: var(--tp-bg);
    color: var(--tp-text);
    min-height: 100vh;
}

.app-header { background: linear-gradient(120deg, var(--tp-navy), var(--tp-blue)); }
.navbar { min-height: 64px; }
.navbar-brand { letter-spacing: -.03em; }
.btn-touch { min-height: 48px; display: inline-flex; align-items: center; justify-content: center; }
.btn-primary { background-color: var(--tp-blue); border-color: var(--tp-blue); }
.btn-primary:hover, .btn-primary:focus { background-color: var(--tp-navy); border-color: var(--tp-navy); }

.app-card {
    background: #fff;
    border: 1px solid rgba(16, 42, 67, .08);
    border-radius: 1rem;
    box-shadow: 0 8px 28px rgba(16, 42, 67, .07);
    padding: 1.25rem;
}

.auth-shell, .form-shell { max-width: 560px; margin: 4vh auto 0; }
.brand-mark {
    align-items: center;
    background: linear-gradient(135deg, var(--tp-blue), var(--tp-mint));
    border-radius: 1rem;
    color: #fff;
    display: flex;
    font-size: 1.25rem;
    font-weight: 800;
    height: 56px;
    justify-content: center;
    width: 56px;
}

.page-heading {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    justify-content: space-between;
    margin-bottom: 1.5rem;
}
.page-heading h1 { font-size: clamp(1.8rem, 5vw, 2.6rem); font-weight: 750; letter-spacing: -.04em; margin: 0; }
.eyebrow { color: var(--tp-blue); display: block; font-size: .75rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.card-grid { display: grid; gap: 1rem; grid-template-columns: 1fr; }
.detail-grid { display: grid; gap: 1rem; }
.match-date { color: var(--tp-blue); font-weight: 700; margin: 1.25rem 0 .35rem; }
.match-situation {
    display: grid;
    gap: .35rem;
    margin: 1rem 0;
    min-width: 0;
}
.match-situation-head {
    align-items: center;
    color: var(--tp-blue);
    display: flex;
    flex-wrap: wrap;
    font-weight: 800;
    gap: .35rem;
    line-height: 1.35;
}
.match-situation-opponent {
    color: var(--tp-navy);
    font-size: 1.2rem;
    font-weight: 800;
    overflow-wrap: anywhere;
}
.match-situation-status {
    align-items: center;
    display: flex;
    font-weight: 800;
    gap: .4rem;
    margin-top: .4rem;
}
.match-situation-success { color: #147d64; }
.match-situation-warning { color: #a15c00; }
.match-situation-confirmed {
    color: var(--tp-navy);
    font-size: 1.05rem;
    font-weight: 800;
}
.match-own-response {
    color: #486581;
    margin-top: .25rem;
}
.match-admin-badges {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
    margin-top: .4rem;
}
.match-admin-badges span {
    background: #f0f4f8;
    border-radius: 999px;
    color: var(--tp-navy);
    font-size: .82rem;
    font-weight: 700;
    padding: .35rem .55rem;
}
.status-pill { background: #e7f7f5; border-radius: 999px; color: #12635f; font-size: .75rem; font-weight: 700; padding: .35rem .7rem; white-space: nowrap; }
.metric-row { display: flex; gap: 2rem; margin: 1.5rem 0; }
.metric-row div { display: flex; flex-direction: column; }
.metric-row strong { font-size: 1.65rem; }
.metric-row span { color: #627d98; font-size: .8rem; }
.availability-actions { display: grid; gap: .5rem; grid-template-columns: 1fr; }
.availability-management-row {
    align-items: center;
    display: grid;
    gap: .5rem;
}
.availability-admin-actions,
.availability-admin-form {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
}
.availability-admin-form {
    align-items: center;
}
.availability-admin-form .form-select {
    width: auto;
    min-width: 10rem;
}
.availability-notify-check {
    font-size: .85rem;
}
.stack-list > div { align-items: center; border-bottom: 1px solid #e9eef3; display: flex; justify-content: space-between; padding: .75rem 0; }
.stack-list > div.availability-management-row {
    align-items: center;
    display: grid;
    justify-content: stretch;
}
.stack-list > div:last-child { border-bottom: 0; }
.lineup-list { list-style: none; margin: 0 0 1rem; padding: 0; }
.lineup-list li { align-items: center; border-bottom: 1px solid #e9eef3; display: flex; justify-content: space-between; padding: .75rem 0; }
.lineup-list small { color: #627d98; }
.empty-state { padding: 2.5rem 1.25rem; text-align: center; }
.form-control, .form-select { min-height: 46px; }
.culture-select { min-height: 36px; min-width: 105px; }
.admin-nav { display: flex; gap: .5rem; overflow-x: auto; padding-bottom: .25rem; }
.admin-nav a { background: #fff; border: 1px solid #d8e2eb; border-radius: 999px; color: var(--tp-navy); padding: .55rem .85rem; text-decoration: none; white-space: nowrap; }
.admin-metric-grid { display: grid; gap: .75rem; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-metric { display: flex; flex-direction: column; padding: 1rem; }
.admin-metric strong { color: var(--tp-navy); font-size: 1.7rem; }
.admin-metric span, .compact-list small { color: #627d98; font-size: .82rem; }
.compact-list > div { border-bottom: 1px solid #e9eef3; display: flex; flex-direction: column; padding: .75rem 0; }
.compact-list > div:last-child { border-bottom: 0; }
.filter-grid { display: grid; gap: 1rem; grid-template-columns: 1fr; }
.admin-card-list { display: grid; gap: 1rem; grid-template-columns: 1fr; }
.admin-details { display: grid; gap: .35rem .75rem; grid-template-columns: minmax(110px, .7fr) 1.3fr; margin-bottom: 1rem; }
.admin-details dt { color: #627d98; font-weight: 600; }
.admin-details dd { margin: 0; overflow-wrap: anywhere; }

@media (min-width: 576px) {
    .page-heading { align-items: center; flex-direction: row; }
    .availability-actions { grid-template-columns: repeat(3, 1fr); }
    .availability-management-row {
        grid-template-columns: 1fr auto;
    }
    .availability-management-row > strong {
        justify-self: end;
    }
    .availability-admin-actions,
    .availability-admin-form {
        grid-column: 1 / -1;
    }
}

@media (min-width: 768px) {
    .app-card { padding: 1.5rem; }
    .card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .detail-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .admin-metric-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .filter-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .admin-card-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (min-width: 1200px) {
    .card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .admin-card-list { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.auth-language {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: .15rem;
    margin: -.5rem -.5rem .5rem 0;
}

.auth-language .btn {
    padding: .15rem .35rem;
    font-size: .8rem;
}

.compact-input {
    width: 7rem;
}

.membership-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
}

.club-logo-preview {
    max-width: 9rem;
    max-height: 5rem;
    object-fit: contain;
    border-radius: .5rem;
    background: #fff;
}

.club-identity-link {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
}

.club-identity-link img {
    width: 1.75rem;
    height: 1.75rem;
    object-fit: contain;
    border-radius: .25rem;
    background: #fff;
}

.club-overview-header {
    align-items: center;
    display: flex;
    gap: 1rem;
    min-width: 0;
}

.club-overview-header h1 {
    overflow-wrap: anywhere;
}

.club-overview-venue {
    color: #486581;
    font-size: .95rem;
}

.calendar-filter-grid {
    align-items: end;
    display: grid;
    gap: .85rem;
    grid-template-columns: 1fr;
}

.calendar-filter-check {
    align-self: center;
    padding-top: .75rem;
}

.calendar-filter-actions {
    display: flex;
}

.club-calendar-list {
    display: grid;
    gap: 1rem;
}

.club-calendar-card {
    display: grid;
    gap: .6rem;
}

.club-calendar-card-cancelled {
    opacity: .82;
}

.club-calendar-date {
    color: var(--tp-blue);
    display: flex;
    flex-wrap: wrap;
    font-weight: 800;
    gap: .35rem;
}

.club-calendar-main {
    min-width: 0;
}

.club-calendar-main h2,
.club-calendar-main p {
    overflow-wrap: anywhere;
}

.club-calendar-home-away {
    color: var(--tp-navy);
    font-size: .92rem;
    font-weight: 800;
    margin-bottom: .15rem;
}

.club-calendar-status {
    align-items: flex-end;
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
    gap: .35rem;
}

@media (min-width: 768px) {
    .calendar-filter-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .club-calendar-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .calendar-filter-grid {
        grid-template-columns: 1fr 1.4fr 1fr 1fr auto auto;
    }

    .club-calendar-list {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

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

    .match-card {
        overflow: hidden;
    }

    .match-card .metric-row {
        display: none;
    }

    .match-situation-opponent {
        font-size: 1.05rem;
    }

    .match-admin-badges span {
        font-size: .78rem;
    }

    .club-overview-header {
        align-items: flex-start;
    }

    .club-overview-header .club-logo-preview {
        max-width: 4.5rem;
        max-height: 3.5rem;
    }

    .club-calendar-status {
        align-items: flex-end;
        max-width: 45%;
    }

    .player-table table,
    .player-table thead,
    .player-table tbody,
    .player-table tr,
    .player-table th,
    .player-table td {
        display: block;
    }

    .player-table thead {
        display: none;
    }

    .player-table tr {
        padding: 1rem;
        border-bottom: 1px solid var(--bs-border-color);
    }

    .player-table td {
        border: 0;
        padding: .35rem 0;
    }
}
