﻿/* ==========================================================================
   IRGame Design System — Master Stylesheet
   Version: 2.0  (cascade-safe)

   CASCADE SAFETY RULES
   ─────────────────────
   1.  NO bare HTML tag selectors (html, body, *, h1, input, table, a, etc.)
       Nothing in this file touches elements outside an .ir-root container.

   2.  :root is used ONLY for CSS custom property declarations.
       Custom property declarations carry zero style side-effects and are
       therefore safe to declare globally.

   3.  Every visual rule is scoped to either:
         .ir-root          — opt-in wrapper; normalises box-sizing/font only
                             for its own descendants
         .ir-*             — BEM component classes; self-contained

   4.  This file can coexist with Bootstrap, site.css, Dashboard.css, or any
       other stylesheet on the same page without conflict.

   USAGE
   ──────
   In <head>:
     <link href="https://fonts.googleapis.com/css2?family=DM+Serif+Display
                 &family=DM+Sans:wght@300;400;500;600&display=swap"
           rel="stylesheet"/>
     <link rel="stylesheet" href="/css/irgame.css" />

   Wrap IRGame UI in the opt-in root class:
     <div class="ir-root"> ... </div>

   For full-page IRGame views the <body> may carry the class:
     <body class="ir-root">
   ========================================================================== */


/* --------------------------------------------------------------------------
   1. CSS Custom Properties  (design tokens — zero side-effects)
   -------------------------------------------------------------------------- */
:root {
    /* Palette */
    --ir-navy: #0f1c2e;
    --ir-ink: #1a2e45;
    --ir-steel: #2d4a6b;
    --ir-sky: #4a9edd;
    --ir-sky-deep: #2278c2;
    --ir-gold: #c9a84c;
    --ir-cream: #f5f0e8;
    --ir-white: #ffffff;
    --ir-muted: #8fa3b8;
    --ir-danger: #e05a5a;
    --ir-success: #4aab7e;
    /* Opacity surfaces */
    --ir-surface-1: rgba(255,255,255,.04);
    --ir-surface-2: rgba(255,255,255,.07);
    --ir-surface-3: rgba(255,255,255,.12);
    --ir-border: rgba(255,255,255,.10);
    --ir-border-focus: rgba(74,158,221,.50);
    /* Tints */
    --ir-sky-tint-sm: rgba(74,158,221,.08);
    --ir-sky-tint-md: rgba(74,158,221,.15);
    --ir-sky-tint-lg: rgba(74,158,221,.25);
    --ir-gold-tint-sm: rgba(201,168,76,.07);
    --ir-gold-tint-md: rgba(201,168,76,.15);
    --ir-gold-border: rgba(201,168,76,.28);
    --ir-danger-tint: rgba(224,90,90,.12);
    --ir-danger-border: rgba(224,90,90,.35);
    /* Typography */
    --ir-font-display: 'DM Serif Display', Georgia, serif;
    --ir-font-body: 'DM Sans', system-ui, sans-serif;
    --ir-text-xs: 11px;
    --ir-text-sm: 13px;
    --ir-text-base: 15px;
    --ir-text-md: 17px;
    --ir-text-lg: 22px;
    --ir-text-xl: 26px;
    --ir-text-2xl: 34px;
    /* Spacing */
    --ir-space-1: 4px;
    --ir-space-2: 8px;
    --ir-space-3: 12px;
    --ir-space-4: 16px;
    --ir-space-5: 20px;
    --ir-space-6: 24px;
    --ir-space-7: 28px;
    --ir-space-8: 32px;
    --ir-space-10: 40px;
    --ir-space-12: 48px;
    /* Radii */
    --ir-radius-sm: 6px;
    --ir-radius-md: 10px;
    --ir-radius-lg: 18px;
    --ir-radius-xl: 24px;
    --ir-radius-full: 9999px;
    /* Shadows */
    --ir-shadow-card: 0 24px 64px rgba(15,28,46,.18), 0 4px 16px rgba(15,28,46,.10);
    --ir-shadow-btn: 0 6px 24px rgba(74,158,221,.35);
    --ir-shadow-btn-hover: 0 8px 32px rgba(74,158,221,.50);
    --ir-shadow-focus: 0 0 0 3px rgba(74,158,221,.20);
    /* Transitions */
    --ir-transition-fast: .15s ease;
    --ir-transition-base: .20s ease;
    --ir-transition-slow: .35s ease;
}


/* --------------------------------------------------------------------------
   2. Scoped Base  (.ir-root)
   Applies normalisation ONLY to the subtree that opts in.
   Does not touch html, body, or any bare tag outside .ir-root.
   -------------------------------------------------------------------------- */
.ir-root {
    box-sizing: border-box;
    font-family: var(--ir-font-body);
    font-size: var(--ir-text-base);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

    /* box-sizing inheritance — contained entirely within .ir-root */
    .ir-root *,
    .ir-root *::before,
    .ir-root *::after {
        box-sizing: inherit;
    }


/* --------------------------------------------------------------------------
   3. Page Layout — Centred single-column (forms, auth, wizards)
   -------------------------------------------------------------------------- */
.ir-page {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--ir-space-10) var(--ir-space-4);
    background-color: var(--ir-navy);
    background-image: radial-gradient(ellipse 80% 60% at 70% 20%, rgba(74,158,221,.12) 0%, transparent 60%), radial-gradient(ellipse 50% 40% at 10% 80%, rgba(201,168,76,.07) 0%, transparent 55%);
    color: var(--ir-white);
    font-family: var(--ir-font-body);
}

.ir-page--compact {
    /*min-height: 100vh;*/
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--ir-space-10) var(--ir-space-4);
    background-color: var(--ir-navy);
    background-image: radial-gradient(ellipse 80% 60% at 70% 20%, rgba(74,158,221,.12) 0%, transparent 60%), radial-gradient(ellipse 50% 40% at 10% 80%, rgba(201,168,76,.07) 0%, transparent 55%);
    color: var(--ir-white);
    font-family: var(--ir-font-body);
}

.ir-page--wide {
    align-items: stretch;
    justify-content: flex-start;
    padding: 0;
}


/* --------------------------------------------------------------------------
   4. Brand / Logo Bar
   -------------------------------------------------------------------------- */
.ir-brand {
    /*  display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: var(--ir-space-8);
    animation: ir-fade-down .5s ease both;*/
    background-image: url("/images/IRGame_Logo_1.A.png");
    background-size: cover;
    background-position: center; /* Centers the image within the container */
    background-repeat: no-repeat; /* Prevents tiling */
    width: 60px;
    height: 60px;
    color: transparent; /* make the text invisible */
    user-select: none; /* prevent selection of the text */
}

/*.ir-brand__logo {
    width: 38px;
    height: 38px;
    background: linear-gradient(135deg, var(--ir-sky), var(--ir-gold));
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--ir-font-display);
    font-size: 18px;
    color: var(--ir-white);
    box-shadow: 0 4px 14px rgba(74,158,221,.40);
    flex-shrink: 0;
}

.ir-brand__name {
    font-family: var(--ir-font-display);
    font-size: var(--ir-text-lg);
    color: var(--ir-white);
    letter-spacing: .02em;
}

.ir-brand__name--accent {
    color: var(--ir-gold);
}
*/

/* --------------------------------------------------------------------------
   5. Card
   -------------------------------------------------------------------------- */
.ir-card {
    width: 100%;
    max-width: 520px;
    background: var(--ir-surface-1);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--ir-border);
    border-radius: var(--ir-radius-lg);
    box-shadow: var(--ir-shadow-card);
    overflow: hidden;
    animation: ir-fade-up .55s ease both .1s;
}

.ir-card--wide {
    max-width: 760px;
}

.ir-card--full {
    max-width: 100%;
    border-radius: 0;
}

.ir-card__header {
    padding: var(--ir-space-7) var(--ir-space-8) var(--ir-space-6);
    border-bottom: 1px solid var(--ir-surface-2);
    background: linear-gradient(135deg, rgba(74,158,221,.10), rgba(201,168,76,.06));
}

.ir-card__title {
    font-family: var(--ir-font-display);
    font-size: var(--ir-text-xl);
    color: var(--ir-white);
    letter-spacing: .01em;
    line-height: 1.2;
    margin: 0;
}

.ir-card__subtitle {
    margin-top: var(--ir-space-2);
    font-size: var(--ir-text-sm);
    color: var(--ir-muted);
    line-height: 1.5;
}

.ir-card__body {
    padding: var(--ir-space-7) var(--ir-space-8) var(--ir-space-8);
}

.ir-card__footer {
    padding: var(--ir-space-5) var(--ir-space-8);
    border-top: 1px solid var(--ir-surface-2);
    background: var(--ir-surface-1);
    display: flex;
    align-items: center;
    gap: var(--ir-space-4);
}

@media (max-width: 600px) {
    .ir-card__header,
    .ir-card__body,
    .ir-card__footer {
        padding-left: var(--ir-space-5);
        padding-right: var(--ir-space-5);
    }

    .ir-card {
        border-radius: var(--ir-radius-md);
    }
}


/* --------------------------------------------------------------------------
   6. Badges & Tags
   -------------------------------------------------------------------------- */
.ir-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    border-radius: var(--ir-radius-full);
    font-size: var(--ir-text-xs);
    font-weight: 600;
    letter-spacing: .05em;
    text-transform: uppercase;
    line-height: 1;
    font-family: var(--ir-font-body);
}

.ir-badge--gold {
    background: var(--ir-gold-tint-md);
    border: 1px solid var(--ir-gold-border);
    color: var(--ir-gold);
}

.ir-badge--sky {
    background: var(--ir-sky-tint-md);
    border: 1px solid var(--ir-border-focus);
    color: var(--ir-sky);
}

.ir-badge--danger {
    background: var(--ir-danger-tint);
    border: 1px solid var(--ir-danger-border);
    color: var(--ir-danger);
}

.ir-badge--success {
    background: rgba(74,171,126,.12);
    border: 1px solid rgba(74,171,126,.30);
    color: var(--ir-success);
}

.ir-badge svg {
    width: 12px;
    height: 12px;
    flex-shrink: 0;
}


/* --------------------------------------------------------------------------
   7. Form Elements
   -------------------------------------------------------------------------- */
.ir-field {
    margin-bottom: var(--ir-space-5);
}

.ir-field__label {
    display: block;
    font-size: var(--ir-text-xs);
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ir-muted);
    margin-bottom: 7px;
    font-family: var(--ir-font-body);
}

.ir-input {
    display: block;
    width: 100%;
    padding: 13px 16px;
    background: var(--ir-surface-1);
    border: 1px solid var(--ir-surface-3);
    border-radius: var(--ir-radius-md);
    color: var(--ir-white);
    font-family: var(--ir-font-body);
    font-size: var(--ir-text-base);
    line-height: 1.5;
    transition: border-color var(--ir-transition-base), background var(--ir-transition-base), box-shadow var(--ir-transition-base);
    outline: none;
    appearance: none;
    -webkit-appearance: none;
}

    .ir-input::placeholder {
        color: rgba(255,255,255,.28);
    }

    .ir-input:focus {
        border-color: var(--ir-sky);
        background: var(--ir-sky-tint-sm);
        box-shadow: var(--ir-shadow-focus);
    }

.ir-input--error {
    border-color: var(--ir-danger);
    background: var(--ir-danger-tint);
}

.ir-select {
    display: block;
    width: 100%;
    padding: 13px 40px 13px 16px;
    background-color: var(--ir-surface-1);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%238fa3b8' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    border: 1px solid var(--ir-surface-3);
    border-radius: var(--ir-radius-md);
    color: var(--ir-white);
    font-family: var(--ir-font-body);
    font-size: var(--ir-text-base);
    line-height: 1.5;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    outline: none;
    transition: border-color var(--ir-transition-base), background var(--ir-transition-base), box-shadow var(--ir-transition-base);
}

    .ir-select:focus {
        border-color: var(--ir-sky);
        background-color: var(--ir-sky-tint-sm);
        box-shadow: var(--ir-shadow-focus);
    }

/* Scoped to .ir-root to avoid touching selects on other parts of the page */
.ir-root .ir-select option {
    background: var(--ir-ink);
    color: var(--ir-white);
}

.ir-textarea {
    display: block;
    width: 100%;
    padding: 13px 16px;
    background: var(--ir-surface-1);
    border: 1px solid var(--ir-surface-3);
    border-radius: var(--ir-radius-md);
    color: var(--ir-white);
    font-family: var(--ir-font-body);
    font-size: var(--ir-text-base);
    line-height: 1.6;
    resize: vertical;
    min-height: 100px;
    outline: none;
    transition: border-color var(--ir-transition-base), background var(--ir-transition-base), box-shadow var(--ir-transition-base);
}

    .ir-textarea::placeholder {
        color: rgba(255,255,255,.28);
    }

    .ir-textarea:focus {
        border-color: var(--ir-sky);
        background: var(--ir-sky-tint-sm);
        box-shadow: var(--ir-shadow-focus);
    }

.ir-field__error {
    display: block;
    margin-top: 5px;
    font-size: var(--ir-text-xs);
    color: var(--ir-danger);
    font-family: var(--ir-font-body);
}

.ir-validation-summary {
    padding: var(--ir-space-3) var(--ir-space-4);
    background: var(--ir-danger-tint);
    border-left: 3px solid var(--ir-danger);
    border-radius: var(--ir-radius-sm);
    color: #f4a0a0;
    font-size: var(--ir-text-sm);
    margin-bottom: var(--ir-space-5);
    line-height: 1.5;
    font-family: var(--ir-font-body);
}


/* --------------------------------------------------------------------------
   8. Custom Checkbox
   -------------------------------------------------------------------------- */
.ir-check-group {
    display: flex;
    flex-direction: column;
    gap: var(--ir-space-3);
}

.ir-check {
    display: flex;
    align-items: center;
    gap: 11px;
    cursor: pointer;
    user-select: none;
}

/* Visually hidden but accessible — does NOT use display:none */
.ir-check__input {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.ir-check__box {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    border: 2px solid var(--ir-surface-3);
    border-radius: 5px;
    background: var(--ir-surface-1);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: border-color var(--ir-transition-base), background var(--ir-transition-base);
}

    .ir-check__box svg {
        opacity: 0;
        transition: opacity var(--ir-transition-fast);
        width: 11px;
        height: 11px;
    }

.ir-check__input:checked + .ir-check__box {
    border-color: var(--ir-sky);
    background: var(--ir-sky-tint-md);
}

    .ir-check__input:checked + .ir-check__box svg {
        opacity: 1;
    }

.ir-check__label {
    font-size: var(--ir-text-base);
    color: rgba(255,255,255,.80);
    line-height: 1.4;
    font-family: var(--ir-font-body);
}


/* --------------------------------------------------------------------------
   9. Buttons
   -------------------------------------------------------------------------- */
.ir-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--ir-space-2);
    padding: 13px var(--ir-space-6);
    border: none;
    border-radius: var(--ir-radius-md);
    font-family: var(--ir-font-body);
    font-size: var(--ir-text-base);
    font-weight: 600;
    letter-spacing: .03em;
    line-height: 1;
    cursor: pointer;
    text-decoration: none;
    transition: opacity var(--ir-transition-base), transform var(--ir-transition-fast), box-shadow var(--ir-transition-base);
    position: relative;
    overflow: hidden;
}

    .ir-btn::after {
        content: '';
        position: absolute;
        inset: 0;
        background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
        transform: translateX(-100%);
        transition: transform .5s ease;
    }

    .ir-btn:hover::after {
        transform: translateX(100%);
    }

    .ir-btn:active {
        transform: scale(.985);
    }

.ir-btn--primary {
    background: linear-gradient(135deg, var(--ir-sky) 0%, var(--ir-sky-deep) 100%);
    color: var(--ir-white);
    box-shadow: var(--ir-shadow-btn);
}

    .ir-btn--primary:hover {
        opacity: .92;
        box-shadow: var(--ir-shadow-btn-hover);
    }

.ir-btn--secondary {
    background: var(--ir-surface-2);
    border: 1px solid var(--ir-border);
    color: rgba(255,255,255,.80);
}

    .ir-btn--secondary:hover {
        background: var(--ir-surface-3);
        color: var(--ir-white);
    }

.ir-btn--danger {
    background: linear-gradient(135deg, var(--ir-danger), #b03030);
    color: var(--ir-white);
    box-shadow: 0 6px 24px rgba(224,90,90,.30);
}

.ir-btn--gold {
    background: linear-gradient(135deg, var(--ir-gold), #a07a28);
    color: var(--ir-white);
    box-shadow: 0 6px 24px rgba(201,168,76,.25);
}

.ir-btn--full {
    width: 100%;
}

.ir-btn--sm {
    padding: 8px 16px;
    font-size: var(--ir-text-sm);
}


/* --------------------------------------------------------------------------
   10. Divider
   -------------------------------------------------------------------------- */
.ir-divider {
    height: 1px;
    background: var(--ir-surface-2);
    margin: var(--ir-space-5) 0;
    border: none;
}


/* --------------------------------------------------------------------------
   11. Notice / Info Cards
   -------------------------------------------------------------------------- */
.ir-notice {
    padding: var(--ir-space-4) var(--ir-space-5);
    border-radius: var(--ir-radius-md);
    font-size: var(--ir-text-sm);
    line-height: 1.55;
    font-family: var(--ir-font-body);
}

    .ir-notice p {
        margin: 0;
    }

        .ir-notice p + p {
            margin-top: 6px;
        }

    .ir-notice strong {
        font-weight: 600;
    }

.ir-notice--gold {
    background: var(--ir-gold-tint-md);
    border: 1px solid var(--ir-gold-border);
    color: rgba(201,168,76,.90);
}

    .ir-notice--gold strong {
        color: var(--ir-gold);
    }

.ir-notice--info {
    background: var(--ir-sky-tint-sm);
    border: 1px solid var(--ir-sky-tint-md);
    color: rgba(74,158,221,.90);
}

    .ir-notice--info strong {
        color: var(--ir-sky);
    }

.ir-notice--danger {
    background: var(--ir-danger-tint);
    border: 1px solid var(--ir-danger-border);
    color: #f4a0a0;
}

    .ir-notice--danger strong {
        color: var(--ir-danger);
    }

.ir-notice--success {
    background: rgba(74,171,126,.10);
    border: 1px solid rgba(74,171,126,.28);
    color: rgba(74,171,126,.90);
}

    .ir-notice--success strong {
        color: var(--ir-success);
    }


/* --------------------------------------------------------------------------
   12. Typography Utilities
   -------------------------------------------------------------------------- */
.ir-text-display {
    font-family: var(--ir-font-display);
    font-size: var(--ir-text-2xl);
    color: var(--ir-white);
    line-height: 1.15;
    letter-spacing: .01em;
}

.ir-text-heading {
    font-family: var(--ir-font-display);
    font-size: var(--ir-text-xl);
    color: var(--ir-white);
    line-height: 1.2;
}

.ir-text-subheading {
    font-family: var(--ir-font-body);
    font-size: var(--ir-text-md);
    font-weight: 500;
    color: rgba(255,255,255,.85);
    line-height: 1.4;
}

.ir-text-label {
    font-family: var(--ir-font-body);
    font-size: var(--ir-text-xs);
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ir-muted);
}

.ir-text-muted {
    color: var(--ir-muted);
}

.ir-text-sky {
    color: var(--ir-sky);
}

.ir-text-gold {
    color: var(--ir-gold);
}

.ir-text-danger {
    color: var(--ir-danger);
}

.ir-text-sm {
    font-size: var(--ir-text-sm);
}

.ir-text-xs {
    font-size: var(--ir-text-xs);
}


/* --------------------------------------------------------------------------
   13. Keyframe Animations
   (Keyframes are global by spec — prefixed with ir- to avoid collisions)
   -------------------------------------------------------------------------- */
@keyframes ir-fade-down {
    from {
        opacity: 0;
        transform: translateY(-14px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes ir-fade-up {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes ir-fade-in {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes ir-slide-in-right {
    from {
        opacity: 0;
        transform: translateX(24px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes ir-pulse-warning {
    0%,100% {
        opacity: 1;
    }

    50% {
        opacity: .55;
    }
}

.ir-anim-fade-down {
    animation: ir-fade-down .50s ease both;
}

.ir-anim-fade-up {
    animation: ir-fade-up .55s ease both;
}

.ir-anim-fade-in {
    animation: ir-fade-in .40s ease both;
}

.ir-anim-delay-1 {
    animation-delay: .10s;
}

.ir-anim-delay-2 {
    animation-delay: .20s;
}

.ir-anim-delay-3 {
    animation-delay: .30s;
}

.ir-anim-delay-4 {
    animation-delay: .40s;
}


/* --------------------------------------------------------------------------
   14. Responsive Helpers
   -------------------------------------------------------------------------- */
@media (max-width: 600px) {
    .ir-card__header,
    .ir-card__body,
    .ir-card__footer {
        padding-left: var(--ir-space-5);
        padding-right: var(--ir-space-5);
    }

    .ir-card {
        border-radius: var(--ir-radius-md);
    }
}


/* --------------------------------------------------------------------------
   15. Dashboard / Wide Page Layout
   -------------------------------------------------------------------------- */
.ir-dash {
    padding: var(--ir-space-6) 1.75rem;
    background: #f4f6f9;
    box-sizing: border-box;
    font-family: var(--ir-font-body);
}

@media (max-width: 768px) {
    .ir-dash {
        padding: var(--ir-space-4);
    }
}


/* --------------------------------------------------------------------------
   16. Page Header Banner
   -------------------------------------------------------------------------- */
.ir-page-header {
    background: linear-gradient(135deg, #1a3a5c 0%, #0f6cbd 100%);
    border-radius: var(--ir-radius-lg);
    padding: 1.6rem 2rem;
    color: var(--ir-white);
    margin-bottom: var(--ir-space-6);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1.25rem;
}

.ir-page-header__eyebrow {
    font-size: var(--ir-text-xs);
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(255,255,255,.60);
    margin-bottom: .35rem;
    font-family: var(--ir-font-body);
}

.ir-page-header__title {
    font-family: var(--ir-font-display);
    font-size: 1.75rem;
    line-height: 1.2;
    color: var(--ir-white);
    margin: 0 0 .2rem;
}

.ir-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
}

.ir-meta-pill {
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.25);
    border-radius: var(--ir-radius-full);
    padding: .3rem .85rem;
    font-size: .8rem;
    color: var(--ir-white);
    white-space: nowrap;
    font-family: var(--ir-font-body);
}

    .ir-meta-pill strong {
        font-weight: 700;
        margin-right: .25rem;
        opacity: .70;
    }

@media (max-width: 768px) {
    .ir-page-header {
        padding: 1.25rem;
    }

    .ir-page-header__title {
        font-size: 1.35rem;
    }
}


/* --------------------------------------------------------------------------
   17. Section Cards  (light surface, dashboard context)
   -------------------------------------------------------------------------- */
.ir-section-card {
    background: #ffffff;
    border-radius: var(--ir-radius-lg);
    box-shadow: 0 2px 4px rgba(0,0,0,.05), 0 8px 24px rgba(0,0,0,.07);
    margin-bottom: var(--ir-space-6);
    overflow: hidden;
}

.ir-section-card__header {
    padding: 1rem 1.5rem;
    border-bottom: 1px solid #edf1f5;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ir-space-4);
}

.ir-section-card__title {
    font-size: 1rem;
    font-weight: 700;
    color: #1a3a5c;
    margin: 0;
    display: flex;
    align-items: center;
    gap: .5rem;
    font-family: var(--ir-font-body);
}

.ir-section-card__icon {
    width: 28px;
    height: 28px;
    background: #e8f0fb;
    border-radius: 7px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #0f6cbd;
    font-size: .9rem;
    flex-shrink: 0;
}

.ir-btn-add {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .4rem .9rem;
    background: linear-gradient(135deg, #1a3a5c 0%, #0f6cbd 100%);
    color: var(--ir-white);
    border: none;
    border-radius: 8px;
    font-size: .82rem;
    font-weight: 600;
    cursor: pointer;
    transition: opacity var(--ir-transition-base), box-shadow var(--ir-transition-base);
    box-shadow: 0 2px 8px rgba(15,108,189,.30);
    white-space: nowrap;
    font-family: var(--ir-font-body);
    text-decoration: none;
}

    .ir-btn-add:hover {
        opacity: .88;
        box-shadow: 0 4px 14px rgba(15,108,189,.38);
    }


/* --------------------------------------------------------------------------
   18. Data Tables
   -------------------------------------------------------------------------- */
.ir-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .9rem;
    font-family: var(--ir-font-body);
}

    .ir-table thead tr {
        background: #f8fafc;
    }

    .ir-table thead th {
        padding: .7rem 1.25rem;
        text-align: left;
        font-size: var(--ir-text-xs);
        font-weight: 700;
        letter-spacing: .07em;
        text-transform: uppercase;
        color: #7a8fa6;
        border-bottom: 1px solid #edf1f5;
        white-space: nowrap;
    }

    .ir-table tbody tr {
        border-bottom: 1px solid #f1f4f8;
        transition: background var(--ir-transition-fast);
    }

        .ir-table tbody tr:last-child {
            border-bottom: none;
        }

        .ir-table tbody tr:hover {
            background: #f8fbff;
        }

    .ir-table td {
        padding: .75rem 1.25rem;
        vertical-align: middle;
        color: #1e2d3d;
    }

.ir-table__cell--name {
    font-weight: 600;
}

.ir-table__cell--email {
    font-size: .88rem;
    color: #374151;
    font-weight: 500;
}

.ir-table__cell--sub {
    font-size: .85rem;
    color: #64748b;
}

.ir-player-badge {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    background: #e8f0fb;
    color: #0f6cbd;
    border-radius: var(--ir-radius-full);
    padding: .2rem .65rem;
    font-size: .8rem;
    font-weight: 600;
    font-family: var(--ir-font-body);
}

.ir-table__empty {
    padding: 2rem 1.5rem;
    text-align: center;
    color: #94a3b8;
    font-size: .875rem;
    font-family: var(--ir-font-body);
}

@media (max-width: 768px) {
    .ir-table thead {
        display: none;
    }

    .ir-table tbody tr {
        display: block;
        padding: .75rem 0;
        border-bottom: 1px solid #edf1f5;
    }

    .ir-table td {
        display: block;
        padding: .4rem 1rem;
    }

        .ir-table td::before {
            content: attr(data-label);
            font-weight: 700;
            font-size: var(--ir-text-xs);
            text-transform: uppercase;
            color: #94a3b8;
            display: block;
            margin-bottom: .15rem;
        }
}


/* --------------------------------------------------------------------------
   19. Icon Action Buttons
   -------------------------------------------------------------------------- */
.ir-actions {
    display: flex;
    align-items: center;
    gap: .25rem;
}

.ir-icon-btn {
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 7px;
    color: #5a6a7e;
    background: transparent;
    border: 1.5px solid transparent;
    cursor: pointer;
    transition: color var(--ir-transition-fast), background var(--ir-transition-fast), border-color var(--ir-transition-fast);
    font-size: .9rem;
    text-decoration: none;
}

    .ir-icon-btn:hover {
        background: #f0f4f8;
        border-color: #d6dce5;
        color: #0f6cbd;
    }

.ir-icon-btn--danger:hover {
    background: #fff5f5;
    border-color: #fca5a5;
    color: #dc2626;
}

.ir-icon-btn--success:hover {
    background: #f0fdf4;
    border-color: #86efac;
    color: #16a34a;
}

@media (max-width: 768px) {
    .ir-actions {
        padding-left: 1rem;
    }
}


/* --------------------------------------------------------------------------
   20. Table Assignment Chips
   -------------------------------------------------------------------------- */
.ir-chips {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
}

.ir-chip {
    display: inline-block;
    padding: .2rem .6rem;
    border-radius: var(--ir-radius-sm);
    background: #f0f4f8;
    border: 1px solid #d6dce5;
    color: #1a3a5c;
    font-size: .78rem;
    font-weight: 500;
    cursor: pointer;
    text-decoration: none;
    transition: background var(--ir-transition-fast), border-color var(--ir-transition-fast), color var(--ir-transition-fast);
    font-family: var(--ir-font-body);
}

    .ir-chip:hover {
        background: #e8f0fb;
        border-color: #0f6cbd;
        color: #0f6cbd;
        text-decoration: none;
    }


/* --------------------------------------------------------------------------
   21. Facilitate Page — Two-Column Layout
   -------------------------------------------------------------------------- */
.ir-facilitate {
    height: calc(100vh - 135px);
    overflow-y: auto;
    padding: var(--ir-space-3) var(--ir-space-4);
    box-sizing: border-box;
    font-family: var(--ir-font-body);
    background: #f4f6f9;
    font-size: 85%; /* scale entire facilitate page to match icon scale */
}

.ir-facilitate__title {
    font-family: var(--ir-font-display);
    font-size: 1.6rem;
    color: #1a3a5c;
    margin-bottom: var(--ir-space-2);
}

    .ir-facilitate__title span {
        color: #0f6cbd;
    }

.ir-facilitate-row {
    display: flex;
    gap: var(--ir-space-4);
    align-items: flex-start;
    margin-bottom: var(--ir-space-4);
}

.ir-facilitate-main {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: var(--ir-space-3);
}

.ir-facilitate-sidebar {
    flex: 0 0 220px;
    width: 220px;
}

@media (max-width: 900px) {
    .ir-facilitate-row {
        flex-direction: column;
    }

    .ir-facilitate-sidebar {
        flex: none;
        width: 100%;
    }
}


/* --------------------------------------------------------------------------
   22. Slide Panel
   -------------------------------------------------------------------------- */
.ir-slide-panel {
    background: #ffffff;
    border-radius: var(--ir-radius-lg);
    box-shadow: 0 2px 4px rgba(0,0,0,.05), 0 8px 24px rgba(0,0,0,.07);
    padding: var(--ir-space-5) var(--ir-space-6);
}

.ir-slide-panel__bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--ir-space-4);
    flex-wrap: wrap;
    gap: var(--ir-space-3);
}

.ir-slide-panel__day-title {
    font-family: var(--ir-font-display);
    font-size: 1.15rem;
    color: #1a3a5c;
    font-weight: 600;
}

.ir-timer {
    font-family: var(--ir-font-body);
    font-size: 2rem;
    font-weight: 700;
    color: #1a3a5c;
    letter-spacing: .04em;
    min-width: 90px;
    text-align: right;
    transition: color var(--ir-transition-base);
}

.ir-timer--warning {
    color: #dc2626;
    animation: ir-pulse-warning 1s ease-in-out infinite;
}

.ir-slide-panel__content {
    font-size: var(--ir-text-base);
    color: #1e2d3d;
    line-height: 1.65;
    font-family: var(--ir-font-body);
}


/* --------------------------------------------------------------------------
   23. Inject Strip  (see section 26 — ir-inject-bar — for full implementation)
   -------------------------------------------------------------------------- */


/* --------------------------------------------------------------------------
   24. Resources Panel
   -------------------------------------------------------------------------- */
.ir-resources-card {
    background: #e8ecf1;
    border-radius: var(--ir-radius-md);
    box-shadow: 0 1px 3px rgba(0,0,0,.07);
    padding: var(--ir-space-3) var(--ir-space-5);
    display: flex;
    align-items: center;
    gap: var(--ir-space-5);
    margin-bottom: var(--ir-space-4);
    flex-wrap: wrap;
}

.ir-resources-card__label {
    font-size: var(--ir-text-xs);
    font-weight: 700;
    letter-spacing: .10em;
    text-transform: uppercase;
    color: #7a8fa6;
    line-height: 1.3;
    font-family: var(--ir-font-body);
    white-space: nowrap;
    flex-shrink: 0;
}

.ir-resources-grid {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--ir-space-4);
    align-items: center;
}

.ir-resource-item {
    display: flex;
    align-items: center;
    gap: var(--ir-space-2);
}

.ir-resource-item__icon {
    font-size: 1.5rem;
    line-height: 1;
    flex-shrink: 0;
}

.ir-resource-item__count {
    font-size: var(--ir-text-sm);
    color: #1a3a5c;
    font-weight: 500;
    white-space: nowrap;
    font-family: var(--ir-font-body);
}

    .ir-resource-item__count span {
        font-weight: 700;
        color: #0f6cbd;
    }


/* --------------------------------------------------------------------------
   25. Role Assignment Cards
   -------------------------------------------------------------------------- */
.ir-roles-grid {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ir-space-4);
    align-items: flex-start;
}

.ir-role-card {
    background: #ffffff;
    border-radius: var(--ir-radius-md);
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
    padding: var(--ir-space-4) var(--ir-space-5);
    flex: 0 0 auto;
    min-width: 140px;
    border: 2px solid #e2e8f0;
    transition: border-color var(--ir-transition-base), box-shadow var(--ir-transition-base);
}

.ir-role-card--occupied {
    border-color: #16a34a;
    box-shadow: 0 2px 12px rgba(22,163,74,.15);
}

.ir-role-card--empty {
    border-color: #dc2626;
    box-shadow: 0 2px 12px rgba(220,38,38,.10);
}

.ir-role-card--default {
    border-color: #0f6cbd;
    box-shadow: 0 2px 12px rgba(15,108,189,.15);
}

/* Name and icons flow inline — mirrors original <big> + inline-block icon pattern */
.ir-role-card__header {
    display: block;
    margin-bottom: var(--ir-space-2);
    line-height: 1.6;
}

/* Name renders as a large inline element so icons follow on the same line */
.ir-role-card__name {
    font-family: var(--ir-font-display);
    font-size: 1.15rem;
    color: #1a3a5c;
    display: inline;
    margin-right: 4px;
}

/* Icons container is also inline so it sits right after the name */
.ir-role-card__icons {
    display: inline;
}

/* Each icon is inline-block: flows with text, no clipping, natural spacing */
.ir-role-card__resource-icon {
    font-size: 1.25rem;
    line-height: 1;
    display: inline-block;
    vertical-align: middle;
    margin: 0 2px;
}

.ir-role-card__limit {
    font-size: var(--ir-text-xs);
    color: #64748b;
    margin-bottom: var(--ir-space-2);
    font-family: var(--ir-font-body);
}

    .ir-role-card__limit strong {
        color: #1a3a5c;
    }

.ir-role-card__users {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.ir-role-card__user {
    font-size: var(--ir-text-sm);
    color: #374151;
    line-height: 1.3;
    font-family: var(--ir-font-body);
}

/* Two-column layout: default role card left, roles grid right */
.ir-roles-layout {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: var(--ir-space-4);
    margin-bottom: var(--ir-space-4);
}

@media (max-width: 768px) {
    .ir-roles-layout {
        grid-template-columns: 1fr;
    }
}


/* --------------------------------------------------------------------------
   26. Inject Bar  (standalone full-width row between slide panel and roles)
   Displays all inject icons for the current slide. Alignment states:
     past      ( < 0 ) = darkred,  muted — already fired, locked
     available ( = 0 ) = grey,     clickable — can be forced now
     done      ( > 0 ) = darkgreen — completed
   -------------------------------------------------------------------------- */
.ir-inject-bar {
    background: #ffffff;
    border-radius: var(--ir-radius-md);
    box-shadow: 0 2px 4px rgba(0,0,0,.05), 0 4px 16px rgba(0,0,0,.06);
    padding: var(--ir-space-3) var(--ir-space-5);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--ir-space-2);
    min-height: 52px;
    margin-bottom: var(--ir-space-4);
}

    /* When there are no injects yet, keep the bar from collapsing */
    .ir-inject-bar:empty::after {
        content: 'No injects for this slide';
        font-size: var(--ir-text-xs);
        color: #94a3b8;
        font-family: var(--ir-font-body);
        font-style: italic;
    }

.ir-inject-icon {
    font-size: 1.5rem;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform var(--ir-transition-fast), opacity var(--ir-transition-fast);
}

.ir-inject-icon--past {
    color: darkred;
    opacity: .65;
}

.ir-inject-icon--available {
    color: #64748b;
    cursor: pointer;
}

    .ir-inject-icon--available:hover {
        transform: scale(1.2);
        opacity: 1;
        color: #0f6cbd;
    }

.ir-inject-icon--done {
    color: darkgreen;
}

/* --------------------------------------------------------------------------
   27. Dashboard Game Page — two-column layout + game info panel + table cards
   -------------------------------------------------------------------------- */

/* Two-column wrapper: slide content left, game info panel right */
.ir-dash-layout {
    display: flex;
    gap: var(--ir-space-6);
    align-items: flex-start;
    margin-bottom: var(--ir-space-6);
}

/* Left column: slide title + slide HTML content */
.ir-dash-layout__main {
    flex: 1 1 0;
    min-width: 0;
}

/* Right column: game info panel — fixed width */
.ir-dash-layout__sidebar {
    flex: 0 0 600px;
    width: 600px;
}

@media (max-width: 1100px) {
    .ir-dash-layout {
        flex-direction: column-reverse;
    }

    .ir-dash-layout__sidebar {
        flex: none;
        width: 100%;
    }
}

/* Slide title — rendered via data-bind="html: model.SlideTitle" */
.ir-slide-title {
    font-family: var(--ir-font-display);
    font-size: 1.3rem;
    color: #1a3a5c;
    margin-bottom: var(--ir-space-3);
    line-height: 1.3;
}

/* Slide HTML content area */
.ir-slide-content {
    height: 420px;
}

/* Game info panel card */
.ir-gameinfo-card {
    background: #ffffff;
    border-radius: var(--ir-radius-lg);
    box-shadow: 0 2px 4px rgba(0,0,0,.05), 0 8px 24px rgba(0,0,0,.07);
    padding: var(--ir-space-5) var(--ir-space-6);
    display: flex;
    flex-direction: column;
    gap: var(--ir-space-4);
}

/* Each timer row: label left, clock right */
.ir-gameinfo-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ir-space-4);
}

.ir-gameinfo-row__label {
    font-size: var(--ir-text-sm);
    font-weight: 600;
    color: #64748b;
    font-family: var(--ir-font-body);
    white-space: nowrap;
}

/* Reuse .ir-timer from section 22 for the clock display */

/* Meta list below the timers */
.ir-gameinfo-meta {
    display: flex;
    flex-direction: column;
    gap: var(--ir-space-2);
    padding-top: var(--ir-space-2);
    border-top: 1px solid #edf1f5;
}

    .ir-gameinfo-meta p {
        margin: 0;
        font-size: var(--ir-text-sm);
        color: #374151;
        font-family: var(--ir-font-body);
    }

    .ir-gameinfo-meta strong {
        color: #1a3a5c;
    }

/* Table cards grid — wraps naturally, each card sizes to content */
.ir-table-cards {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ir-space-4);
    margin-bottom: var(--ir-space-6);
}

.ir-table-card {
    background: #ffffff;
    border-radius: var(--ir-radius-md);
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
    padding: var(--ir-space-4) var(--ir-space-5);
    flex: 0 0 auto;
    min-width: 180px;
    border: 2px solid #e2e8f0;
    transition: border-color var(--ir-transition-base), box-shadow var(--ir-transition-base);
}

    .ir-table-card:hover {
        border-color: #0f6cbd;
        box-shadow: 0 4px 16px rgba(15,108,189,.15);
    }

.ir-table-card__name {
    font-family: var(--ir-font-display);
    font-size: 1.1rem;
    color: #1a3a5c;
    display: block;
    margin-bottom: var(--ir-space-2);
}

.ir-table-card__score {
    font-size: var(--ir-text-sm);
    color: #374151;
    margin-bottom: var(--ir-space-3);
    font-family: var(--ir-font-body);
}

/* Errors section */
.ir-errors-scroll {
    height: 500px;
    overflow-y: auto;
}
