:root{--bg:#0f1512;--panel:#18211c;--panel2:#202b25;--text:#edf3ee;--muted:#b7c2ba;--line:#344239;--accent:#d7b46a;--green:#41b883;--yellow:#d7b46a;--orange:#d4813c;--red:#c94c4c;}
*{box-sizing:border-box} body{margin:0;font-family:Segoe UI,Arial,sans-serif;background:radial-gradient(circle at top,#26352d,#0f1512 55%);color:var(--text)}
a{color:inherit;text-decoration:none}.topbar{display:flex;justify-content:space-between;align-items:center;padding:18px 28px;border-bottom:1px solid var(--line);background:rgba(12,17,14,.92);position:sticky;top:0;z-index:10;backdrop-filter:blur(8px)}.brand-left,.brand-right{display:flex;align-items:center;gap:16px}.crest{width:76px;height:76px;object-fit:contain}.small-crest{width:52px;height:52px;object-fit:contain}.topbar h1{font-size:24px;margin:0;letter-spacing:.08em}.topbar p{margin:4px 0 0;color:var(--muted)}.user-pill,.link-button{border:1px solid var(--line);padding:9px 12px;border-radius:999px;background:var(--panel2);font-size:13px}.container{max-width:1280px;margin:0 auto;padding:28px}.section-title{display:flex;justify-content:space-between;align-items:end;margin-bottom:20px}.section-title h2,.detail-header h2{margin:0;font-size:30px}.section-title p,.detail-header p{color:var(--muted);margin:6px 0 0}.service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:20px}.service-card{display:block;background:linear-gradient(180deg,rgba(32,43,37,.98),rgba(21,29,24,.98));border:1px solid var(--line);border-radius:22px;padding:20px;box-shadow:0 12px 35px rgba(0,0,0,.22);transition:.18s}.service-card:hover{transform:translateY(-3px);border-color:var(--accent)}.card-head{display:flex;gap:16px;min-height:88px}.service-icon{width:62px;height:62px;border-radius:18px;background:#111812;display:grid;place-items:center;font-size:34px;border:1px solid var(--line)}.card-head h3{margin:0 0 6px;font-size:22px}.card-head p{margin:0;color:var(--muted);font-size:14px}.next-box{border-radius:16px;padding:14px;margin:14px 0;background:#111812;border:1px solid var(--line)}.next-box span{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.next-box strong{display:block;font-size:22px;margin:4px 0}.next-box small{color:var(--muted)}.progress{height:9px;background:#0b100d;border-radius:999px;overflow:hidden;margin-top:10px}.progress i{display:block;height:100%;border-radius:999px;background:var(--green)}.status-medium .progress i{background:var(--yellow)}.status-high .progress i{background:var(--orange)}.status-full .progress i{background:var(--red)}.mini-calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:7px}.day-chip{border-radius:12px;padding:8px 4px;text-align:center;background:#101711;border:1px solid var(--line);font-size:12px}.day-chip b,.day-chip span,.day-chip em{display:block}.day-chip em{font-style:normal;color:var(--muted);font-size:11px}.status-low{border-color:rgba(65,184,131,.8)}.status-medium{border-color:rgba(215,180,106,.9)}.status-high{border-color:rgba(212,129,60,.9)}.status-full{border-color:rgba(201,76,76,.95);opacity:.95}.incident-summary{display:flex;gap:10px;margin-top:14px}.badge{padding:9px 12px;border-radius:999px;font-weight:700}.badge.danger{background:rgba(201,76,76,.18);border:1px solid var(--red)}.badge.warning{background:rgba(215,180,106,.16);border:1px solid var(--yellow)}.floating-admin{position:fixed;right:26px;bottom:26px;background:var(--accent);color:#16110a;padding:14px 18px;border-radius:999px;font-weight:800;box-shadow:0 10px 30px rgba(0,0,0,.35)}.auth-card,.reserve-panel,.calendar-panel{max-width:760px;margin:35px auto;background:rgba(32,43,37,.98);border:1px solid var(--line);border-radius:22px;padding:24px}.auth-card.wide{max-width:940px}.form-stack,.grid-form{display:grid;gap:14px}.grid-form{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.grid-form .full{grid-column:1/-1}label{display:grid;gap:7px;color:var(--muted)}input,select{width:100%;padding:12px 13px;border-radius:12px;border:1px solid var(--line);background:#101711;color:var(--text)}button.primary,.primary{border:0;background:var(--accent);color:#171108;border-radius:12px;padding:13px 16px;font-weight:800;cursor:pointer}.secondary-link{display:inline-block;margin-top:16px;color:var(--accent)}.alert{background:rgba(201,76,76,.18);border:1px solid var(--red);padding:12px;border-radius:12px;margin:12px 0}.back{display:inline-block;color:var(--accent);margin-bottom:10px}.calendar-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.calendar-day{background:#101711;border:1px solid var(--line);border-radius:16px;padding:14px}.calendar-day strong,.calendar-day small{display:block}.calendar-day small{color:var(--muted)}.legend{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:12px 0 18px;color:var(--muted)}.dot{width:12px;height:12px;border-radius:50%;display:inline-block}.dot.low{background:var(--green)}.dot.medium{background:var(--yellow)}.dot.high{background:var(--orange)}.dot.full{background:var(--red)}.inline-form{display:flex;align-items:flex-end;gap:10px;flex-wrap:nowrap}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{border-bottom:1px solid var(--line);padding:10px;text-align:left}.data-table th{color:var(--accent)}@media(max-width:760px){.topbar{display:block}.brand-right{margin-top:12px;flex-wrap:wrap}.section-title{display:block}.container{padding:18px}.mini-calendar{grid-template-columns:repeat(4,1fr)}}

.admin-header {
    margin-bottom: 24px;
}

.admin-header h1 {
    font-size: 2rem;
    margin-bottom: 6px;
}

.admin-header p {
    color: #d8d8d8;
}

.admin-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 18px;
    margin-bottom: 26px;
}

.admin-summary-card {
    background: linear-gradient(145deg, #1d2a22, #101713);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    padding: 20px;
    box-shadow: 0 12px 30px rgba(0,0,0,0.28);
}

.summary-title {
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: 1px;
}

.summary-number {
    font-size: 2.4rem;
    font-weight: 800;
    margin: 8px 0;
}

.summary-detail {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.admin-panel {
    background: rgba(10, 16, 13, 0.86);
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 20px;
    padding: 22px;
    margin-bottom: 24px;
    box-shadow: 0 12px 28px rgba(0,0,0,0.22);
}

.panel-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 18px;
}

.panel-title-row h2,
.admin-panel h2 {
    margin-bottom: 6px;
}

.panel-title-row p,
.admin-panel p {
    color: #d8d8d8;
}

.filters-row,
.preload-form {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px;
    margin: 18px 0;
    align-items: end;
}

.filters-row label,
.preload-form label {
    display: flex;
    flex-direction: column;
    font-weight: 600;
    gap: 6px;
}

.filters-row input,
.filters-row select,
.preload-form input,
.preload-form select {
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.18);
    background: #111a15;
    color: #fff;
}

.table-wrapper {
    overflow-x: auto;
}

.admin-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 12px;
    overflow: hidden;
    border-radius: 14px;
}

.admin-table th {
    background: #243529;
    color: #fff;
    text-align: left;
    padding: 12px;
    font-size: 0.92rem;
}

.admin-table td {
    padding: 12px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.admin-table tr:hover {
    background: rgba(255,255,255,0.04);
}

.badge {
    display: inline-block;
    padding: 5px 9px;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 700;
}

.badge.ok {
    background: rgba(59, 180, 115, 0.20);
    color: #7CFFB2;
}

.badge.pending {
    background: rgba(255, 190, 80, 0.18);
    color: #FFD27A;
}

.module-pill {
    display: inline-block;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.10);
    font-weight: 700;
    letter-spacing: 0.5px;
}

.btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    padding: 10px 14px;
    border-radius: 12px;
    background: #6f8f5b;
    color: #fff;
    text-decoration: none;
    border: none;
    font-weight: 700;
    cursor: pointer;
}

.btn.secondary {
    background: #2f6f8f;
}

.btn.ghost {
    background: transparent;
    border: 1px solid rgba(255,255,255,0.22);
}

@media (max-width: 700px) {
    .panel-title-row {
        flex-direction: column;
        align-items: stretch;
    }

    .admin-panel {
        padding: 16px;
    }
}

body {
    margin: 0;
    background: #0b120e;
    color: #f4f4f4;
    font-family: Arial, sans-serif;
}

.app-shell {
    display: flex;
    min-height: 100vh;
}

.sidebar {
    width: 260px;
    background: #101a14;
    border-right: 1px solid rgba(255,255,255,0.12);
    padding: 20px;
}

.brand {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 28px;
}

.brand-logo {
    width: 56px;
    height: 56px;
    object-fit: contain;
}

.brand h2 {
    margin: 0;
}

.brand p {
    margin: 0;
    color: #b8c7b8;
}

.side-menu {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.side-menu a {
    color: #f4f4f4;
    text-decoration: none;
    padding: 12px 14px;
    border-radius: 12px;
    background: rgba(255,255,255,0.04);
}

.side-menu a:hover {
    background: rgba(255,255,255,0.12);
}

.main-content {
    flex: 1;
}

.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #18251d;
    padding: 18px 28px;
    border-bottom: 1px solid rgba(255,255,255,0.12);
}

.topbar h1 {
    margin: 0;
    font-size: 1.7rem;
    text-align: center;
}

.topbar p {
    margin: 4px 0 0;
    color: #cbd8cb;
    text-align: center;
}

.top-logo {
    width: 72px;
    height: 72px;
    object-fit: contain;
}

.content-area {
    padding: 28px;
}

.service-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 22px;
}

.service-card {
    background: linear-gradient(145deg, #1b2a20, #101812);
    border-radius: 22px;
    padding: 22px;
    border: 1px solid rgba(255,255,255,0.12);
    box-shadow: 0 14px 32px rgba(0,0,0,0.28);
}

.service-card h2 {
    margin-top: 0;
}

.service-icon {
    font-size: 2.8rem;
}

.calendar-strip {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}
.day-box {
    text-align: center;
    padding: 6px 2px;
    border-radius: 8px;
    font-size: 0.68rem;
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
    overflow: hidden;
    word-break: keep-all;
}
.day-box.low {
    background: rgba(67, 190, 120, 0.28);
}

.day-box.medium {
    background: rgba(240, 190, 70, 0.28);
}

.day-box.high {
    background: rgba(230, 120, 50, 0.32);
}

.day-box.full {
    background: rgba(220, 60, 60, 0.38);
}

.occupancy-bar {
    height: 9px;
    background: rgba(255,255,255,0.12);
    border-radius: 99px;
    overflow: hidden;
    margin: 10px 0;
}

.occupancy-fill {
    height: 100%;
    background: #8cab6f;
}

.card-actions {
    margin-top: 16px;
}

.card-actions a {
    display: inline-block;
    padding: 10px 14px;
    border-radius: 12px;
    background: #6f8f5b;
    color: white;
    text-decoration: none;
    font-weight: bold;
}

@media (max-width: 900px) {
    .app-shell {
        flex-direction: column;
    }

    .sidebar {
        width: auto;
    }

    .side-menu {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    }

    .topbar {
        gap: 12px;
    }

    .top-logo {
        width: 52px;
        height: 52px;
    }
}

.services-config-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 18px;
    margin-top: 18px;
}

.service-config-card {
    background: rgba(255,255,255,0.045);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.service-config-title {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
    font-size: 1.1rem;
}

.service-config-icon {
    font-size: 2rem;
}

.service-config-card label {
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-weight: 700;
}

.service-config-card input,
.service-config-card select,
.service-config-card textarea {
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.18);
    background: #111a15;
    color: #fff;
}

.service-config-card textarea {
    resize: vertical;
}

.checkbox-line {
    flex-direction: row !important;
    align-items: center;
    font-weight: 600 !important;
}

.checkbox-line input {
    width: auto;
}



/* Ajuste formulario Exportar Excel */
.inline-form {
    display: flex;
    align-items: flex-end;
    gap: 10px;
    flex-wrap: nowrap;
}

.inline-form label {
    margin: 0;
    gap: 4px;
}

.inline-form input[type="date"] {
    width: 160px;
    height: 38px;
    padding: 6px 10px;
}

.inline-form button,
.inline-form .primary {
    height: 38px;
    padding: 0 14px;
    line-height: 38px;
}

/* Icono calendario visible sobre fondo oscuro en Edge/Chrome */
input[type="date"]::-webkit-calendar-picker-indicator {
    filter: brightness(0) invert(1);
    opacity: 1;
    cursor: pointer;
}


/* ===== MODO MOVIL / RESPONSIVE LEST ===== */

@media (max-width: 768px) {
    html, body {
        width: 100%;
        overflow-x: hidden;
    }

    .app-shell {
        flex-direction: column;
        min-height: 100vh;
    }

    .sidebar {
    display: none;
    }
    
    .brand {
        justify-content: center;
        margin-bottom: 12px;
    }

    .brand-logo {
        width: 46px;
        height: 46px;
    }

    .brand h2 {
        font-size: 1.2rem;
    }

    .brand p {
        font-size: 0.85rem;
    }

    .side-menu {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }

    .side-menu a {
        text-align: center;
        padding: 13px 8px;
        font-size: 0.9rem;
        border-radius: 12px;
    }

    .main-content {
        width: 100%;
    }

    .topbar {
        flex-direction: column;
        text-align: center;
        gap: 8px;
        padding: 12px;
        position: relative;
    }

    .topbar h1 {
        font-size: 1.15rem;
        line-height: 1.25;
        letter-spacing: 0.03em;
    }

    .topbar p {
        font-size: 0.85rem;
    }

    .top-logo {
        width: 48px;
        height: 48px;
    }

    .content-area,
    .container {
        padding: 12px;
    }

    .section-title,
    .panel-title-row {
        display: block;
    }

    .section-title h2,
    .detail-header h2,
    .admin-header h1 {
        font-size: 1.45rem;
    }

    .service-grid {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .service-card {
        padding: 16px;
        border-radius: 18px;
    }

    .service-icon {
        width: 54px;
        height: 54px;
        font-size: 2rem;
    }

    .calendar-strip {
        grid-template-columns: repeat(4, 1fr);
        gap: 6px;
    }

    .day-box {
        font-size: 0.72rem;
        padding: 8px 3px;
    }

    .calendar-row {
        grid-template-columns: 1fr;
    }

    .auth-card,
    .reserve-panel,
    .calendar-panel,
    .admin-panel {
        max-width: 100%;
        margin: 16px 0;
        padding: 16px;
        border-radius: 18px;
    }

    .grid-form,
    .filters-row,
    .preload-form,
    .services-config-grid,
    .admin-summary-grid {
        grid-template-columns: 1fr;
    }

    input,
    select,
    textarea,
    button,
    .btn,
    .primary,
    .card-actions a {
        min-height: 44px;
        font-size: 1rem;
    }

    .card-actions a,
    .btn,
    .primary {
        width: 100%;
        justify-content: center;
        text-align: center;
    }

    .inline-form {
        flex-direction: column;
        align-items: stretch;
        flex-wrap: nowrap;
    }

    .inline-form input[type="date"],
    .inline-form button,
    .inline-form .primary {
        width: 100%;
        height: 44px;
        line-height: normal;
    }

    .table-wrapper {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .admin-table,
    .data-table {
        min-width: 680px;
        font-size: 0.88rem;
    }

    .admin-table th,
    .admin-table td {
        padding: 10px;
    }
}

@media (max-width: 420px) {
    .side-menu {
        grid-template-columns: 1fr;
    }

    .calendar-strip {
        grid-template-columns: repeat(2, 1fr);
    }

    .topbar h1 {
        font-size: 1rem;
    }
}

/* ===== FASE 1: mensajes y cancelaciones ===== */
.alert.success {
    background: rgba(65,184,131,.18);
    border: 1px solid var(--green);
    color: #dfffee;
}

.danger-button {
    background: var(--red) !important;
    color: #fff !important;
}

.admin-table .inline-form {
    margin: 0;
}

.admin-table .danger-button {
    height: 34px;
    line-height: 34px;
    padding: 0 12px;
    border-radius: 10px;
}


/* ===== Usuario conectado y acceso restringido ===== */
.user-session {
    margin-top: 8px !important;
    color: #d7b46a !important;
    font-size: 0.9rem !important;
    font-weight: 600;
    text-align: center;
}

.user-session strong {
    color: #ffffff;
}

.no-permission-box {
    max-width: 720px;
    margin: 40px auto;
    background: rgba(32,43,37,.98);
    border: 1px solid rgba(215,180,106,.55);
    border-radius: 22px;
    padding: 28px;
    text-align: center;
    box-shadow: 0 14px 32px rgba(0,0,0,0.28);
}

.no-permission-icon {
    font-size: 3rem;
    margin-bottom: 12px;
}

.no-permission-box h2 {
    margin-top: 0;
}

.no-permission-box p {
    color: var(--muted);
}

@media (max-width: 768px) {
    .user-session {
        font-size: 0.8rem !important;
        line-height: 1.35;
    }

    .no-permission-box {
        margin: 16px 0;
        padding: 20px;
    }
}


/* ===== Usuario conectado en barra lateral ===== */
.user-panel {
    margin: 0 0 18px 0;
    padding: 13px 12px;
    border-radius: 14px;
    background: rgba(255,255,255,0.055);
    border: 1px solid rgba(255,255,255,0.12);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.user-panel-title {
    color: var(--muted);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 8px;
}

.user-panel-name {
    color: #ffffff;
    font-weight: 800;
    line-height: 1.25;
    margin-bottom: 7px;
}

.user-panel-role {
    color: #4ea3ff;
    font-weight: 800;
    margin-bottom: 6px;
}

.user-panel-module {
    color: #cfd8dc;
    font-size: 0.9rem;
    font-weight: 600;
}

/* El antiguo texto de usuario en cabecera queda desactivado */
.user-session {
    display: none;
}

@media (max-width: 768px) {
    .user-panel {
        margin: 10px 0 14px 0;
        text-align: center;
    }

    .user-panel-name,
    .user-panel-role,
    .user-panel-module {
        font-size: 0.92rem;
    }
}



/* ===== Usuario conectado en barra lateral - versión limpia ===== */
.user-panel {
    margin: 16px 0 18px 0;
    padding: 12px 12px 13px;
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.035));
    border: 1px solid rgba(255,255,255,0.13);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.user-panel-title {
    color: #b8c7b8;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 8px;
}

.user-panel-name {
    color: #ffffff;
    font-weight: 800;
    font-size: 0.98rem;
    line-height: 1.25;
    margin-bottom: 6px;
}

.user-panel-role {
    display: inline-block;
    color: #58aaff;
    background: rgba(78,163,255,0.12);
    border: 1px solid rgba(78,163,255,0.28);
    border-radius: 999px;
    padding: 4px 9px;
    font-weight: 800;
    font-size: 0.82rem;
    margin: 2px 0 7px 0;
}

.user-panel-module {
    color: #d7b46a;
    font-size: 0.86rem;
    font-weight: 700;
}

/* Desactiva cualquier texto antiguo de usuario en cabecera */
.user-session {
    display: none !important;
}

@media (max-width: 768px) {
    .user-panel {
        margin: 10px 0 14px 0;
        text-align: center;
    }

    .user-panel-role {
        margin-top: 4px;
    }

    .user-panel-name {
        font-size: 0.95rem;
    }

    .user-panel-module {
        font-size: 0.86rem;
    }
}


/* ===== Recuperación y cambio de contraseña ===== */
.reset-action-form {
    display: inline-flex;
    margin: 2px 4px 2px 0;
}

.password-help {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid rgba(255,255,255,0.10);
}

.password-help p {
    color: var(--muted);
    margin: 0 0 8px 0;
}

.account-info {
    background: rgba(255,255,255,0.045);
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 14px;
    padding: 14px;
    margin-bottom: 18px;
}

@media (max-width: 768px) {
    .reset-action-form {
        display: flex;
        width: 100%;
        margin: 4px 0;
    }
}


/* ===== Mostrar/Ocultar contraseña ===== */
.password-wrapper {
    position: relative;
    width: 100%;
}

.password-wrapper input {
    width: 100%;
    padding-right: 50px;
}

.password-toggle {
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: #ffffff;
    cursor: pointer;
    font-size: 1.2rem;
    font-weight: 700;
    user-select: none;
    opacity: 0.98;
    line-height: 1;
}

.password-toggle:hover {
    color: #d7b46a;
}

@media (max-width: 768px) {
    .password-toggle {
        right: 16px;
        font-size: 1.25rem;
    }
}


/* ===== Pantallas sin sesión: login sin menú lateral ===== */
.login-main {
    width: 100%;
    min-height: 100vh;
}

.login-main .topbar {
    justify-content: center;
    gap: 28px;
}

.login-main .content-area {
    max-width: 720px;
    margin: 0 auto;
    padding-top: 58px;
    padding-left: 18px;
    padding-right: 18px;
}

.login-main .auth-card {
    margin-top: 0;
}

@media (max-width: 768px) {
    .login-main .content-area {
        padding-top: 24px;
    }

    .login-main .topbar {
        gap: 8px;
    }
}

/* ===== LEST v1.3: servicios por módulo ===== */
.module-banner {
    display: inline-block;
    margin: 10px 0 12px 0;
    padding: 7px 14px;
    border-radius: 999px;
    background: rgba(78, 163, 255, 0.18);
    border: 1px solid rgba(78, 163, 255, 0.45);
    color: #78bdff;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.module-banner.small {
    font-size: 0.78rem;
    padding: 5px 10px;
    margin: 8px 0;
}

.module-banner.select {
    background: rgba(215, 180, 106, 0.16);
    border-color: rgba(215, 180, 106, 0.5);
    color: #ffd27a;
}

.module-banner.global {
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.18);
    color: #ffffff;
}

.module-hint {
    color: #ffd27a;
    font-weight: 700;
    background: rgba(215, 180, 106, 0.10);
    border: 1px solid rgba(215, 180, 106, 0.25);
    border-radius: 12px;
    padding: 9px 11px;
}

.module-select-form {
    margin: 10px 0 18px 0;
    max-width: 320px;
}

.module-select-form label {
    font-weight: 800;
}

.module-static {
    display: flex;
    align-items: center;
    min-height: 44px;
    padding: 10px 13px;
    border-radius: 12px;
    border: 1px solid rgba(78,163,255,0.35);
    background: rgba(78,163,255,0.10);
    color: #eaf5ff;
}

.module-config-card {
    border-color: rgba(78,163,255,0.25);
}

/* ===== Menú móvil ===== */

.mobile-actions{
    display:none;
}

@media (max-width:768px){

    .mobile-actions{
        display:flex;
        flex-wrap:wrap;
        gap:8px;
        justify-content:center;
        padding:10px;
        background:#18251d;
        border-bottom:1px solid rgba(255,255,255,0.12);
    }

    .mobile-actions a{
        background:#243529;
        color:#fff;
        padding:10px 14px;
        border-radius:10px;
        text-decoration:none;
        font-size:.85rem;
        font-weight:700;
    }

    .mobile-actions a:hover{
        background:#2f4536;
    }
}



/* ===== LEST v1.4 ===== */
.alert-banner{background:rgba(201,76,76,.22);border-bottom:1px solid rgba(201,76,76,.65);color:#fff;padding:12px 18px;text-align:center;font-weight:800;}
.meal-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.08);flex-wrap:wrap;}
.dual-columns{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.object-card{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:14px;margin:10px 0;}
.object-card h4{margin:0 0 8px 0;font-size:1.1rem;}
@media(max-width:768px){.dual-columns{grid-template-columns:1fr}.meal-row{display:block}.meal-row form{margin-top:8px}.top-logo{width:54px;height:54px}.sidebar{display:none!important}}

/* ===== LEST v1.4.1: días sin servicio y detalles de disponibilidad ===== */
.status-disabled,
.day-box.disabled,
.calendar-day.status-disabled {
    background: rgba(210, 215, 210, 0.16) !important;
    border: 1px solid rgba(210, 215, 210, 0.28) !important;
    color: #b9c0b9 !important;
    opacity: 0.78;
}

.calendar-day.status-disabled .progress,
.status-disabled .progress {
    display: none !important;
}

.calendar-day.status-disabled small,
.day-box.disabled {
    color: #aeb6ae !important;
}

.availability-info {
    margin-top: 14px;
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(78, 163, 255, 0.10);
    border: 1px solid rgba(78, 163, 255, 0.28);
    color: #eaf5ff;
    font-weight: 700;
}

.meal-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: center;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255,255,255,0.10);
}

.meal-row:last-child {
    border-bottom: none;
}

.meal-row .inline-form {
    grid-column: 1 / -1;
    margin-top: 6px;
}

@media (max-width: 768px) {
    .meal-row {
        grid-template-columns: 1fr;
    }
}


/* ===== LEST v2.0 ===== */
.alert-marquee {
    overflow: hidden;
    white-space: nowrap;
    border-bottom: 1px solid rgba(255,255,255,0.18);
    background: rgba(10, 16, 13, 0.96);
}
.alert-marquee-track {
    display: inline-block;
    padding: 10px 0;
    animation: lest-marquee 28s linear infinite;
}
.alert-item {
    display: inline-block;
    margin-right: 45px;
    padding: 8px 14px;
    border-radius: 999px;
    font-weight: 800;
}
.alert-item.prohibicion,
.alert-card.prohibicion {
    background: rgba(201,76,76,0.22) !important;
    border: 1px solid rgba(201,76,76,0.75) !important;
    color: #ffd8d8 !important;
}
.alert-item.permitido,
.alert-card.permitido {
    background: rgba(65,184,131,0.20) !important;
    border: 1px solid rgba(65,184,131,0.65) !important;
    color: #dfffee !important;
}
.alert-item.informacion,
.alert-card.informacion {
    background: rgba(212,129,60,0.22) !important;
    border: 1px solid rgba(212,129,60,0.70) !important;
    color: #ffe6c7 !important;
}
@keyframes lest-marquee {
    0% { transform: translateX(100vw); }
    100% { transform: translateX(-100%); }
}
.object-photo {
    width: 100%;
    max-height: 220px;
    object-fit: contain;
    border-radius: 14px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.14);
    margin: 10px 0;
}
.menu-downloads {
    margin: 14px 0;
    padding: 14px;
    border-radius: 14px;
    background: rgba(78,163,255,0.10);
    border: 1px solid rgba(78,163,255,0.28);
}
.status-disabled,
.day-box.disabled,
.calendar-day.status-disabled {
    background: rgba(210, 215, 210, 0.16) !important;
    border: 1px solid rgba(210, 215, 210, 0.28) !important;
    color: #b9c0b9 !important;
    opacity: 0.78;
}
.calendar-day.status-disabled .progress,
.status-disabled .progress { display: none !important; }
.availability-info {
    margin-top: 14px;
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(78, 163, 255, 0.10);
    border: 1px solid rgba(78, 163, 255, 0.28);
    color: #eaf5ff;
    font-weight: 700;
}
.meal-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: center;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255,255,255,0.10);
}
.meal-row:last-child { border-bottom: none; }
.meal-row .inline-form { grid-column: 1 / -1; margin-top: 6px; }
@media (max-width: 768px) {
    .meal-row { grid-template-columns: 1fr; }
    .alert-marquee-track { animation-duration: 22s; }
}


/* ===== Registro: acceso a login ===== */
.auth-actions {
    margin: 12px 0 18px 0;
    display: flex;
    justify-content: flex-start;
    gap: 10px;
    flex-wrap: wrap;
}

.auth-actions-bottom {
    margin-top: 18px;
    padding-top: 14px;
    border-top: 1px solid rgba(255,255,255,0.10);
}

@media (max-width: 768px) {
    .auth-actions,
    .auth-actions-bottom {
        justify-content: center;
    }

    .auth-actions .btn,
    .auth-actions-bottom .btn {
        width: 100%;
    }
}


/* ===== LEST v3.0 SMS / Sistema de alertas ===== */
.sms-checkbox {
    background: rgba(215, 180, 106, 0.12);
    border: 1px solid rgba(215, 180, 106, 0.35);
    padding: 12px;
    border-radius: 12px;
}

.alert-card.prohibicion {
    border-color: rgba(201,76,76,.95);
    box-shadow: 0 0 0 1px rgba(201,76,76,.45);
}

.alert-card.permitido {
    border-color: rgba(65,184,131,.95);
    box-shadow: 0 0 0 1px rgba(65,184,131,.35);
}

.alert-card.informacion {
    border-color: rgba(212,129,60,.95);
    box-shadow: 0 0 0 1px rgba(212,129,60,.35);
}

.alert-marquee .alert-item.prohibicion {
    color: #ffb5b5;
}

.alert-marquee .alert-item.permitido {
    color: #b8ffd7;
}

.alert-marquee .alert-item.informacion {
    color: #ffd7a2;
}


/* ===== LEST v3.1 ===== */
.menu-card-home {
    border-color: rgba(215,180,106,.65);
}

.menu-card-home .service-icon {
    background: rgba(215,180,106,.14);
}

button[type="reset"].btn.ghost {
    min-height: 44px;
}


/* ===== LEST v3.2 ===== */
.menu-viewer-panel {
    max-width: 1100px;
}

.menu-pages {
    display: grid;
    gap: 24px;
}

.menu-page {
    background: #0f1512;
    border: 1px solid rgba(255,255,255,0.14);
    border-radius: 18px;
    padding: 14px;
    text-align: center;
}

.menu-page img {
    width: 100%;
    max-width: 1000px;
    border-radius: 12px;
    display: block;
    margin: 0 auto;
}

.rest-info {
    background: rgba(215,180,106,0.12);
    border-color: rgba(215,180,106,0.35);
}

.object-photo {
    width: 100%;
    max-height: 220px;
    object-fit: contain;
    border-radius: 14px;
    background: rgba(0,0,0,0.20);
    border: 1px solid rgba(255,255,255,0.10);
    margin: 10px 0;
}

.object-card.delivered {
    opacity: 0.82;
}

#objectSearch {
    width: 100%;
}


/* ===== LEST v3.3 ===== */
.incident-photo {
    width: 84px;
    max-height: 72px;
    object-fit: cover;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,0.18);
}

.user-notices {
    border: 1px solid rgba(215,180,106,.45);
    background: rgba(215,180,106,.08);
}

.personal-notice {
    padding: 12px 14px;
    margin: 10px 0;
    border-radius: 14px;
    background: rgba(0,0,0,.18);
    border: 1px solid rgba(255,255,255,.12);
}
