:root {
    --od-accent: #f97316;
    --od-accent-strong: color-mix(in srgb, var(--od-accent), #111827 58%);
    --od-accent-surface: var(--od-accent);
    --od-accent-surface-hover: var(--od-accent-strong);
    --od-accent-ink: #ffffff;
    --od-accent-outline: rgba(0, 0, 0, .82);
    --od-accent-text-shadow:
        0 1px 0 rgba(0, 0, 0, .82),
        1px 0 0 rgba(0, 0, 0, .62),
        -1px 0 0 rgba(0, 0, 0, .62),
        0 -1px 0 rgba(0, 0, 0, .62);
    --od-radius: 8px;
    --od-border-width: 2px;
    --od-divider-width: 2px;
    --od-border: rgba(51, 65, 85, 0.48);
    --od-bg: #eef2f7;
    --od-surface: #ffffff;
    --od-surface-2: #edf2f7;
    --od-surface-soft: #f4f7fb;
    --od-text: #263244;
    --od-heading: #162033;
    --od-muted: #4f5f76;
    --od-tool-bg: #eef2f7;
    --od-tool-surface: #ffffff;
    --od-tool-surface-2: #edf2f7;
    --od-tool-surface-soft: #f4f7fb;
    --od-tool-text: #263244;
    --od-tool-muted: #4f5f76;
    --od-tool-placeholder: #52627a;
    --od-tool-hover: #e2e8f0;
    --od-tool-row-alt: #f4f7fb;
    --od-shadow: 0 16px 34px rgba(15, 23, 42, 0.10);
    color-scheme: light;
}

:root[data-theme="dark"] {
    --od-accent-strong: color-mix(in srgb, var(--od-accent), #fff 28%);
    --od-accent-surface: color-mix(in srgb, var(--od-accent) 82%, #000000);
    --od-accent-surface-hover: color-mix(in srgb, var(--od-accent) 72%, #000000);
    --od-accent-outline: rgba(0, 0, 0, .9);
    --od-accent-text-shadow:
        0 1px 0 rgba(0, 0, 0, .9),
        1px 0 0 rgba(0, 0, 0, .72),
        -1px 0 0 rgba(0, 0, 0, .72),
        0 -1px 0 rgba(0, 0, 0, .72);
    --od-border: rgba(226, 232, 240, 0.28);
    --od-bg: #0b111e;
    --od-surface: #111827;
    --od-surface-2: #182235;
    --od-surface-soft: #151f32;
    --od-text: #eef2f7;
    --od-heading: #f8fafc;
    --od-muted: #a8b3c3;
    --od-tool-bg: #0b111e;
    --od-tool-surface: #111827;
    --od-tool-surface-2: #182235;
    --od-tool-surface-soft: #151f32;
    --od-tool-text: #eef2f7;
    --od-tool-muted: #a8b3c3;
    --od-tool-placeholder: #94a3b8;
    --od-tool-hover: color-mix(in srgb, var(--od-accent) 16%, #111827);
    --od-tool-row-alt: #151f32;
    --od-shadow: 0 18px 42px rgba(0, 0, 0, 0.28);
    color-scheme: dark;
}

* {
    box-sizing: border-box;
}

[x-cloak] {
    display: none !important;
}

html {
    min-width: 0;
    background: var(--od-bg);
    overflow-x: hidden;
}

body.od-body {
    width: 100%;
    max-width: 100%;
    min-height: 100vh;
    margin: 0;
    overflow-x: hidden;
    background: var(--od-bg);
    color: var(--od-text);
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    letter-spacing: 0;
}

h1,
h2,
h3,
h4,
h5,
h6,
.od-brand strong {
    color: var(--od-heading);
}

a {
    color: inherit;
}

.od-container {
    width: min(100% - 32px, 1240px);
    margin-inline: auto;
}

.od-header {
    position: sticky;
    top: 0;
    z-index: 50;
    border-bottom: 1px solid var(--od-border);
    background: color-mix(in srgb, var(--od-surface), transparent 8%);
    backdrop-filter: blur(14px);
}

.od-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 68px;
    gap: 1rem;
}

.od-brand {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    text-decoration: none;
}

.od-brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: var(--od-radius);
    background: var(--od-accent);
    color: white;
    font-weight: 850;
}

.od-brand strong,
.od-brand small {
    display: block;
    line-height: 1.1;
}

.od-brand small,
.od-muted,
.od-page-head p,
.od-panel p,
.od-table small {
    color: var(--od-muted);
}

.od-menu {
    display: flex;
    align-items: center;
    gap: .35rem;
}

.od-menu a,
.od-dropdown > button,
.od-icon-btn,
.od-user-link {
    min-height: 34px;
    border: 1px solid transparent;
    border-radius: var(--od-radius);
    background: transparent;
    color: var(--od-text);
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .45rem .62rem;
    text-decoration: none;
    font-weight: 650;
    font-size: .88rem;
}

.od-menu a:hover,
.od-dropdown > button:hover,
.od-icon-btn:hover,
.od-user-link:hover {
    border-color: color-mix(in srgb, var(--od-accent), transparent 65%);
    background: color-mix(in srgb, var(--od-accent), transparent 88%);
    color: var(--od-accent);
}

.od-dropdown {
    position: relative;
}

.od-dropdown-menu {
    position: absolute;
    top: 100%;
    right: 0;
    z-index: 60;
    display: none;
    min-width: 230px;
    padding: .4rem;
    border: 1px solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface);
    box-shadow: var(--od-shadow);
}

.od-dropdown.is-open .od-dropdown-menu {
    display: grid;
}

@media (hover: hover) {
    .od-dropdown:hover .od-dropdown-menu {
        display: grid;
    }
}

.od-dropdown.is-open > button {
    border-color: color-mix(in srgb, var(--od-accent), transparent 65%);
    background: color-mix(in srgb, var(--od-accent), transparent 88%);
    color: var(--od-accent);
}

.od-dropdown-menu a {
    justify-content: flex-start;
    width: 100%;
}

.od-menu-toggle {
    display: none;
    width: 42px;
    height: 42px;
    border: 1px solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface-2);
    color: var(--od-text);
}

.od-main {
    min-height: calc(100vh - 68px);
    max-width: 100%;
    overflow-x: hidden;
}

.od-landing {
    min-height: calc(100vh - 68px);
    display: grid;
    align-items: center;
    padding: 42px 0;
}

.od-landing-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr);
    gap: clamp(1.4rem, 4vw, 4rem);
    align-items: center;
}

.od-landing-copy h1 {
    margin: .4rem 0 .8rem;
    font-size: clamp(2rem, 5vw, 4.2rem);
    line-height: 1.02;
    font-weight: 850;
    letter-spacing: 0;
}

.od-page-head h1 {
    margin: .35rem 0 .6rem;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.06;
    font-weight: 800;
    letter-spacing: 0;
}

.od-admin .od-page-head {
    padding: 28px 0 16px;
}

.od-admin .od-page-head h1 {
    margin: .25rem 0 .35rem;
    font-size: clamp(1.55rem, 2.2vw, 2rem);
    font-weight: 720;
    line-height: 1.15;
}

.od-admin .od-page-head p:not(.od-kicker) {
    font-size: .92rem;
}

.od-landing-copy p {
    max-width: 680px;
    font-size: 1.05rem;
    line-height: 1.8;
}

.od-kicker,
.od-stat-label {
    margin: 0;
    color: var(--od-accent);
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.od-info-list {
    display: grid;
    gap: .75rem;
    margin-top: 1.4rem;
}

.od-info-list div {
    display: flex;
    align-items: center;
    gap: .75rem;
    color: var(--od-text);
    font-weight: 650;
}

.od-info-list i {
    color: var(--od-accent);
    font-size: 1.15rem;
}

.od-login-panel,
.od-panel {
    border: 1px solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface);
    box-shadow: var(--od-shadow);
}

.od-login-panel {
    padding: clamp(1.25rem, 4vw, 2rem);
}

.od-login-form,
.od-form-grid {
    display: grid;
    gap: 1rem;
    align-content: start;
    align-items: start;
}

.od-login-form h2,
.od-panel h2 {
    margin: .25rem 0 0;
    font-size: 1.35rem;
    font-weight: 800;
}

.od-admin .od-panel h2,
.od-admin .od-modal h2 {
    font-size: 1.15rem;
    font-weight: 720;
}

.od-field {
    display: grid;
    gap: .4rem;
    min-width: 0;
    align-content: start;
}

.od-field span,
.od-check span {
    color: var(--od-muted);
    font-size: .86rem;
    font-weight: 700;
}

.od-field input,
.od-field select,
.od-field textarea,
.od-search input,
.od-table select,
.od-reset-pass input {
    width: 100%;
    min-height: 42px;
    border: 1px solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface-2);
    color: var(--od-text);
    padding: .55rem .7rem;
    outline: none;
}

.od-field input,
.od-field select,
.od-search input,
.od-table select,
.od-reset-pass input {
    height: 42px;
}

.od-readonly-input {
    cursor: default;
    background: color-mix(in srgb, var(--od-muted) 10%, var(--od-surface-2)) !important;
    color: color-mix(in srgb, var(--od-text) 74%, var(--od-muted)) !important;
}

.od-dropdown-menu,
.od-theme-toggle,
.od-login-panel,
.od-panel,
.od-field input,
.od-field select,
.od-field textarea,
.od-search input,
.od-table select,
.od-reset-pass input,
.od-primary-btn,
.od-secondary-btn,
.od-icon-action,
.od-admin-tabs button,
.od-row-actions button,
.od-reset-pass button,
.od-chip,
.od-table-wrap,
.od-modal,
.od-modal-options button {
    border-width: var(--od-border-width);
}

.od-field input[type="color"] {
    min-height: 42px;
    padding: .22rem;
}

.od-color-field {
    gap: .7rem;
}

.od-color-palette {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(126px, 1fr));
    gap: .55rem;
}

.od-profile-grid .od-color-palette {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.od-color-option {
    position: relative;
    min-height: 44px;
    border: var(--od-border-width) solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface-2);
    color: var(--od-text);
    display: flex;
    align-items: center;
    gap: .55rem;
    padding: .5rem .62rem;
    font-weight: 760;
    cursor: pointer;
    transition: border-color .16s ease, background .16s ease, box-shadow .16s ease;
}

.od-color-option input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}

.od-color-swatch {
    width: 24px;
    height: 24px;
    border: 2px solid color-mix(in srgb, var(--swatch), #000 24%);
    border-radius: 999px;
    background: var(--swatch);
    box-shadow: inset 0 0 0 2px rgba(255, 255, 255, .52);
    flex: 0 0 auto;
}

.od-color-name {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--od-text) !important;
    font-size: .82rem !important;
    font-weight: 760 !important;
}

.od-color-option:has(input:checked) {
    border-color: var(--od-accent);
    background: color-mix(in srgb, var(--od-accent) 18%, var(--od-surface));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--od-accent) 20%, transparent);
}

.od-color-option:has(input:focus-visible) {
    border-color: var(--od-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--od-accent), transparent 82%);
}

.od-field input:focus,
.od-field select:focus,
.od-field textarea:focus,
.od-search input:focus,
.od-table select:focus,
.od-reset-pass input:focus {
    border-color: var(--od-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--od-accent), transparent 82%);
}

.od-field small,
.od-error {
    color: #ef4444;
    font-weight: 700;
}

.od-primary-btn {
    min-height: 44px;
    border: 1px solid color-mix(in srgb, var(--od-accent), #000 10%);
    border-radius: var(--od-radius);
    background: var(--od-accent);
    color: var(--od-accent-ink);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: .62rem 1rem;
    font-weight: 800;
    text-decoration: none;
    -webkit-text-stroke: 0 transparent;
    paint-order: stroke fill;
    text-shadow: var(--od-accent-text-shadow);
}

.od-primary-btn:hover {
    color: var(--od-accent-ink);
    background: var(--od-accent-strong);
}

.od-btn-sm {
    min-height: 38px;
    padding: .48rem .85rem;
}

.od-page-head {
    padding: 34px 0 18px;
}

.od-page-head-row,
.od-panel-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}

.od-grid-3,
.od-grid-2,
.od-profile-grid,
.od-admin-layout {
    display: grid;
    gap: 1rem;
}

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

.od-grid-2,
.od-profile-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.od-profile-grid {
    align-items: start;
}

.od-profile-grid .od-panel {
    align-self: start;
}

.od-panel {
    padding: 1rem;
}

.od-panel strong {
    display: block;
    margin-top: .35rem;
    font-size: 1.55rem;
    font-weight: 800;
}

.od-home-events {
    margin-top: 1.2rem;
    padding-bottom: 48px;
}

.od-home-events-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.od-home-events-head h2 {
    margin: .25rem 0 0;
    font-size: clamp(1.25rem, 2vw, 1.7rem);
    font-weight: 800;
}

.od-home-tabs {
    display: inline-flex;
    gap: .35rem;
    padding: .25rem;
    border: 1px solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface);
}

.od-home-tabs button {
    min-height: 36px;
    border: 1px solid transparent;
    border-radius: calc(var(--od-radius) - 2px);
    background: transparent;
    color: var(--od-muted);
    padding: .45rem .72rem;
    font-weight: 800;
}

.od-home-tabs button.is-active {
    border-color: var(--od-accent);
    background: var(--od-accent);
    color: var(--od-accent-ink);
    text-shadow: var(--od-accent-text-shadow);
}

.od-home-tabs span {
    margin-left: .25rem;
    font-size: .75rem;
}

.od-home-events-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .85rem;
    max-height: 318px;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: .45rem;
    scrollbar-color: var(--od-accent) color-mix(in srgb, var(--od-accent) 14%, var(--od-surface-2));
    scrollbar-width: thin;
}

.od-home-events-grid::-webkit-scrollbar {
    width: 10px;
}

.od-home-events-grid::-webkit-scrollbar-track {
    background: color-mix(in srgb, var(--od-accent) 12%, var(--od-surface-2));
    border-radius: 999px;
}

.od-home-events-grid::-webkit-scrollbar-thumb {
    border: 2px solid color-mix(in srgb, var(--od-accent) 12%, var(--od-surface-2));
    border-radius: 999px;
    background: var(--od-accent);
}

.od-home-event-card {
    min-width: 0;
    min-height: 138px;
    border: 1px solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface);
    box-shadow: var(--od-shadow);
    padding: .9rem;
}

.od-home-event-top,
.od-home-event-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .8rem;
}

.od-home-league {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--od-accent);
    font-size: .76rem;
    font-weight: 850;
}

.od-home-time {
    display: inline-flex;
    align-items: center;
    gap: .28rem;
    color: var(--od-heading);
    font-weight: 850;
}

.od-home-teams {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: center;
    gap: .55rem;
    margin: .85rem 0;
}

.od-home-team {
    display: flex;
    align-items: center;
    gap: .6rem;
    min-width: 0;
}

.od-home-team.is-away {
    justify-content: flex-end;
    text-align: right;
}

.od-home-teams strong {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--od-heading);
    font-size: .95rem;
}

.od-home-team-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    flex: 0 0 32px;
    border-radius: var(--od-radius);
    background: color-mix(in srgb, #2563eb 18%, var(--od-surface-2));
    color: #2563eb;
}

.od-home-team-icon.is-away {
    background: color-mix(in srgb, #ec4899 18%, var(--od-surface-2));
    color: #db2777;
}

.od-home-vs {
    width: 34px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--od-accent) 16%, var(--od-surface-2));
    color: var(--od-accent);
    text-align: center;
    font-size: .7rem;
    font-weight: 900;
    text-transform: uppercase;
}

.od-home-event-foot {
    border-top: 1px solid var(--od-border);
    padding-top: .65rem;
    color: var(--od-muted);
    font-size: .78rem;
    font-weight: 700;
}

.od-home-events-state {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .55rem;
    min-height: 96px;
    border: 1px solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface);
    color: var(--od-muted);
    font-weight: 800;
}

.od-home-events-state.is-error {
    border-color: #ef4444;
    color: #ef4444;
}

.od-home-spinner {
    width: 18px;
    height: 18px;
    border: 2px solid color-mix(in srgb, var(--od-accent) 30%, transparent);
    border-top-color: var(--od-accent);
    border-radius: 999px;
    animation: od-spin .8s linear infinite;
}

@keyframes od-spin {
    to {
        transform: rotate(360deg);
    }
}

.od-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.od-span-2 {
    grid-column: 1 / -1;
}

.od-alert {
    grid-column: 1 / -1;
    border: 1px solid color-mix(in srgb, var(--od-accent), transparent 55%);
    border-radius: var(--od-radius);
    background: color-mix(in srgb, var(--od-accent), transparent 88%);
    color: var(--od-text);
    padding: .75rem .9rem;
    font-weight: 800;
}

.od-profile-form .od-panel-head,
.od-password-form .od-panel-head,
.od-profile-form .od-alert,
.od-password-form .od-alert {
    grid-column: 1 / -1;
}

.od-profile-form .od-alert,
.od-password-form .od-alert {
    align-self: start;
    min-height: 0;
    margin: 0;
    padding: .62rem .8rem;
}

.od-profile-form .od-field,
.od-password-form .od-field {
    align-self: start !important;
    height: auto !important;
    min-height: 0 !important;
}

.od-profile-form .od-field input,
.od-profile-form .od-field select,
.od-password-form .od-field input {
    height: 42px !important;
    min-height: 42px !important;
    max-height: 42px !important;
}

.od-profile-form .od-theme-field {
    width: min(100%, 320px);
}

.od-profile-form .od-color-field {
    align-self: start !important;
}

.od-profile-form .od-color-palette {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.od-settings-form {
    display: grid;
    gap: 1rem;
}

.od-settings-head {
    padding-bottom: .85rem;
    border-bottom: 1px solid var(--od-border);
}

.od-settings-card {
    display: grid;
    gap: .9rem;
    border: 1px solid color-mix(in srgb, var(--od-border) 84%, var(--od-accent) 16%);
    border-radius: var(--od-radius);
    background: color-mix(in srgb, var(--od-surface-2) 62%, var(--od-surface));
    padding: .95rem;
}

.od-settings-title h3 {
    margin: .12rem 0 0;
    color: var(--od-heading);
    font-size: 1.05rem;
    font-weight: 820;
}

.od-settings-form .od-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .85rem 1rem;
}

.od-settings-appearance-grid {
    display: grid;
    grid-template-columns: minmax(230px, .42fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

.od-settings-form .od-color-palette {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.od-settings-theme-field {
    width: 100%;
}

.od-settings-form .od-field textarea {
    min-height: 92px;
    resize: vertical;
}

.od-admin-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
}

.od-admin-tabs button,
.od-row-actions button,
.od-reset-pass button,
.od-chip {
    border: 1px solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface);
    color: var(--od-text);
    padding: .45rem .65rem;
    font-weight: 700;
}

.od-admin-tabs button.is-active,
.od-admin-tabs button:hover,
.od-row-actions button:hover,
.od-reset-pass button:hover {
    border-color: var(--od-accent);
    color: var(--od-accent);
}

/* Admin tabs reuse the clean line-tab pattern from the calculators. */
.od-admin-tabs.od-line-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: .15rem;
    align-items: flex-end;
    padding: 0 .05rem;
    border-bottom: 1px solid color-mix(in srgb, var(--od-accent) 58%, var(--od-border));
}

.od-admin-tabs.od-line-tabs .od-line-tab {
    position: relative;
    min-height: 42px;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: var(--od-muted);
    padding: .68rem .86rem .76rem;
    font-size: .88rem;
    font-weight: 780;
    line-height: 1.1;
    box-shadow: none !important;
    text-shadow: none !important;
    transition: color .16s ease, background .16s ease;
}

.od-admin-tabs.od-line-tabs .od-line-tab::after {
    content: "";
    position: absolute;
    left: .36rem;
    right: .36rem;
    bottom: -1px;
    height: 3px;
    border-radius: 999px 999px 0 0;
    background: transparent;
}

.od-admin-tabs.od-line-tabs .od-line-tab:hover,
.od-admin-tabs.od-line-tabs .od-line-tab:focus {
    background: color-mix(in srgb, var(--od-accent) 8%, transparent) !important;
    color: var(--od-heading);
}

.od-admin-tabs.od-line-tabs .od-line-tab.is-active {
    background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--od-accent) 11%, transparent)) !important;
    color: var(--od-accent);
    font-weight: 900;
}

.od-admin-tabs.od-line-tabs .od-line-tab.is-active::after {
    background: var(--od-accent);
    box-shadow: 0 0 14px color-mix(in srgb, var(--od-accent) 44%, transparent);
}

:root[data-theme="dark"] .od-admin-tabs.od-line-tabs {
    border-bottom-color: color-mix(in srgb, var(--od-accent) 62%, #243247);
}

:root[data-theme="dark"] .od-admin-tabs.od-line-tabs .od-line-tab {
    color: #9aa8bb;
}

:root[data-theme="dark"] .od-admin-tabs.od-line-tabs .od-line-tab:hover,
:root[data-theme="dark"] .od-admin-tabs.od-line-tabs .od-line-tab:focus {
    background: color-mix(in srgb, var(--od-accent) 10%, transparent) !important;
    color: #eef6ff;
}

:root[data-theme="dark"] .od-admin-tabs.od-line-tabs .od-line-tab.is-active {
    color: color-mix(in srgb, var(--od-accent) 76%, #ffffff);
    background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--od-accent) 16%, transparent)) !important;
}

.od-admin-layout {
    grid-template-columns: 1fr;
}

.od-admin-users-layout {
    place-items: start stretch;
}

.od-admin-users-panel {
    width: 100%;
}

.od-panel-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: .65rem;
    flex-wrap: wrap;
}

.od-search {
    position: relative;
    width: min(100%, 360px);
}

.od-search i {
    position: absolute;
    top: 50%;
    left: .72rem;
    transform: translateY(-50%);
    color: var(--od-muted);
}

.od-search input {
    padding-left: 2.1rem;
}

.od-table-wrap {
    width: 100%;
    margin-top: 1rem;
    overflow-x: auto;
    border: 1px solid var(--od-border);
    border-radius: var(--od-radius);
}

.od-table {
    width: 100%;
    min-width: 860px;
    border-collapse: collapse;
}

.od-table th,
.od-table td {
    padding: .72rem .8rem;
    border-bottom: var(--od-divider-width) solid var(--od-border);
    border-right: var(--od-divider-width) solid var(--od-border);
    vertical-align: middle;
}

.od-table th:last-child,
.od-table td:last-child {
    border-right: 0;
}

.od-table tbody tr:hover > * {
    background: color-mix(in srgb, var(--od-accent), transparent 94%);
}

.od-table th {
    color: var(--od-muted);
    font-size: .78rem;
    font-weight: 680;
    text-transform: uppercase;
    background: var(--od-surface-soft);
}

.od-table td strong,
.od-table td small {
    display: block;
}

.od-table td strong {
    margin: 0 0 .15rem;
    font-size: .95rem;
    font-weight: 680;
}

.od-table td small {
    line-height: 1.35;
}

.od-row-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
}

.od-table-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
}

.od-admin-plan-panel {
    width: 100%;
}

.od-plan-table-wrap {
    margin-top: .85rem;
}

.od-plan-table {
    min-width: 1080px;
}

.od-plan-table th {
    background: color-mix(in srgb, var(--od-accent) 14%, var(--od-surface-soft));
    color: var(--od-heading);
}

.od-plan-table td {
    vertical-align: top;
}

.od-plan-code-cell {
    min-width: 150px;
}

.od-tier-code {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    border: 1px solid color-mix(in srgb, var(--od-accent) 54%, var(--od-border));
    border-radius: 999px;
    background: color-mix(in srgb, var(--od-accent) 12%, var(--od-surface));
    color: var(--od-accent);
    padding: .22rem .55rem;
    font-size: .76rem;
    font-weight: 850;
}

.od-table-input,
.od-table-textarea {
    width: 100%;
    border: var(--od-border-width) solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface-2);
    color: var(--od-text);
    padding: .52rem .62rem;
    outline: none;
}

.od-table-input {
    height: 40px;
}

.od-table-textarea {
    min-height: 72px;
    resize: vertical;
}

.od-number-input {
    min-width: 100px;
}

.od-table-input:focus,
.od-table-textarea:focus {
    border-color: var(--od-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--od-accent), transparent 82%);
}

.od-plan-table .od-check-compact {
    min-height: 40px;
    align-items: center;
    white-space: nowrap;
}

.od-plan-table .od-primary-btn {
    width: 100%;
    min-width: 92px;
}

.od-access-stack {
    display: grid;
    gap: .15rem;
}

.od-access-stack span {
    color: var(--od-text);
    font-weight: 680;
}

.od-muted-line {
    margin: .15rem 0 0;
    color: var(--od-muted);
    font-size: .9rem;
}

.od-row-actions .is-danger {
    color: #ef4444;
}

.od-chip.is-ok {
    color: #16a34a;
    border-color: color-mix(in srgb, #16a34a, transparent 50%);
}

.od-chip.is-danger {
    color: #ef4444;
    border-color: color-mix(in srgb, #ef4444, transparent 50%);
}

.od-reset-pass {
    display: grid;
    grid-template-columns: minmax(130px, 1fr) auto;
    gap: .4rem;
}

.od-check {
    display: flex;
    align-items: center;
    gap: .5rem;
}

.od-check input {
    width: 18px;
    height: 18px;
    accent-color: var(--od-accent);
}

input[type="checkbox"],
input[type="radio"] {
    accent-color: var(--od-accent);
}

::placeholder {
    color: var(--od-tool-placeholder);
    opacity: 1;
}

.od-secondary-btn,
.od-icon-action {
    border: 1px solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface);
    color: var(--od-text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .45rem;
    font-weight: 750;
}

.od-secondary-btn {
    min-height: 38px;
    padding: .5rem .85rem;
}

.od-icon-action {
    width: 36px;
    height: 36px;
    padding: 0;
}

.od-secondary-btn:hover,
.od-icon-action:hover {
    border-color: var(--od-accent);
    background: color-mix(in srgb, var(--od-accent), transparent 90%);
    color: var(--od-accent);
}

.od-modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1065;
    display: grid;
    place-items: center;
    padding: 1rem;
    background: color-mix(in srgb, var(--od-bg), transparent 22%);
    backdrop-filter: blur(8px);
}

.od-modal {
    width: min(720px, 94vw);
    max-height: calc(100vh - 2rem);
    overflow: auto;
    border: 1px solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface);
    color: var(--od-text);
    box-shadow: var(--od-shadow);
    padding: 1rem;
}

.od-modal-sm {
    width: min(460px, 94vw);
}

.od-modal-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: .75rem;
    border-bottom: 1px solid var(--od-border);
}

.od-modal-actions {
    display: flex;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: .6rem;
    padding-top: .75rem;
}

.od-modal-options {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .55rem;
    padding: .9rem 0 .4rem;
}

.od-modal-options button {
    min-height: 40px;
    border: 1px solid var(--od-border);
    border-radius: var(--od-radius);
    background: var(--od-surface-2);
    color: var(--od-text);
    font-weight: 680;
}

.od-modal-options button:hover {
    border-color: var(--od-accent);
    background: color-mix(in srgb, var(--od-accent) 16%, var(--od-surface));
    color: var(--od-accent-strong);
}

.od-modal-options button.is-selected {
    border-color: var(--od-accent);
    background: color-mix(in srgb, var(--od-accent) 22%, var(--od-surface));
    color: var(--od-accent-strong);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--od-accent) 20%, transparent);
}

.od-modal-field-inline {
    margin-top: .6rem;
}

.od-secondary-btn.is-danger {
    color: #dc2626;
    border-color: color-mix(in srgb, #dc2626, transparent 58%);
}

.od-autofill-decoy {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
}

.od-pagination {
    margin-top: 1rem;
}

.od-tool-narrow {
    width: min(100% - 32px, 960px);
    margin: 24px auto;
}

.btn,
.form-control,
.form-select,
.card,
.table {
    border-radius: var(--od-radius);
}

@media (max-width: 1080px) {
    .od-admin-layout,
    .od-landing-grid,
    .od-home-events-grid,
    .od-grid-3,
    .od-grid-2,
    .od-profile-grid,
    .od-settings-appearance-grid {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 721px) and (max-width: 1080px) {
    .od-home-events-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-height: 456px;
    }
}

@media (max-width: 720px) {
    .od-home-events-head {
        align-items: stretch;
        display: grid;
    }

    .od-home-tabs {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        width: 100%;
    }

    .od-home-tabs button {
        width: 100%;
    }

    .od-home-events-grid {
        max-height: 72vh;
        padding-right: .35rem;
    }

    .od-profile-grid .od-color-palette,
    .od-settings-form .od-color-palette {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 420px) {
    .od-profile-grid .od-color-palette,
    .od-settings-form .od-color-palette,
    .od-settings-form .od-form-grid,
    .od-profile-grid .od-form-grid {
        grid-template-columns: 1fr;
    }

    .od-profile-grid .od-span-2,
    .od-settings-form .od-span-2 {
        grid-column: auto;
    }
}

@media (max-width: 860px) {
    .od-menu-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .od-menu {
        position: fixed;
        top: 68px;
        left: 0;
        right: 0;
        display: none;
        grid-template-columns: 1fr;
        gap: .25rem;
        padding: .75rem 1rem 1rem;
        border-bottom: 1px solid var(--od-border);
        background: var(--od-surface);
        box-shadow: var(--od-shadow);
    }

    .od-menu.is-open {
        display: grid;
    }

    .od-dropdown-menu {
        position: static;
        display: none;
        box-shadow: none;
        margin-top: .35rem;
    }

    .od-dropdown.is-open .od-dropdown-menu {
        display: grid;
    }

    .od-user-link,
    .od-menu a,
    .od-dropdown > button {
        justify-content: space-between;
        width: 100%;
    }
}

@media (max-width: 640px) {
    .od-container {
        width: min(100% - 20px, 1240px);
        min-width: 0;
        max-width: calc(100vw - 20px);
    }

    .od-header,
    .od-main,
    .od-nav {
        width: 100%;
        max-width: 100vw;
        overflow-x: clip;
    }

    .od-brand {
        min-width: 0;
        flex: 1 1 auto;
    }

    .od-brand > span:last-child {
        min-width: 0;
    }

    .od-brand strong,
    .od-brand small {
        max-width: 190px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .od-landing {
        align-items: start;
        padding-top: 24px;
    }

    .od-form-grid {
        grid-template-columns: 1fr;
    }

    .od-page-head-row,
    .od-panel-head {
        display: grid;
    }

    .od-panel-actions,
    .od-search {
        width: 100%;
    }

    .od-panel-actions .od-primary-btn {
        width: 100%;
    }

    .od-modal {
        grid-template-columns: 1fr;
    }

    .od-modal-head,
    .od-modal-actions {
        grid-column: 1;
    }
}
