/* ================================================================
   THE AUGUR — Unified Stylesheet
   Halitherses · SCAF v1.4
   ================================================================ */

/* --- Reduced motion --- */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* --- Variables --- */
:root {
    --bg: #FFFFFF;
    --text: #0A0A0A;
    --text-secondary: #6B6B6B;
    --border: #E2E2E2;
    --card-bg: #F9F9F9;
    --accent: #8B0000;
    --watch: #C8A951;
    --elevated: #8B4000;
    --pending: #9B9B9B;
    --font-serif: Georgia, 'Times New Roman', serif;
    --font-sans: system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    --font-mono: monospace;
}

/* --- Reset --- */
* { margin: 0; padding: 0; box-sizing: border-box; }
body {
    font-family: var(--font-sans);
    background: var(--bg);
    color: var(--text);
    line-height: 1.5;
    font-size: 14px;
}
a { color: var(--text); text-decoration: none; }

/* ================================================================
   PUBLIC SITE
   ================================================================ */

/* --- Public nav --- */
.pub-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 2rem;
    border-bottom: 1px solid var(--border);
}
.pub-wordmark {
    font-family: var(--font-serif);
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    color: var(--accent);
    text-transform: uppercase;
}
.pub-links {
    display: flex;
    gap: 2rem;
}
.pub-links a {
    font-family: var(--font-sans);
    font-size: 0.8rem;
    color: var(--text-secondary);
}
.pub-links a:hover { color: var(--text); }

/* --- Public page content --- */
.pub-content {
    max-width: 540px;
    margin: 0 auto;
    padding: 6rem 2rem;
}
.pub-content.centered { text-align: center; }
.pub-content h1 {
    font-family: var(--font-serif);
    font-size: 1.8rem;
    font-weight: 400;
    letter-spacing: 0.04em;
    margin-bottom: 1.5rem;
}
.pub-content p {
    color: var(--text-secondary);
    font-size: 0.95rem;
    line-height: 1.7;
    margin-bottom: 1rem;
}
.pub-content .contact-email {
    margin-top: 2rem;
    font-size: 0.9rem;
}
.pub-content .contact-email a {
    color: var(--text);
}
.pub-content .contact-email a:hover { text-decoration: underline; }

/* ================================================================
   AUTHENTICATED — HEADER
   ================================================================ */
.header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 2rem;
    height: 52px;
    border-bottom: 1px solid var(--border);
    background: var(--bg);
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
}
.wordmark {
    font-family: var(--font-serif);
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    color: var(--accent);
    text-transform: uppercase;
    white-space: nowrap;
}
.header-clock {
    font-family: var(--font-mono);
    font-size: 0.75rem;
    color: var(--text-secondary);
    white-space: nowrap;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}
.header-right {
    display: flex;
    align-items: center;
    gap: 1rem;
    white-space: nowrap;
}
.institution-code {
    font-family: var(--font-mono);
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    color: var(--text-secondary);
    text-transform: uppercase;
}
.header-sep {
    width: 1px;
    height: 16px;
    background: var(--border);
}
.logout-link {
    font-family: var(--font-mono);
    font-size: 0.7rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.logout-link:hover { color: var(--text); }

/* ================================================================
   CONTENT WRAPPER
   ================================================================ */
.content {
    max-width: 1200px;
    margin: 0 auto;
    padding: 2.5rem 2rem;
    padding-top: calc(52px + 2.5rem);
}

/* ================================================================
   CLASSIFICATION STATE TREATMENTS
   ================================================================ */
.state-baseline { font-weight: 400; color: var(--text); }
.state-watch { font-weight: 500; color: var(--watch); }
.state-elevated { font-weight: 600; color: var(--elevated); }
.state-dislocation { font-weight: 700; color: var(--accent); }
.state-pending { font-weight: 400; font-style: italic; color: var(--pending); }

/* Border treatments — on elements */
.border-watch { border-left: 3px solid var(--watch); }
.border-elevated { border-left: 3px solid var(--elevated); }
.border-dislocation { border-left: 3px solid var(--accent); }

/* Border treatments — on table rows (applied to first td) */
tr.border-watch > td:first-child { border-left: 3px solid var(--watch); padding-left: 0.75rem; }
tr.border-elevated > td:first-child { border-left: 3px solid var(--elevated); padding-left: 0.75rem; }
tr.border-dislocation > td:first-child { border-left: 3px solid var(--accent); padding-left: 0.75rem; }

/* Row-level state treatments are defined with .asset-class-cell pill rules below */

/* Pulse — only Watch and above */
@keyframes borderPulse {
    0%, 100% { border-left-color: inherit; }
    50% { border-left-color: transparent; }
}
.pulse-watch { animation: borderPulse 2s ease-in-out infinite; border-left-color: var(--watch); }
.pulse-elevated { animation: borderPulse 2s ease-in-out infinite; border-left-color: var(--elevated); }
.pulse-dislocation { animation: borderPulse 2s ease-in-out infinite; border-left-color: var(--accent); }

/* Row-level pulse — animate first td border */
tr.pulse-watch > td:first-child { animation: borderPulse 2s ease-in-out infinite; border-left-color: var(--watch); }
tr.pulse-elevated > td:first-child { animation: borderPulse 2s ease-in-out infinite; border-left-color: var(--elevated); }
tr.pulse-dislocation > td:first-child { animation: borderPulse 2s ease-in-out infinite; border-left-color: var(--accent); }

/* ================================================================
   HERO — THE AUGUR INDEX
   ================================================================ */
.hero {
    margin-bottom: 2.5rem;
}
.hero-label {
    font-family: var(--font-serif);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--text-secondary);
    font-variant: small-caps;
    margin-bottom: 0.5rem;
}
.hero-score {
    font-family: var(--font-mono);
    font-size: 52px;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.01em;
}
.hero-state {
    display: inline-block;
    font-family: var(--font-serif);
    font-size: 1.5rem;
    margin-top: 0.5rem;
    padding: 0.25rem 0.95rem;
    border-radius: 999px;
    transition: opacity 0.25s, background-color 0.3s;
}
.hero-state.state-baseline    { background: rgba(10,10,10,0.06); }
.hero-state.state-watch        { background: rgba(200,169,81,0.14); }
.hero-state.state-elevated     { background: rgba(139,64,0,0.13); }
.hero-state.state-dislocation  { background: rgba(139,0,0,0.12); }
.hero-row {
    display: flex;
    align-items: flex-end;
    gap: 2rem;
    flex-wrap: wrap;
}
.hero-sparkline {
    width: 200px;
    height: 48px;
    flex-shrink: 0;
}
.hero-sparkline canvas {
    width: 100%;
    height: 100%;
    display: block;
}
.hero-sparkline { display: none; }
.hero-meta {
    font-family: var(--font-mono);
    font-size: 0.65rem;
    color: var(--text-secondary);
    margin-top: 0.75rem;
}

/* ================================================================
   SECTION LABELS & DIVIDERS
   ================================================================ */
.section-label {
    font-family: var(--font-serif);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--text-secondary);
    font-variant: small-caps;
    margin-bottom: 0.75rem;
}
.section-divider {
    border: none;
    border-top: 1px solid var(--border);
    margin: 1.5rem 0;
}

/* ================================================================
   ASSET TABLES
   ================================================================ */
.tables-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
}
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.asset-table { width: 100%; border-collapse: collapse; }
.asset-table thead th {
    font-family: var(--font-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-secondary);
    font-weight: 500;
    padding: 0 0 0.6rem 0;
    text-align: left;
    border-bottom: 1px solid var(--border);
}
.asset-table thead th.col-right { text-align: right; }
.asset-table thead th:not(:first-child) { padding-left: 1.5rem; }
.asset-table tbody td:not(:first-child)  { padding-left: 1.5rem; }
.asset-table tbody tr {
    cursor: pointer;
    transition: background-color 0.1s;
}
.asset-table tbody tr:hover { background: var(--card-bg); }
.asset-table tbody td {
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
}
.asset-name-cell {
    font-size: 0.85rem;
}
.asset-ticker {
    font-family: var(--font-mono);
    font-size: 0.7rem;
    color: var(--text-secondary);
    margin-left: 0.4rem;
}
.asset-index-cell {
    font-family: var(--font-mono);
    font-size: 1.1rem;
    font-weight: 700;
    text-align: right;
}
.asset-class-cell {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 0.7rem;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    letter-spacing: 0.02em;
    white-space: nowrap;
}
tr.state-baseline   .asset-class-cell { background: rgba(10,10,10,0.06);    color: var(--text-secondary); font-weight: 400; }
tr.state-watch      .asset-class-cell { background: rgba(200,169,81,0.14);  color: var(--watch);          font-weight: 500; }
tr.state-elevated   .asset-class-cell { background: rgba(139,64,0,0.14);    color: var(--elevated);       font-weight: 600; }
tr.state-dislocation .asset-class-cell { background: rgba(139,0,0,0.13);   color: var(--accent);         font-weight: 700; }
/* Standalone state pill — used in events table and anywhere without a state-class parent tr */
.state-pill {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 11px;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    letter-spacing: 0.02em;
    white-space: nowrap;
}
.state-pill.state-baseline    { background: rgba(10,10,10,0.06);    color: var(--text-secondary); font-weight: 400; }
.state-pill.state-watch        { background: rgba(200,169,81,0.14);  color: var(--watch);          font-weight: 500; }
.state-pill.state-elevated     { background: rgba(139,64,0,0.14);    color: var(--elevated);       font-weight: 600; }
.state-pill.state-dislocation  { background: rgba(139,0,0,0.13);     color: var(--accent);         font-weight: 700; }
.asset-updated-cell {
    font-family: var(--font-mono);
    font-size: 0.65rem;
    color: var(--text-secondary);
    text-align: right;
}

/* ================================================================
   ASSET DETAIL PAGE
   ================================================================ */
.back-nav {
    font-family: var(--font-serif);
    font-size: 0.7rem;
    color: var(--text-secondary);
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin-bottom: 2rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-variant: small-caps;
}
.back-nav:hover { color: var(--text); }

.asset-header {
    display: flex;
    align-items: baseline;
    gap: 1rem;
    margin-bottom: 0.5rem;
    flex-wrap: wrap;
}
.asset-title {
    font-family: var(--font-serif);
    font-size: 22px;
    font-weight: 600;
}
.asset-title-ticker {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 0.75rem;
    color: var(--text-secondary);
    background: rgba(10,10,10,0.06);
    padding: 0.15rem 0.55rem;
    border-radius: 999px;
    vertical-align: middle;
    letter-spacing: 0.04em;
}
.detail-score {
    font-family: var(--font-mono);
    font-size: 52px;
    font-weight: 700;
    line-height: 1.1;
    margin-top: 0.25rem;
    letter-spacing: -0.01em;
}
.detail-state {
    display: inline-block;
    font-family: var(--font-serif);
    font-size: 1.1rem;
    margin-top: 0.5rem;
    padding: 0.22rem 0.85rem;
    border-radius: 999px;
    transition: opacity 0.25s, background-color 0.3s;
}
.detail-state.state-baseline   { background: rgba(10,10,10,0.06); }
.detail-state.state-watch       { background: rgba(200,169,81,0.14); }
.detail-state.state-elevated    { background: rgba(139,64,0,0.13); }
.detail-state.state-dislocation { background: rgba(139,0,0,0.12); }

/* State indicator dot — shown next to asset name */
.state-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    vertical-align: middle;
    margin-left: 0.5rem;
    flex-shrink: 0;
}
.state-dot.state-baseline   { background: var(--text-secondary); }
.state-dot.state-watch       { background: var(--watch); }
.state-dot.state-elevated    { background: var(--elevated); }
.state-dot.state-dislocation { background: var(--accent); }
.detail-meta {
    font-family: var(--font-mono);
    font-size: 0.65rem;
    color: var(--text-secondary);
    margin-top: 0.5rem;
    margin-bottom: 2.5rem;
}

/* --- Domain intelligence table --- */
.domain-table { width: 100%; border-collapse: collapse; margin-bottom: 0; }
.domain-table thead th {
    font-family: var(--font-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-secondary);
    font-weight: 500;
    padding: 0 0 0.5rem 0;
    text-align: left;
    border-bottom: 1px solid var(--border);
}
.domain-table thead th.col-right { text-align: right; }
.domain-table tbody td {
    padding: 0.9rem 0;
    border-bottom: 1px solid var(--border);
    font-family: var(--font-mono);
    font-size: 14px;
    font-weight: 400;
    vertical-align: middle;
}
.domain-name { text-transform: capitalize; }
.domain-inactive { color: var(--text-secondary); }
.domain-value { font-family: var(--font-mono); }
.domain-status-active   { color: var(--watch); font-weight: 600; }
.domain-status-inactive { color: var(--text-secondary); font-weight: 400; }

/* Relative timestamp shown alongside UTC */
.relative-time {
    font-family: var(--font-mono);
    font-size: 0.65rem;
    color: var(--text-secondary);
    opacity: 0.8;
}
.relative-time:not(:empty)::before {
    content: ' \00B7  '; /* middot + space */
}

/* Persistence bar */
.persistence-bar {
    width: 100%;
    max-width: 120px;
    height: 4px;
    background: var(--border);
}
.persistence-fill {
    height: 100%;
    transition: width 0.3s;
}
.fill-baseline { background: var(--text); }
.fill-watch { background: var(--watch); }
.fill-elevated { background: var(--elevated); }
.fill-dislocation { background: var(--accent); }

.contribution-cell {
    font-family: var(--font-mono);
    text-align: right;
}

/* --- Historical chart --- */
.chart-section { margin-bottom: 2.5rem; }
.period-selector {
    display: flex;
    gap: 0;
    margin-bottom: 1rem;
}
.period-btn {
    font-family: var(--font-mono);
    font-size: 0.7rem;
    padding: 0.4rem 0.75rem;
    border: none;
    background: none;
    color: var(--text-secondary);
    cursor: pointer;
    letter-spacing: 0.03em;
    border-bottom: 2px solid transparent;
}
.period-btn.active {
    color: var(--text);
    border-bottom-color: var(--text);
}
.period-btn:hover:not(.active) { color: var(--text); }

.chart-wrap {
    position: relative;
    width: 100%;
    height: 320px;
    background: var(--bg);
    overflow: hidden;
}
.chart-canvas {
    width: 100%;
    height: 100%;
    display: block;
}
.chart-tooltip {
    display: none;
    position: absolute;
    background: var(--bg);
    border: 1px solid var(--border);
    padding: 0.5rem 0.75rem;
    font-family: var(--font-mono);
    font-size: 0.7rem;
    pointer-events: none;
    z-index: 10;
    white-space: nowrap;
    line-height: 1.6;
}

/* --- Replay section --- */
.replay-section { margin-bottom: 2.5rem; }
.replay-controls {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 0.75rem;
}
.replay-btn {
    font-family: var(--font-mono);
    font-size: 0.65rem;
    padding: 0.3rem 0.8rem;
    background: none;
    color: var(--text-secondary);
    border: 1px solid var(--border);
    cursor: pointer;
    letter-spacing: 0.03em;
}
.replay-btn:hover { background: var(--card-bg); color: var(--text); border-color: var(--text); }
.replay-btn.playing { background: var(--text); color: var(--bg); border-color: var(--text); }
.speed-selector {
    display: flex;
    gap: 0;
}
.speed-btn {
    font-family: var(--font-mono);
    font-size: 0.65rem;
    padding: 0.3rem 0.6rem;
    border: 1px solid var(--border);
    background: none;
    color: var(--text-secondary);
    cursor: pointer;
    margin-left: -1px;
}
.speed-btn:first-child { margin-left: 0; }
.speed-btn.active {
    background: var(--text);
    color: var(--bg);
    border-color: var(--text);
}
.replay-timestamp {
    font-family: var(--font-mono);
    font-size: 0.75rem;
    color: var(--text-secondary);
}
.replay-dates {
    font-family: var(--font-mono);
    font-size: 0.65rem;
    color: var(--text-secondary);
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.25rem;
}
.replay-track-wrap {
    position: relative;
    width: 100%;
    height: 32px;
    margin-bottom: 0.5rem;
}
.replay-track {
    width: 100%;
    height: 4px;
    background: var(--border);
    position: absolute;
    top: 14px;
    cursor: pointer;
}
.replay-fill { height: 100%; background: var(--text); width: 0; }
.replay-handle {
    position: absolute;
    top: 8px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--accent);
    cursor: ew-resize;
    z-index: 5;
    transform: translateX(-7px);
    box-shadow: 0 0 0 3px rgba(139,0,0,0.18);
    transition: box-shadow 0.15s;
}
.replay-handle:hover {
    box-shadow: 0 0 0 5px rgba(139,0,0,0.22);
}
.replay-event-tick {
    position: absolute;
    top: 8px;
    width: 1px;
    height: 16px;
    background: var(--text);
    opacity: 0.25;
}

/* --- Events table --- */
.events-section { margin-bottom: 2.5rem; }
.events-table { width: 100%; border-collapse: collapse; }
.events-table thead th {
    font-family: var(--font-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-secondary);
    font-weight: 500;
    padding: 0 0 0.5rem 0;
    text-align: left;
    border-bottom: 1px solid var(--border);
}
/* Higher-specificity rule to prevent any cascade from overriding
   the grey header colour (e.g. admin-table or browser link defaults). */
.events-table > thead > tr > th { color: var(--text-secondary); }
.events-table tbody td {
    font-family: var(--font-mono);
    font-size: 14px;
    font-weight: 400;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border);
}
.event-time { color: var(--text-secondary); }

/* ================================================================
   PAGE TRANSITIONS
   ================================================================ */
.page-fade { animation: fadeIn 200ms ease; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

/* ================================================================
   LOGIN PAGE
   ================================================================ */
.login-wrap {
    min-height: calc(100vh - 53px);
    display: flex;
    align-items: center;
    justify-content: center;
}
.login-container { width: 100%; max-width: 400px; padding: 0 1.5rem; }
.login-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    padding: 2.5rem 2rem;
}
.login-form { display: flex; flex-direction: column; gap: 1.25rem; }
.form-field label {
    display: block;
    font-size: 0.7rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-bottom: 0.4rem;
}
.form-field input {
    width: 100%;
    padding: 0.75rem 0.875rem;
    font-family: var(--font-mono);
    font-size: 0.9rem;
    border: 1px solid var(--border);
    background: var(--bg);
    color: var(--text);
    outline: none;
    transition: border-color 0.2s;
}
.form-field input:focus { border-color: var(--text); }
.form-field input::placeholder { color: var(--pending); }
.error-msg { font-size: 0.75rem; color: var(--accent); margin-top: 0.25rem; }
.login-btn {
    width: 100%;
    padding: 0.8rem;
    font-family: inherit;
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: var(--text);
    color: #FFFFFF;
    border: none;
    cursor: pointer;
    margin-top: 0.5rem;
    transition: background-color 0.2s;
}
.login-btn:hover { background: #333333; }

/* ================================================================
   DIGIT TICK ANIMATION
   ================================================================ */
.digit-tick span {
    display: inline-block;
    transition: transform 40ms ease, opacity 40ms ease;
}
.digit-up {
    animation: digitRollUp 40ms ease forwards;
}
@keyframes digitRollUp {
    from { transform: translateY(100%); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 768px) {
    .header { padding: 0 1rem; }
    .header-clock { position: static; transform: none; font-size: 0.65rem; }
    .content { padding: 1.5rem 1rem; padding-top: calc(52px + 1.5rem); }
    .hero-score { font-size: 2.4rem; }
    .hero-state { font-size: 1.4rem; }
    .tables-grid { grid-template-columns: 1fr; gap: 2rem; }
    .table-scroll { display: block; overflow-x: auto; }
    .chart-wrap { height: 220px; }
    .period-selector { flex-wrap: wrap; }
    .pub-nav { padding: 1rem; }
    .pub-links { gap: 1.25rem; }
    .pub-content { padding: 4rem 1.5rem; }
    .pub-content h1 { font-size: 1.5rem; }
    .login-container { padding: 0 1rem; }
    .login-card { padding: 2rem 1.5rem; }
    .hero-row { flex-direction: column; gap: 1rem; }
}

/* ================================================================
   ADMIN PANEL — DARK THEME
   ================================================================ */
body.admin-theme {
    background: #0D1117;
    color: #E6EDF3;
    font-family: var(--font-sans);
}
body.admin-theme .admin-wrap {
    display: flex;
    min-height: 100vh;
}

/* Sidebar */
.admin-sidebar {
    width: 220px;
    flex-shrink: 0;
    background: #161B22;
    border-right: 1px solid #30363D;
    min-height: 100vh;
    padding: 1.5rem 0;
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
}
.admin-sidebar-brand {
    font-family: var(--font-serif);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    color: var(--accent);
    text-transform: uppercase;
    padding: 0 1.25rem 1.5rem;
    border-bottom: 1px solid #30363D;
    margin-bottom: 1rem;
}
.admin-sidebar-sub {
    display: block;
    font-family: var(--font-mono);
    font-size: 0.6rem;
    color: #8B949E;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-top: 0.25rem;
}
.admin-nav-link {
    display: block;
    padding: 0.6rem 1.25rem;
    color: #8B949E;
    text-decoration: none;
    font-size: 0.8rem;
    font-family: var(--font-mono);
    letter-spacing: 0.03em;
    transition: all 0.15s;
}
.admin-nav-link:hover { color: #E6EDF3; background: rgba(255,255,255,0.03); }
.admin-nav-link.active {
    color: #E6EDF3;
    background: rgba(255,255,255,0.05);
    border-left: 2px solid var(--accent);
    padding-left: calc(1.25rem - 2px);
}

/* Main area */
.admin-main {
    flex: 1;
    padding: 2rem;
    margin-left: 220px;
    overflow-x: auto;
}
.admin-page-title {
    font-family: var(--font-serif);
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 2rem;
    letter-spacing: 0.05em;
    color: #E6EDF3;
}

/* Cards */
.admin-card {
    background: #161B22;
    border: 1px solid #30363D;
    padding: 1.25rem;
    margin-bottom: 1.5rem;
}
.admin-card-title {
    font-family: var(--font-mono);
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #8B949E;
    margin-bottom: 1rem;
}
.admin-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1.5rem;
}
.admin-stat-value {
    font-family: var(--font-mono);
    font-size: 1.6rem;
    font-weight: 700;
    color: #E6EDF3;
}
.admin-stat-value.accent { color: var(--accent); }
.admin-stat-label {
    font-family: var(--font-mono);
    font-size: 0.65rem;
    color: #8B949E;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 0.2rem;
}

/* Tables */
.admin-table { width: 100%; border-collapse: collapse; }
.admin-table th {
    font-family: var(--font-mono);
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #8B949E;
    text-align: left;
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid #30363D;
    font-weight: 500;
}
.admin-table td {
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid #30363D;
    font-size: 0.8rem;
    font-family: var(--font-mono);
    color: #E6EDF3;
}
.admin-table tr:hover { background: rgba(255,255,255,0.02); }
.badge-active { color: #4ADE80; font-size: 0.7rem; }
.badge-inactive { color: #8B949E; font-size: 0.7rem; }

/* Forms */
.admin-form {
    display: flex;
    gap: 0.75rem;
    align-items: flex-end;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
}
.admin-form .form-group label {
    display: block;
    font-family: var(--font-mono);
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #8B949E;
    margin-bottom: 0.25rem;
}
.admin-form input, .admin-form select {
    background: #0D1117;
    border: 1px solid #30363D;
    color: #E6EDF3;
    padding: 0.5rem 0.75rem;
    font-family: var(--font-mono);
    font-size: 0.8rem;
    outline: none;
}
.admin-form input:focus { border-color: var(--accent); }
.admin-btn {
    font-family: var(--font-mono);
    font-size: 0.75rem;
    padding: 0.5rem 1rem;
    background: var(--accent);
    color: #FFFFFF;
    border: none;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: opacity 0.15s;
}
.admin-btn:hover { opacity: 0.85; }
.admin-btn.secondary {
    background: transparent;
    border: 1px solid #30363D;
    color: #E6EDF3;
}
.admin-btn.secondary:hover { border-color: #E6EDF3; }

/* Tick feed */
.tick-feed { max-height: 400px; overflow-y: auto; }
.tick-row {
    display: grid;
    grid-template-columns: 160px 80px 80px 120px 60px;
    padding: 0.4rem 0.75rem;
    border-bottom: 1px solid #30363D;
    font-family: var(--font-mono);
    font-size: 0.75rem;
    color: #E6EDF3;
}
.tick-row.new { animation: tickFlash 0.5s ease; }
@keyframes tickFlash { from { background: rgba(139,0,0,0.1); } to { background: transparent; } }

/* Alerts */
.alert-toggle {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid #30363D;
}
.toggle-switch {
    width: 36px;
    height: 20px;
    background: #30363D;
    border-radius: 10px;
    position: relative;
    cursor: pointer;
    transition: background 0.2s;
}
.toggle-switch.on { background: var(--accent); }
.toggle-switch::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: 16px;
    height: 16px;
    background: #E6EDF3;
    border-radius: 8px;
    transition: transform 0.2s;
}
.toggle-switch.on::after { transform: translateX(16px); }

/* Admin responsive */
@media (max-width: 768px) {
    .admin-sidebar {
        position: static;
        width: 100%;
        min-height: auto;
        flex-direction: row;
        padding: 0;
        overflow-x: auto;
    }
    .admin-sidebar-brand { display: none; }
    .admin-nav-link {
        padding: 0.75rem 1rem;
        white-space: nowrap;
    }
    .admin-nav-link.active {
        border-left: none;
        border-bottom: 2px solid var(--accent);
        padding-left: 1rem;
    }
    .admin-main { margin-left: 0; }
}
