/* ============================================================
   CoachEval — Sideline Core Design System
   v2.0.0 | WCAG 2.1 AA | 48px touch targets
   ============================================================ */

/* ── Design Tokens ─────────────────────────────────────────── */
:root {
    --ce-text:            #111827;
    --ce-text-secondary:  #374151;
    --ce-text-muted:      #6B7280;
    --ce-accent:          #1D4ED8;
    --ce-accent-light:    #eff6ff;
    --ce-accent-dark:     #1E3A8A;
    --ce-success:         #15803D;
    --ce-success-light:   #f0fdf4;
    --ce-danger:          #B91C1C;
    --ce-danger-light:    #fef2f2;
    --ce-warning:         #D97706;
    --ce-warning-light:   #fffbeb;
    --ce-border:          #D1D5DB;
    --ce-border-focus:    #1D4ED8;
    --ce-bg:              #FFFFFF;
    --ce-bg-alt:          #F9FAFB;
    --ce-bg-alt2:         #F3F4F6;
    --ce-touch-min:       48px;
    --ce-radius:          8px;
    --ce-shadow-sm:       0 1px 3px rgba(0,0,0,.10);
    --ce-shadow-md:       0 4px 12px rgba(0,0,0,.12);
    --ce-font:            -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    --ce-mono:            "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
}

/* ── Reset & Base ──────────────────────────────────────────── */
.ce-app,
.ce-gate,
.ce-onboard-wrap,
.ce-checkout-wrap {
    font-family:  var(--ce-font);
    color:        var(--ce-text);
    box-sizing:   border-box;
    line-height:  1.5;
}

.ce-app *,
.ce-gate *,
.ce-onboard-wrap *,
.ce-checkout-wrap * {
    box-sizing: border-box;
}

/* No-sidebar utility — add this class to the page body or wrapper via JS/PHP */
body.ce-no-sidebar .wp-sidebar,
body.ce-no-sidebar #secondary,
body.ce-no-sidebar .sidebar,
body.ce-no-sidebar .widget-area {
    display: none !important;
}

/* ── Typography ────────────────────────────────────────────── */
.ce-section-title   { font-size: 1.125rem; font-weight: 700; color: var(--ce-text); margin: 0 0 16px; }
.ce-screen-title    { font-size: 1.25rem;  font-weight: 700; color: var(--ce-text); margin: 0; }
.ce-program-title   { font-size: 1.25rem;  font-weight: 700; color: var(--ce-text); margin: 0; }
.ce-program-meta    { font-size: .875rem;  color: var(--ce-text-secondary); margin: 2px 0 0; }
.ce-field-hint      { font-size: .8125rem; color: var(--ce-text-muted); margin: 4px 0 0; }
.ce-checklist-header { font-size: .875rem; font-weight: 600; color: var(--ce-text-secondary); margin: 0 0 8px; }

/* ── Layout Containers ─────────────────────────────────────── */
.ce-app   { max-width: 1200px; margin: 0 auto; padding: 0 16px; }
.ce-screen { padding: 24px 0; }
.ce-screen-header {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    gap:             16px;
    margin-bottom:   24px;
    flex-wrap:       wrap;
}

/* ── Navigation Tabs ───────────────────────────────────────── */
.ce-nav {
    display:         flex;
    flex-direction:  row;
    gap:             4px;
    border-bottom:   2px solid var(--ce-border);
    padding-bottom:  0;
    margin-bottom:   24px;
    overflow-x:      auto;
    -webkit-overflow-scrolling: touch;
}

.ce-nav__item {
    display:         flex;
    align-items:     center;
    min-height:      var(--ce-touch-min);
    padding:         10px 20px;
    font-size:       .9375rem;
    font-weight:     500;
    color:           var(--ce-text-secondary);
    text-decoration: none;
    border-bottom:   3px solid transparent;
    margin-bottom:   -2px;
    white-space:     nowrap;
    transition:      color .15s, border-color .15s;
}
.ce-nav__item:hover            { color: var(--ce-accent); }
.ce-nav__item--active          {
    color:        var(--ce-accent);
    border-color: var(--ce-accent);
    font-weight:  700;
}
.ce-nav__item:focus-visible {
    outline: 3px dashed var(--ce-border-focus);
    outline-offset: 2px;
}

/* ── Buttons ───────────────────────────────────────────────── */
.ce-btn {
    display:          inline-flex;
    align-items:      center;
    justify-content:  center;
    gap:              6px;
    min-height:       var(--ce-touch-min);
    padding:          0 20px;
    font-family:      var(--ce-font);
    font-size:        .9375rem;
    font-weight:      600;
    border-radius:    var(--ce-radius);
    border:           2px solid transparent;
    cursor:           pointer;
    text-decoration:  none;
    transition:       background .15s, color .15s, border-color .15s, box-shadow .15s;
    white-space:      nowrap;
    user-select:      none;
}
.ce-btn:focus-visible {
    outline: 3px dashed var(--ce-border-focus);
    outline-offset: 2px;
}

.ce-btn--primary {
    background: var(--ce-accent);
    color:      #fff;
    border-color: var(--ce-accent);
}
.ce-btn--primary:hover { background: var(--ce-accent-dark); border-color: var(--ce-accent-dark); }

.ce-btn--secondary {
    background:   var(--ce-bg);
    color:        var(--ce-accent);
    border-color: var(--ce-accent);
}
.ce-btn--secondary:hover { background: var(--ce-accent-light); }

.ce-btn--ghost {
    background:   transparent;
    color:        var(--ce-text-secondary);
    border-color: var(--ce-border);
}
.ce-btn--ghost:hover { background: var(--ce-bg-alt2); color: var(--ce-text); }

.ce-btn--history {
    background:   transparent;
    color:        var(--ce-accent);
    border-color: transparent;
    font-size:    .875rem;
    padding:      0 8px;
}
.ce-btn--history:hover { text-decoration: underline; }

.ce-btn--full  { width: 100%; }
.ce-btn--cta   { font-size: 1.0625rem; padding: 0 32px; }
.ce-btn--sm    { min-height: 36px; padding: 0 12px; font-size: .8125rem; }

.ce-chevron { transition: transform .2s; display: inline-block; }
.ce-history-toggle[aria-expanded="true"] .ce-chevron { transform: rotate(180deg); }

/* ── Form Controls ─────────────────────────────────────────── */
.ce-input,
.ce-select {
    display:       block;
    width:         100%;
    min-height:    var(--ce-touch-min);
    padding:       10px 14px;
    font-family:   var(--ce-font);
    font-size:     1rem;
    color:         var(--ce-text);
    background:    var(--ce-bg);
    border:        2px solid var(--ce-border);
    border-radius: var(--ce-radius);
    transition:    border-color .15s, box-shadow .15s;
    appearance:    none;
    -webkit-appearance: none;
}
.ce-input:focus,
.ce-select:focus {
    outline:       none;
    border-color:  var(--ce-border-focus);
    box-shadow:    0 0 0 3px rgba(29,78,216,.2);
}
.ce-select { min-height: 52px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }

.ce-input--sm  { min-height: 38px; padding: 6px 10px; font-size: .875rem; }
.ce-select--sm { min-height: 38px; padding: 6px 28px 6px 10px; font-size: .875rem; }

.ce-label {
    display:     block;
    font-size:   .875rem;
    font-weight: 600;
    color:       var(--ce-text);
    margin-bottom: 6px;
}

.ce-field       { margin-bottom: 20px; }
.ce-field-row   { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .ce-field-row { grid-template-columns: 1fr; } }

.ce-input-unit-wrap {
    position: relative;
    display:  flex;
    gap:      8px;
    align-items: center;
}
.ce-input-unit-wrap .ce-input { flex: 1; }
.ce-unit-badge {
    background: var(--ce-bg-alt2);
    border:     2px solid var(--ce-border);
    border-radius: var(--ce-radius);
    padding:    0 12px;
    min-height: var(--ce-touch-min);
    display:    flex;
    align-items: center;
    font-size:  .875rem;
    font-weight: 600;
    color:      var(--ce-text-secondary);
    white-space: nowrap;
}

.ce-ob-label {
    font-size:   .9375rem;
    font-weight: 700;
    color:       var(--ce-text);
    margin-bottom: 12px;
    display: block;
}
.ce-ob-section { margin-bottom: 28px; }

/* ── Rating Buttons (1-5 Radio) ────────────────────────────── */
.ce-rating-row {
    display:  flex;
    gap:      8px;
    flex-wrap: wrap;
}
.ce-rating-option { display: contents; }
.ce-rating-option input { position: absolute; opacity: 0; width: 0; height: 0; }
.ce-rating-btn {
    display:       flex;
    align-items:   center;
    justify-content: center;
    width:         52px;
    height:        52px;
    border:        2px solid var(--ce-border);
    border-radius: var(--ce-radius);
    font-size:     1.125rem;
    font-weight:   700;
    color:         var(--ce-text-secondary);
    cursor:        pointer;
    transition:    background .12s, color .12s, border-color .12s;
    user-select:   none;
}
.ce-rating-option input:checked  + .ce-rating-btn {
    background:   var(--ce-accent);
    color:        #fff;
    border-color: var(--ce-accent);
}
.ce-rating-option input:focus-visible + .ce-rating-btn {
    outline: 3px dashed var(--ce-border-focus);
    outline-offset: 2px;
}
.ce-rating-btn:hover { border-color: var(--ce-accent); color: var(--ce-accent); }

/* ── Tap Blocks (Checkbox rows) ────────────────────────────── */
.ce-tap-block {
    display:        flex;
    align-items:    center;
    gap:            12px;
    min-height:     var(--ce-touch-min);
    padding:        10px 14px;
    border:         2px solid var(--ce-border);
    border-radius:  var(--ce-radius);
    margin-bottom:  8px;
    cursor:         pointer;
    transition:     background .12s, border-color .12s;
    user-select:    none;
}
.ce-tap-block:hover { border-color: var(--ce-accent); background: var(--ce-accent-light); }
.ce-tap-block__input { position: absolute; opacity: 0; width: 0; height: 0; }
.ce-tap-block__check {
    flex-shrink:   0;
    width:         24px;
    height:        24px;
    border:        2px solid var(--ce-border);
    border-radius: 5px;
    display:       flex;
    align-items:   center;
    justify-content: center;
    transition:    background .12s, border-color .12s;
}
.ce-tap-block__input:checked ~ .ce-tap-block__check {
    background:   var(--ce-success);
    border-color: var(--ce-success);
}
.ce-tap-block__input:checked ~ .ce-tap-block__check::after {
    content: '✓';
    color:   #fff;
    font-size: .875rem;
    font-weight: 700;
}
.ce-tap-block:has(.ce-tap-block__input:checked) {
    background:   var(--ce-success-light);
    border-color: var(--ce-success);
}
.ce-tap-block__text { font-size: .9375rem; color: var(--ce-text); }
.ce-tap-block:has(.ce-tap-block__input:checked) .ce-tap-block__text { font-weight: 700; }
.ce-tap-block__input:focus-visible ~ .ce-tap-block__check {
    outline: 3px dashed var(--ce-border-focus);
    outline-offset: 2px;
}

/* ── Sport Cards (Onboarding) ──────────────────────────────── */
.ce-sport-cards {
    display:               grid;
    grid-template-columns: repeat(3, 1fr);
    gap:                   16px;
}
@media (max-width: 600px) {
    .ce-sport-cards { grid-template-columns: 1fr; }
}

/* Radio input hidden inside each card label */
.ce-sport-card__radio {
    position: absolute;
    opacity:  0;
    width:    0;
    height:   0;
    pointer-events: none;
}

.ce-sport-card {
    display:         flex;
    flex-direction:  column;
    align-items:     center;
    justify-content: center;
    gap:             8px;
    min-height:      120px;
    padding:         16px 20px;
    background:      var(--ce-bg);
    border:          2px solid var(--ce-border);
    border-radius:   var(--ce-radius);
    cursor:          pointer;
    transition:      background .15s, border-color .15s, color .15s;
    font-family:     var(--ce-font);
    user-select:     none;
}
.ce-sport-card:hover {
    border-color: var(--ce-accent);
    background:   var(--ce-accent-light);
}
/* Checked state via :has() — all modern browsers */
.ce-sport-card:has(.ce-sport-card__radio:checked) {
    background:   var(--ce-accent-light);
    border:       3px solid var(--ce-accent);
    color:        var(--ce-accent-dark);
}
/* Fallback via JS-added class for older browsers */
.ce-sport-card--selected {
    background:   var(--ce-accent-light);
    border:       3px solid var(--ce-accent);
    color:        var(--ce-accent-dark);
}
.ce-sport-card:has(.ce-sport-card__radio:focus-visible) {
    outline:        3px dashed var(--ce-accent);
    outline-offset: 2px;
}
.ce-sport-icon { font-size: 2rem; line-height: 1; }
.ce-sport-name { font-size: .9375rem; font-weight: 700; color: inherit; text-align: center; }

/* ── Onboarding Card ───────────────────────────────────────── */
.ce-onboard-wrap { padding: 24px 0; }
.ce-onboard-card {
    max-width:     540px;
    margin:        0 auto;
    background:    var(--ce-bg);
    border:        1px solid var(--ce-border);
    border-radius: var(--ce-radius);
    padding:       32px;
    box-shadow:    var(--ce-shadow-sm);
}
.ce-progress-bar { margin-bottom: 28px; }
.ce-progress-label { font-size: .875rem; color: var(--ce-text-secondary); display: block; margin-bottom: 6px; }
.ce-progress-track { height: 6px; background: var(--ce-bg-alt2); border-radius: 3px; overflow: hidden; }
.ce-progress-fill  { height: 100%; background: var(--ce-accent); border-radius: 3px; transition: width .3s; }

/* ── Notice Banners ────────────────────────────────────────── */
.ce-notice {
    padding:       14px 18px;
    border-radius: var(--ce-radius);
    font-size:     .9375rem;
    margin-bottom: 20px;
    border-left:   4px solid;
}
.ce-notice--success { background: var(--ce-success-light); color: var(--ce-success); border-color: var(--ce-success); }
.ce-notice--error   { background: var(--ce-danger-light);  color: var(--ce-danger);  border-color: var(--ce-danger);  }
.ce-notice--warning { background: var(--ce-warning-light); color: var(--ce-warning); border-color: var(--ce-warning); }
.ce-notice--info    { background: var(--ce-accent-light);  color: var(--ce-accent);  border-color: var(--ce-accent);  }

/* ── Program Header ────────────────────────────────────────── */
.ce-program-header {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    padding:         20px 24px;
    background:      var(--ce-bg);
    border:          1px solid var(--ce-border);
    border-radius:   var(--ce-radius);
    margin-bottom:   24px;
    box-shadow:      var(--ce-shadow-sm);
    gap:             16px;
}
.ce-program-header__info { display: flex; align-items: center; gap: 16px; }
.ce-program-icon { font-size: 2rem; }
.ce-headcount-num   { display: block; font-size: 2rem; font-weight: 800; color: var(--ce-accent); line-height: 1; }
.ce-headcount-label { font-size: .75rem; color: var(--ce-text-secondary); text-transform: uppercase; letter-spacing: .04em; }

/* ── CSV Ingestion Portal ──────────────────────────────────── */
.ce-csv-portal {
    display:       flex;
    align-items:   center;
    gap:           12px;
    flex-wrap:     wrap;
    background:    var(--ce-bg-alt);
    border:        1px solid var(--ce-border);
    border-radius: var(--ce-radius);
    padding:       16px 20px;
    margin-bottom: 24px;
}
.ce-csv-portal__title { font-weight: 700; font-size: .9375rem; width: 100%; margin-bottom: 4px; }
.ce-csv-form   { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.ce-csv-filename { font-size: .875rem; color: var(--ce-text-secondary); }
.ce-csv-template-link { font-size: .875rem; color: var(--ce-accent); margin-left: auto; text-decoration: underline; }

/* ── Roster Table ──────────────────────────────────────────── */
.ce-roster-header {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    margin-bottom:   12px;
    flex-wrap:       wrap;
    gap:             12px;
}

.ce-roster-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

.ce-roster-table {
    width:           100%;
    border-collapse: collapse;
    font-size:       .9375rem;
}
.ce-roster-table th {
    text-align:       left;
    font-size:        .8125rem;
    font-weight:      700;
    text-transform:   uppercase;
    letter-spacing:   .04em;
    color:            var(--ce-text-secondary);
    border-bottom:    2px solid var(--ce-border);
    padding:          10px 16px;
    white-space:      nowrap;
    background:       var(--ce-bg-alt);
}
.ce-roster-table td { padding: 0 16px; vertical-align: middle; }

.ce-roster-row       { min-height: 64px; border-bottom: 1px solid var(--ce-border); }
.ce-roster-row:hover { background: var(--ce-bg-alt); }

/* Set row height via td min-height isn't direct — use first td line-height trick */
.ce-roster-row td:first-child { padding-top: 14px; padding-bottom: 14px; }

.ce-athlete-name    { font-weight: 700; color: var(--ce-text); }
.ce-athlete-meta    { font-size: .8125rem; color: var(--ce-text-secondary); margin-top: 2px; }
.ce-position-abbr   { font-weight: 700; font-size: 1.0625rem; color: var(--ce-accent); }
.ce-position-group  { font-size: .8125rem; color: var(--ce-text-secondary); }
.ce-score-capsule   { font-size: 1.125rem; font-weight: 800; color: var(--ce-text); }
.ce-score-denom     { font-size: .75rem; font-weight: 400; color: var(--ce-text-muted); }
.ce-tier-label      { font-size: .8125rem; font-weight: 600; color: var(--ce-success); }
.ce-readiness-label { font-size: .75rem; font-weight: 500; color: var(--ce-accent); margin-top: 2px; }
.ce-score-empty     { font-size: .875rem; color: var(--ce-text-muted); font-style: italic; }
.ce-row-actions     { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

/* ── History Drawer ────────────────────────────────────────── */
.ce-history-drawer { background: var(--ce-bg-alt); }
.ce-history-drawer > td { padding: 0; }

.ce-history-panel { padding: 20px 24px; }
.ce-history-title { font-weight: 700; font-size: .9375rem; color: var(--ce-text-secondary); margin-bottom: 14px; }
.ce-history-empty { color: var(--ce-text-muted); font-style: italic; }
.ce-history-entry { border: 1px solid var(--ce-border); border-radius: var(--ce-radius); padding: 14px 16px; margin-bottom: 10px; background: var(--ce-bg); }
.ce-history-entry__header { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 6px; }
.ce-history-date  { font-weight: 700; color: var(--ce-text); }
.ce-history-score { font-weight: 800; font-size: 1.0625rem; color: var(--ce-accent); margin-left: auto; }
.ce-history-meta  { font-size: .8125rem; color: var(--ce-text-secondary); }

/* ── Evaluation Form ───────────────────────────────────────── */
.ce-eval-header {
    position:      sticky;
    top:           0;
    z-index:       10;
    background:    var(--ce-text);
    color:         #fff;
    display:       flex;
    align-items:   center;
    justify-content: space-between;
    padding:       14px 24px;
    border-radius: var(--ce-radius);
    margin-bottom: 24px;
    gap:           16px;
    flex-wrap:     wrap;
}
.ce-eval-header__athlete { display: flex; flex-direction: column; gap: 2px; }
.ce-eval-name  { font-size: 1.125rem; font-weight: 800; color: #fff; }
.ce-eval-pos   { font-size: .875rem;  color: rgba(255,255,255,.75); }
.ce-eval-progress { font-size: .9375rem; color: rgba(255,255,255,.9); white-space: nowrap; }
.ce-eval-progress strong { color: #fff; font-size: 1.125rem; }

.ce-eval-grid {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   24px;
}
@media (max-width: 840px) { .ce-eval-grid { grid-template-columns: 1fr; } }

.ce-eval-section {
    background:    var(--ce-bg);
    border:        1px solid var(--ce-border);
    border-radius: var(--ce-radius);
    padding:       24px;
    margin-bottom: 24px;
}
.ce-eval-section-title {
    font-size:    1.0625rem;
    font-weight:  800;
    margin:       0 0 20px;
    color:        var(--ce-text);
    display:      flex;
    align-items:  center;
    gap:          10px;
}
.ce-section-num {
    background:    var(--ce-accent);
    color:         #fff;
    border-radius: 50%;
    width:         28px;
    height:        28px;
    display:       inline-flex;
    align-items:   center;
    justify-content: center;
    font-size:     .875rem;
    font-weight:   800;
    flex-shrink:   0;
}
.ce-eval-section-hint { font-size: .875rem; color: var(--ce-text-secondary); margin-bottom: 16px; }

.ce-eval-submit {
    display:         flex;
    align-items:     center;
    gap:             16px;
    flex-wrap:       wrap;
    padding:         24px 0;
}

/* ── Athlete Form ──────────────────────────────────────────── */
.ce-form-grid {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   16px 24px;
}
@media (max-width: 600px) { .ce-form-grid { grid-template-columns: 1fr; } }
.ce-form-actions {
    display:     flex;
    gap:         12px;
    flex-wrap:   wrap;
    margin-top:  28px;
    padding-top: 20px;
    border-top:  2px solid var(--ce-border);
}

/* ── Depth Chart ───────────────────────────────────────────── */
.ce-depth-group { margin-bottom: 32px; }
.ce-depth-group__title { font-size: 1.0625rem; font-weight: 700; margin: 0 0 12px; color: var(--ce-text-secondary); }

.ce-depth-table { width: 100%; border-collapse: collapse; }
.ce-depth-table th {
    text-align:   left;
    font-size:    .8125rem;
    font-weight:  700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color:        var(--ce-text-secondary);
    border-bottom: 2px solid var(--ce-border);
    padding:      10px 16px;
    background:   var(--ce-bg-alt);
}
.ce-depth-table td { padding: 14px 16px; border-bottom: 1px solid var(--ce-border); vertical-align: middle; }
.ce-depth-row:hover { background: var(--ce-bg-alt); }

.ce-string-label {
    display:       inline-block;
    padding:       3px 10px;
    border-radius: 20px;
    font-size:     .8125rem;
    font-weight:   700;
}
.ce-string-label--1 { background: #fef9c3; color: #92400e; }
.ce-string-label--2 { background: var(--ce-bg-alt2); color: var(--ce-text-secondary); }
.ce-string-label--3 { background: var(--ce-bg-alt2); color: var(--ce-text-muted); }
.ce-string-label--4 { background: var(--ce-bg-alt); color: var(--ce-text-muted); }

.ce-depth-jersey { font-size: .8125rem; color: var(--ce-text-secondary); margin-left: 8px; }
.ce-depth-score  { font-weight: 700; color: var(--ce-accent); }
.ce-depth-controls { display: flex; gap: 8px; }

.ce-depth-unassigned {
    background:    var(--ce-bg-alt);
    border:        1px solid var(--ce-border);
    border-radius: var(--ce-radius);
    padding:       16px 20px;
    margin-bottom: 24px;
}
.ce-depth-unassigned__title { font-weight: 700; margin-bottom: 12px; color: var(--ce-text-secondary); }
.ce-depth-unassigned__list  { display: flex; flex-direction: column; gap: 10px; }
.ce-depth-assign-form { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.ce-athlete-chip {
    padding:       4px 10px;
    background:    var(--ce-accent-light);
    color:         var(--ce-accent-dark);
    border-radius: 20px;
    font-size:     .875rem;
    font-weight:   600;
}

/* ── Empty State ───────────────────────────────────────────── */
.ce-empty-state {
    text-align:  center;
    padding:     48px 24px;
    color:       var(--ce-text-secondary);
    border:      2px dashed var(--ce-border);
    border-radius: var(--ce-radius);
}
.ce-empty-state p { font-size: 1rem; margin-bottom: 20px; }

/* ── Admin Preview Banner ──────────────────────────────────── */
.ce-admin-preview-bar {
    background:    #1e3a8a;
    color:         #fff;
    font-size:     .875rem;
    font-weight:   600;
    text-align:    center;
    padding:       10px 20px;
    border-radius: var(--ce-radius);
    margin-bottom: 16px;
    letter-spacing: .01em;
}

/* ── Gate / Checkout Cards ─────────────────────────────────── */
.ce-gate {
    display:         flex;
    align-items:     center;
    justify-content: center;
    min-height:      400px;
    padding:         40px 16px;
}
.ce-gate-card {
    max-width:     420px;
    width:         100%;
    background:    var(--ce-bg);
    border:        1px solid var(--ce-border);
    border-radius: var(--ce-radius);
    padding:       40px 32px;
    text-align:    center;
    box-shadow:    var(--ce-shadow-md);
}
.ce-gate-card h2 { font-size: 1.375rem; margin: 0 0 12px; }
.ce-gate-card p  { color: var(--ce-text-secondary); margin: 0 0 24px; }

.ce-checkout-wrap {
    display:         flex;
    align-items:     center;
    justify-content: center;
    padding:         24px;
}
.ce-checkout-card {
    max-width:     460px;
    width:         100%;
    background:    var(--ce-bg);
    border:        1px solid var(--ce-border);
    border-radius: var(--ce-radius);
    padding:       32px;
    text-align:    center;
    box-shadow:    var(--ce-shadow-md);
}
.ce-checkout-desc { color: var(--ce-text-secondary); margin-bottom: 24px; }

/* Checkout pre-form */
.ce-checkout-card--form { max-width: 520px; text-align: left; }
.ce-checkout-heading { font-size: 1.375rem; font-weight: 800; margin: 0 0 8px; }
.ce-signup-form { margin-top: 24px; }
.ce-signup-row {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   14px;
    margin-bottom:         14px;
}
@media (max-width: 480px) { .ce-signup-row { grid-template-columns: 1fr; } }
.ce-signup-field { margin-bottom: 14px; }
.ce-signup-field:last-child { margin-bottom: 20px; }
.ce-checkout-legal {
    font-size:   .8125rem;
    color:       var(--ce-text-muted);
    text-align:  center;
    margin-top:  16px;
    line-height: 1.5;
}

/* Steps indicator */
.ce-steps {
    display:         flex;
    align-items:     center;
    gap:             12px;
    margin-bottom:   24px;
    padding-bottom:  20px;
    border-bottom:   1px solid var(--ce-border);
}
.ce-step {
    display:     flex;
    align-items: center;
    gap:         8px;
    font-size:   .9375rem;
    color:       var(--ce-text-muted);
    font-weight: 500;
}
.ce-step--active { color: var(--ce-accent); font-weight: 700; }
.ce-step--done   { color: var(--ce-success); font-weight: 600; }
.ce-step-num {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    width:           26px;
    height:          26px;
    border-radius:   50%;
    background:      var(--ce-bg-alt2);
    font-size:       .8125rem;
    font-weight:     800;
    color:           var(--ce-text-muted);
}
.ce-step--active .ce-step-num { background: var(--ce-accent);   color: #fff; }
.ce-step--done   .ce-step-num { background: var(--ce-success);  color: #fff; }
.ce-step-divider { color: var(--ce-border); font-size: 1.125rem; }

/* Checkout success message */
.ce-checkout-success-msg {
    background:    var(--ce-success-light);
    color:         var(--ce-success);
    border:        1px solid var(--ce-success);
    border-radius: var(--ce-radius);
    padding:       14px 18px;
    font-weight:   600;
    font-size:     .9375rem;
    margin-bottom: 20px;
}
.ce-checkout-account-row {
    display:      flex;
    align-items:  center;
    gap:          8px;
    padding:      12px 16px;
    background:   var(--ce-bg-alt);
    border-radius: var(--ce-radius);
    margin-bottom: 20px;
    font-size:    .9375rem;
}
.ce-checkout-account-label { color: var(--ce-text-secondary); }
.ce-checkout-pending {
    background:    var(--ce-accent-light);
    color:         var(--ce-accent-dark);
    border-radius: var(--ce-radius);
    padding:       14px 18px;
    font-size:     .9375rem;
    line-height:   1.6;
    margin-top:    8px;
}

/* ── Clipboard Grid ────────────────────────────────────────── */
.ce-clipboard-grid {
    display:               grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap:                   20px;
    margin-top:            24px;
}
.ce-clipboard-card {
    background:    var(--ce-bg);
    border:        1px solid var(--ce-border);
    border-radius: var(--ce-radius);
    padding:       24px;
    box-shadow:    var(--ce-shadow-sm);
}
.ce-clipboard-card h3 { font-size: 1.0625rem; margin: 0 0 8px; }
.ce-clipboard-card p  { font-size: .9375rem; color: var(--ce-text-secondary); margin: 0 0 16px; }

/* ── Print Styles (Player Report Card) ─────────────────────── */
@media print {
    @page { size: letter portrait; margin: 0.75in; }

    body { background: #fff !important; }

    .ce-nav,
    .ce-program-header,
    .ce-csv-portal,
    .ce-roster-header,
    .ce-btn,
    .ce-history-toggle,
    .ce-row-actions { display: none !important; }

    .ce-shield { page-break-inside: avoid; }

    .ce-shield-header,
    .ce-shield-body    { break-inside: avoid; }

    * { color: #000 !important; background: #fff !important; box-shadow: none !important; }

    .ce-shield-badge { border: 2px solid #000 !important; }
    .ce-shield-score-value { font-size: 48pt !important; }
}

/* ── Player Report Card (screen) ───────────────────────────── */
.ce-shield {
    max-width:     780px;
    margin:        0 auto;
    font-family:   var(--ce-font);
    padding:       24px;
}
.ce-shield-header {
    display:   flex;
    gap:       24px;
    flex-wrap: wrap;
    border-bottom: 3px solid var(--ce-text);
    padding-bottom: 20px;
    margin-bottom: 24px;
    align-items: flex-start;
}
.ce-shield-logo { font-size: 1.5rem; font-weight: 900; letter-spacing: -.02em; }
.ce-shield-meta { flex: 1; }
.ce-shield-name { font-size: 1.5rem; font-weight: 800; margin: 0 0 4px; }
.ce-shield-details { font-size: .875rem; color: var(--ce-text-secondary); }

.ce-shield-badge {
    text-align:    center;
    background:    var(--ce-text);
    color:         #fff;
    border-radius: var(--ce-radius);
    padding:       20px 28px;
    min-width:     180px;
}
.ce-shield-score-value { font-size: 3.5rem; font-weight: 900; line-height: 1; color: #fff; display: block; }
.ce-shield-score-denom { font-size: .875rem; color: rgba(255,255,255,.7); }
.ce-shield-tier        { font-size: .875rem; font-weight: 700; margin-top: 6px; color: #fff; }

.ce-shield-body {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   20px;
}
@media (max-width: 600px) { .ce-shield-body { grid-template-columns: 1fr; } }

.ce-shield-quadrant {
    border:        1px solid var(--ce-border);
    border-radius: var(--ce-radius);
    padding:       20px;
}
.ce-shield-quadrant-title { font-size: .875rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--ce-text-secondary); margin-bottom: 14px; }

.ce-shield-notes {
    margin-top:    20px;
    border:        2px solid var(--ce-accent);
    border-radius: var(--ce-radius);
    padding:       20px;
}
.ce-shield-notes-title { font-weight: 700; color: var(--ce-accent); margin-bottom: 10px; }

.ce-print-btn {
    margin-top:  20px;
    text-align:  right;
}

/* Stat row inside report card */
.ce-shield-stat { display: flex; justify-content: space-between; align-items: center; padding: 6px 0; border-bottom: 1px solid var(--ce-bg-alt2); font-size: .9375rem; }
.ce-shield-stat:last-child { border-bottom: none; }
.ce-shield-stat-label { color: var(--ce-text-secondary); }
.ce-shield-stat-value { font-weight: 700; color: var(--ce-text); }

/* ── Bench Press Card ─────────────────────────────────────── */
.ce-bench-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-top: 8px;
}
.ce-bench-col { display: flex; flex-direction: column; }

/* ── Responsive Utility ────────────────────────────────────── */
@media (max-width: 480px) {
    .ce-onboard-card { padding: 24px 16px; }
    .ce-bench-grid   { grid-template-columns: 1fr; }
}
