/* StreetHunter panel-web — port visual real desde PanelWebDiseñoEjemplo/Ciser */
:root {
    color-scheme: light dark;
    --sidebar-w: 300px;
    --font-ui: Inter, "Segoe UI", Roboto, Arial, sans-serif;

    --brand-rgb: 126, 211, 95;
    --brand: #7ed35f;
    --brand-strong: #5faa40;
    --brand-soft: #b8ea72;
    --brand-glow: rgba(var(--brand-rgb), 0.22);
    --accent-orange: #ff8a22;
    --accent-cyan: #21b8d7;
    --danger: #dc3545;
    --danger-soft: rgba(220, 53, 69, 0.13);

    --text-primary: #1e2124;
    --text-secondary: #5a6270;
    --text-heading: #111317;
    --surface-page: #f0f2f5;
    --surface-1: rgba(255,255,255,0.94);
    --surface-2: #f5f7fa;
    --surface-3: #edf2f7;
    --border-subtle: #dce2ea;
    --sidebar-bg: rgba(255,255,255,0.94);
    --sidebar-border: #dce2ea;
    --topbar-bg: rgba(255,255,255,0.9);
    --topbar-border: #dce2ea;
    --card-bg: rgba(255,255,255,0.94);
    --card-shadow: 0 2px 12px rgba(0,0,0,0.08);
    --card-hover-shadow: 0 14px 32px rgba(var(--brand-rgb), 0.20);
    --input-bg: #ffffff;
    --input-border: #c8cdd5;
    --input-text: #1e2124;
    --table-header-bg: #f5f7fa;
    --table-row-hover-bg: rgba(var(--brand-rgb), 0.06);
    --body-overlay: linear-gradient(135deg, rgba(244,247,242,0.82), rgba(250,252,247,0.78));
    --login-overlay: linear-gradient(135deg, rgba(230,239,219,0.72), rgba(247,250,241,0.66), rgba(225,237,218,0.72));
    --login-panel-bg: rgba(255,255,255,0.78);
    --login-panel-border: rgba(var(--brand-rgb), 0.34);
    --login-shadow: 0 20px 60px rgba(0,0,0,0.14), 0 0 0 1px rgba(var(--brand-rgb),0.10), inset 0 1px 0 rgba(255,255,255,0.9);
    
    /* Branding Assets */
    --logo-stacked: url("assets/brand/logo-stacked-light.png");
    --logo-horizontal: url("assets/brand/logo-horizontal-light.png");
}

[data-theme="dark"] {
    color-scheme: dark;
    --brand-rgb: 144, 196, 63;
    --brand: #90c43f;
    --brand-strong: #7aad36;
    --brand-soft: #b5e063;
    --brand-glow: rgba(var(--brand-rgb), 0.26);
    --accent-orange: #ff9d34;
    --accent-cyan: #28c7df;
    --danger: #ff6b7a;
    --danger-soft: rgba(255, 107, 122, 0.14);

    --text-primary: #e9ecef;
    --text-secondary: #b6bfd0;
    --text-heading: #f4f6fc;
    --surface-page: #080c14;
    --surface-1: rgba(27, 31, 37, 0.90);
    --surface-2: rgba(255,255,255,0.055);
    --surface-3: rgba(255,255,255,0.09);
    --border-subtle: rgba(255,255,255,0.12);
    --sidebar-bg: rgba(10, 14, 22, 0.86);
    --sidebar-border: rgba(var(--brand-rgb),0.16);
    --topbar-bg: rgba(10, 14, 22, 0.88);
    --topbar-border: rgba(255,255,255,0.08);
    --card-bg: rgba(28, 32, 38, 0.90);
    --card-shadow: 0 4px 24px rgba(0,0,0,0.45);
    --card-hover-shadow: 0 16px 40px rgba(var(--brand-rgb), 0.26);
    --input-bg: rgba(255,255,255,0.07);
    --input-border: rgba(255,255,255,0.14);
    --input-text: #f0f2f8;
    --table-header-bg: rgba(255,255,255,0.06);
    --table-row-hover-bg: rgba(255,255,255,0.05);
    --body-overlay: linear-gradient(135deg, rgba(5,8,13,0.72), rgba(6,16,10,0.62), rgba(5,8,13,0.78));
    --login-overlay: linear-gradient(135deg, rgba(0,0,0,0.58), rgba(6,20,6,0.46), rgba(0,0,0,0.62));
    --login-panel-bg: rgba(12,17,14,0.76);
    --login-panel-border: rgba(var(--brand-rgb), 0.28);
    --login-shadow: 0 25px 65px rgba(0,0,0,0.60), 0 0 0 1px rgba(255,255,255,0.04), inset 0 1px 0 rgba(255,255,255,0.07);

    /* Branding Assets */
    --logo-stacked: url("assets/brand/logo-stacked.png");
    --logo-horizontal: url("assets/brand/logo-horizontal.png");
}

* { box-sizing: border-box; }
html { min-height: 100%; scrollbar-gutter: stable; }
body {
    min-height: 100vh;
    margin: 0;
    font-family: var(--font-ui);
    background: var(--surface-page);
    color: var(--text-primary);
    overflow-y: scroll;
    transition: background-color .35s ease, color .35s ease;
}

body::before,
body::after {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
}

body::before {
    z-index: -2;
    background: url("img/EstadioVallecas.jpeg") center / cover no-repeat;
}

body::after {
    z-index: -1;
    background: var(--body-overlay);
}

button,
input,
select,
textarea { font: inherit; }
button { cursor: pointer; }
button:disabled { cursor: wait; opacity: .72; }

.icon,
.btn-icon,
.nav-icon,
.empty-state-icon {
    display: inline-block;
    width: 1.1em;
    height: 1.1em;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    flex: 0 0 auto;
}
.icon-lg { width: 1.45em; height: 1.45em; }
.btn-icon { width: 16px; height: 16px; }
.nav-icon { width: 21px; height: 21px; }

/* Identidad Visual - Logos */
.logo-stacked-image {
    width: 220px;
    height: 84px;
    background-image: var(--logo-stacked);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    transition: background-image 0.3s ease;
}

.logo-horizontal-image {
    width: 196px;
    height: 48px;
    background-image: var(--logo-horizontal);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: left center;
    transition: background-image 0.3s ease;
}

.brand-logo-horizontal {
    height: 44px;
    width: auto;
    object-fit: contain;
    display: block;
}

.brand-logo-stacked {
    height: 72px;
    width: auto;
    object-fit: contain;
    display: block;
}

.brand-icon-symbol {
    height: 32px;
    width: auto;
    object-fit: contain;
    display: block;
}

/* Contenedores de logos para pulido visual */
.brand-logo-stacked-container {
    margin-bottom: 12px;
    display: flex;
    justify-content: center;
}

.brand-logo-horizontal-container {
    display: flex;
    align-items: center;
}

/* Cápsula oscura (mejorada) */
.logo-dark-capsule {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    transition: all 0.3s ease;
}

[data-theme="light"] .logo-dark-capsule {
    /* Ya no es una cápsula oscura pegada si usamos el logo light */
    background-color: transparent;
    padding: 0;
}

[data-theme="dark"] .logo-dark-capsule {
    background-color: transparent;
    padding: 0;
}

/* LOGIN — arquitectura Ciser */
.login-wrapper {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 34px;
    overflow: hidden;
}

.login-bg-layer {
    position: fixed;
    inset: 0;
    background: url("img/EstadioVallecas.jpeg") center / cover no-repeat;
    z-index: 0;
}

.login-bg-layer::after {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--login-overlay);
    transition: background .45s ease;
}

.login-panel {
    position: relative;
    z-index: 2;
    width: min(430px, 100%);
    padding: 46px 44px 38px;
    text-align: center;
    border: 1px solid var(--login-panel-border);
    border-radius: 20px;
    background: var(--login-panel-bg);
    box-shadow: var(--login-shadow);
    backdrop-filter: blur(22px) saturate(1.45);
    -webkit-backdrop-filter: blur(22px) saturate(1.45);
    animation: panelEnter .62s cubic-bezier(.22,1,.36,1) both;
}

@keyframes panelEnter {
    from { opacity: 0; transform: translateY(28px) scale(.965); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

.login-brand {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 13px;
    margin: 0 auto 20px;
}

.brand-emblem,
.sidebar-brand-icon,
.card-icon,
.form-module-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 15px;
    background: var(--brand-glow);
    color: var(--brand);
    border: 1px solid rgba(var(--brand-rgb), .28);
}

.brand-emblem { width: 52px; height: 52px; box-shadow: 0 0 22px var(--brand-glow); }
.login-brand-text { display: grid; text-align: left; line-height: 1.1; }
.login-brand-text strong { color: var(--text-heading); font-size: 1.14rem; letter-spacing: -.02em; }
.login-brand-text span { color: var(--text-secondary); font-size: .74rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }

.login-divider {
    height: 1px;
    margin: 0 0 22px;
    background: linear-gradient(90deg, transparent, rgba(var(--brand-rgb), .48), transparent);
}

.login-title {
    margin: 0 0 8px;
    color: var(--text-heading);
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.login-subtitle {
    margin: 0 0 26px;
    color: var(--text-secondary);
    font-size: .88rem;
    line-height: 1.55;
}

.login-form { display: grid; gap: 15px; }
.input-group {
    display: flex;
    align-items: center;
    min-height: 48px;
    border: 1px solid var(--input-border);
    border-radius: 10px;
    background: var(--input-bg);
    color: var(--input-text);
    overflow: hidden;
    transition: border-color .2s ease, box-shadow .2s ease, background .25s ease;
}
.input-group:focus-within {
    border-color: var(--brand);
    box-shadow: 0 0 0 .2rem rgba(var(--brand-rgb), .18);
}
.input-icon {
    width: 48px;
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--brand);
    border-right: 1px solid var(--input-border);
    background: rgba(var(--brand-rgb), .07);
}
.input-group input {
    min-width: 0;
    flex: 1;
    height: 48px;
    border: 0;
    outline: 0;
    padding: 0 14px;
    background: transparent;
    color: var(--input-text);
}
.input-group input::placeholder { color: color-mix(in srgb, var(--text-secondary) 75%, transparent); }
.login-password-toggle {
    align-self: stretch;
    min-width: 82px;
    padding: 0 13px;
    border: 0;
    border-left: 1px solid var(--input-border);
    background: var(--surface-2);
    color: var(--text-secondary);
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.login-password-toggle:hover { color: var(--brand); }
.login-footer {
    margin: 21px 0 0;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    color: var(--text-secondary);
    font-size: .76rem;
}

.theme-toggle-login {
    position: fixed;
    right: 26px;
    bottom: 24px;
    z-index: 30;
    width: 46px;
    height: 46px;
    overflow: hidden;
    text-indent: -999px;
    border-radius: 999px;
    border: 1px solid var(--login-panel-border);
    background: var(--login-panel-bg);
    box-shadow: 0 4px 18px rgba(0,0,0,.22);
    backdrop-filter: blur(16px);
}
.theme-toggle-login::before {
    content: "◐";
    text-indent: 0;
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    color: var(--brand);
    font-size: 1.2rem;
}
.theme-toggle-login:hover { transform: rotate(18deg) scale(1.08); border-color: var(--brand); }

/* ADMIN LAYOUT */
.admin-layout {
    min-height: 100vh;
    grid-template-columns: var(--sidebar-w) minmax(0,1fr);
}

.sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    width: var(--sidebar-w);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background: var(--sidebar-bg);
    border-right: 1px solid var(--sidebar-border);
    z-index: 50;
    backdrop-filter: blur(18px) saturate(1.25);
    -webkit-backdrop-filter: blur(18px) saturate(1.25);
}

.sidebar-logo-box {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 28px 24px 22px;
}
.sidebar-brand-icon { width: 50px; height: 50px; }
.sidebar-brand-text { display: grid; gap: 3px; }
.sidebar-brand-text span {
    color: var(--brand);
    font-size: .72rem;
    font-weight: 850;
    letter-spacing: .13em;
    text-transform: uppercase;
}
.sidebar-brand-text strong {
    color: var(--text-heading);
    font-size: 1.35rem;
    line-height: 1;
    letter-spacing: -.035em;
}

.sidebar-primary-action {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin: 0 24px 14px;
    min-height: 44px;
    border: 0;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--brand), var(--brand-strong));
    color: #10150c;
    font-size: .86rem;
    font-weight: 850;
    letter-spacing: .02em;
    box-shadow: 0 14px 28px rgba(var(--brand-rgb), .24);
}
.sidebar-primary-action:hover { filter: brightness(1.05); transform: translateY(-1px); }

.sidebar-nav {
    flex: 1;
    padding: 12px 0 18px;
    overflow-y: auto;
}
.sidebar-link,
.nav-link {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 48px;
    padding: 13px 24px;
    border: 0;
    border-left: 3px solid transparent;
    background: transparent;
    color: var(--text-secondary);
    text-align: left;
    font-size: .9rem;
    font-weight: 650;
    transition: color .18s ease, background .18s ease, border-color .18s ease;
}
.sidebar-link:hover,
.nav-link:hover {
    color: var(--brand);
    background: rgba(var(--brand-rgb), .08);
}
.sidebar-link.active,
.nav-link.active {
    color: var(--brand);
    background: rgba(var(--brand-rgb), .13);
    border-left-color: var(--brand);
    font-weight: 800;
}

.sidebar-system-card {
    margin: 0 24px 18px;
    padding: 15px;
    border-radius: 12px;
    border: 1px solid var(--border-subtle);
    background: var(--surface-2);
    display: grid;
    gap: 5px;
}
.sidebar-system-card span {
    color: var(--accent-cyan);
    font-size: .68rem;
    font-weight: 850;
    letter-spacing: .12em;
    text-transform: uppercase;
}
.sidebar-system-card strong { color: var(--text-heading); }
.sidebar-system-card small { color: var(--text-secondary); }
.sidebar-footer {
    padding: 16px 24px;
    border-top: 1px solid var(--border-subtle);
}

.main-wrapper,
.main-content {
    min-height: 100vh;
    margin-left: var(--sidebar-w);
    display: flex;
    flex-direction: column;
    position: relative;
}
.main-wrapper::before {
    content: "";
    position: absolute;
    inset: 0;
    background: url("img/EstadioVallecas.jpeg") top center / cover no-repeat;
    opacity: .16;
    z-index: -1;
    pointer-events: none;
    -webkit-mask-image: linear-gradient(to bottom, black 0%, black 72%, transparent 100%);
    mask-image: linear-gradient(to bottom, black 0%, black 72%, transparent 100%);
}
[data-theme="dark"] .main-wrapper::before { opacity: .11; }

.topbar {
    position: sticky;
    top: 0;
    z-index: 20;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    min-height: 78px;
    padding: 17px 30px;
    background: var(--topbar-bg);
    border-bottom: 1px solid var(--topbar-border);
    backdrop-filter: blur(18px) saturate(1.25);
    -webkit-backdrop-filter: blur(18px) saturate(1.25);
}
.topbar-title-block { min-width: 0; }
.topbar-title {
    margin: 2px 0 0;
    color: var(--text-heading);
    font-size: 1.18rem;
    font-weight: 800;
    letter-spacing: -.015em;
}
.topbar-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }

.content-area {
    flex: 1;
    padding: 28px 30px 42px;
    position: relative;
    z-index: 2;
}
.content-view { display: none; }
.content-view.active { display: block; animation: moduleIn .22s ease both; }
@keyframes moduleIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }

/* COMPONENTES Ciser-like */
.section-kicker,
.kpi-label,
.preview-label {
    margin: 0;
    color: var(--brand);
    font-size: .72rem;
    font-weight: 850;
    letter-spacing: .1em;
    text-transform: uppercase;
}
.muted-text,
.small-text,
.table-description { color: var(--text-secondary); }
.small-text { margin: 3px 0 0; font-size: .83rem; line-height: 1.45; }
.module-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 20px;
}
.module-heading.compact { margin-bottom: 18px; }
.module-heading h2,
.hero-card h2,
.panel-card h2,
.form-module h3,
.poi-mobile-card h3 {
    margin: 4px 0 0;
    color: var(--text-heading);
    line-height: 1.08;
    letter-spacing: -.025em;
}
.module-heading h2 { font-size: clamp(1.45rem, 2.2vw, 2rem); }
.module-heading .muted-text { margin: 7px 0 0; }
.module-heading-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }

.card,
.panel-card,
.hero-card,
.stat-card {
    background: var(--card-bg);
    border: 1px solid transparent;
    border-top: 4px solid var(--brand);
    border-radius: 10px;
    box-shadow: var(--card-shadow);
    color: var(--text-primary);
    transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease, background .35s ease;
}
[data-theme="dark"] .card,
[data-theme="dark"] .panel-card,
[data-theme="dark"] .hero-card,
[data-theme="dark"] .stat-card {
    border-color: rgba(255,255,255,.08);
    border-top-color: var(--brand);
}
.card:hover,
.panel-card:hover,
.hero-card:hover,
.stat-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--card-hover-shadow);
}
.card-body { padding: 22px; }
.card-body-horizontal { display: flex; align-items: center; gap: 16px; }
.card-icon { width: 52px; height: 52px; font-size: 1.4rem; }
.card-title {
    margin: 0 0 2px;
    color: var(--text-secondary);
    font-size: .78rem;
    font-weight: 850;
    letter-spacing: .07em;
    text-transform: uppercase;
}
.stat-number {
    display: block;
    color: var(--text-heading);
    font-size: clamp(2rem, 4vw, 3.15rem);
    line-height: .95;
    letter-spacing: -.04em;
}
.stat-card-warning { border-top-color: var(--accent-orange); }
.stat-card-info { border-top-color: var(--accent-cyan); }
.stat-card-warning .card-icon { color: var(--accent-orange); background: rgba(255,138,34,.14); border-color: rgba(255,138,34,.26); }
.stat-card-info .card-icon { color: var(--accent-cyan); background: rgba(33,184,215,.14); border-color: rgba(33,184,215,.28); }

.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0,1fr));
    gap: 18px;
    margin-bottom: 18px;
}
.dashboard-lower-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(300px, .75fr);
    gap: 18px;
}
.hero-card-main,
.insight-card,
.table-panel,
.form-panel,
.preview-card { padding: 22px; }
.hero-card-header { display: flex; align-items: center; gap: 15px; margin-bottom: 14px; }
.hero-icon { width: 54px; height: 54px; }
.hero-text { margin: 0; max-width: 72ch; color: var(--text-secondary); line-height: 1.65; }
.mini-status-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 12px;
    margin-top: 20px;
}
.mini-status-item,
.preview-metric,
.preview-coords > div,
.kpi-card {
    padding: 14px;
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    background: var(--surface-2);
}
.mini-status-item span,
.preview-metric span,
.preview-coords span {
    display: block;
    color: var(--text-secondary);
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .07em;
    text-transform: uppercase;
}
.mini-status-item strong,
.preview-metric strong,
.preview-coords strong {
    display: block;
    margin-top: 4px;
    color: var(--text-heading);
    font-size: 1.35rem;
}
.insight-card .card-body { padding: 0; }
.insight-number {
    margin-top: 20px;
    color: var(--brand);
    font-size: clamp(3rem, 8vw, 5.3rem);
    font-weight: 900;
    line-height: .9;
    letter-spacing: -.06em;
}

/* Botones */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 40px;
    padding: 10px 15px;
    border-radius: 10px;
    border: 1px solid transparent;
    font-size: .84rem;
    font-weight: 800;
    line-height: 1;
    text-decoration: none;
    transition: transform .16s ease, box-shadow .16s ease, background .16s ease, border-color .16s ease, color .16s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0) scale(.985); }
.btn-primary {
    background: linear-gradient(135deg, var(--brand), var(--brand-strong));
    color: #10150c;
    box-shadow: 0 12px 24px rgba(var(--brand-rgb), .22);
}
.btn-secondary {
    background: var(--surface-2);
    color: var(--text-heading);
    border-color: var(--border-subtle);
}
.btn-secondary:hover { border-color: rgba(var(--brand-rgb), .42); color: var(--brand); }
.btn-outline,
.btn-outline-danger {
    width: 100%;
    background: transparent;
    color: var(--danger);
    border-color: color-mix(in srgb, var(--danger) 70%, transparent);
}
.btn-outline-danger:hover,
.btn-outline:hover { background: var(--danger-soft); color: var(--danger); }
.btn-danger {
    background: var(--danger-soft);
    color: var(--danger);
    border-color: color-mix(in srgb, var(--danger) 45%, transparent);
}
.btn-small { min-height: 34px; padding: 8px 11px; font-size: .76rem; border-radius: 8px; }
.btn.is-busy::after,
.btn-login-submit.is-busy::after {
    content: "";
    width: 12px;
    height: 12px;
    border-radius: 999px;
    border: 2px solid currentColor;
    border-right-color: transparent;
    animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Alerts / estado */
.alert {
    margin: 0 0 14px;
    padding: 12px 14px;
    border-radius: 10px;
    border: 1px solid var(--border-subtle);
    font-size: .86rem;
    line-height: 1.45;
}
.alert-login { text-align: left; margin-bottom: 16px; }
.alert-success { background: rgba(var(--brand-rgb), .14); border-color: rgba(var(--brand-rgb), .28); color: var(--brand); }
.alert-error { background: var(--danger-soft); border-color: color-mix(in srgb, var(--danger) 35%, transparent); color: var(--danger); }
.status-pill {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 0 13px;
    border-radius: 999px;
    border: 1px solid rgba(var(--brand-rgb), .26);
    background: rgba(var(--brand-rgb), .12);
    color: var(--brand);
    font-size: .75rem;
    font-weight: 850;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.status-pill[data-state="error"] { color: var(--danger); background: var(--danger-soft); border-color: color-mix(in srgb, var(--danger) 34%, transparent); }
.status-pill[data-state="loading"] { color: var(--accent-cyan); background: rgba(33,184,215,.12); border-color: rgba(33,184,215,.28); }

/* Listado / tablas */
.filter-card {
    display: grid;
    grid-template-columns: minmax(240px, 1fr) minmax(180px, 240px);
    gap: 14px;
    padding: 16px;
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    background: var(--surface-2);
    margin-bottom: 16px;
}
.toolbar-field { display: grid; gap: 7px; }
.toolbar-field span,
.form-group label {
    color: var(--text-secondary);
    font-size: .72rem;
    font-weight: 850;
    letter-spacing: .07em;
    text-transform: uppercase;
}
input,
select,
textarea {
    width: 100%;
    border: 1px solid var(--input-border);
    border-radius: 9px;
    background: var(--input-bg);
    color: var(--input-text);
    outline: 0;
    transition: border-color .2s ease, box-shadow .2s ease, background .25s ease;
}
input,
select { min-height: 42px; padding: 0 12px; }
textarea { min-height: 96px; resize: vertical; padding: 12px; line-height: 1.5; }
input:focus,
select:focus,
textarea:focus {
    border-color: var(--brand);
    box-shadow: 0 0 0 .2rem rgba(var(--brand-rgb), .17);
}
.kpi-row,
.list-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 12px;
    margin-bottom: 16px;
}
.kpi-card { display: grid; gap: 5px; }
.kpi-count {
    color: var(--text-heading);
    font-size: 1.6rem;
    line-height: 1;
}
.table-wrap,
.table-responsive {
    overflow: auto;
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    background: var(--card-bg);
}
.table-scroll { max-height: 56vh; scrollbar-width: thin; scrollbar-color: var(--brand) transparent; }
table,
.table { width: 100%; border-collapse: separate; border-spacing: 0; color: var(--text-primary); }
.table th,
table th {
    position: sticky;
    top: 0;
    z-index: 2;
    padding: 13px 15px;
    background: var(--table-header-bg);
    color: var(--text-secondary);
    font-size: .74rem;
    font-weight: 850;
    letter-spacing: .07em;
    text-align: left;
    text-transform: uppercase;
    border-bottom: 2px solid var(--brand);
}
.table td,
table td {
    padding: 14px 15px;
    border-bottom: 1px solid var(--border-subtle);
    vertical-align: top;
}
tbody tr { transition: background .16s ease, box-shadow .16s ease; }
tbody tr:hover { background: var(--table-row-hover-bg); box-shadow: inset 3px 0 0 var(--brand); }
.table-title-cell { display: grid; gap: 5px; min-width: 240px; }
.table-title-cell strong { color: var(--text-heading); }
.table-description { max-width: 430px; display: block; font-size: .84rem; line-height: 1.4; }
.table-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.empty-row {
    padding: 30px !important;
    text-align: center;
    color: var(--text-secondary);
}
.empty-row .empty-state-icon { width: 28px; height: 28px; margin-right: 8px; vertical-align: middle; color: var(--brand); }

.badge,
.preview-pill {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid transparent;
    font-size: .72rem;
    font-weight: 850;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.badge-activo { background: rgba(var(--brand-rgb), .15); border-color: rgba(var(--brand-rgb), .30); color: var(--brand); }
.badge-borrador { background: rgba(255,138,34,.14); border-color: rgba(255,138,34,.30); color: var(--accent-orange); }
.badge-inactivo { background: var(--danger-soft); border-color: color-mix(in srgb, var(--danger) 34%, transparent); color: var(--danger); }
.preview-pill { background: rgba(33,184,215,.13); border-color: rgba(33,184,215,.28); color: var(--accent-cyan); }

/* Formulario modular */
.form-layout-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(330px, .65fr);
    gap: 18px;
    align-items: start;
}
.stack-form { display: grid; gap: 16px; }
.form-module {
    position: relative;
    display: grid;
    gap: 15px;
    padding: 18px;
    border: 1px solid var(--border-subtle);
    border-top: 3px solid var(--brand);
    border-radius: 12px;
    background: var(--surface-2);
    overflow: hidden;
}
.form-module-map { border-top-color: var(--accent-cyan); }
.form-module-game { border-top-color: var(--accent-orange); }
.quiz-section { border-top-color: var(--brand); }
.form-module::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(var(--brand-rgb), .35), transparent);
}
.form-module-header { display: flex; align-items: center; gap: 13px; }
.form-module-icon { width: 44px; height: 44px; }
.form-module h3 { font-size: 1.05rem; }
.form-grid { display: grid; gap: 13px; }
.two-columns { grid-template-columns: repeat(2, minmax(0,1fr)); }
.three-columns { grid-template-columns: repeat(3, minmax(0,1fr)); }
.form-group { display: grid; gap: 7px; }
.actions-row {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    padding-top: 2px;
}

.preview-card {
    position: sticky;
    top: 98px;
    display: grid;
    gap: 16px;
}
.preview-top h2 { font-size: 1.35rem; }
.preview-top .muted-text { margin: 8px 0 0; line-height: 1.5; }
.preview-map-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.map-preview-box {
    min-height: 260px;
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(var(--brand-rgb), .10), rgba(33,184,215,.10));
}
.map-help { margin: -6px 0 0; font-size: .82rem; line-height: 1.45; }
.preview-badges { display: flex; flex-wrap: wrap; gap: 8px; }
.preview-metrics,
.preview-coords {
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 10px;
}
.preview-quiz-box {
    padding: 14px;
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    background: var(--surface-2);
}
.preview-quiz-box p { margin: 6px 0 0; color: var(--text-secondary); line-height: 1.45; }

/* Mobile cards generadas por app.js */
.poi-card-list { display: none; }
.poi-mobile-card {
    border: 1px solid var(--border-subtle);
    border-top: 3px solid var(--brand);
    border-radius: 10px;
    background: var(--card-bg);
    padding: 16px;
    box-shadow: var(--card-shadow);
}
.poi-mobile-card + .poi-mobile-card { margin-top: 12px; }
.poi-mobile-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.poi-mobile-card h3 { font-size: 1.05rem; }
.poi-mobile-card p { color: var(--text-secondary); line-height: 1.45; }
.poi-mobile-meta { display: grid; gap: 6px; margin: 12px 0; color: var(--text-secondary); font-size: .86rem; }
.empty-card { text-align: center; color: var(--text-secondary); }
.empty-card .empty-state-icon { width: 36px; height: 36px; color: var(--brand); }

/* Auth transition */
.auth-transition-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: grid;
    place-items: center;
    opacity: 0;
    pointer-events: none;
    background: var(--admin-photo) center / cover no-repeat;
    transition: opacity .5s cubic-bezier(.4, 0, .2, 1);
    overflow: hidden;
}

.auth-transition-overlay::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at center, rgba(11, 16, 24, 0.90) 0%, rgba(4, 8, 14, 0.98) 100%);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

.auth-transition-overlay.visible { opacity: 1; pointer-events: all; }

.auth-transition-panel {
    position: relative;
    z-index: 2;
    width: min(460px, calc(100vw - 40px));
    padding: 56px 48px;
    text-align: center;
    border: 1px solid rgba(var(--accent-orange-rgb), .2);
    border-radius: 28px;
    background: rgba(10, 14, 22, 0.72);
    color: #fff;
    box-shadow: 
        0 42px 90px rgba(0, 0, 0, 0.6), 
        0 0 50px rgba(var(--accent-orange-rgb), 0.12),
        inset 0 1px 1px rgba(255,255,255,0.06);
    transform: scale(0.9) translateY(24px);
    transition: transform 0.6s cubic-bezier(.22, 1, .36, 1);
}

.auth-transition-overlay.visible .auth-transition-panel {
    transform: scale(1) translateY(0);
}

.auth-transition-logo-container {
    margin-bottom: 40px;
    display: flex;
    justify-content: center;
    filter: drop-shadow(0 0 20px rgba(var(--accent-orange-rgb), 0.35));
    animation: authLogoGlow 3.5s ease-in-out infinite;
}

@keyframes authLogoGlow {
    0%, 100% { filter: drop-shadow(0 0 18px rgba(var(--accent-orange-rgb), 0.25)); transform: scale(1); }
    50% { filter: drop-shadow(0 0 32px rgba(var(--accent-orange-rgb), 0.45)); transform: scale(1.03); }
}

.auth-transition-kicker {
    margin: 0 0 12px;
    color: var(--cta);
    font-size: .82rem;
    font-weight: 900;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.auth-transition-title { margin: 0; font-size: 1.85rem; font-weight: 850; letter-spacing: -0.025em; }
.auth-transition-text { margin: 14px 0 38px; color: rgba(255, 255, 255, 0.55); font-size: 1.05rem; line-height: 1.6; }

.auth-transition-track { height: 7px; border-radius: 999px; background: rgba(255, 255, 255, 0.06); overflow: hidden; }
.auth-transition-progress {
    height: 100%;
    width: 0%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--cta), var(--gps));
    box-shadow: 0 0 15px rgba(var(--accent-orange-rgb), 0.3);
    transition: width .86s cubic-bezier(.22,1,.36,1);
}

.auth-transition-track { height: 6px; border-radius: 999px; background: rgba(255, 255, 255, 0.08); overflow: hidden; }
.auth-transition-progress {
    height: 100%;
    width: 0%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--brand-strong), var(--brand), var(--brand-soft));
    box-shadow: 0 0 12px var(--brand-glow);
    transition: width .86s cubic-bezier(.22,1,.36,1);
}

.sidebar-nav::-webkit-scrollbar,
.table-scroll::-webkit-scrollbar,
.content-area::-webkit-scrollbar { width: 10px; height: 10px; }
.sidebar-nav::-webkit-scrollbar-thumb,
.table-scroll::-webkit-scrollbar-thumb,
.content-area::-webkit-scrollbar-thumb { background: var(--brand); border-radius: 999px; }

@media (max-width: 1180px) {
    .dashboard-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .dashboard-lower-grid,
    .form-layout-grid { grid-template-columns: 1fr; }
    .preview-card { position: relative; top: auto; }
}

@media (max-width: 920px) {
    .admin-layout { grid-template-columns: 1fr; }
    .sidebar {
        position: relative;
        width: 100%;
        min-height: auto;
        border-right: 0;
        border-bottom: 1px solid var(--border-subtle);
    }
    .sidebar-nav { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); padding: 8px 12px 14px; }
    .sidebar-link,
    .nav-link { justify-content: center; padding: 12px; border-left: 0; border-bottom: 3px solid transparent; }
    .sidebar-link.active,
    .nav-link.active { border-left-color: transparent; border-bottom-color: var(--brand); }
    .sidebar-system-card { display: none; }
    .sidebar-footer { padding: 12px 24px 18px; }
    .main-wrapper,
    .main-content { margin-left: 0; }
    .topbar { align-items: flex-start; flex-direction: column; }
    .topbar-actions { justify-content: flex-start; }
}

@media (max-width: 720px) {
    .login-wrapper { padding: 72px 16px 22px; }
    .login-panel { padding: 36px 24px 28px; }
    .content-area { padding: 20px 16px 32px; }
    .module-heading,
    .module-heading-actions,
    .actions-row,
    .preview-map-head,
    .poi-mobile-top { flex-direction: column; align-items: stretch; }
    .dashboard-grid,
    .mini-status-grid,
    .filter-card,
    .kpi-row,
    .list-summary-grid,
    .two-columns,
    .three-columns,
    .preview-metrics,
    .preview-coords { grid-template-columns: 1fr; }
    .table-wrap { display: none; }
    .poi-card-list { display: block; }
    .sidebar-nav { grid-template-columns: 1fr; }
    .btn,
    .module-heading-actions .btn,
    .topbar-actions .btn,
    .status-pill { width: 100%; }
    .theme-toggle-login { right: 16px; bottom: 16px; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        scroll-behavior: auto !important;
        transition-duration: .01ms !important;
    }
}

/* ─────────────────────────────────────────────────────────────
   REPARACIÓN FINAL — recuperar login anterior + arreglar shell admin
   ───────────────────────────────────────────────────────────── */
body.app-state-login #admin-container { display: none !important; }
body.app-state-admin #login-container { display: none !important; }
body.app-state-admin #admin-container.admin-layout {
    display: block !important;
    min-height: 100vh;
}

body.app-state-admin::after {
    background:
        linear-gradient(90deg, rgba(5, 9, 15, 0.96) 0%, rgba(5, 9, 15, 0.84) 30%, rgba(5, 9, 15, 0.72) 100%),
        rgba(5, 9, 15, 0.72);
}

:root[data-theme="light"] body.app-state-admin::after {
    background:
        linear-gradient(90deg, rgba(244, 247, 242, 0.98) 0%, rgba(244, 247, 242, 0.88) 35%, rgba(244, 247, 242, 0.76) 100%),
        rgba(244, 247, 242, 0.82);
}

/* Login anterior, pero saneado: dos columnas, héroe + card de acceso */
.login-shell {
    min-height: 100dvh;
    position: relative;
    isolation: isolate;
    overflow: hidden;
    display: flex;
    align-items: stretch;
    justify-content: center;
    padding: 0;
}

.login-shell::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(5, 11, 17, 0.08), rgba(5, 11, 17, 0.74)),
        linear-gradient(125deg, rgba(7, 17, 13, 0.04), rgba(7, 17, 13, 0.76)),
        url("assets/streethunter-panel-scene.svg") center/cover no-repeat;
    pointer-events: none;
    z-index: -2;
}

:root[data-theme="light"] .login-shell::before {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(244, 247, 242, 0.80)),
        linear-gradient(125deg, rgba(244, 247, 242, 0.12), rgba(234, 242, 235, 0.72)),
        url("assets/streethunter-panel-scene.svg") center/cover no-repeat;
}

.login-shell-grid {
    position: relative;
    z-index: 1;
    width: 100%;
    min-height: 100dvh;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(440px, 0.92fr);
    align-items: stretch;
}

.login-hero {
    position: relative;
    display: flex;
    align-items: flex-end;
    padding: 56px;
    overflow: hidden;
}

.login-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(10, 15, 13, 0.10) 0%, rgba(10, 15, 13, 0.84) 100%);
    pointer-events: none;
}

:root[data-theme="light"] .login-hero-overlay {
    background: linear-gradient(180deg, rgba(248, 250, 249, 0.18) 0%, rgba(248, 250, 249, 0.82) 100%);
}

.login-hero-content {
    position: relative;
    z-index: 1;
    max-width: 500px;
    display: grid;
    gap: 20px;
}

.login-hero-badge {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 8px 14px;
    border-radius: 999px;
    border: 1px solid rgba(245, 158, 11, 0.25);
    background: rgba(245, 158, 11, 0.10);
    color: var(--accent-orange);
    font-size: 12px;
    font-weight: 850;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.login-hero-content h1 {
    margin: 0;
    font-size: clamp(38px, 4.4vw, 64px);
    line-height: 1.02;
    letter-spacing: -0.045em;
    color: #f4fafc;
    text-wrap: balance;
}

:root[data-theme="light"] .login-hero-content h1 { color: var(--text-heading); }

.login-hero-content p {
    margin: 0;
    font-size: 17px;
    line-height: 1.65;
    color: rgba(244, 250, 252, 0.74);
    max-width: 42ch;
}

:root[data-theme="light"] .login-hero-content p { color: var(--text-secondary); }

.login-hero-footer {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 8px;
}

.login-form-area {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 44px;
    background:
        linear-gradient(180deg, rgba(8, 12, 20, 0.78), rgba(8, 12, 20, 0.92)),
        rgba(8, 12, 20, 0.86);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

:root[data-theme="light"] .login-form-area {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.78), rgba(244,247,242,0.92)),
        rgba(244, 247, 242, 0.88);
}

.login-card {
    width: min(440px, 100%);
    min-height: auto;
    margin: 0 auto;
    padding: 42px 38px 34px;
    position: relative;
    overflow: hidden;
    border-radius: 32px;
    background: var(--card-bg);
    border: 1px solid var(--border-subtle);
    box-shadow: 0 28px 80px rgba(0, 0, 0, 0.32);
    display: grid;
    gap: 20px;
    animation: panelEnter .42s ease both;
}

.login-card > * {
    position: relative;
    z-index: 1;
}

.login-card h1 {
    font-size: clamp(30px, 5vw, 40px);
    line-height: 1.05;
    letter-spacing: -0.03em;
    margin: 0;
    color: var(--text-heading);
}

.login-brand-mark {
    display: grid;
    gap: 8px;
    margin-bottom: 4px;
}

.login-brand-badge {
    color: var(--brand);
    font-size: 13px;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.login-brand-context {
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 700;
}

.login-card .muted-text {
    max-width: 38ch;
    margin: 0;
    line-height: 1.55;
}

.login-card .stack-form {
    margin-top: 6px;
    gap: 18px;
}

.login-card .form-group { gap: 10px; }

.login-card .form-group label {
    font-size: 13px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.login-field {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 56px;
    border: 1px solid var(--input-border);
    border-radius: 18px;
    background: var(--input-bg);
    color: var(--input-text);
    overflow: hidden;
}

.login-field:focus-within {
    border-color: var(--brand);
    box-shadow: 0 0 0 4px rgba(var(--brand-rgb), 0.16);
}

.login-field-addon {
    width: 56px;
    align-self: stretch;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--brand);
    border-right: 1px solid var(--input-border);
    background: rgba(var(--brand-rgb), 0.08);
}

.login-field input {
    border: 0;
    min-height: 56px;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
}

.login-field input:focus { box-shadow: none; }

.login-helper,
.login-footer-note {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.55;
    font-size: 13px;
}

.login-footer-note {
    padding-top: 16px;
    border-top: 1px solid var(--border-subtle);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

/* Theme Toggle Buttons — Saneamiento Visual */
.app-shell-theme-toggle,
.theme-toggle {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 44px;
    min-width: 160px;
    padding: 0 24px;
    border-radius: 999px;
    border: 1px solid var(--border-subtle);
    background: var(--card-bg);
    color: var(--text-heading);
    font-family: var(--font-ui);
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-shadow: none !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    position: relative;
    z-index: 100;
}

.app-shell-theme-toggle {
    position: fixed;
    top: 24px;
    right: 24px;
}

.app-shell-theme-toggle::before,
.app-shell-theme-toggle::after,
.theme-toggle::before,
.theme-toggle::after {
    display: none !important;
    content: none !important;
}

.app-shell-theme-toggle:hover,
.theme-toggle:hover {
    transform: translateY(-2px);
    border-color: var(--cta);
    color: var(--cta);
    background: var(--surface-1);
    box-shadow: 0 10px 24px rgba(var(--accent-orange-rgb), 0.18);
}

.app-shell-theme-toggle:active,
.theme-toggle:active {
    transform: translateY(0) scale(0.98);
}

/* Ocultar botones antiguos/redundantes */
#theme-toggle-login.theme-toggle-login,
.theme-toggle-login {
    display: none !important;
}

/* Reparación del admin: la sidebar es fija; el main NO puede ser un grid item de 300px. */
#admin-container .main-wrapper.main-content {
    margin-left: var(--sidebar-w);
    width: calc(100vw - var(--sidebar-w));
    max-width: none;
    min-width: 0;
}

#admin-container .main-wrapper::before {
    opacity: 0.055;
}

:root[data-theme="light"] #admin-container .main-wrapper::before {
    opacity: 0.08;
}

#admin-container .topbar {
    width: 100%;
    min-width: 0;
}

#admin-container .content-area {
    width: 100%;
    max-width: 1480px;
}

#admin-container .dashboard-grid {
    grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
    align-items: stretch;
}

#admin-container .stat-card {
    min-height: 148px;
    overflow: hidden;
}

#admin-container .card-body-horizontal {
    align-items: flex-start;
}

#admin-container .stat-number {
    font-size: clamp(42px, 4vw, 58px);
}

#admin-container .dashboard-lower-grid {
    grid-template-columns: minmax(0, 1.25fr) minmax(360px, 0.75fr);
}

#admin-container .card,
#admin-container .panel-card,
#admin-container .hero-card,
#admin-container .stat-card {
    background: color-mix(in srgb, var(--card-bg) 94%, #0b1018 6%);
}

:root[data-theme="light"] #admin-container .card,
:root[data-theme="light"] #admin-container .panel-card,
:root[data-theme="light"] #admin-container .hero-card,
:root[data-theme="light"] #admin-container .stat-card {
    background: rgba(255,255,255,0.96);
}

@media (max-width: 1120px) {
    .login-shell-grid {
        grid-template-columns: 1fr;
    }

    .login-hero {
        display: none;
    }

    .login-form-area {
        min-height: 100dvh;
        padding: 24px;
    }

    #admin-container .dashboard-lower-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 920px) {
    body.app-state-admin #admin-container.admin-layout {
        display: block !important;
    }

    #admin-container .main-wrapper.main-content {
        margin-left: 0;
        width: 100%;
    }

    #admin-container .content-area {
        max-width: none;
    }
}

@media (max-width: 640px) {
    .login-card {
        padding: 30px 24px;
        border-radius: 24px;
    }

    .login-form-area {
        padding: 18px;
    }
}

/* ─────────────────────────────────────────────────────────────
   UI/UX FINAL — Fondo Ciser, identidad StreetHunter, lectura sólida
   ───────────────────────────────────────────────────────────── */
:root {
    --admin-photo: url("img/EstadioVallecas.jpeg");
    --admin-dark-overlay:
        radial-gradient(circle at 72% 16%, rgba(144,196,63,0.14), transparent 30%),
        linear-gradient(90deg, rgba(6,10,18,0.96) 0%, rgba(6,10,18,0.88) 36%, rgba(6,10,18,0.74) 100%);
    --admin-light-overlay:
        radial-gradient(circle at 72% 16%, rgba(126,211,95,0.14), transparent 30%),
        linear-gradient(90deg, rgba(246,248,243,0.98) 0%, rgba(246,248,243,0.90) 38%, rgba(246,248,243,0.78) 100%);
}

body::before,
.login-bg-layer,
.main-wrapper::before,
.auth-transition-overlay {
    background-image: var(--admin-photo);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

body.app-state-admin::after {
    background: var(--admin-dark-overlay);
}

:root[data-theme="light"] body.app-state-admin::after {
    background: var(--admin-light-overlay);
}

.login-shell::before {
    background:
        linear-gradient(180deg, rgba(5, 11, 17, 0.08), rgba(5, 11, 17, 0.74)),
        linear-gradient(125deg, rgba(7, 17, 13, 0.04), rgba(7, 17, 13, 0.76)),
        var(--admin-photo) center/cover no-repeat;
}

:root[data-theme="light"] .login-shell::before {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.12), rgba(244,247,242,0.80)),
        linear-gradient(125deg, rgba(244,247,242,0.12), rgba(234,242,235,0.72)),
        var(--admin-photo) center/cover no-repeat;
}

#admin-container .main-wrapper::before {
    opacity: 0;
}

#admin-container .content-area {
    padding: 30px;
    margin: 0 auto;
    max-width: 1540px;
}

#admin-container .topbar {
    min-height: 82px;
    padding: 18px 30px;
    background: rgba(10, 14, 22, 0.90);
    border-bottom: 1px solid rgba(255,255,255,0.10);
    box-shadow: 0 12px 34px rgba(0,0,0,0.20);
}

:root[data-theme="light"] #admin-container .topbar {
    background: rgba(255,255,255,0.92);
    border-bottom-color: rgba(15,23,42,0.10);
}

.topbar-subtitle {
    margin: 6px 0 0;
    color: var(--text-secondary);
    font-size: 0.88rem;
    line-height: 1.35;
}

.sidebar {
    background: rgba(9, 13, 21, 0.94);
    border-right-color: rgba(144,196,63,0.18);
    box-shadow: 16px 0 40px rgba(0,0,0,0.24);
}

:root[data-theme="light"] .sidebar {
    background: rgba(255,255,255,0.95);
    border-right-color: rgba(15,23,42,0.10);
    box-shadow: 14px 0 34px rgba(15,23,42,0.08);
}

.sidebar-logo-box {
    padding-top: 30px;
    padding-bottom: 24px;
}

.sidebar-brand-text strong {
    font-size: 1.42rem;
}

.sidebar-primary-action {
    min-height: 46px;
    border-radius: 10px;
}

.sidebar-system-card {
    background: rgba(255,255,255,0.055);
    border-color: rgba(255,255,255,0.12);
}

:root[data-theme="light"] .sidebar-system-card {
    background: #f5f7fa;
    border-color: #dde3ea;
}

.sidebar-system-card small {
    line-height: 1.35;
}

#admin-container .module-heading {
    align-items: center;
    padding: 20px 22px;
    border: 1px solid rgba(255,255,255,0.09);
    border-left: 4px solid var(--brand);
    border-radius: 12px;
    background: rgba(16, 22, 32, 0.76);
    box-shadow: 0 10px 28px rgba(0,0,0,0.18);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

:root[data-theme="light"] #admin-container .module-heading {
    background: rgba(255,255,255,0.90);
    border-color: rgba(15,23,42,0.10);
    border-left-color: var(--brand);
}

#admin-container .module-heading.compact {
    margin-bottom: 18px;
}

#admin-container .module-heading h2 {
    font-size: clamp(1.55rem, 2.25vw, 2.25rem);
}

#admin-container .dashboard-grid {
    grid-template-columns: repeat(4, minmax(220px, 1fr));
    gap: 18px;
}

#admin-container .card,
#admin-container .panel-card,
#admin-container .hero-card,
#admin-container .stat-card {
    border-radius: 12px;
    background: rgba(25, 30, 38, 0.94);
    border-color: rgba(255,255,255,0.10);
    border-top-width: 4px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.28);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

:root[data-theme="light"] #admin-container .card,
:root[data-theme="light"] #admin-container .panel-card,
:root[data-theme="light"] #admin-container .hero-card,
:root[data-theme="light"] #admin-container .stat-card {
    background: rgba(255,255,255,0.96);
    border-color: rgba(15,23,42,0.10);
    box-shadow: 0 10px 26px rgba(15,23,42,0.09);
}

#admin-container .stat-card {
    min-height: 172px;
}

#admin-container .stat-card .card-body {
    height: 100%;
}

#admin-container .card-body-horizontal {
    gap: 18px;
}

#admin-container .card-title {
    min-height: 2.1em;
}

#admin-container .small-text {
    max-width: 22ch;
}

#admin-container .dashboard-lower-grid {
    grid-template-columns: minmax(0, 1.3fr) minmax(360px, 0.7fr);
    gap: 18px;
}

.dashboard-ops-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 18px;
    margin-top: 18px;
}

.ops-card {
    padding: 22px;
    min-height: 236px;
}

.route-card { grid-column: span 7; }
.readiness-card { grid-column: span 5; }
.quality-card { grid-column: span 5; }
.tactical-card { grid-column: span 7; }

.ops-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.ops-card-header h2 {
    margin: 4px 0 0;
    color: var(--text-heading);
    font-size: clamp(1.15rem, 1.6vw, 1.55rem);
    line-height: 1.12;
    letter-spacing: -0.025em;
}

.ops-chip {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(var(--brand-rgb), 0.28);
    background: rgba(var(--brand-rgb), 0.12);
    color: var(--brand);
    font-size: 0.72rem;
    font-weight: 850;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
}

.ops-chip[data-state="ok"] {
    border-color: rgba(var(--brand-rgb), 0.35);
    background: rgba(var(--brand-rgb), 0.16);
    color: var(--brand);
}

.ops-chip[data-state="warning"] {
    border-color: rgba(255,138,34,0.35);
    background: rgba(255,138,34,0.15);
    color: var(--accent-orange);
}

.quality-intro {
    margin-top: -6px;
    margin-bottom: 16px;
    line-height: 1.55;
}

.route-flow {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.route-step {
    position: relative;
    min-height: 150px;
    padding: 16px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.12);
    background:
        linear-gradient(180deg, rgba(255,255,255,0.065), rgba(255,255,255,0.035)),
        rgba(255,255,255,0.035);
    overflow: hidden;
}

:root[data-theme="light"] .route-step {
    border-color: rgba(15,23,42,0.10);
    background: #f5f7fa;
}

.route-step::after {
    content: "";
    position: absolute;
    inset: auto -20px -34px auto;
    width: 88px;
    height: 88px;
    border-radius: 50%;
    background: rgba(var(--brand-rgb), 0.10);
}

.route-node {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    margin-bottom: 18px;
    border-radius: 14px;
    background: rgba(var(--brand-rgb), 0.16);
    border: 1px solid rgba(var(--brand-rgb), 0.30);
    color: var(--brand);
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.05em;
}

.route-step strong,
.route-step small {
    position: relative;
    z-index: 1;
    display: block;
}

.route-step strong {
    color: var(--text-heading);
    font-size: 1rem;
    margin-bottom: 7px;
}

.route-step small {
    color: var(--text-secondary);
    line-height: 1.45;
}

.route-step.is-progress .route-node,
.quality-track-cyan span {
    background: rgba(33,184,215,0.16);
    border-color: rgba(33,184,215,0.30);
    color: var(--accent-cyan);
}

.route-step.is-pending .route-node {
    background: rgba(255,138,34,0.15);
    border-color: rgba(255,138,34,0.30);
    color: var(--accent-orange);
}

.readiness-list,
.quality-list {
    display: grid;
    gap: 12px;
}

.readiness-item {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 13px 14px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(255,255,255,0.045);
}

:root[data-theme="light"] .readiness-item {
    border-color: rgba(15,23,42,0.10);
    background: #f5f7fa;
}

.readiness-dot {
    width: 11px;
    height: 11px;
    margin-top: 6px;
    border-radius: 999px;
    background: var(--brand);
    box-shadow: 0 0 0 4px rgba(var(--brand-rgb), 0.14);
    flex: 0 0 auto;
}

.readiness-item.is-progress .readiness-dot {
    background: var(--accent-cyan);
    box-shadow: 0 0 0 4px rgba(33,184,215,0.14);
}

.readiness-item.is-pending .readiness-dot {
    background: var(--accent-orange);
    box-shadow: 0 0 0 4px rgba(255,138,34,0.14);
}

.readiness-item strong {
    display: block;
    color: var(--text-heading);
    margin-bottom: 4px;
}

.readiness-item small {
    color: var(--text-secondary);
    line-height: 1.45;
}

.quality-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px 14px;
    align-items: center;
    padding: 14px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(255,255,255,0.045);
}

:root[data-theme="light"] .quality-row {
    border-color: rgba(15,23,42,0.10);
    background: #f5f7fa;
}

.quality-row span {
    color: var(--text-heading);
    font-weight: 800;
}

.quality-row strong {
    color: var(--accent-orange);
    font-size: 1.25rem;
    letter-spacing: -0.03em;
    line-height: 1;
}

.quality-row small {
    grid-column: 1 / -1;
    color: var(--text-secondary);
    line-height: 1.45;
}

.quality-row-critical {
    border-color: rgba(255,91,91,0.28);
    background: rgba(255,91,91,0.07);
}

.quality-row-critical strong {
    color: var(--danger);
}

.quality-track {
    grid-column: 1 / -1;
    height: 8px;
    border-radius: 999px;
    background: rgba(255,255,255,0.10);
    overflow: hidden;
}

:root[data-theme="light"] .quality-track {
    background: #e4e9ef;
}

.quality-track span {
    display: block;
    width: var(--value);
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--brand), var(--brand-strong));
    box-shadow: 0 0 18px rgba(var(--brand-rgb), 0.22);
}

.quality-track-cyan span {
    background: linear-gradient(90deg, var(--accent-cyan), #58e0ef);
    box-shadow: 0 0 18px rgba(33,184,215,0.20);
}

.tactical-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 188px;
    align-items: center;
    gap: 20px;
}

.tactical-card .ops-card-header {
    margin-bottom: 10px;
}

.tactical-card .muted-text {
    max-width: 52ch;
    line-height: 1.6;
}

.tactical-radar {
    position: relative;
    width: 176px;
    height: 176px;
    border-radius: 50%;
    justify-self: end;
    background:
        radial-gradient(circle, rgba(var(--brand-rgb),0.22) 0 3px, transparent 4px),
        radial-gradient(circle, rgba(var(--brand-rgb),0.08), rgba(33,184,215,0.06) 42%, transparent 68%),
        linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
    border: 1px solid rgba(var(--brand-rgb),0.22);
    overflow: hidden;
}

.radar-ring {
    position: absolute;
    inset: 22px;
    border: 1px solid rgba(var(--brand-rgb),0.24);
    border-radius: 50%;
}

.radar-ring-2 { inset: 48px; border-color: rgba(33,184,215,0.22); }
.radar-ring-3 { inset: 74px; border-color: rgba(255,138,34,0.25); }

.radar-pulse {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 86px;
    height: 2px;
    transform-origin: left center;
    background: linear-gradient(90deg, rgba(var(--brand-rgb),0.95), transparent);
    animation: radarSweep 4s linear infinite;
}

.radar-pin {
    position: absolute;
    right: 45px;
    top: 52px;
    width: 13px;
    height: 13px;
    border-radius: 999px;
    background: var(--accent-orange);
    box-shadow: 0 0 0 6px rgba(255,138,34,0.14), 0 0 18px rgba(255,138,34,0.45);
}

@keyframes radarSweep {
    to { transform: rotate(360deg); }
}

#admin-container .hero-card-main,
#admin-container .insight-card {
    min-height: 260px;
}

.hero-card-main {
    background:
        linear-gradient(135deg, rgba(25,30,38,0.96), rgba(25,30,38,0.90)),
        linear-gradient(90deg, rgba(var(--brand-rgb),0.12), transparent);
}

.hero-text {
    font-size: 0.98rem;
}

.mini-status-item,
.preview-metric,
.preview-coords > div,
.kpi-card,
.preview-quiz-box,
.form-module,
.filter-card {
    background: rgba(255,255,255,0.055);
    border-color: rgba(255,255,255,0.12);
}

:root[data-theme="light"] .mini-status-item,
:root[data-theme="light"] .preview-metric,
:root[data-theme="light"] .preview-coords > div,
:root[data-theme="light"] .kpi-card,
:root[data-theme="light"] .preview-quiz-box,
:root[data-theme="light"] .form-module,
:root[data-theme="light"] .filter-card {
    background: #f5f7fa;
    border-color: #dce2ea;
}

.table-wrap,
.table-responsive {
    background: rgba(25, 30, 38, 0.96);
}

:root[data-theme="light"] .table-wrap,
:root[data-theme="light"] .table-responsive {
    background: rgba(255,255,255,0.98);
}

.table th,
table th {
    background: rgba(255,255,255,0.075);
}

:root[data-theme="light"] .table th,
:root[data-theme="light"] table th {
    background: #f3f6f8;
}

.preview-card {
    top: 106px;
}

.map-preview-box {
    min-height: 300px;
}

@media (max-width: 1280px) {
    #admin-container .dashboard-grid {
        grid-template-columns: repeat(2, minmax(240px, 1fr));
    }

    .route-card,
    .tactical-card {
        grid-column: span 12;
    }

    .readiness-card,
    .quality-card {
        grid-column: span 6;
    }
}

@media (max-width: 1120px) {
    #admin-container .dashboard-lower-grid,
    .form-layout-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-ops-grid {
        grid-template-columns: 1fr;
    }

    .route-card,
    .readiness-card,
    .quality-card,
    .tactical-card {
        grid-column: auto;
    }

    .route-flow {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tactical-card {
        grid-template-columns: 1fr;
    }

    .tactical-radar {
        justify-self: start;
    }
}

@media (max-width: 720px) {
    #admin-container .content-area {
        padding: 18px;
    }

    #admin-container .dashboard-grid {
        grid-template-columns: 1fr;
    }

    #admin-container .module-heading {
        padding: 18px;
    }

    .ops-card {
        padding: 18px;
    }

    .ops-card-header {
        flex-direction: column;
    }

    .route-flow {
        grid-template-columns: 1fr;
    }

    .tactical-radar {
        width: 152px;
        height: 152px;
    }
}

/* ─────────────────────────────────────────────────────────────
   FASE B — Identidad StreetHunter, gráficos y microinteracciones
   ───────────────────────────────────────────────────────────── */
:root {
    --accent-orange-rgb: 255, 138, 34;
    --accent-cyan-rgb: 33, 184, 215;
    --danger-rgb: 220, 53, 69;
    --cta: var(--accent-orange);
    --cta-strong: #e56f12;
    --cta-soft: rgba(var(--accent-orange-rgb), 0.16);
    --gps: var(--accent-cyan);
    --gps-soft: rgba(var(--accent-cyan-rgb), 0.15);
    --success: var(--brand);
    --success-soft: rgba(var(--brand-rgb), 0.15);
}

[data-theme="dark"] {
    --accent-orange-rgb: 255, 157, 52;
    --accent-cyan-rgb: 40, 199, 223;
    --danger-rgb: 255, 107, 122;
    --cta: #ff9d34;
    --cta-strong: #ff7d1a;
    --cta-soft: rgba(var(--accent-orange-rgb), 0.18);
    --gps: #28c7df;
    --gps-soft: rgba(var(--accent-cyan-rgb), 0.16);
}

body.app-state-admin::after {
    background:
        radial-gradient(circle at 72% 12%, rgba(var(--accent-orange-rgb),0.16), transparent 30%),
        radial-gradient(circle at 28% 60%, rgba(var(--accent-cyan-rgb),0.14), transparent 34%),
        linear-gradient(90deg, rgba(6,10,18,0.88) 0%, rgba(6,10,18,0.72) 43%, rgba(6,10,18,0.55) 100%);
}

:root[data-theme="light"] body.app-state-admin::after {
    background:
        radial-gradient(circle at 74% 10%, rgba(var(--accent-orange-rgb),0.13), transparent 30%),
        radial-gradient(circle at 22% 58%, rgba(var(--accent-cyan-rgb),0.11), transparent 34%),
        linear-gradient(90deg, rgba(248,250,246,0.94) 0%, rgba(248,250,246,0.82) 44%, rgba(248,250,246,0.62) 100%);
}

.login-shell::before {
    background:
        linear-gradient(180deg, rgba(5, 11, 17, 0.03), rgba(5, 11, 17, 0.62)),
        linear-gradient(125deg, rgba(7, 17, 13, 0.02), rgba(7, 17, 13, 0.66)),
        var(--admin-photo) center/cover no-repeat;
}

:root[data-theme="light"] .login-shell::before {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.04), rgba(244,247,242,0.68)),
        linear-gradient(125deg, rgba(244,247,242,0.04), rgba(234,242,235,0.58)),
        var(--admin-photo) center/cover no-repeat;
}

.login-hero-overlay {
    background:
        radial-gradient(circle at 24% 18%, rgba(var(--accent-orange-rgb), 0.28), transparent 28%),
        linear-gradient(180deg, rgba(10, 15, 13, 0.04) 0%, rgba(10, 15, 13, 0.78) 100%);
}

:root[data-theme="light"] .login-hero-overlay {
    background:
        radial-gradient(circle at 24% 18%, rgba(var(--accent-orange-rgb), 0.18), transparent 28%),
        linear-gradient(180deg, rgba(248,250,249,0.05) 0%, rgba(248,250,249,0.74) 100%);
}

.login-brand-badge,
.login-hero-badge {
    color: var(--cta);
}

.login-field:focus-within {
    border-color: var(--gps);
    box-shadow: 0 0 0 4px rgba(var(--accent-cyan-rgb), 0.16);
}

.login-field-addon {
    color: var(--gps);
    background: rgba(var(--accent-cyan-rgb), 0.09);
}

.btn-primary,
.sidebar-primary-action,
.btn-login-submit {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, var(--cta), var(--cta-strong));
    color: #170c03;
    box-shadow: 0 14px 28px rgba(var(--accent-orange-rgb), 0.26), inset 0 1px 0 rgba(255,255,255,0.25);
}

.btn-primary:hover,
.sidebar-primary-action:hover,
.btn-login-submit:hover {
    box-shadow: 0 18px 36px rgba(var(--accent-orange-rgb), 0.34), 0 0 0 1px rgba(var(--accent-orange-rgb), 0.24);
}

.btn-secondary.hero-outline,
.module-heading-actions .btn-secondary {
    border-color: rgba(var(--accent-cyan-rgb), 0.34);
    color: var(--gps);
}

.sidebar {
    background:
        linear-gradient(180deg, rgba(9,13,21,0.95), rgba(9,13,21,0.90)),
        linear-gradient(135deg, rgba(var(--accent-orange-rgb),0.07), transparent 42%);
    border-right-color: rgba(var(--accent-orange-rgb),0.22);
}

:root[data-theme="light"] .sidebar {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.93)),
        linear-gradient(135deg, rgba(var(--accent-orange-rgb),0.07), transparent 45%);
    border-right-color: rgba(var(--accent-orange-rgb),0.18);
}

.sidebar-brand-icon {
    color: var(--cta);
    background: rgba(var(--accent-orange-rgb), 0.14);
    border-color: rgba(var(--accent-orange-rgb), 0.28);
}

.sidebar-brand-text span {
    color: var(--cta);
}

.sidebar-link:hover,
.nav-link:hover {
    color: var(--cta);
    background: rgba(var(--accent-orange-rgb), .09);
}

.sidebar-link.active,
.nav-link.active {
    color: var(--cta);
    background: linear-gradient(90deg, rgba(var(--accent-orange-rgb), .16), transparent);
    border-left-color: var(--cta);
}

.sidebar-link .nav-icon,
.sidebar-primary-action .nav-icon {
    transition: transform .18s ease, color .18s ease;
}

.sidebar-link:hover .nav-icon,
.sidebar-primary-action:hover .nav-icon {
    transform: scale(1.08);
}

.system-mini-grid {
    display: grid;
    gap: 8px;
    margin-top: 8px;
}

.system-mini {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 28px;
    padding: 0 9px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.10);
    background: rgba(255,255,255,0.055);
    font-weight: 800;
}

:root[data-theme="light"] .system-mini {
    background: #fff;
    border-color: rgba(15,23,42,0.08);
}

.mini-icon {
    width: 15px;
    height: 15px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    flex: 0 0 auto;
}

.system-mini-green { color: var(--brand); }
.system-mini-cyan { color: var(--gps); }
.system-mini-orange { color: var(--cta); }

#firebase-status[data-state="ok"] {
    color: var(--brand);
    border-color: rgba(var(--brand-rgb), 0.32);
    background: rgba(var(--brand-rgb), 0.13);
    animation: firebasePulse 2.8s ease-in-out infinite;
}

@keyframes firebasePulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(var(--brand-rgb), 0.18); }
    50% { box-shadow: 0 0 0 7px rgba(var(--brand-rgb), 0); }
}

#admin-container .module-heading {
    border-left-color: var(--cta);
    background:
        linear-gradient(90deg, rgba(var(--accent-orange-rgb), 0.10), transparent 36%),
        rgba(16, 22, 32, 0.70);
}

:root[data-theme="light"] #admin-container .module-heading {
    border-left-color: var(--cta);
    background:
        linear-gradient(90deg, rgba(var(--accent-orange-rgb), 0.10), transparent 36%),
        rgba(255,255,255,0.88);
}

.section-kicker,
.kpi-label,
.preview-label {
    color: var(--cta);
}

#admin-container .card,
#admin-container .panel-card,
#admin-container .hero-card,
#admin-container .stat-card {
    background: rgba(25, 30, 38, 0.86);
    border-color: rgba(255,255,255,0.12);
}

:root[data-theme="light"] #admin-container .card,
:root[data-theme="light"] #admin-container .panel-card,
:root[data-theme="light"] #admin-container .hero-card,
:root[data-theme="light"] #admin-container .stat-card {
    background: rgba(255,255,255,0.90);
}

#admin-container .stat-card {
    position: relative;
    isolation: isolate;
}

#admin-container .stat-card::after {
    content: "";
    position: absolute;
    right: -26px;
    bottom: -34px;
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: rgba(var(--accent-cyan-rgb), 0.08);
    z-index: -1;
}

#admin-container .stat-card:hover .card-icon {
    transform: scale(1.08) rotate(-3deg);
}

.stat-card-map {
    border-top-color: var(--gps);
}

.stat-card-map .card-icon {
    color: var(--gps);
    background: rgba(var(--accent-cyan-rgb), .14);
    border-color: rgba(var(--accent-cyan-rgb), .28);
}

.stat-card-success {
    border-top-color: var(--brand);
}

.stat-card-success .card-icon {
    color: var(--brand);
    background: rgba(var(--brand-rgb), .14);
    border-color: rgba(var(--brand-rgb), .28);
}

.stat-card-warning,
.stat-card-quiz {
    border-top-color: var(--cta);
}

.stat-card-warning .card-icon,
.stat-card-quiz .card-icon {
    color: var(--cta);
    background: rgba(var(--accent-orange-rgb), .15);
    border-color: rgba(var(--accent-orange-rgb), .30);
}

.hero-card-main {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 220px;
    grid-template-areas:
        "copy radar"
        "stats stats";
    gap: 20px;
    overflow: hidden;
    min-height: 330px;
    background:
        linear-gradient(90deg, rgba(8,12,20,0.88) 0%, rgba(8,12,20,0.68) 52%, rgba(8,12,20,0.40) 100%),
        radial-gradient(circle at 78% 24%, rgba(var(--accent-orange-rgb),0.30), transparent 28%),
        var(--admin-photo) center/cover no-repeat;
    border-top-color: var(--cta);
}

:root[data-theme="light"] .hero-card-main {
    background:
        linear-gradient(90deg, rgba(255,255,255,0.90) 0%, rgba(255,255,255,0.72) 52%, rgba(255,255,255,0.48) 100%),
        radial-gradient(circle at 78% 24%, rgba(var(--accent-orange-rgb),0.18), transparent 28%),
        var(--admin-photo) center/cover no-repeat;
}

.hero-card-copy {
    grid-area: copy;
    position: relative;
    z-index: 1;
}

.hero-card-main .mini-status-grid {
    grid-area: stats;
    position: relative;
    z-index: 1;
}

.hero-card-main .hero-icon {
    color: var(--cta);
    background: rgba(var(--accent-orange-rgb), .16);
    border-color: rgba(var(--accent-orange-rgb), .32);
}

.hero-card-main h2 {
    max-width: 16ch;
    font-size: clamp(2rem, 4vw, 3.45rem);
    line-height: .98;
}

.hero-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 20px;
}

.hero-visual-radar {
    grid-area: radar;
    position: relative;
    align-self: center;
    justify-self: end;
    width: 196px;
    height: 196px;
    border-radius: 50%;
    border: 1px solid rgba(var(--accent-cyan-rgb),0.28);
    background:
        radial-gradient(circle, rgba(var(--accent-cyan-rgb),.18) 0 4px, transparent 5px),
        radial-gradient(circle, rgba(var(--accent-cyan-rgb),.10), transparent 65%);
    box-shadow: inset 0 0 34px rgba(var(--accent-cyan-rgb),0.08), 0 0 46px rgba(var(--accent-cyan-rgb),0.16);
}

.hero-visual-radar span {
    position: absolute;
    inset: 18px;
    border-radius: 50%;
    border: 1px solid rgba(var(--accent-cyan-rgb),0.28);
}

.hero-visual-radar span:nth-child(2) { inset: 52px; border-color: rgba(var(--accent-orange-rgb),0.30); }
.hero-visual-radar span:nth-child(3) {
    inset: auto auto 54px 54px;
    width: 18px;
    height: 18px;
    background: var(--cta);
    border: 0;
    box-shadow: 0 0 0 8px rgba(var(--accent-orange-rgb),0.16), 0 0 28px rgba(var(--accent-orange-rgb),0.45);
}

.mini-status-item,
.preview-metric,
.preview-coords > div,
.kpi-card,
.preview-quiz-box,
.form-module,
.filter-card,
.readiness-item,
.quality-row,
.route-step {
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.mini-status-item:hover,
.kpi-card:hover,
.route-step:hover,
.readiness-item:hover,
.quality-row:hover {
    border-color: rgba(var(--accent-orange-rgb), 0.25);
}

.ops-chip {
    color: var(--gps);
    background: var(--gps-soft);
    border-color: rgba(var(--accent-cyan-rgb),0.30);
}

.route-step.is-ready .route-node,
.quality-track span {
    color: var(--brand);
    background: rgba(var(--brand-rgb), 0.16);
    border-color: rgba(var(--brand-rgb), 0.30);
}

.route-step.is-progress .route-node {
    color: var(--gps);
    background: var(--gps-soft);
    border-color: rgba(var(--accent-cyan-rgb),0.30);
}

.route-step.is-pending .route-node {
    color: var(--cta);
    background: var(--cta-soft);
    border-color: rgba(var(--accent-orange-rgb),0.30);
}

.quality-track-orange span {
    background: linear-gradient(90deg, var(--cta), var(--cta-strong));
    box-shadow: 0 0 18px rgba(var(--accent-orange-rgb),0.22);
}

.quality-track-cyan span {
    background: linear-gradient(90deg, var(--gps), #58e0ef);
    box-shadow: 0 0 18px rgba(var(--accent-cyan-rgb),0.22);
}

.tactical-radar,
.hero-visual-radar {
    animation: radarGlow 4.5s ease-in-out infinite;
}

@keyframes radarGlow {
    0%, 100% { filter: saturate(1); }
    50% { filter: saturate(1.2) brightness(1.08); }
}

.filter-card {
    position: relative;
    padding: 16px;
    border-left: 4px solid var(--gps);
}

.toolbar-label {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    color: var(--gps);
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.table th,
table th {
    color: var(--gps);
    letter-spacing: 0.08em;
    border-bottom: 1px solid rgba(var(--accent-cyan-rgb),0.22);
}

.badge {
    border: 1px solid transparent;
    font-weight: 850;
    letter-spacing: 0.04em;
}

.badge-activo {
    color: var(--brand);
    background: rgba(var(--brand-rgb), 0.14);
    border-color: rgba(var(--brand-rgb), 0.28);
}

.badge-borrador {
    color: var(--cta);
    background: rgba(var(--accent-orange-rgb), 0.14);
    border-color: rgba(var(--accent-orange-rgb), 0.28);
}

.badge-inactivo {
    color: var(--danger);
    background: rgba(var(--danger-rgb), 0.12);
    border-color: rgba(var(--danger-rgb), 0.24);
}

.table-actions .btn-secondary {
    color: var(--gps);
    border-color: rgba(var(--accent-cyan-rgb), 0.28);
}

.table-actions .btn-danger {
    color: var(--danger);
    border-color: rgba(var(--danger-rgb), 0.28);
}

.form-module {
    position: relative;
    overflow: hidden;
    border-top: 4px solid var(--gps);
}

.form-module::after {
    content: "";
    position: absolute;
    right: -28px;
    top: -28px;
    width: 86px;
    height: 86px;
    border-radius: 50%;
    background: rgba(var(--accent-cyan-rgb),0.08);
    pointer-events: none;
}

.form-module-basic,
.form-module-map {
    border-top-color: var(--gps);
}

.form-module-game,
.quiz-section {
    border-top-color: var(--cta);
}

.form-module-basic .form-module-icon,
.form-module-map .form-module-icon {
    color: var(--gps);
    background: var(--gps-soft);
    border-color: rgba(var(--accent-cyan-rgb),0.30);
}

.form-module-game .form-module-icon,
.quiz-section .form-module-icon {
    color: var(--cta);
    background: var(--cta-soft);
    border-color: rgba(var(--accent-orange-rgb),0.30);
}

input:focus,
select:focus,
textarea:focus {
    border-color: var(--gps);
    box-shadow: 0 0 0 4px rgba(var(--accent-cyan-rgb), 0.14);
}

.form-module-game input:focus,
.form-module-game select:focus,
.quiz-section input:focus,
.quiz-section select:focus {
    border-color: var(--cta);
    box-shadow: 0 0 0 4px rgba(var(--accent-orange-rgb), 0.14);
}

.preview-card {
    border-top-color: var(--gps);
    overflow: hidden;
}

.preview-card::before {
    content: "";
    position: absolute;
    right: -70px;
    top: 84px;
    width: 190px;
    height: 190px;
    border-radius: 50%;
    border: 1px solid rgba(var(--accent-cyan-rgb),0.20);
    box-shadow: inset 0 0 0 34px rgba(var(--accent-cyan-rgb),0.035), inset 0 0 0 70px rgba(var(--accent-orange-rgb),0.035);
    pointer-events: none;
}

.preview-card > * {
    position: relative;
    z-index: 1;
}

.preview-map-head {
    padding: 12px;
    border-radius: 14px 14px 0 0;
    background: linear-gradient(90deg, rgba(var(--accent-cyan-rgb),0.12), rgba(var(--accent-orange-rgb),0.08));
    border: 1px solid rgba(var(--accent-cyan-rgb),0.20);
    border-bottom: 0;
}

.map-preview-box {
    min-height: 360px;
    border: 1px solid rgba(var(--accent-cyan-rgb),0.34);
    box-shadow: inset 0 0 0 1px rgba(var(--accent-cyan-rgb),0.10), 0 18px 38px rgba(var(--accent-cyan-rgb),0.08);
}

.preview-status-box {
    display: grid;
    gap: 12px;
    padding: 14px;
    margin: 16px 0;
    border-radius: 14px;
    border: 1px solid rgba(var(--accent-cyan-rgb),0.22);
    background: linear-gradient(135deg, rgba(var(--accent-cyan-rgb),0.10), rgba(var(--accent-orange-rgb),0.07));
}

.preview-status-box strong {
    color: var(--text-heading);
}

.preview-metric:first-child {
    border-color: rgba(var(--accent-orange-rgb),0.24);
}

.preview-metric:first-child strong {
    color: var(--cta);
}

.preview-coords > div {
    border-color: rgba(var(--accent-cyan-rgb),0.20);
}

.preview-coords strong {
    color: var(--gps);
}

.card,
.stat-card,
.panel-card,
.hero-card,
.ops-card,
.form-module {
    animation: cardRise .36s ease both;
}

@keyframes cardRise {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.btn-primary {
    position: relative;
    overflow: hidden;
}

.btn-primary::after,
.sidebar-primary-action::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,0.28) 45%, transparent 70%);
    transform: translateX(-120%);
    animation: ctaSheen 4.2s ease-in-out infinite;
    pointer-events: none;
}

@keyframes ctaSheen {
    0%, 72%, 100% { transform: translateX(-120%); }
    84% { transform: translateX(120%); }
}

@media (max-width: 1120px) {
    .hero-card-main {
        grid-template-columns: 1fr;
        grid-template-areas:
            "copy"
            "radar"
            "stats";
    }

    .hero-visual-radar {
        justify-self: start;
    }
}

@media (max-width: 720px) {
    .hero-card-main h2 {
        max-width: 100%;
    }

    .hero-visual-radar {
        width: 150px;
        height: 150px;
    }

    .hero-card-actions {
        flex-direction: column;
    }

    .hero-card-actions .btn {
        width: 100%;
    }
}

@media (prefers-reduced-motion: reduce) {
    #firebase-status[data-state="ok"],
    .tactical-radar,
    .hero-visual-radar,
    .card,
    .stat-card,
    .panel-card,
    .hero-card,
    .ops-card,
    .form-module,
    .btn-primary::after,
    .sidebar-primary-action::after {
        animation: none !important;
    }
}
