
:root{
--primary:#1B4FD8;--primary-dark:#1340B0;--primary-light:#EEF3FD;
--accent:#10B981;--danger:#EF4444;--warning:#F59E0B;--purple:#7C3AED;
--bg:#F0F2F7;--surface:#fff;--surface2:#F8FAFC;
--border:#E2E8F0;--text:#1E2A3B;--text2:#64748B;--text3:#94A3B8;
--sidebar-bg:#0F172A;
--radius:10px;--radius-lg:16px;
--shadow:0 1px 3px rgba(0,0,0,.08),0 4px 12px rgba(0,0,0,.06);
--shadow-lg:0 4px 16px rgba(0,0,0,.12),0 12px 40px rgba(0,0,0,.08);
--font:'DM Sans',sans-serif;
}
/* ═══ RESET & BASE ═══ */
*{box-sizing:border-box}
body{font-family:var(--font);margin:0;background:var(--bg);overflow-x:hidden;color:var(--text);line-height:1.5}
button{padding:9px 16px;border:none;border-radius:8px;cursor:pointer;background:var(--primary);color:#fff;font-size:13px;font-weight:600;font-family:var(--font);transition:all .18s}
button:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px rgba(27,79,216,.25)}
button:active{transform:translateY(0);box-shadow:none}
button[style*="#e74c3c"],button[style*="#dc2626"],button[style*="background:#EF4444"]{color:#fff!important}
input,select,textarea{width:100%;padding:10px 12px;margin:6px 0;border:1.5px solid var(--border);border-radius:8px;font-size:13px;font-family:var(--font);color:var(--text);background:var(--surface);transition:border-color .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(27,79,216,.1)}
input:read-only,select:disabled,textarea:read-only{background:var(--surface2);color:var(--text2);cursor:not-allowed}
/* ═══ LANDING PAGE ═══ */
.landing-page{display:block}
.landing-hidden{display:none!important}
.landing-header{background:linear-gradient(135deg,#1a252f 0%,#2c3e50 100%);color:#fff;padding:12px 0;position:sticky;top:0;z-index:1000;box-shadow:0 2px 10px rgba(0,0,0,.15)}
.landing-header .container{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 20px}
.landing-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px}
.landing-logo-icon{font-size:24px}
.landing-nav{display:flex;gap:4px;align-items:center}
.landing-nav a{color:#ecf0f1;text-decoration:none;padding:8px 14px;border-radius:5px;font-size:14px;transition:background .2s}
.landing-nav a:hover{background:rgba(255,255,255,.15)}
.landing-nav .btn-login{background:#27ae60;padding:8px 18px;font-weight:600;margin-left:8px}
.landing-nav .btn-login:hover{background:#219653}
.landing-hero{background:linear-gradient(rgba(0,0,0,.4),rgba(0,0,0,.4)),var(--banner-bg,#2c73d2);color:#fff;padding:80px 20px;text-align:center;background-size:cover;background-position:center;min-height:450px;display:flex;align-items:center;justify-content:center}
.landing-hero .container{max-width:900px}
.landing-hero h1{font-size:2.8em;margin:0 0 16px;text-shadow:0 2px 4px rgba(0,0,0,.3)}
.landing-hero p{font-size:1.3em;margin:0 0 24px;opacity:.95;max-width:700px;margin-left:auto;margin-right:auto}
.landing-hero .btn-cta{background:#fff;color:#2c3e50;padding:12px 32px;font-size:16px;font-weight:700;border-radius:30px;text-decoration:none;display:inline-block;transition:transform .2s,box-shadow .2s}
.landing-hero .btn-cta:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.25)}
.landing-section{padding:60px 20px;background:#fff}
.landing-section.alt{background:#f8f9fa}
.landing-section .container{max-width:1100px;margin:0 auto}
.landing-section h2{font-size:2em;margin:0 0 12px;color:#2c3e50;text-align:center}
.landing-section .subtitle{text-align:center;color:#666;margin:0 0 40px;font-size:1.1em}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.service-card{background:#fff;padding:24px;border-radius:12px;text-align:center;box-shadow:0 3px 15px rgba(0,0,0,.08);transition:transform .2s}
.service-card:hover{transform:translateY(-4px)}
.service-card .icon{font-size:36px;margin-bottom:12px}
.service-card h3{margin:0 0 8px;font-size:1.2em;color:#2c3e50}
.service-card p{margin:0;color:#666;font-size:14px}
.about-content{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.about-text h3{margin:0 0 16px;color:#2c3e50}
.about-text p{line-height:1.7;color:#555;margin:0 0 12px}
.about-image{background:linear-gradient(135deg,#3498db,#2c73d2);border-radius:12px;height:280px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:48px}
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px}
.contact-item{text-align:center;padding:20px}
.contact-item .icon{font-size:32px;margin-bottom:10px;color:#2c73d2}
.contact-item h4{margin:0 0 8px;color:#2c3e50}
.contact-item p{margin:0;color:#666}
.landing-footer{background:#1a252f;color:#bdc3c7;padding:40px 20px 20px}
.landing-footer .container{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:30px}
.landing-footer h4{color:#fff;margin:0 0 16px;font-size:1.1em}
.landing-footer p,.landing-footer a{margin:6px 0;color:#bdc3c7;text-decoration:none;font-size:14px}
.landing-footer a:hover{color:#fff}
.landing-footer .copyright{text-align:center;padding-top:20px;margin-top:20px;border-top:1px solid #34495e;font-size:13px}
/* ═══ LAYOUT APP ═══ */
.sidebar{width:220px;height:100vh;background:var(--sidebar-bg);color:#fff;position:fixed;padding:20px 14px;transition:transform .3s;z-index:1001;overflow-y:auto}
.sidebar a{display:flex;align-items:center;gap:8px;margin:3px 0;padding:10px 12px;background:transparent;border-radius:8px;color:rgba(255,255,255,.75);cursor:pointer;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s}
.sidebar a:hover{background:rgba(255,255,255,.1);color:#fff}
.sidebar .sa-badge{background:#8e44ad;font-size:10px;padding:2px 6px;border-radius:10px;margin-left:6px;vertical-align:middle}
.nav-badge{background:#e74c3c;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;line-height:18px;text-align:center;border-radius:50%;margin-left:auto;animation:pulseBadge 2s infinite}
.nav-badge.naranja{background:#f39c12;animation:pulseBadgeN 2s infinite}
@keyframes pulseBadge{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
@keyframes pulseBadgeN{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.main{margin-left:240px;padding:24px;min-height:100vh;transition:margin-left .3s}
.menu-toggle{display:none;position:fixed;top:15px;left:15px;z-index:1002;background:#2c3e50;color:#fff;border:none;padding:10px;border-radius:5px;font-size:18px}
/* ═══ LOGIN ═══ */
.login{width:90%;max-width:360px;margin:70px auto;background:var(--surface);padding:36px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.pass-wrap{position:relative;margin:8px 0}
.pass-wrap input{margin:0;padding-right:40px}
.pass-eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);cursor:pointer;background:none;border:none;padding:0;font-size:18px;color:#888;line-height:1}
.pass-eye:hover{color:#2c73d2;background:none}
.pass-hint{font-size:11px;color:#888;margin-top:-4px;margin-bottom:4px}
/* ═══ TABLAS ═══ */
table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
th,td{padding:12px 8px;border-bottom:1px solid #eee;text-align:center;font-size:13px}
th{background:var(--sidebar-bg);color:rgba(255,255,255,.9);cursor:pointer;position:sticky;top:0;z-index:10;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px}
/* ═══ CALENDARIO ═══ */
.calendar{background:#fff;padding:15px;border-radius:8px;width:100%;max-width:340px;box-shadow:0 2px 10px rgba(0,0,0,.1)}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-top:10px}
.day{padding:8px;text-align:center;border-radius:4px;cursor:pointer;font-size:12px;font-weight:bold;transition:all .2s;position:relative}
.day.libre{background:#BFDBFE;color:#1E3A8A}
.day.reservada{background:#FCD34D;color:#78350F;cursor:not-allowed!important}
.day.aprobada{background:#6EE7B7;color:#064E3B}
.day.cancelada{background:#FCA5A5;color:#7F1D1D}
.day.bloqueada{background:#94A3B8;color:#1E293B;cursor:not-allowed!important;opacity:.85}
.day.jacuzzi-libre{background:#a8e6cf;color:#2c3e50}
.day.jacuzzi-ocupado{background:#fdcb6e;color:#2c3e50}
.day.jacuzzi-completo{background:#e17055;color:#fff}
.day.admin-morning{background:#9b59b6;color:#fff}
.day.partial-occupied{background:#f39c12;color:#2c3e50}
.day.dia-reservado{background:#15803D;color:#fff;cursor:not-allowed!important;opacity:1;border:2px solid #14532D;font-weight:800}
/* Bicolor: residente(tarde verde) + admin(mañana morado) — solo admin lo ve */
.day.dia-split{background:linear-gradient(135deg,#7C3AED 50%,#15803D 50%)!important;color:#fff!important;cursor:not-allowed!important;border:2px solid #14532D!important;font-weight:800;opacity:1}
/* Pendiente (propio y de otro) — mismo color ámbar */
.day.pendiente-otro{background:#D97706!important;color:#fff!important;cursor:not-allowed!important;border:2px solid #92400E!important;font-weight:800;opacity:1}
.propia-reservada{background:#D97706!important;color:#fff!important;border:2px solid #92400E!important;font-weight:800!important;cursor:not-allowed!important}
.propia-aprobada{background:#15803D!important;color:#fff!important;border:2px solid #14532D!important;font-weight:800!important;cursor:not-allowed!important}
.propia-cancelada{background:#DC2626!important;color:#fff!important;border:2px solid #7F1D1D!important;font-weight:800!important;opacity:.8}
.otro-ocupado{background:#f1c40f!important;color:#2c3e50!important;opacity:.9}
.res-urgente-1{background:#fef9e7!important;border-left:3px solid #e6a800!important}
.res-urgente-2{background:#fff0eb!important;border-left:3px solid #c45200!important}
.res-urgente-3{background:#fdecea!important;border-left:3px solid #8b0000!important;animation:pulseSem .9s ease-in-out infinite alternate}
/* ═══ MODAL ═══ */
.modal{position:fixed;top:0;left:0;width:100%;height:100%;display:none;background:rgba(15,23,42,.6);align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto;backdrop-filter:blur(4px)}
.modal-content{background:var(--surface);padding:28px;width:95%;max-width:800px;border-radius:var(--radius-lg);max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal-content-large{max-width:1000px}
.btn-cancel{background:#EF4444!important;color:#fff!important}
.btn-cancel:hover{background:#DC2626!important;color:#fff!important}
/* ═══ MODAL USUARIO (Enhanced) ═══ */
.modal-header{background:linear-gradient(135deg,var(--primary) 0%,#6366f1 100%);color:#fff;padding:20px 24px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;margin:-28px -28px 20px;display:flex;align-items:center;gap:14px}
.modal-header .modal-icon{width:46px;height:46px;background:rgba(255,255,255,.18);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.modal-header h3{margin:0;font-size:17px;font-weight:700;color:#fff;line-height:1.3}
.modal-header .modal-subtitle{font-size:12px;opacity:.82;margin-top:2px;font-weight:400}
.modal-body{padding:0 4px}
.modal-section{margin-bottom:18px}
.modal-section:last-of-type{margin-bottom:8px}
.modal-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text3);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.toggle-card{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1.5px solid var(--border);border-radius:10px;cursor:pointer;transition:all .2s;background:var(--surface);margin-bottom:8px}
.toggle-card:hover{border-color:var(--primary);background:var(--primary-light)}
.toggle-card input[type="checkbox"]{width:18px;height:18px;margin:0;accent-color:var(--primary);cursor:pointer;flex-shrink:0}
.toggle-card .tc-icon{font-size:18px;flex-shrink:0}
.toggle-card .tc-label{font-size:13px;font-weight:600;color:var(--text);line-height:1.2}
.toggle-card .tc-desc{font-size:11px;color:var(--text3);margin-top:1px}
.toggle-card input[type="checkbox"]:checked~.tc-label{color:var(--primary)}
.modal-footer{display:flex;gap:10px;padding-top:16px;border-top:1px solid var(--border);margin-top:8px}
.modal-footer button{flex:1;padding:12px 20px;font-size:14px;border-radius:10px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px}
.modal-btn-save{background:var(--primary)!important;color:#fff!important}
.modal-btn-save:hover{background:var(--primary-dark)!important;box-shadow:0 4px 14px rgba(27,79,216,.3)!important}
.modal-btn-cancel{background:var(--surface2)!important;color:var(--text2)!important;border:1.5px solid var(--border)!important}
.modal-btn-cancel:hover{background:#f1f5f9!important;color:var(--text)!important;box-shadow:none!important;transform:none!important}
/* ═══ SEMÁFORO URGENCIA ═══ */
.resaltar-amarillo{background:#f9e79f!important}
.resaltar-rojo{background:#f1948a!important}
.urgente-1{background:#f9c74f!important;color:#5a3e00!important;font-weight:bold;border-left:4px solid #e6a800}
.urgente-2{background:#f4752b!important;color:#fff!important;font-weight:bold;border-left:4px solid #c45200}
.urgente-3{background:#d62828!important;color:#fff!important;font-weight:bold;border-left:4px solid #8b0000;animation:pulseSem .9s ease-in-out infinite alternate}
@keyframes pulseSem{from{opacity:1}to{opacity:.82}}
/* ═══ FILTROS ═══ */
.filtros{background:#fff;padding:15px 20px;border-radius:8px;margin-bottom:15px;box-shadow:0 2px 10px rgba(0,0,0,.1);display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}
.filtros select,.filtros input{margin:0;flex:1;min-width:130px}
.filtros-btns{display:flex;gap:8px;flex-shrink:0}
.inv-filtros{background:#fff;padding:14px 18px;border-radius:8px;margin-bottom:12px;box-shadow:0 2px 8px rgba(0,0,0,.08);display:flex;flex-wrap:wrap;gap:8px;align-items:flex-end}
.inv-filtros input,.inv-filtros select{margin:0;flex:1;min-width:130px}
/* ═══ CARDS GENÉRICAS ═══ */
.stat-card{background:#fff;padding:20px;border-radius:8px;text-align:center;box-shadow:0 2px 10px rgba(0,0,0,.1)}
.stat-card h2{margin:0 0 10px;font-size:2em}
.notificacion{position:fixed;top:20px;right:20px;background:#e74c3c;color:#fff;padding:12px 16px;border-radius:5px;box-shadow:0 4px 12px rgba(0,0,0,.3);z-index:2000;animation:slideIn .3s ease;max-width:320px;font-size:13px;line-height:1.4}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
/* ═══ EXPORTAR ═══ */
.export-opciones{display:flex;gap:15px;margin-top:15px;flex-wrap:wrap}
.export-opcion{flex:1;min-width:120px;padding:20px 15px;border-radius:8px;border:2px solid transparent;cursor:pointer;text-align:center;font-size:15px;font-weight:bold;transition:all .2s}
.export-opcion:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}
.opc-pdf{background:#fdecea;color:#c0392b;border-color:#e74c3c}.opc-pdf:hover{background:#e74c3c;color:#fff}
.opc-excel{background:#eafaf1;color:#1e8449;border-color:#27ae60}.opc-excel:hover{background:#27ae60;color:#fff}
.export-resumen{background:#f8f9fa;border-radius:6px;padding:10px 14px;font-size:13px;margin-top:12px;color:#555;line-height:1.7}
.export-resumen strong{color:#2c3e50}
/* ═══ CONFIGURACIÓN ═══ */
.cfg-section{background:#fff;padding:20px;border-radius:8px;margin-bottom:15px;box-shadow:0 2px 10px rgba(0,0,0,.1)}
.cfg-section h4{margin:0 0 12px;color:#2c3e50;border-bottom:2px solid #eee;padding-bottom:8px}
.toggle-row{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 0;border-bottom:1px solid #f0f0f0;gap:10px}
.toggle-row:last-child{border-bottom:none}
.toggle-row .tr-label{font-size:14px;color:#333;flex:1}
.toggle-row .toggle-desc{font-size:11px;color:#888;display:block;margin-top:3px}
.switch{position:relative;display:inline-block;width:46px;height:24px;flex-shrink:0;margin-top:2px}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#ccc;border-radius:24px;transition:.3s}
.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}
input:checked+.slider{background:#2ecc71}
input:checked+.slider:before{transform:translateX(22px)}
.info-box{border-radius:6px;padding:10px 14px;font-size:12px;margin-top:8px;line-height:1.7}
.info-box.blue{background:#eaf4ff;border:1px solid #b8d9f5;color:#1a4a7a}
.info-box.yellow{background:#fff8e1;border:1px solid #ffe082;color:#7b5800}
.info-box.green{background:#eafaf1;border:1px solid #a9dfbf;color:#1a5c34}
.info-box.purple{background:#f5eeff;border:1px solid #c9a0f5;color:#5a2d8c}
.info-box.red{background:#fdecea;border:1px solid #e74c3c;color:#922b21}
.info-box code{background:rgba(0,0,0,.07);padding:1px 4px;border-radius:3px;font-family:monospace;font-size:11px}
.info-box a{color:inherit;font-weight:bold}
.cfg-sub{font-weight:bold;font-size:13px;margin:14px 0 4px;color:#2c3e50}
/* ═══ NOTIFICACIONES (tabla) ═══ */
.notif-table{width:100%;border-collapse:collapse;margin-top:12px;font-size:13px}
.notif-table th{background:#2c3e50;color:#fff;padding:10px 14px;text-align:left;font-weight:600;white-space:nowrap}
.notif-table th:not(:first-child){text-align:center;min-width:110px}
.notif-table td{padding:10px 14px;border-bottom:1px solid #eee;background:#fff;vertical-align:middle}
.notif-table tr:last-child td{border-bottom:none}
.notif-table td:not(:first-child){text-align:center}
.notif-table tr:hover td{background:#fafbfc}
.notif-table td:first-child{text-align:left;font-weight:500;color:#2c3e50}
.notif-cell{display:inline-flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:5px 8px;border-radius:8px;transition:background .15s;user-select:none;min-width:80px}
.notif-cell:hover{background:#f0f4ff}
.nb{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap;transition:all .2s}
.nb-on{background:#d5f5e3;color:#1a5c34}.nb-sim{background:#fef9e7;color:#7b5800;border:1px dashed #f39c12}
.nb-off{background:#f2f3f4;color:#aaa}.nb-na{background:#f2f3f4;color:#bbb;cursor:not-allowed}
.notif-cell .cell-hint{font-size:10px;color:#aaa;margin-top:1px}
.notif-cell.active .cell-hint{color:#27ae60}
.mini-sw{width:32px;height:16px;background:#ccc;border-radius:16px;position:relative;transition:.25s;flex-shrink:0}
.mini-sw::before{content:"";position:absolute;width:12px;height:12px;border-radius:50%;background:#fff;top:2px;left:2px;transition:.25s}
.notif-cell.active .mini-sw{background:#2ecc71}.notif-cell.active .mini-sw::before{left:18px}
.notif-cell.sim .mini-sw{background:#f39c12}.notif-cell.sim .mini-sw::before{left:18px}
/* ═══ SUPERADMIN & MÓDULOS ══ */
.sa-panel{background:linear-gradient(135deg,#1a0536,#2d0a5e);color:#fff;border-radius:12px;padding:24px;margin-bottom:16px}
.sa-panel h3{margin:0 0 6px;color:#e8c4ff;font-size:18px}
.sa-panel p{margin:0 0 16px;font-size:12px;color:#c9a0f5;opacity:.85}
.modulo-card{background:#fff;border-radius:10px;padding:18px 20px;margin-bottom:12px;box-shadow:0 2px 10px rgba(0,0,0,.12);display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.modulo-card .mc-info{flex:1;min-width:180px}
.modulo-card .mc-info h4{margin:0 0 4px;font-size:15px;color:#2c3e50}
.modulo-card .mc-info p{margin:0;font-size:12px;color:#888}
.modulo-card .mc-badge{padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700}
.mc-activo{background:#d5f5e3;color:#1a5c34}.mc-inactivo{background:#f2f3f4;color:#888}
/* ═══ INVENTARIO/ACTIVOS ═══ */
.inv-estado{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:14px;font-size:11px;font-weight:700;white-space:nowrap}
.codigo-toggle{display:flex;border-radius:6px;overflow:hidden;border:1px solid #ddd;margin:4px 0 8px}
.codigo-toggle button{flex:1;border-radius:0;border:none;padding:8px 10px;font-size:13px;background:#f4f6f9;color:#555;transition:.2s}
.codigo-toggle button.activo{background:#2c73d2;color:#fff}
.inv-tag{display:inline-block;background:#eaf4ff;color:#1a4a7a;border-radius:12px;padding:2px 10px;font-size:11px;font-weight:600;margin:2px}
.inv-tag.vence-pronto{background:#fff3cd;color:#856404}
.inv-tag.vencido{background:#fdecea;color:#c0392b}
.attr-chip{display:inline-flex;align-items:center;gap:5px;background:#f4f6f9;border:1px solid #ddd;border-radius:6px;padding:4px 10px;font-size:12px;margin:3px}
.attr-chip button{padding:0 4px;background:none;color:#e74c3c;font-size:14px;line-height:1}
.attr-chip button:hover{background:none;color:#c0392b}
/* ═══ DASHBOARD ═══ */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:12px;margin-bottom:18px}
.kpi-card{background:var(--surface);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;position:relative;overflow:hidden;transition:transform .18s,box-shadow .18s;border:1px solid var(--border)}
.kpi-card:hover{transform:translateY(-2px);box-shadow:0 5px 18px rgba(0,0,0,.12)}
.kpi-icon{font-size:28px;flex-shrink:0;line-height:1}
.kpi-data{flex:1;min-width:0}
.kpi-val{font-size:24px;font-weight:800;line-height:1.1;margin-bottom:2px}
.kpi-label{font-size:10px;color:#888;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.kpi-trend{font-size:10px;margin-top:3px;font-weight:600;white-space:nowrap}
.kpi-trend.up{color:#2ecc71}.kpi-trend.warn{color:#f39c12}.kpi-trend.dn{color:#e74c3c}
.kpi-bar{position:absolute;bottom:0;left:0;height:3px;transition:width .4s}
.dash-row{display:grid;gap:14px;margin-bottom:14px}
.dash-row.c2{grid-template-columns:repeat(2,1fr)}
.dash-row.c3{grid-template-columns:repeat(3,1fr)}
.dash-panel{background:var(--surface);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow);min-width:0;border:1px solid var(--border)}
.dash-panel h4{margin:0 0 12px;font-size:11px;color:#7a8a9a;display:flex;align-items:center;gap:6px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #f2f3f4;padding-bottom:10px}
.dash-panel h4 em{font-size:15px;font-style:normal}
.chart-wrap{width:100%;position:relative}
.chart-wrap .cw-inner{position:relative;width:100%;padding-bottom:70%}
.chart-wrap.sq .cw-inner{padding-bottom:80%}
.chart-wrap canvas{position:absolute!important;top:0!important;left:0!important;width:100%!important;height:100%!important}
.act-list{max-height:230px;overflow-y:auto;padding-right:2px}
.act-item{display:flex;align-items:flex-start;gap:9px;padding:7px 10px;border-radius:8px;margin-bottom:5px;font-size:12px;background:#f8f9fa;transition:background .12s}
.act-item:hover{background:#eef2ff}
.act-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:3px}
.act-dot.aprobada{background:#2ecc71}.act-dot.reservada{background:#f1c40f}.act-dot.cancelada{background:#e74c3c}
.act-info{flex:1;min-width:0}
.act-apt{font-weight:700;color:#2c3e50;font-size:12px}
.act-meta{font-size:10px;color:#bbb;margin-top:2px}
.urg-list{list-style:none;padding:0;margin:0;max-height:230px;overflow-y:auto}
.urg-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;margin-bottom:5px;font-size:12px;font-weight:600;border-left:3px solid transparent}
.urg-item.u1{background:#fef9e7;border-color:#e6a800;color:#5a3e00}
.urg-item.u2{background:#fff0eb;border-color:#c45200;color:#7a2e00}
.urg-item.u3{background:#fdecea;border-color:#8b0000;color:#7b1212}
.inv-est-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(105px,1fr));gap:8px;margin-top:4px}
.inv-est-chip{padding:9px 6px;border-radius:8px;text-align:center;font-size:11px;font-weight:700;line-height:1.5}
/* ── DASHBOARD FILTROS ─────────────────────────────── */
.dash-filtros{background:#fff;border-radius:12px;padding:14px 18px;margin-bottom:14px;box-shadow:0 2px 10px rgba(0,0,0,.07);display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}
.dash-filtros select{margin:0;flex:1;min-width:130px;padding:8px 10px;font-size:13px}
.dash-filtros label{font-size:11px;font-weight:700;color:#7a8a9a;text-transform:uppercase;letter-spacing:.4px;display:block;margin-bottom:3px}
.dash-filtros-group{display:flex;flex-direction:column;flex:1;min-width:130px}
.dash-filtros-btns{display:flex;gap:8px;align-items:flex-end;flex-shrink:0}
.dash-filtros-btns button{padding:8px 14px;font-size:13px}
.dash-filtros-btns .btn-reset{background:#95a5a6}
.dash-filtros-btns .btn-reset:hover{background:#7f8c8d}
.panel-filtro-activo{position:relative}
.panel-filtro-activo::after{content:"●";position:absolute;top:8px;right:10px;color:#2c73d2;font-size:9px}
.filtros select.activo-filtro{border-color:#2c73d2;background:#eaf4ff}
/* ═══ GESTIÓN DE CONTENIDO LANDING ═══ */
.content-mgmt-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}
.content-card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 10px rgba(0,0,0,.1)}
.content-card h4{margin:0 0 12px;color:#2c3e50;border-bottom:2px solid #eee;padding-bottom:8px}
.content-card label{display:block;font-size:13px;font-weight:600;color:#555;margin:12px 0 4px}
.content-card input[type="text"],.content-card input[type="url"],.content-card textarea{margin:4px 0 12px}
.content-card .preview-banner{background:#f4f6f9;border-radius:8px;padding:15px;margin:12px 0;text-align:center;min-height:120px;display:flex;align-items:center;justify-content:center;color:#666;font-size:14px}
.content-card .preview-banner.has-content{background:linear-gradient(rgba(0,0,0,.3),rgba(0,0,0,.3)),var(--prev-bg,#2c73d2);color:#fff;min-height:150px}
.content-card .preview-banner.has-content h3{margin:0 0 8px;font-size:1.4em}
.content-card .preview-banner.has-content p{margin:0;opacity:.9}
/* ═══ PRESTAMOS (NUEVO) ═══ */
.prestamo-activo{background:#d5f5e3;color:#1a5c34;border:1px solid #2ecc71}
.prestamo-devuelto{background:#f2f3f4;color:#7f8c8d;border:1px solid #bdc3c7}
.prestamo-vencido{background:#fdecea;color:#c0392b;border:1px solid #e74c3c}
.prestamo-solicitado{background:#fef9e7;color:#7b5800;border:1px solid #f39c12}
/* ═══ LEGENDA CALENDARIO ═══ */
.cal-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px;padding-top:15px;border-top:1px solid #eee;font-size:11px;justify-content:center}
.legend-item{display:flex;align-items:center;gap:5px}
.legend-dot{width:12px;height:12px;border-radius:3px;display:inline-block}
.legend-dot.libre{background:#BFDBFE}
.legend-dot.reservada{background:#FCD34D}
.legend-dot.aprobada{background:#6EE7B7}
.legend-dot.cancelada{background:#FCA5A5}
.legend-dot.bloqueada{background:#94A3B8}
.legend-dot.jacuzzi-libre{background:#a8e6cf}
.legend-dot.jacuzzi-ocupado{background:#fdcb6e}
.legend-dot.jacuzzi-completo{background:#e17055}
.legend-dot.admin-morning{background:#9b59b6}
.legend-dot.partial-occupied{background:#f39c12}
.legend-dot.dia-reservado{background:#15803D}
.legend-dot.pendiente-otro{background:#D97706}
.legend-dot.propia-aprobada{background:#059669}
/* ═══ SELECTOR TIPO RESERVA ═══ */
.reserva-tipo-selector{display:flex;gap:10px;margin-bottom:15px;flex-wrap:wrap}
.reserva-tipo-btn{flex:1;min-width:120px;padding:12px;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;text-align:center;font-weight:600;transition:all .2s}
.reserva-tipo-btn:hover{border-color:#2c73d2}
.reserva-tipo-btn.activo{border-color:#2c73d2;background:#eaf4ff;color:#2c73d2}
/* ═══ FORMULARIO RESERVA SALÓN ═══ */
.reserva-form-section{background:#f8f9fa;padding:15px;border-radius:8px;margin:12px 0}
.reserva-form-section h4{margin:0 0 12px;color:#2c3e50;font-size:14px;border-bottom:2px solid #2c73d2;padding-bottom:6px;display:inline-block}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin:8px 0}
.form-group{display:flex;flex-direction:column}
.form-group label{font-size:12px;font-weight:600;color:#555;margin-bottom:4px}
.form-group .field-hint{font-size:10px;color:#888;margin-top:2px}
.form-group.required label::after{content:" *";color:#e74c3c}
.terms-box{background:#fff8e1;border:1px solid #ffe082;border-radius:6px;padding:12px;margin:12px 0;font-size:12px;line-height:1.6}
.terms-box h5{margin:0 0 8px;color:#7b5800;font-size:13px}
.terms-box ul{margin:8px 0;padding-left:20px}
.terms-box li{margin:4px 0}
.terms-note{font-size:11px;color:#888;margin-top:8px;font-style:italic}
.attendee-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:12px}
.attendee-table th{background:#2c73d2;color:#fff;padding:8px;text-align:left;font-size:11px}
.attendee-table td{padding:6px;border-bottom:1px solid #eee}
.attendee-table input{padding:6px;margin:0;font-size:12px}
.inventory-section{background:#eaf4ff;border:1px solid #b8d9f5;border-radius:6px;padding:12px;margin:12px 0}
.inventory-section h5{margin:0 0 8px;color:#1a4a7a;font-size:13px}
.inventory-item{display:flex;justify-content:space-between;align-items:center;padding:8px;background:#fff;border-radius:4px;margin:4px 0}
.inventory-item input{width:80px;text-align:center}
.admin-review-section{background:#fdecea;border:1px solid #e74c3c;border-radius:6px;padding:12px;margin:12px 0}
.admin-review-section h5{margin:0 0 8px;color:#922b21;font-size:13px}
.review-options{display:flex;gap:15px;margin:8px 0}
.review-options label{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer}
.signature-section{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:20px 0;padding:15px;background:#f8f9fa;border-radius:6px}
.signature-box{text-align:center;padding:10px}
.signature-line{border-bottom:1px solid #333;height:40px;margin:10px 0}
.signature-label{font-size:11px;color:#666}
.print-only{display:none}
.franja-horaria-badge{display:inline-block;padding:3px 8px;border-radius:12px;font-size:10px;font-weight:700;margin-left:6px}
.franja-manana{background:#9b59b6;color:#fff}
.franja-tarde{background:#27ae60;color:#fff}
/* ═══ TRAZABILIDAD DEVOLUCIONES ═══ */
.dev-estado-ok{background:#d5f5e3;color:#1a5c34;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:700}
.dev-estado-dano{background:#fdecea;color:#922b21;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:700}
.dev-badge-bloq{background:#e74c3c;color:#fff;padding:2px 6px;border-radius:4px;font-size:10px;margin-left:6px}
@media print{
.sidebar,.menu-toggle,.filtros,.filtros-btns,.reserva-tipo-selector,.no-print{display:none!important}
.main{margin:0;padding:0}
.modal{position:static;background:none;padding:0}
.modal-content{box-shadow:none;max-width:100%;padding:0}
.print-only{display:block}
body{background:#fff}
}
/* ═══ RESPONSIVE — 5 breakpoints ═══ */
@media(max-width:768px){
.menu-toggle{display:block}
.sidebar{transform:translateX(-100%)}
.sidebar.open{transform:translateX(0)}
.main{margin-left:0;padding:60px 14px 20px}
.login{margin:60px auto;padding:20px}
table{font-size:12px}
th,td{padding:8px 5px}
.calendar{max-width:100%}
.calendar-grid{gap:3px}
.day{padding:7px 4px;font-size:11px}
.filtros,.inv-filtros{flex-direction:column}
.filtros select,.filtros input,.inv-filtros input,.inv-filtros select{min-width:100%;flex:none}
.filtros-btns{width:100%;justify-content:stretch}
.filtros-btns button{flex:1}
.modal-content{width:100%;max-width:100%;padding:18px}
.export-opciones{flex-direction:column}
.notif-table{font-size:11px}
.notif-table th,.notif-table td{padding:8px 6px}
.notif-cell{min-width:60px;padding:4px}
.cfg-section{padding:15px}
.stat-card{padding:15px}
.stat-card h2{font-size:1.6em}
.modulo-card{flex-direction:column;align-items:flex-start}
.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}
.dash-row.c2,.dash-row.c3{grid-template-columns:1fr}
.kpi-val{font-size:20px}.kpi-icon{font-size:22px}
.chart-wrap .cw-inner{padding-bottom:72%}
.chart-wrap.sq .cw-inner{padding-bottom:80%}
.inv-est-grid{grid-template-columns:repeat(3,1fr)}
.dash-filtros{flex-direction:column}
.dash-filtros-group{min-width:100%}
.dash-filtros-btns{width:100%}
.dash-filtros-btns button{flex:1}
.landing-header .container{flex-wrap:wrap;gap:10px}
.landing-nav{width:100%;justify-content:center}
.landing-hero h1{font-size:2.2em}
.landing-hero p{font-size:1.1em}
.about-content{grid-template-columns:1fr}
.modal-content-large{max-width:100%}
.signature-section{grid-template-columns:1fr}
}
@media(max-width:480px){
th,td{padding:6px 3px;font-size:11px}
button{padding:6px 8px;font-size:12px}
.day{padding:5px 2px;font-size:10px}
.login{margin:40px auto;padding:18px}
.modal-content{padding:14px}
.modal-header{margin:-14px -14px 16px;padding:16px 18px}
.modal-header .modal-icon{width:38px;height:38px;font-size:18px}
.modal-header h3{font-size:15px}
.form-row-2{grid-template-columns:1fr}
.modal-footer{flex-direction:column}
.modal-footer button{width:100%}
.notif-table{font-size:10px}
.notif-cell{min-width:50px;padding:3px}
.nb{font-size:10px;padding:2px 6px}
.sidebar{width:200px;padding:14px}
.stat-card h2{font-size:1.4em}
.kpi-grid{grid-template-columns:repeat(2,1fr);gap:8px}
.kpi-card{padding:11px 12px}
.kpi-val{font-size:18px}.kpi-icon{font-size:20px}
.chart-wrap .cw-inner{padding-bottom:78%}
.act-item{font-size:11px}
.inv-est-grid{grid-template-columns:repeat(2,1fr)}
.landing-hero{padding:50px 15px;min-height:380px}
.landing-hero h1{font-size:1.8em}
.landing-section{padding:40px 15px}
.landing-section h2{font-size:1.6em}
.form-row{grid-template-columns:1fr}
}
@media(max-width:360px){
th,td{padding:5px 2px;font-size:10px}
button{padding:5px 6px;font-size:11px}
.day{font-size:9px;padding:4px 1px}
.kpi-grid{grid-template-columns:1fr}
.kpi-card{padding:10px}
}
@media(min-width:1200px){
.filtros{flex-wrap:nowrap}
.main{padding:25px 30px}
.kpi-grid{grid-template-columns:repeat(6,1fr)}
.dash-row.c2{grid-template-columns:repeat(2,1fr)}
.dash-row.c3{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:1600px){
.sidebar{width:240px}
.main{margin-left:260px}
th,td{padding:14px 10px;font-size:14px}
.kpi-val{font-size:26px}
}
/* ═══ CASILLEROS ═══ */
.cas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:6px;margin-top:12px}
.cas-cell{width:100%;aspect-ratio:1;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;font-size:10px;font-weight:700;border:2px solid transparent;transition:all .2s;position:relative}
.cas-cell:hover{transform:scale(1.08);box-shadow:0 4px 12px rgba(0,0,0,.18);z-index:2}
.cas-libre{background:#DBEAFE;color:#1E40AF;border-color:#93C5FD}
.cas-domicilio{background:#D1FAE5;color:#065F46;border-color:#6EE7B7}
.cas-retirado{background:#F3F4F6;color:#6B7280;border-color:#D1D5DB}
.cas-sema-1d{background:#D1FAE5!important;border-color:#10B981!important}
.cas-sema-2d{background:#FEF3C7!important;border-color:#F59E0B!important;color:#92400E!important}
.cas-sema-3d{background:#FEE2E2!important;border-color:#EF4444!important;color:#991B1B!important;animation:pulseSem .9s ease-in-out infinite alternate}
.cas-num{font-size:13px;font-weight:800;line-height:1}
.cas-apt{font-size:8px;opacity:.8;margin-top:2px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cas-badge{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;font-size:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800}
.cas-filtros{background:#fff;padding:14px 18px;border-radius:8px;margin-bottom:14px;box-shadow:0 2px 10px rgba(0,0,0,.08);display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}
.cas-filtros select,.cas-filtros input{margin:0;flex:1;min-width:120px}
.cas-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px;padding:12px;background:#fff;border-radius:8px;box-shadow:0 2px 10px rgba(0,0,0,.08);font-size:12px}
.cas-legend-item{display:flex;align-items:center;gap:5px;font-weight:600}
.cas-legend-dot{width:16px;height:16px;border-radius:4px;border:2px solid transparent}
.cas-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:14px}
.cas-kpi{background:#fff;padding:16px;border-radius:8px;text-align:center;box-shadow:0 2px 10px rgba(0,0,0,.08)}
.cas-kpi h3{margin:0;font-size:28px}
.cas-kpi p{margin:4px 0 0;font-size:11px;color:#888;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.cas-tbl{width:100%;border-collapse:collapse;font-size:12px}
.cas-tbl th{background:var(--sidebar-bg);color:#fff;padding:10px 8px;font-size:11px;text-transform:uppercase;letter-spacing:.3px}
.cas-tbl td{padding:8px;border-bottom:1px solid #eee;text-align:center;vertical-align:middle}
.cas-tbl tr:hover td{background:#f8fafc}
.cas-estado-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:14px;font-size:11px;font-weight:700}
.cas-dias-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:10px;font-size:10px;font-weight:800}
@media(max-width:768px){.cas-grid{grid-template-columns:repeat(auto-fill,minmax(42px,1fr));gap:4px}.cas-cell{font-size:9px}.cas-num{font-size:11px}.cas-apt{font-size:7px}.cas-kpi-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.cas-grid{grid-template-columns:repeat(auto-fill,minmax(36px,1fr));gap:3px}.cas-cell{font-size:8px}.cas-num{font-size:10px}}
/* ═══ VEHÍCULOS ═══ */
.veh-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-top:12px}
.veh-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:14px}
.veh-kpi{background:#fff;padding:16px;border-radius:8px;text-align:center;box-shadow:0 2px 10px rgba(0,0,0,.08)}
.veh-kpi h3{margin:0;font-size:28px}
.veh-kpi p{margin:4px 0 0;font-size:11px;color:#888;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.veh-filtros{background:#fff;padding:14px 18px;border-radius:8px;margin-bottom:14px;box-shadow:0 2px 10px rgba(0,0,0,.08);display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}
.veh-filtros select,.veh-filtros input{margin:0;flex:1;min-width:120px}
.veh-estado-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:14px;font-size:11px;font-weight:700}
.veh-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px;padding:12px;background:#fff;border-radius:8px;box-shadow:0 2px 10px rgba(0,0,0,.08);font-size:12px}
.veh-legend-item{display:flex;align-items:center;gap:5px;font-weight:600}
.veh-legend-dot{width:16px;height:16px;border-radius:4px;border:2px solid transparent}
.veh-tbl{width:100%;border-collapse:collapse;font-size:12px}
.veh-tbl th{background:var(--sidebar-bg);color:#fff;padding:10px 8px;font-size:11px;text-transform:uppercase;letter-spacing:.3px}
.veh-tbl td{padding:8px;border-bottom:1px solid #eee;text-align:center;vertical-align:middle}
.veh-tbl tr:hover td{background:#f8fafc}
.veh-entrada{background:#D1FAE5;color:#065F46;padding:3px 10px;border-radius:14px;font-size:11px;font-weight:700;display:inline-flex;align-items:center;gap:4px}
.veh-salida{background:#F3F4F6;color:#6B7280;padding:3px 10px;border-radius:14px;font-size:11px;font-weight:700;display:inline-flex;align-items:center;gap:4px}
.veh-acceso{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:14px;font-size:11px;font-weight:700}
.veh-acceso-residente{background:#DBEAFE;color:#1E40AF}
.veh-acceso-visitante{background:#FEF3C7;color:#92400E}
.veh-quick-actions{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.veh-quick-actions button{display:flex;align-items:center;gap:6px}
/* ═══ VEHICLE TABLERO CARDS ═══ */
.veh-tablero-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:14px}
.veh-card{background:#fff;border-radius:14px;padding:16px;box-shadow:0 2px 10px rgba(0,0,0,.08);border:2px solid transparent;transition:all .22s;position:relative;overflow:hidden}
.veh-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.12)}
.veh-card.dentro{border-color:#10B981;background:linear-gradient(135deg,#f0fdf4 0%,#dcfce7 100%)}
.veh-card.fuera{border-color:#F59E0B;background:linear-gradient(135deg,#fffbeb 0%,#fef3c7 100%)}
.veh-card-estado{position:absolute;top:12px;right:12px;width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.8)}
.veh-card.dentro .veh-card-estado{background:#10B981}
.veh-card.fuera .veh-card-estado{background:#F59E0B}
.veh-card-placa{font-size:20px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px;color:var(--text)}
.veh-card-info{display:flex;flex-direction:column;gap:3px;margin-top:8px;font-size:12px;color:var(--text2)}
.veh-card-info strong{color:var(--text)}
.veh-card-attrs{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}
.veh-card-attr{background:rgba(255,255,255,.7);padding:2px 8px;border-radius:8px;font-size:10px;font-weight:600;color:#555;border:1px solid rgba(0,0,0,.06)}
.veh-card-actions{margin-top:12px;display:flex;gap:6px;flex-wrap:wrap}
.veh-card-actions button{padding:5px 10px;font-size:11px;border-radius:8px}
.veh-card-phone{display:inline-flex;align-items:center;gap:4px;background:#DBEAFE;color:#1E40AF;padding:3px 10px;border-radius:10px;font-size:11px;font-weight:700;margin-top:6px;text-decoration:none;border:none;cursor:pointer}
.veh-card-phone:hover{background:#BFDBFE}
.veh-view-toggle{display:flex;gap:4px;margin-bottom:10px}
.veh-view-btn{padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:var(--surface);color:var(--text2);transition:all .15s}
.veh-view-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.veh-search-box{position:relative}
.veh-search-box input{padding-left:40px;font-size:15px;font-weight:600}
.veh-search-box .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:18px;color:#94A3B8}
@media(max-width:768px){.veh-tablero-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px}.veh-card{padding:12px}.veh-card-placa{font-size:17px}}
@media(max-width:480px){.veh-tablero-grid{grid-template-columns:1fr}.veh-card-placa{font-size:18px}}
/* ═══ PORTERÍA / SUPERVISOR CONTROL ═══ */
.port-search{background:var(--surface);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);margin-bottom:14px;border:2px solid transparent;transition:border-color .2s}
.port-search.found{border-color:#10B981}
.port-search.notfound{border-color:#F59E0B}
.port-search-input{width:100%;padding:14px 16px;font-size:20px;font-weight:700;border:2px solid var(--border);border-radius:12px;text-align:center;text-transform:uppercase;letter-spacing:2px;transition:all .2s}
.port-search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(27,79,216,.12)}
.port-result{margin-top:16px;padding:16px;border-radius:10px;display:none}
.port-result.show{display:block}
.port-result.residente{background:#D1FAE5;border:1px solid #6EE7B7}
.port-result.visitante{background:#FEF3C7;border:1px solid #FCD34D}
.port-result.denegado{background:#FEE2E2;border:1px solid #FCA5A5}
.port-result-info{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.port-result-icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}
.port-result-icon.ok{background:#059669;color:#fff}
.port-result-icon.warn{background:#D97706;color:#fff}
.port-result-icon.deny{background:#DC2626;color:#fff}
.port-result-details{flex:1;min-width:200px}
.port-result-details h4{margin:0 0 4px;font-size:15px}
.port-result-details p{margin:2px 0;font-size:13px;color:#555}
.port-result-actions{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.port-result-actions button{padding:12px 24px;font-size:14px;font-weight:700;border-radius:10px;display:flex;align-items:center;gap:6px}
.port-bitacora{background:var(--surface);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow)}
.port-bitacora h4{margin:0 0 12px;font-size:14px;color:var(--text);display:flex;align-items:center;gap:8px}
.port-bit-list{max-height:400px;overflow-y:auto}
.port-bit-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;margin-bottom:4px;font-size:13px;transition:background .15s}
.port-bit-item:hover{background:#f0f4ff}
.port-bit-item .bit-time{font-size:11px;color:#888;min-width:60px;white-space:nowrap}
.port-bit-item .bit-placa{font-weight:800;font-size:14px;min-width:90px}
.port-bit-item .bit-info{flex:1;color:#555}
.port-bit-item .bit-accion{font-weight:700;font-size:11px;padding:3px 10px;border-radius:10px}
.port-visit-form{background:#f8f9fa;padding:16px;border-radius:10px;margin-top:12px;border:1px solid var(--border)}
.port-visit-form h5{margin:0 0 10px;color:var(--text);font-size:13px}
.port-visit-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:8px 0}
@media(max-width:768px){.veh-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}.veh-kpi-grid{grid-template-columns:repeat(2,1fr)}.veh-filtros{flex-direction:column}.veh-filtros select,.veh-filtros input{min-width:100%;flex:none}.port-search-input{font-size:16px;letter-spacing:1px}.port-result-info{flex-direction:column;align-items:flex-start}.port-visit-form .form-row{grid-template-columns:1fr}}
@media(max-width:480px){.veh-grid{grid-template-columns:1fr}.veh-kpi-grid{grid-template-columns:repeat(2,1fr);gap:8px}.port-result-actions{flex-direction:column}.port-result-actions button{width:100%;justify-content:center}}
