.attendance-modal {
    position: fixed; inset: 0; z-index: var(--z-modal);
    display: none;
    background: rgba(12, 33, 63, 0.55);
    backdrop-filter: blur(6px);
    padding: var(--space-5);
    overflow: hidden;
    animation: scrim-in var(--t-base) var(--e-standard);
}
.attendance-modal:not(.hidden) { display: grid; place-items: center; }

.attendance-container {
    width: 100%;
    max-width: var(--container-full);
    max-height: calc(100vh - 2 * var(--space-5));
    background: var(--cream-lightest);
    border-radius: var(--radius-l);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 40px 100px -40px rgba(12, 33, 63, 0.6);
    animation: sheet-in var(--t-enter) var(--e-emphasis);
}

.attendance-hero {
    background: var(--navy);
    color: var(--text-inverse);
    flex-shrink: 0;
}
.attendance-hero-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--space-5);
    align-items: start;
    padding: var(--space-6) var(--space-6) var(--space-5);
}

.attendance-hero-lede { display: grid; gap: 0.55rem; max-width: 40rem; }
.attendance-hero-lede .eyebrow {
    color: var(--highlighter);
    font-family: var(--font-ui);
    font-size: var(--fs-caption);
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    line-height: 1;
}
.attendance-hero-title {
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 4vw + 1rem, 4.25rem);
    letter-spacing: -0.032em;
    line-height: 0.92;
    color: var(--text-inverse);
    margin: 0;
}
.attendance-hero-title .hl-dot {
    display: inline-block;
    color: var(--highlighter);
    padding-left: 0.04em;
}
.attendance-hero-meta {
    margin: 0;
    font-family: var(--font-ui);
    font-size: var(--fs-small);
    color: rgba(255, 249, 241, 0.7);
    letter-spacing: 0.01em;
}
.attendance-hero-meta-key {
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-size: 0.7rem;
    color: rgba(255, 249, 241, 0.5);
    margin-right: 0.55rem;
}
.attendance-hero-meta-val { color: var(--text-inverse); font-weight: 700; font-variant-numeric: tabular-nums; }

.attendance-hero-actions { display: flex; align-items: center; gap: 0.6rem; }

.attendance-refresh-btn {
    appearance: none;
    display: inline-flex; align-items: center; gap: 0.45rem;
    padding: 0.6rem 1.1rem;
    background: var(--highlighter);
    color: var(--ink);
    border: var(--border-w) solid var(--highlighter);
    border-radius: var(--radius-pill);
    font-family: var(--font-ui); font-size: var(--fs-small); font-weight: 700;
    cursor: pointer;
    transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
}
.attendance-refresh-btn:hover { background: var(--cream-lightest); border-color: var(--text-inverse); color: var(--accent-text); transform: translateY(-1px); }
.attendance-refresh-btn svg { width: 0.95rem; height: 0.95rem; }
.attendance-refresh-btn.loading svg { animation: spin 0.85s linear infinite; }

.attendance-close {
    appearance: none;
    width: 2.35rem; height: 2.35rem;
    display: grid; place-items: center;
    background: transparent;
    border: var(--border-w) solid rgba(255, 249, 241, 0.25);
    border-radius: 50%;
    color: var(--text-inverse);
    cursor: pointer;
    transition: background var(--t-fast), border-color var(--t-fast);
}
.attendance-close:hover { background: rgba(255, 249, 241, 0.12); border-color: var(--text-inverse); }
.attendance-close svg { width: 0.95rem; height: 0.95rem; }

.attendance-hero-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 0;
    padding: 0;
    border-top: var(--border-w) solid rgba(255, 249, 241, 0.12);
}
.attendance-hero-stats .attendance-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    padding: var(--space-5) var(--space-6) var(--space-5);
    background: transparent;
    border: 0;
    border-right: var(--border-w) solid rgba(255, 249, 241, 0.12);
    border-radius: 0;
    min-height: 0;
    overflow: hidden;
}
.attendance-hero-stats .attendance-card::before,
.attendance-hero-stats .attendance-card::after { display: none; }
.attendance-hero-stats .attendance-card:last-child { border-right: 0; }

.attendance-hero-stats .card-label {
    font-family: var(--font-ui);
    font-size: var(--fs-caption);
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--highlighter);
    line-height: 1;
    order: 1;
}
.attendance-hero-stats .card-value {
    font-family: var(--font-display);
    font-size: clamp(2.75rem, 4vw + 1rem, 4rem);
    letter-spacing: -0.035em;
    line-height: 0.9;
    color: var(--text-inverse);
    font-variant-numeric: tabular-nums;
    order: 2;
}
.attendance-hero-stats .card-sub {
    font-family: var(--font-ui);
    font-size: var(--fs-small);
    color: rgba(255, 249, 241, 0.6);
    line-height: 1.45;
    order: 3;
}
.attendance-hero-stats .card-sub strong {
    color: var(--text-inverse);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

@media (max-width: 780px) {
    .attendance-hero-stats { grid-template-columns: 1fr; }
    .attendance-hero-stats .attendance-card {
        border-right: 0;
        border-bottom: var(--border-w) solid rgba(255, 249, 241, 0.12);
    }
    .attendance-hero-stats .attendance-card:last-child { border-bottom: 0; }
}

.attendance-nav {
    display: flex;
    gap: 0;
    padding: 0 var(--space-6);
    background: var(--cream-lightest);
    border-bottom: var(--border-w) solid var(--border-hairline);
    flex-shrink: 0;
}
.attendance-tab {
    appearance: none;
    background: transparent;
    border: 0;
    padding: var(--space-4) 0;
    margin-right: var(--space-6);
    display: inline-flex;
    align-items: baseline;
    gap: 0.65rem;
    color: var(--text-muted);
    cursor: pointer;
    position: relative;
    transition: color var(--t-fast);
}
.attendance-tab:hover { color: var(--text-primary); }
.attendance-tab .tab-num {
    font-family: var(--font-display);
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--text-muted);
    letter-spacing: 0;
    line-height: 1;
    transition: color var(--t-fast);
}
.attendance-tab .tab-label {
    font-family: var(--font-ui);
    font-size: var(--fs-body);
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: 0.005em;
}
.attendance-tab::after {
    content: "";
    position: absolute;
    left: 0; right: 0; bottom: -1px;
    height: 2px;
    background: var(--highlighter);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform var(--t-base) var(--e-emphasis);
}
.attendance-tab.active { color: var(--text-primary); }
.attendance-tab.active .tab-num { color: var(--accent-text); }
.attendance-tab.active::after { transform: scaleX(1); }

.attendance-filters {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4) var(--space-5);
    align-items: center;
    padding: var(--space-4) var(--space-6);
    background: var(--cream-lightest);
    border-bottom: var(--border-w) solid var(--border-subtle);
    flex-shrink: 0;
}
.attendance-filters .attendance-filter-group {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    min-width: 12rem;
}
.attendance-filters .attendance-filter-group label {
    font-family: var(--font-ui);
    font-size: var(--fs-caption);
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--text-muted);
    white-space: nowrap;
    margin: 0;
    flex-shrink: 0;
}
.attendance-filters .branded-select { flex: 1; min-width: 0; }

.attendance-tab-content {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding: var(--space-5) var(--space-6) var(--space-6);
    background: var(--cream-lightest);
}

.attendance-loading {
    display: grid; place-items: center; gap: 0.85rem;
    padding: var(--space-9) var(--space-5);
    color: var(--text-muted);
    font-family: var(--font-ui);
    font-size: var(--fs-small);
}

.attendance-meter-toolbar {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.85rem 1.1rem;
    padding: 0 0 var(--space-4);
    margin: 0;
    font-family: var(--font-ui);
}
.meter-toolbar-label {
    font-size: var(--fs-caption);
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--text-muted);
    line-height: 1;
    margin: 0;
}
.meter-toolbar-select {
    appearance: none;
    -webkit-appearance: none;
    padding: 0.5rem 2.25rem 0.5rem 0.9rem;
    background-color: transparent;
    border: 0;
    border-bottom: 1.5px solid var(--navy);
    border-radius: 0;
    color: var(--accent-text);
    font-family: var(--font-display);
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: -0.005em;
    cursor: pointer;
    line-height: 1;
    background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20width%3D%2712%27%20height%3D%278%27%20viewBox%3D%270%200%2012%208%27%3E%3Cpath%20d%3D%27M1%201l5%205%205-5%27%20stroke%3D%27%230c3166%27%20stroke-width%3D%271.75%27%20fill%3D%27none%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27%2F%3E%3C%2Fsvg%3E");
    background-repeat: no-repeat;
    background-position: right 0.45rem center;
    background-size: 0.7rem auto;
    transition: border-color var(--t-fast), color var(--t-fast);
}
.meter-toolbar-select:hover,
.meter-toolbar-select:focus { outline: 0; border-bottom-color: var(--ink); color: var(--ink); }
.meter-toolbar-meta {
    font-size: var(--fs-small);
    color: var(--text-muted);
    letter-spacing: 0.005em;
    margin-left: auto;
}
.meter-toolbar-meta strong {
    font-family: var(--font-ui);
    color: var(--text-primary);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.attendance-meters {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 0 0 var(--space-5);
    background: var(--cream-lightest);
    border-top: 1px solid var(--navy);
    border-bottom: 1px solid var(--navy);
}
.meter-stat {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: var(--space-5) var(--space-5) var(--space-5);
    border-right: var(--border-w) solid var(--border-subtle);
    min-width: 0;
}
.meter-stat:last-child { border-right: 0; }

.meter-eyebrow {
    font-family: var(--font-ui);
    font-size: var(--fs-caption);
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--text-muted);
    line-height: 1;
}
.meter-stat[data-tone="brand"] .meter-eyebrow { color: var(--brand-blue); }
.meter-stat[data-tone="accent"] .meter-eyebrow { color: var(--accent-text); }

.meter-value {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 3vw + 1.25rem, 3.5rem);
    letter-spacing: -0.035em;
    line-height: 0.9;
    color: var(--text-primary);
    font-variant-numeric: tabular-nums;
}
.meter-value-pct {
    font-size: 0.9rem;
    font-family: var(--font-ui);
    font-weight: 700;
    letter-spacing: 0.01em;
    color: var(--text-muted);
}
.meter-stat[data-tone="accent"] .meter-value { color: var(--accent-text); }

.meter-sub {
    font-family: var(--font-ui);
    font-size: var(--fs-small);
    color: var(--text-muted);
    line-height: 1.45;
    letter-spacing: 0.005em;
    margin-top: auto;
    padding-top: 0.15rem;
}
.meter-sub strong {
    color: var(--text-primary);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

@media (max-width: 780px) {
    .attendance-meters { grid-template-columns: 1fr; }
    .meter-stat {
        border-right: 0;
        border-bottom: var(--border-w) solid var(--border-subtle);
    }
    .meter-stat:last-child { border-bottom: 0; }
    .meter-toolbar-meta { margin-left: 0; width: 100%; }
}

.attendance-tab-content > div[style*="display:flex"] {
    display: flex !important;
    flex-wrap: wrap;
    gap: 0.55rem !important;
    margin: 0 0 var(--space-3) !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
}

.attendance-table {
    width: 100%;
    border-collapse: collapse;
    background: transparent;
    border: 0;
    font-variant-numeric: tabular-nums;
    margin-top: var(--space-3);
}
.attendance-table thead th {
    padding: 0.75rem 1rem;
    text-align: left;
    background: var(--cream-lightest);
    color: var(--accent-text);
    font-family: var(--font-ui);
    font-size: var(--fs-caption);
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
    border: 0;
    border-bottom: 2px solid var(--navy);
    position: sticky;
    top: 0;
    z-index: 2;
}
.attendance-table thead th:hover { color: var(--text-primary); }
.attendance-table thead th.sort-asc::after,
.attendance-table thead th.sort-desc::after {
    content: "";
    display: inline-block;
    width: 0; height: 0; margin-left: 0.45rem;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    vertical-align: middle;
}
.attendance-table thead th.sort-asc::after  { border-bottom: 5px solid var(--highlighter); }
.attendance-table thead th.sort-desc::after { border-top: 5px solid var(--highlighter); }

.attendance-table tbody td {
    padding: 0.85rem 1rem;
    border-bottom: var(--border-w) solid var(--border-subtle);
    font-family: var(--font-ui);
    font-size: 0.9rem;
    color: var(--text-body);
    vertical-align: middle;
    line-height: 1.35;
}
.attendance-table tbody tr:last-child td { border-bottom: 0; }
.attendance-table tbody tr { transition: background var(--t-fast); }
.attendance-table tbody tr:hover td { background: var(--warm-grey); }

.attendance-table tbody tr > td:first-child {
    font-family: var(--font-display);
    font-size: 0.95rem;
    letter-spacing: -0.005em;
    color: var(--text-primary);
    font-weight: 700;
    line-height: 1.25;
}

.attendance-table tbody tr > td:nth-child(2):not(.num),
.attendance-table tbody td[data-role="code"] {
    font-family: var(--font-mono);
    font-size: 0.76rem;
    font-weight: 700;
    color: var(--accent-text);
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.attendance-table tbody tr > td:nth-child(3) {
    font-family: var(--font-ui);
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-size: 0.72rem;
    color: var(--accent-text);
}

.attendance-table td.num,
.attendance-table td[style*="text-align:right"],
.attendance-table td[style*="text-align: right"] {
    text-align: right !important;
    font-weight: 700;
    font-family: var(--font-ui);
    font-variant-numeric: tabular-nums;
    color: var(--text-primary);
}
.attendance-table td.num.pos,
.attendance-table td[style*="#2ecc71"],
.attendance-table td[style*="#22c55e"] { color: var(--accent-text) !important; font-weight: 800; }
.attendance-table td.num.neg,
.attendance-table td[style*="#ff6b6b"],
.attendance-table td[style*="#ef4444"] { color: var(--ink) !important; font-weight: 800; }
.attendance-table td[style*="#ffaa00"],
.attendance-table td[style*="#f59e0b"] { color: var(--brand-blue) !important; font-weight: 700; }
.attendance-table td[style*="rgba(255,255,255"] { color: var(--dark-grey) !important; }
.attendance-table td span[style*="rgba(255,255,255"] { color: var(--dark-grey) !important; }
.attendance-table td[style*="color:#fff"] { color: var(--text-primary) !important; }
.attendance-table td.muted { color: var(--dark-grey); }

.attendance-table tr.pips-history-row td,
.pips-history-row td {
    padding: 0.55rem 1rem !important;
    background: var(--warm-grey) !important;
    font-family: var(--font-mono) !important;
    font-size: 0.72rem !important;
    color: var(--text-muted) !important;
    border-top: var(--border-w) solid var(--border-subtle) !important;
    border-bottom: var(--border-w) solid var(--border-subtle) !important;
}
.pips-history-badge {
    display: inline-block;
    padding: 0.1rem 0.45rem;
    background: var(--navy);
    color: var(--text-inverse);
    border-radius: var(--radius-xs);
    font-family: var(--font-ui);
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin-right: 0.45rem;
}

.attendance-empty,
.attendance-tab-content .no-data {
    display: grid; gap: 0.35rem; justify-items: center;
    padding: var(--space-9) var(--space-5);
    text-align: center;
    color: var(--text-muted);
    font-family: var(--font-ui);
    font-size: var(--fs-small);
}

@media (max-width: 860px) {
    .attendance-hero-main { grid-template-columns: 1fr; }
    .attendance-hero-actions { justify-self: start; }
    .attendance-nav { overflow-x: auto; -webkit-overflow-scrolling: touch; }
}
