:root{--primary:#2563eb;--primary-hover:#1d4ed8;--bg:#0f172a;--surface:#1e293b;--sidebar-bg:#1e293b;--card-bg:#1e293b;--header-bg:#0f172af2;--text:#f8fafc;--text-dim:#94a3b8;--border:#ffffff1a;--glass:#ffffff0d;--glass-border:#ffffff1a}*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,system-ui,-apple-system,sans-serif}html,body{width:100%;height:100%;margin:0;padding:0;overflow-x:hidden}body{background-color:var(--bg);color:var(--text);-webkit-overflow-scrolling:touch;overflow-y:auto}@media (width<=1024px){html,body{height:auto;min-height:100%;overflow-y:auto!important}}.dashboard-container{width:100vw;height:100vh;display:flex;overflow:hidden}@media (width<=1024px){.dashboard-container{flex-direction:column;height:auto;min-height:100vh;display:flex;overflow:visible}}.sidebar{background-color:var(--sidebar-bg);border-right:1px solid var(--border);z-index:100;flex-direction:column;width:260px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative}@media (width<=1024px){.sidebar{height:100vh;position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-100%);box-shadow:10px 0 30px #00000080}.sidebar.mobile-open{transform:translate(0)}}.sidebar.collapsed{width:80px}.sidebar-header{color:var(--primary);justify-content:space-between;align-items:center;gap:.75rem;padding:1.5rem;font-size:1.25rem;font-weight:700;display:flex}.collapse-toggle{background:var(--glass);border:1px solid var(--border);color:var(--text-dim);width:28px;height:28px;display:center;cursor:pointer;border-radius:6px;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex}.collapse-toggle:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.sidebar.collapsed .sidebar-header{justify-content:center;padding:1.5rem .5rem}.sidebar.collapsed .collapse-toggle{margin-top:1rem}.sidebar-menu{flex:1;padding:1rem;overflow-x:hidden}.menu-item{color:var(--text-dim);cursor:pointer;border-radius:.5rem;align-items:center;gap:1rem;min-width:0;margin-bottom:.5rem;padding:.75rem 1rem;text-decoration:none;transition:all .2s;display:flex}.sidebar.collapsed .menu-item{justify-content:center;padding:.75rem}.menu-item:hover{background-color:#ffffff14}.menu-item.ctacte{color:#38bdf8}.menu-item.boletos{color:#fbbf24}.menu-item.rubros{color:#34d399}.menu-item.persona{color:#a78bfa}.menu-item.apremio{color:#fb7185}.menu-item.auditoria{color:#2dd4bf}.menu-item.explorer{color:#818cf8}.menu-item.excel{color:#a3e635}.menu-item.users{color:#fb923c}.menu-item.profile{color:#f472b6}.menu-item.obras-sociales{color:#f43f5e}.menu-item.logout{color:#f87171}.menu-item.active{font-weight:700;box-shadow:0 4px 12px #0000004d;color:#fff!important}.menu-item.ctacte.active{background:linear-gradient(90deg,#0284c7 0%,#0284c733 100%);border-left:4px solid #38bdf8}.menu-item.boletos.active{background:linear-gradient(90deg,#d97706 0%,#d9770633 100%);border-left:4px solid #fbbf24}.menu-item.rubros.active{background:linear-gradient(90deg,#059669 0%,#05966933 100%);border-left:4px solid #34d399}.menu-item.persona.active{background:linear-gradient(90deg,#7c3aed 0%,#7c3aed33 100%);border-left:4px solid #a78bfa}.menu-item.apremio.active{background:linear-gradient(90deg,#e11d48 0%,#e11d4833 100%);border-left:4px solid #fb7185}.menu-item.auditoria.active{background:linear-gradient(90deg,#0d9488 0%,#0d948833 100%);border-left:4px solid #2dd4bf}.menu-item.explorer.active{background:linear-gradient(90deg,#4f46e5 0%,#4f46e533 100%);border-left:4px solid #818cf8}.menu-item.excel.active{background:linear-gradient(90deg,#65a30d 0%,#65a30d33 100%);border-left:4px solid #a3e635}.menu-item.users.active{background:linear-gradient(90deg,#ea580c 0%,#ea580c33 100%);border-left:4px solid #fb923c}.menu-item.profile.active{background:linear-gradient(90deg,#db2777 0%,#db277733 100%);border-left:4px solid #f472b6}.menu-item.obras-sociales.active{background:linear-gradient(90deg,#be123c 0%,#be123c33 100%);border-left:4px solid #f43f5e}.menu-item.logout.active{background:linear-gradient(90deg,#dc2626 0%,#dc262633 100%);border-left:4px solid #f87171}.menu-item:hover{filter:brightness(1.2)}.resizer{cursor:col-resize;z-index:5;background:0 0;width:6px;margin:0 -3px;transition:background .2s;position:relative}.resizer:hover,.resizer.resizing{background:var(--primary)}.resizer:after{content:"";background:#fff3;border-radius:1px;width:2px;height:40px;display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.resizer:hover:after{display:block}.main-content{flex-direction:column;flex:1;transition:all .3s;display:flex;overflow:hidden}@media (width<=1024px){.main-content{height:auto;min-height:100vh;overflow:visible}}.appointments-grid{grid-template-columns:1.2fr 1.8fr;align-items:start;gap:1.5rem;display:grid}@media (width<=1024px){.appointments-grid{grid-template-columns:1fr}}.menu-toggle{color:#fff;cursor:pointer;background:0 0;border:none;padding:.5rem;display:none}@media (width<=1024px){.menu-toggle{display:block}}.header{background-color:var(--header-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:50;flex-shrink:0;justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex}@media (width<=1024px){.header{z-index:200;width:100%;position:sticky;top:0;left:0;right:0}}@media (width<=768px){.header{flex-direction:column;gap:.5rem;height:auto;min-height:64px;padding:1rem}.connection-status{flex-wrap:wrap;justify-content:center;gap:.5rem;width:100%}}.header-title{font-size:1.1rem;font-weight:600}.connection-status{gap:1.5rem;display:flex}.status-indicator{background:var(--glass);border:1px solid var(--glass-border);border-radius:99px;align-items:center;gap:.5rem;padding:.25rem .75rem;font-size:.85rem;display:flex}.status-dot{border-radius:50%;width:8px;height:8px}.status-dot.connected{background-color:#10b981;box-shadow:0 0 8px #10b981}.status-dot.failed{background-color:#ef4444;box-shadow:0 0 8px #ef4444}.status-dot.pending{background-color:#f59e0b;box-shadow:0 0 8px #f59e0b}.body-content{-webkit-overflow-scrolling:touch;background:radial-gradient(circle at 100% 0,#2563eb0d,#0000);flex:1;padding:2rem;overflow-y:auto}@media (width<=768px){.body-content{padding:1rem;overflow-y:visible}}.body-content-wrapper{flex-direction:column;flex:1;display:flex;overflow:hidden}@media (width<=1024px){.body-content-wrapper{flex:none;overflow:visible}}.welcome-card{background:var(--card-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:1rem;max-width:800px;margin:0 auto;padding:2.5rem}h1{margin-bottom:1rem;font-size:2rem}p{color:var(--text-dim);line-height:1.6}.section-title{border-bottom:2px solid var(--primary);margin:2rem 0 1rem;padding-bottom:.25rem;font-size:1.5rem;display:inline-block}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0000001a}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.2s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.modal-content{border:1px solid var(--border);border-radius:12px;width:500px;max-width:90%;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;overflow:hidden;box-shadow:0 20px 25px -5px #0000004d;background:#1e293b!important}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h2{color:var(--primary);margin:0;font-size:1.25rem}.close-btn{color:var(--text-dim);cursor:pointer;background:0 0;border:none;font-size:1.5rem;line-height:1}.modal-body{padding:1.5rem}.info-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.info-item label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;font-size:.75rem;display:block}.info-item span{color:var(--text);font-size:1rem;font-weight:500}.owner-header{background:var(--glass);border:1px solid var(--border);border-radius:12px;padding:.75rem 1.25rem;transition:all .2s}.owner-header:hover{border-color:var(--primary);background:#2563eb1a;transform:translateY(-2px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.data-card{background:var(--card-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:1rem;transition:all .2s;overflow:hidden}.data-card:hover{border-color:var(--glass-border);box-shadow:0 10px 25px -5px #0003}.input-field{background:var(--glass);border:1px solid var(--glass-border);width:100%;color:var(--text);border-radius:.5rem;outline:none;padding:.6rem 1rem;font-size:.9rem;transition:all .2s}.input-field:focus{border-color:var(--primary);background:#ffffff0d;box-shadow:0 0 0 2px #2563eb33}select.input-field option{color:#fff;background-color:#1e293b}.btn{cursor:pointer;border:1px solid #0000;border-radius:.5rem;outline:none;justify-content:center;align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-size:.9rem;font-weight:500;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--glass);color:var(--text);border-color:var(--glass-border)}.btn-secondary:hover:not(:disabled){border-color:var(--text-dim);background:#ffffff1a}.results-container{margin-top:1rem}.login-page{background:radial-gradient(circle at 0 0,#1e293b,#0f172a);justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:var(--primary);filter:blur(150px);opacity:.1;border-radius:50%;width:500px;height:500px;position:absolute;top:-250px;left:-250px}.login-page:after{content:"";filter:blur(150px);opacity:.1;background:#7c3aed;border-radius:50%;width:400px;height:400px;position:absolute;bottom:-200px;right:-200px}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);z-index:10;background:#1e293bb3;border-radius:1.5rem;width:100%;max-width:420px;padding:3rem;animation:.6s cubic-bezier(.16,1,.3,1) slideUp;box-shadow:0 25px 50px -12px #00000080}.login-header{text-align:center;margin-bottom:2.5rem}.logo-placeholder{background:#fff;border-radius:12px;justify-content:center;align-items:center;margin:0 auto 1.5rem;padding:8px 16px;display:inline-flex;box-shadow:0 4px 12px #0000001a}.login-header h1{background:linear-gradient(90deg,#fff,#94a3b8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-size:2.25rem;font-weight:800}.login-header h2{color:var(--text-dim);letter-spacing:.1em;text-transform:uppercase;margin-top:.5rem;font-size:1rem;font-weight:500}.login-form .form-group{margin-bottom:1.5rem}.login-form label{color:#e2e8f0;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.login-form input{border:1px solid var(--border);color:#fff;background:#0f172a80;border-radius:.75rem;outline:none;width:100%;padding:.875rem 1.25rem;font-size:1rem;transition:all .2s}.login-form input:focus{border-color:var(--primary);background:#0f172acc;box-shadow:0 0 0 4px #2563eb26}.login-error{color:#fca5a5;text-align:center;background:#ef44441a;border:1px solid #ef444433;border-radius:.5rem;margin-bottom:1.5rem;padding:.75rem;font-size:.875rem}.login-button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:.75rem;width:100%;padding:1rem;font-size:1rem;font-weight:600;transition:all .2s;box-shadow:0 4px 6px -1px #2563eb33}.login-button:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;color:var(--text-dim);margin-top:2rem;font-size:.75rem}.user-management-container{padding:2rem}.user-form-card{background:var(--card-bg);border:1px solid var(--border);border-radius:1rem;max-width:600px;margin-bottom:2rem;padding:1.5rem}.users-list-card{background:var(--card-bg);border:1px solid var(--border);border-radius:1rem;padding:1.5rem}.user-table{border-collapse:collapse;width:100%;margin-top:1rem}.user-table th,.user-table td{text-align:left;border-bottom:1px solid var(--border);padding:1rem}.user-table th{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.role-badge{text-transform:uppercase;border-radius:99px;padding:.25rem .6rem;font-size:.75rem;font-weight:600}.role-badge.superadmin{color:#c084fc;background:#8b5cf61a;border:1px solid #8b5cf64d}.role-badge.admin{color:#60a5fa;background:#2563eb1a;border:1px solid #3b82f64d}.role-badge.profesional{color:#34d399;background:#10b9811a;border:1px solid #10b9814d}.role-badge.recepcion{color:#fbbf24;background:#f59e0b1a;border:1px solid #f59e0b4d}.role-badge.usuario{color:#d1d5db;background:#9ca3af1a;border:1px solid #9ca3af4d}.role-badge.municipalidad{color:#2dd4bf;background:#14b8a61a;border:1px solid #14b8a64d}.delete-btn{color:#f87171;cursor:pointer;background:#ef44441a;border:1px solid #ef44444d;border-radius:.4rem;padding:.4rem .75rem;font-size:.8rem}.delete-btn:hover{color:#fff;background:#ef4444}.calendar-day{border:1px solid var(--border);color:var(--text-dim);aspect-ratio:1.1;cursor:pointer;background:#ffffff05;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;min-height:48px;padding:.2rem;font-family:inherit;transition:all .2s;display:flex;position:relative}.calendar-day:hover{border-color:var(--primary);background:#ffffff0f;transform:translateY(-1px)}.calendar-day.empty{cursor:default;pointer-events:none;opacity:0;background:0 0;border-color:#0000}.calendar-day.active-day{box-shadow:0 0 12px #eab30866;background:var(--primary)!important;border-color:var(--primary)!important;color:#000!important;font-weight:700!important}.calendar-day.today-day{color:#fff;border:2px solid #3b82f6;font-weight:700}.calendar-day.works-day{border-bottom:2px solid #eab308}.calendar-day.works-day .day-number{color:#fff;font-weight:600}.calendar-day.off-day{opacity:.4}.shift-dot{background-color:#eab308;border-radius:50%;width:5px;height:5px;position:absolute;bottom:5px}.calendar-day.active-day .shift-dot{background-color:#000}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{animation:1.5s linear infinite spin}.suggestion-item{transition:background-color .15s}.suggestion-item:hover{background-color:#ffffff0f!important}
