:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root{margin:0;padding:0;width:100%;height:100%;font-family:Segoe UI,sans-serif;background:linear-gradient(135deg,#1a237e,#3949ab);color:#212121}.auth-wrapper{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:40px 20px;box-sizing:border-box}.auth-card{display:flex;flex-direction:row;width:100%;max-width:900px;background:#f5f5f5;border-radius:16px;overflow:hidden;box-shadow:0 12px 28px #0003;margin:auto;transition:height .4s ease}.auth-left{flex:1;padding:40px 30px;display:flex;flex-direction:column;justify-content:center;background-color:#fff}.tabs{display:flex;justify-content:center;margin-bottom:20px}.tabs button{padding:10px 25px;margin:0 5px;border:none;border-radius:25px;background:#e0e0e0;cursor:pointer;font-weight:600;color:#1a237e;transition:all .3s ease}.tabs .active{background:linear-gradient(to right,#1a237e,#3949ab);color:#fff}.form-outer{overflow:hidden;transition:height .4s ease}.form-content{animation:fadeUp .4s ease;padding-bottom:30px}@keyframes fadeUp{0%{opacity:0;transform:translateY(40px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.input-box{display:flex;align-items:center;background:#f5f5f5;padding:12px 15px;border-radius:10px;margin-bottom:15px;border:1px solid #9e9e9e}.input-box input{border:none;background:transparent;margin-left:10px;flex:1;font-size:15px;color:#1a237e;outline:none}button[type=submit]{background:linear-gradient(to right,#1a237e,#3949ab);border:none;color:#fff;width:100%;padding:14px;font-size:16px;border-radius:10px;cursor:pointer;font-weight:700;margin-top:15px;margin-bottom:10px;transition:transform .2s ease}button:hover{transform:scale(1.03)}.error{color:red;font-size:14px;text-align:center;margin-top:10px}.auth-right{flex:1;background:linear-gradient(to top right,#3949ab,#1a237e);color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px 30px;text-align:center}.auth-right .logo{font-size:50px;font-weight:700;letter-spacing:2px;text-shadow:2px 2px 6px rgba(0,0,0,.3);margin-bottom:10px}.auth-right p{font-size:16px;max-width:300px;line-height:1.4;color:#fff}@media (max-width: 768px){.auth-card{flex-direction:column}.auth-right{display:none}.auth-left{padding:30px 20px}.tabs button{padding:8px 15px;font-size:14px}}.buscar-container{width:100%;padding:20px 40px;margin:0;color:#111827;font-family:Segoe UI,sans-serif;display:flex;flex-direction:column;align-items:center}.buscar-formulario{background-color:#fff;border-radius:16px;padding:30px;box-shadow:0 8px 24px #00000014;width:100%;max-width:1200px;display:flex;flex-wrap:wrap;gap:20px;align-items:flex-end;justify-content:flex-start;margin-bottom:20px}.buscar-formulario label{display:flex;flex-direction:column;font-weight:600;font-size:14px;color:#374151}.buscar-formulario input{padding:10px 14px;border-radius:8px;border:1px solid #d1d5db;background-color:#e5e7eb;color:#111827;width:180px;font-size:14px;transition:all .2s ease}.buscar-formulario input:focus{border-color:#2563eb;background-color:#fff;color:#111827;outline:none;box-shadow:0 0 0 2px #2563eb33}.buscar-formulario input::placeholder{color:#6b7280}input[type=date]{background-color:#e5e7eb;color:#111827}.buscar-btn{height:40px;padding:0 24px;background-color:#2563eb;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .3s ease}.alerta{margin:20px auto;padding:12px 20px;border-radius:8px;font-weight:700;text-align:center;max-width:800px;-webkit-user-select:text;user-select:text;white-space:pre-wrap}.alerta.info{background-color:#e0f2fe;color:#0369a1;border:1px solid #bae6fd}.alerta.success{background-color:#dcfce7;color:#15803d;border:1px solid #bbf7d0}.alerta.error{background-color:#fee2e2;color:#b91c1c;border:1px solid #fecaca}.colonias-buscadas{margin-top:10px;font-size:14px;color:#555}.tabla-resultados{margin-top:30px;overflow-x:auto;border-radius:12px;background:#fff;box-shadow:0 4px 12px #0000000d}.tabla-resultados table{width:100%;border-collapse:collapse;font-size:15px;min-width:800px}.tabla-resultados th,.tabla-resultados td{padding:14px 16px;text-align:left;border-bottom:1px solid #e5e7eb;vertical-align:middle}.tabla-resultados th{background-color:#f3f4f6;color:#1f2937;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.tabla-resultados tr:hover td{background-color:#f9fafb}.btn-verfoto,.btn-detalles{padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:background-color .2s ease}.btn-verfoto{background-color:#10b981;color:#fff}.btn-verfoto:hover{background-color:#059669}.btn-detalles{background-color:#3b82f6;color:#fff}.btn-detalles:hover{background-color:#2563eb}.fila-detalles td{background-color:#f3f4f6;padding:12px 16px;font-size:14px;color:#1f2937;border-top:1px solid #e5e7eb}.grid-detalles-agrupado{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:10px;background:#f9fafb;padding:16px;border-radius:12px}.grupo{border:1px solid #e5e7eb;border-radius:8px;padding:12px;background:#fff;font-size:14px}.grupo h4{margin-bottom:8px;font-size:15px;color:#1f2937;border-bottom:1px solid #e5e7eb;padding-bottom:4px}.grupo p{margin:4px 0}@media (max-width: 768px){.buscar-container{padding:20px}.buscar-formulario{flex-direction:column;padding:20px}.buscar-formulario input,.buscar-btn{width:100%}.tabla-resultados table{font-size:13px;min-width:100%}}.detalles{padding:10px 0;font-size:14px;color:#1f2937}.detalles p{margin:4px 0}.img-mini{max-width:100%;max-height:200px;border-radius:8px;border:1px solid #ccc;margin-top:6px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;justify-content:center;align-items:center;z-index:9999}.modal-content{background:#fff;padding:20px;border-radius:12px;max-width:90%;max-height:90%;box-shadow:0 0 10px #0000004d}.modal-content img{max-width:100%;max-height:70vh;border-radius:8px}.modal-buttons{display:flex;justify-content:center;gap:16px;margin-top:15px}.modal-buttons a,.modal-buttons button{background-color:#2563eb;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:700;text-decoration:none}.modal-buttons a:hover,.modal-buttons button:hover{background-color:#1e40af}.foto-expandida-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0f0f0fe6;display:flex;align-items:center;justify-content:center;z-index:9999}.foto-expandida-contenedor{position:relative;background:#fff;padding:10px;border-radius:12px;max-width:90%;max-height:90%;box-shadow:0 0 20px #000}.foto-expandida-contenedor img{max-width:100%;max-height:70vh;display:block;margin:0 auto;border-radius:8px}.foto-expandida-botones{display:flex;justify-content:space-between;margin-top:10px}.foto-expandida-botones button{padding:8px 14px;font-size:14px;border:none;background:#111827;color:#fff;border-radius:6px;cursor:pointer}.foto-expandida-botones button:hover{background:#2563eb}.base64-container{margin-top:10px;max-height:200px;overflow:auto;background:#f9fafb;padding:10px;border:1px solid #d1d5db;border-radius:8px;font-size:12px;word-break:break-all}.base64-texto{-webkit-user-select:text;user-select:text;white-space:pre-wrap;margin-bottom:8px}.df-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:9999}.df-card{background:#fff;border-radius:12px;max-width:900px;width:90%;padding:24px;position:relative;max-height:90vh;overflow-y:auto;font-family:Segoe UI,sans-serif}.df-cerrar{position:absolute;top:10px;right:14px;background:none;border:none;font-size:28px;cursor:pointer;color:#555}.df-fotos{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:20px}.df-foto-box{position:relative;border-radius:8px;overflow:hidden;border:1px solid #ddd;width:120px;height:120px;flex-shrink:0}.df-foto-box img{width:100%;height:100%;object-fit:cover}.df-foto-actions{position:absolute;bottom:4px;right:4px;display:flex;gap:4px}.df-foto-actions button{background:#ffffffe6;border:none;padding:2px 6px;font-size:14px;cursor:pointer;border-radius:4px}.df-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;font-size:14px;color:#333}.buscar-container{display:flex;flex-direction:column;align-items:center;padding:20px;max-width:100%}.buscar-formulario{display:flex;flex-wrap:wrap;justify-content:center;background:#fff;border-radius:12px;padding:15px;gap:10px;box-shadow:0 0 8px #0000000d;margin-bottom:10px;width:100%;max-width:950px}.buscar-formulario label{display:flex;flex-direction:column;font-weight:700;font-size:13px}.buscar-formulario input{padding:8px;border:1px solid #ccc;border-radius:8px;width:180px}.buscar-btn{background-color:#2563eb;color:#fff;border:none;border-radius:8px;padding:10px 16px;cursor:pointer;align-self:flex-end}.buscar-btn:hover{background-color:#1e40af}.tabla-resultados{width:100%;max-width:1200px;height:420px;overflow-y:auto;border-radius:8px;box-shadow:0 0 6px #0000000d;background:#fff}.tabla-resultados table{width:100%;border-collapse:collapse;font-size:13px}.tabla-resultados thead{background-color:#f9fafb;position:sticky;top:0;z-index:1}.tabla-resultados th,.tabla-resultados td{padding:10px;text-align:center;border-bottom:1px solid #e5e7eb}.tabla-resultados tbody tr:hover{background-color:#f1f5f9}.alerta{margin:10px auto;padding:10px 18px;border-radius:6px;font-weight:500;text-align:center;max-width:800px}.alerta.info{background-color:#e0f2fe;color:#0369a1}.alerta.success{background-color:#dcfce7;color:#15803d}.alerta.error{background-color:#fee2e2;color:#b91c1c}.btn-verfoto,.btn-detalles{background-color:#2563eb;color:#fff;border:none;border-radius:6px;padding:5px 10px;font-size:12px;cursor:pointer}.btn-verfoto:hover,.btn-detalles:hover{background-color:#1e40af}@media screen and (max-width: 768px){.buscar-formulario input{width:100%}.tabla-resultados{height:350px}.buscar-formulario{flex-direction:column;align-items:center}}.residencias-container{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000001a;font-size:.85rem}.residencias-table{width:100%;border-collapse:collapse}.residencias-table th,.residencias-table td{padding:6px 8px;border-bottom:1px solid #ccc;text-align:left;vertical-align:middle}.residencias-table th{background-color:#f4f4f4;font-weight:700;position:sticky;top:0;z-index:1}.residencias-table input{background-color:#fff;color:#000;border:1px solid #ccc;border-radius:4px;padding:4px 6px;font-size:.85rem;width:100%;box-sizing:border-box;height:28px}.residencias-table input:disabled{background-color:#eee;color:#666;cursor:not-allowed}.residencias-table button{padding:4px 8px;border:none;border-radius:4px;background-color:#1976d2;color:#fff;font-weight:700;font-size:.75rem;cursor:pointer;height:28px;min-width:80px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:2px}.residencias-table button:hover{background-color:#1565c0}.residencias-table .cerrar-btn{background-color:#c62828}.residencias-table .cerrar-btn:hover{background-color:#b71c1c}.residencias-table td>button+button{margin-left:6px}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999}.modal-contenido{background:#fff;padding:20px;border-radius:10px;width:98vw;min-width:1000px;max-width:1200px;max-height:95vh;overflow:hidden;box-shadow:0 0 15px #0000004d;display:flex;flex-direction:column}.tabla-scroll{overflow-y:auto;flex-grow:1;margin-top:10px;border:1px solid #ccc;border-radius:6px}.tabla-scroll table{width:100%;border-collapse:collapse;min-width:800px;font-size:.85rem}.tabla-scroll th,.tabla-scroll td{padding:4px 6px;border-bottom:1px solid #ddd;text-align:left;vertical-align:middle}.tabla-scroll th{background-color:#f5f5f5;position:sticky;top:0;z-index:1}.tabla-scroll tr:hover{background-color:#f0f8ff}.tabla-scroll input,.tabla-scroll select{width:100%;padding:4px 6px;box-sizing:border-box;border:1px solid #ccc;border-radius:4px;background-color:#fff;color:#000;font-size:.85rem}.tabla-scroll td:first-child,.tabla-scroll th:first-child{width:40px;text-align:center}.tabla-scroll td:last-child,.tabla-scroll th:last-child{width:80px;text-align:center}.tabla-scroll td:nth-child(2) input{max-width:280px}.tabla-scroll td:nth-child(3) input{max-width:180px}.tabla-scroll td:nth-child(4) input{max-width:150px}.tabla-scroll td:last-child button{margin:0 2px;padding:4px 6px;font-size:.8rem}.acciones-modal{margin-top:12px;display:flex;justify-content:space-between;gap:10px}.acciones-modal button,.tabla-scroll button{padding:4px 10px;border:none;border-radius:4px;background-color:#1976d2;color:#fff;cursor:pointer;font-weight:700;font-size:.85rem;transition:background-color .3s}.acciones-modal button:hover,.tabla-scroll button:hover{background-color:#1565c0}.cerrar-btn{background-color:#c62828}.cerrar-btn:hover{background-color:#b71c1c}.error{color:red;margin-top:8px}.modal-fondo{position:fixed;top:0;left:0;width:100%;height:100%;background:#0006;display:flex;align-items:center;justify-content:center;z-index:999}.modal-contenido{background:#fff;padding:20px;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 0 12px #0003}.modal-contenido ul{list-style:none;padding:0}.modal-contenido li{display:flex;justify-content:space-between;align-items:center;margin:8px 0}.modal-contenido .error{color:red}.tags-container{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000001a;font-size:.85rem;max-width:1000px;margin:auto}.input-row{display:flex;gap:10px;margin-bottom:1rem;align-items:center}.tags-input{flex:1;background-color:#fff;color:#000;border:1px solid #ccc;border-radius:6px;padding:8px 12px;font-size:.85rem;height:40px;box-sizing:border-box}.tags-buscar-btn{background-color:#1976d2;color:#fff;border:none;border-radius:6px;padding:0 16px;font-size:.85rem;font-weight:700;cursor:pointer;height:40px;white-space:nowrap;display:flex;align-items:center;justify-content:center}.tags-buscar-btn:hover{background-color:#1565c0}.tags-table{width:100%;border-collapse:collapse}.tags-table th,.tags-table td{padding:6px 8px;border-bottom:1px solid #ccc;text-align:left;vertical-align:middle}.tags-table th{background-color:#f4f4f4;font-weight:700;position:sticky;top:0;z-index:1}.tags-table button{padding:4px 8px;border:none;border-radius:4px;background-color:#1976d2;color:#fff;font-weight:700;font-size:.75rem;cursor:pointer;height:28px;min-width:80px;display:inline-flex;align-items:center;justify-content:center}.tags-table button:hover{background-color:#1565c0}.error{color:red;margin-top:8px;font-size:.85rem}.tags-container{align-self:flex-start;margin-top:40px}.dashboard-container{display:flex;min-height:100vh;font-family:Segoe UI,sans-serif}.sidebar{width:240px;background-color:#1f2937;color:#fff;padding:20px;display:flex;flex-direction:column;transition:width .3s ease,padding .3s ease,transform .3s ease}.sidebar.collapsed{width:60px;padding:20px 10px;align-items:center}.logo{font-size:24px;font-weight:700;margin-bottom:40px;text-align:center}.sidebar-btn{background:none;border:none;color:#fff;font-size:16px;padding:12px;margin:5px 0;display:flex;align-items:center;gap:10px;cursor:pointer;transition:background .3s ease;border-radius:8px;width:100%;justify-content:flex-start}.sidebar-btn span{transition:opacity .3s ease}.sidebar.collapsed .sidebar-btn{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-btn span{display:none}.sidebar-btn:hover{background-color:#374151}.logout{margin-top:auto;color:#f87171}.dashboard-main{flex:1;padding:60px 40px;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#111827;overflow-y:auto;display:flex;justify-content:center;align-items:flex-start;transition:padding-left .3s ease}.dashboard-main.expanded{padding-left:80px}.collapse-btn{background:none;border:none;color:#fff;font-size:20px;align-self:flex-end;margin-bottom:20px;cursor:pointer}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:1000;transform:translate(0)}.sidebar.collapsed{transform:translate(-100%)}.collapse-btn{position:absolute;top:10px;right:-35px;background-color:#1f2937;border-radius:50%;width:30px;height:30px;font-size:16px;text-align:center;line-height:30px;border:1px solid white}.dashboard-main.expanded{margin-left:0;padding-left:20px}.dashboard-main{padding:30px 20px}}.inicio-centro{flex:1;display:flex;justify-content:center;align-items:center;padding:20px}.logo-central{max-width:200px;height:auto;filter:drop-shadow(0 2px 6px rgba(0,0,0,.2))}
