body{color:#0f172a;background:#f4f7fb;font-family:Inter,sans-serif}.login-page{background:radial-gradient(circle at 0 0,#2563eb1a,#0000 40%),radial-gradient(circle at 100% 100%,#16a34a1a,#0000 40%),#f8fafc;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:28px;display:flex;position:relative;overflow:hidden}.bg-grid{background-image:linear-gradient(#0f172a0a 1px,#0000 1px),linear-gradient(90deg,#0f172a0a 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle,#000,#0000 75%);mask-image:radial-gradient(circle,#000,#0000 75%)}.bg-orb{filter:blur(80px);z-index:0;border-radius:999px;animation:12s ease-in-out infinite orbFloat;position:absolute}.orb-1{background:radial-gradient(circle,#2563eb38,#0000 70%);width:420px;height:420px;top:-140px;left:-140px}.orb-2{background:radial-gradient(circle,#16a34a33,#0000 70%);width:420px;height:420px;bottom:-140px;right:-140px}@keyframes orbFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-22px)}}.login-wrapper{z-index:2;background:#fff;border:1px solid #0f172a14;border-radius:32px;grid-template-columns:1.2fr 460px;width:100%;max-width:1400px;min-height:760px;display:grid;position:relative;overflow:hidden;box-shadow:0 30px 80px #0f172a1f}.login-showcase{background:linear-gradient(135deg,#2563eb,#1e40af);align-items:center;padding:70px;display:flex}.logo-box{background:#fff;border:2px solid #ffffff59;border-radius:22px;width:92px;height:92px;padding:6px;overflow:hidden;box-shadow:0 10px 30px #00000026,0 0 0 6px #ffffff1a}.logo-box img{object-fit:cover;width:100%;height:100%}.showcase-logo h2{color:#fff;letter-spacing:-1px;font-size:44px;font-weight:900}.hero-content h1{color:#fff;font-size:64px;font-weight:900;line-height:1.05}.hero-content h1 span{color:#dbeafe;display:block}.hero-content p{color:#ffffffd9;margin-top:18px;font-size:18px;line-height:1.7}.login-side{background:#fff;justify-content:center;align-items:center;padding:60px;display:flex}.login-top h2{color:#0f172a;font-size:52px;font-weight:900}.login-top p{color:#475569;font-size:16px}.mobile-logo{background:#fff;border:2px solid #2563eb40;border-radius:22px;width:92px;height:92px;display:none;overflow:hidden;box-shadow:0 10px 25px #0000001a,0 0 0 6px #2563eb14}@media (width<=1100px){.mobile-logo{justify-content:center;align-items:center;display:flex}.mobile-logo img{object-fit:contain;width:100%;height:100%}}.login-loader-box h3{color:#0f172a;margin-top:12px;font-size:22px;font-weight:900}.login-loader-box p{color:#475569;margin-top:6px;font-size:14px}.login-form{flex-direction:column;gap:22px;margin-top:28px;display:flex}.input-group label{color:#0f172a;font-size:14px;font-weight:700}.input-wrapper{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;align-items:center;gap:12px;height:62px;padding:0 18px;transition:all .25s;display:flex}.input-wrapper:focus-within{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb26}.input-wrapper svg{color:#2563eb}.input-wrapper input{color:#0f172a;background:0 0;border:none;outline:none;width:100%;font-size:15px}.login-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:16px;justify-content:center;align-items:center;gap:10px;height:60px;font-size:16px;font-weight:800;transition:all .25s;display:flex;box-shadow:0 15px 30px #2563eb33}.login-button:hover{transform:translateY(-2px);box-shadow:0 20px 40px #2563eb4d}.login-button:active{transform:scale(.98)}.login-error{color:#b91c1c;background:#ef444414;border:1px solid #ef444440;border-radius:14px;padding:12px 16px;font-weight:600}.login-loader-overlay{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:99999;background:#0f172a73;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-loader-box{text-align:center;background:#fff;border-radius:22px;width:100%;max-width:420px;padding:40px;animation:.3s pop}@keyframes pop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.loader-logo{background:#fff;border:2px solid #2563eb40;border-radius:24px;justify-content:center;align-items:center;width:110px;height:110px;margin:auto;display:flex;overflow:hidden;box-shadow:0 10px 30px #2563eb26,0 0 0 8px #2563eb0f}.loader-logo img{object-fit:cover;width:100%;height:100%}.loader-bar{background:#e2e8f0;border-radius:999px;height:10px;margin-top:18px;overflow:hidden}.loader-progress{background:linear-gradient(90deg,#2563eb,#22c55e);width:40%;height:100%;animation:1.2s infinite loading}@keyframes loading{0%{transform:translate(-120%)}to{transform:translate(320%)}}@media (width<=1100px){.login-wrapper{grid-template-columns:1fr}.login-showcase{display:none}.mobile-logo{display:block}}@media (width<=520px){.login-page{padding:16px}.login-side{padding:24px}.login-top h2{font-size:38px}.input-wrapper,.login-button{height:56px}}.login-loader-mini{color:#fff;z-index:9999;background:#111827;border-radius:10px;align-items:center;gap:8px;padding:10px 14px;display:flex;position:fixed;bottom:20px;right:20px}:root{--sidebar-width:270px;--sidebar-collapsed:88px;--transition:all .25s ease;--bg-main:#0f172a;--bg-secondary:#111827;--card-bg:#1e293b;--text-main:#fff;--text-secondary:#94a3b8;--border:#ffffff14;--primary:#2563eb;--primary-hover:#1d4ed8;--hover:#ffffff0f;--shadow:0 10px 40px #00000059}[data-theme=light]{--bg-main:#fff;--bg-secondary:#f8fafc;--card-bg:#fff;--text-main:#0f172a;--text-secondary:#64748b;--border:#0f172a14;--hover:#0f172a0d;--shadow:0 10px 30px #00000014}.sidebar{width:var(--sidebar-width);background:var(--bg-main);border-right:1px solid var(--border);z-index:999;height:100vh;transition:var(--transition);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:22px 18px;display:flex}.header-actions{justify-content:center;align-items:center;display:flex}.sidebar.collapsed .sidebar-header{flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:18px 8px;display:flex}.sidebar.collapsed .brand,.sidebar.collapsed .header-actions{justify-content:center;align-items:center;width:100%;display:flex}.sidebar.collapsed .logo-wrapper{width:44px;min-width:44px;height:44px}.sidebar.collapsed .collapse-btn{margin:0}.brand{align-items:center;gap:14px;display:flex;overflow:hidden}.logo-wrapper{width:46px;min-width:46px;height:46px;box-shadow:var(--shadow);background:#fff;border-radius:14px;overflow:hidden}.logo-img{object-fit:cover;width:100%;height:100%}.brand-info h2{color:var(--text-main);letter-spacing:.5px;font-size:16px;font-weight:800}.brand-info p{color:var(--text-secondary);margin-top:2px;font-size:12px}.collapse-btn{width:40px;height:40px;color:var(--text-main);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:12px}.collapse-btn:hover{background:var(--hover)}.sidebar-menu{flex-direction:column;flex:1;gap:8px;padding:18px 12px;display:flex}.nav-link{color:var(--text-secondary);min-height:54px;transition:var(--transition);border-radius:16px;align-items:center;gap:14px;padding:0 16px;font-size:14px;font-weight:600;text-decoration:none;display:flex;position:relative}.nav-link:hover{background:var(--hover);color:var(--text-main)}.nav-link.active{background:linear-gradient(135deg, var(--primary), var(--primary-hover));color:#fff;box-shadow:0 10px 24px #2563eb59}.nav-link svg{flex-shrink:0}.sidebar.collapsed .nav-link{justify-content:center;padding:0}.sidebar.collapsed{width:88px}.sidebar.collapsed .sidebar-menu{padding-left:10px;padding-right:10px}.user-card{background:var(--hover);border:1px solid var(--border);border-radius:18px;align-items:center;gap:12px;margin:18px 18px 0;padding:14px;display:flex;overflow:hidden}.user-avatar{color:#fff;text-transform:uppercase;background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:14px;justify-content:center;align-items:center;width:44px;min-width:44px;height:44px;font-size:18px;font-weight:800;display:flex}.user-info{overflow:hidden}.user-info h4{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.user-info p{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.user-info span{color:#60a5fa;background:#2563eb22;border-radius:999px;margin-top:8px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.sidebar-footer{border-top:1px solid var(--border);padding:18px}.theme-toggle{background:var(--hover);width:100%;height:52px;color:var(--text-main);cursor:pointer;transition:var(--transition);border:none;border-radius:16px;justify-content:center;align-items:center;gap:10px;font-weight:600;display:flex}.logout-btn{color:#f87171;cursor:pointer;background:#ef44441f;border:none;border-radius:16px;justify-content:center;align-items:center;gap:10px;width:100%;height:52px;margin-top:12px;font-weight:700;transition:all .25s;display:flex}.logout-btn:hover{background:#ef44442e;transform:translateY(-1px)}.theme-toggle:hover{transform:translateY(-1px)}.mobile-topbar{background:var(--bg-main);border-bottom:1px solid var(--border);z-index:1200;justify-content:space-between;align-items:center;height:72px;padding:0 16px;display:none;position:fixed;top:0;left:0;right:0}.mobile-brand{align-items:center;gap:10px;display:flex}.mobile-brand img{border-radius:10px;width:38px;height:38px}.mobile-brand span{color:var(--text-main);font-weight:700}.mobile-menu-btn,.mobile-theme{background:var(--hover);width:42px;height:42px;color:var(--text-main);cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;display:flex}.sidebar-overlay{z-index:998;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#00000073;position:fixed;inset:0}@media (width<=1024px){.mobile-topbar{display:flex}.sidebar{width:280px;transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.collapse-btn{display:none}}@media (width<=480px){.sidebar{width:100%;max-width:320px}.nav-link{min-height:50px}}.logout-modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:5000;background:#0000008c;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.logout-modal{background:var(--bg-main);border:1px solid var(--border);text-align:center;border-radius:28px;width:100%;max-width:420px;padding:32px 28px;animation:.25s modalPop;box-shadow:0 20px 60px #00000059}.logout-icon{color:#ef4444;background:#ef44441f;border-radius:24px;justify-content:center;align-items:center;width:82px;height:82px;margin:0 auto 20px;display:flex}.logout-modal h3{color:var(--text-main);font-size:26px;font-weight:800}.logout-modal p{color:var(--text-secondary);margin-top:10px;font-size:15px;line-height:1.5}.logout-actions{gap:14px;margin-top:30px;display:flex}.cancel-btn,.confirm-logout-btn{cursor:pointer;border:none;border-radius:18px;flex:1;height:54px;font-weight:700;transition:all .25s}.cancel-btn{background:var(--hover);color:var(--text-main)}.cancel-btn:hover{transform:translateY(-2px)}.confirm-logout-btn{color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 12px 24px #ef444440}.confirm-logout-btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px #ef444459}.sidebar.collapsed .user-card{justify-content:center;margin-left:10px;margin-right:10px;padding:12px}.sidebar.collapsed .user-info{display:none}.sidebar.collapsed .user-avatar{margin:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalPop{0%{opacity:0;transform:scale(.92)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}@media (width<=480px){.logout-modal{border-radius:24px;padding:26px 20px}.logout-actions{flex-direction:column}.cancel-btn,.confirm-logout-btn{width:100%}.logout-modal h3{font-size:22px}}html,body,#root{background:var(--bg-secondary);width:100%;min-height:100%;color:var(--text-main);font-family:Inter,system-ui,sans-serif;overflow-x:hidden}body{transition:background .25s}:root{--sidebar-width:270px;--sidebar-collapsed:88px}.layout{background:var(--bg-secondary);min-height:100vh}.layout-content{min-height:100vh;margin-left:var(--sidebar-width);padding:28px;transition:margin-left .25s,padding .25s}.layout-content.expanded{margin-left:var(--sidebar-collapsed)}@media (width<=1400px){.layout-content{padding:24px}}@media (width<=1024px){.layout-content{padding:92px 18px 18px;margin-left:0!important}}@media (width<=640px){.layout-content{padding:88px 14px 14px}}.bed-sidebar-overlay{z-index:9998;background:#00000073;position:fixed;inset:0}.bed-sidebar{z-index:9999;background:#fff;flex-direction:column;width:420px;height:100vh;display:flex;position:fixed;top:0;right:0;box-shadow:-15px 0 40px #00000026}.bed-sidebar-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:24px;display:flex}.bed-sidebar-header h2{margin:0}.bed-sidebar-header p{color:#64748b;margin-top:5px}.bed-close-btn{cursor:pointer;background:0 0;border:none}.bed-sidebar-body{flex-direction:column;gap:16px;padding:24px;display:flex}.bed-detail-card{background:#f8fafc;border-radius:16px;align-items:center;gap:15px;padding:18px;display:flex}.bed-detail-card span{color:#64748b;font-size:13px;display:block}.bed-detail-card strong{margin-top:4px;display:block}@media (width<=768px){.bed-sidebar{width:100%}}:root{--bg:#f6f8fc;--card:#fff;--text:#0f172a;--muted:#64748b;--border:#e5e7eb;--green:#22c55e;--red:#ef4444;--blue:#3b82f6;--yellow:#eab308;--purple:#a855f7}.hospital-dashboard{background:var(--bg);min-height:100vh;padding:22px;font-family:system-ui}.dashboard-top{background:var(--card);border-radius:16px;margin-bottom:18px;padding:20px;box-shadow:0 10px 25px #0000000d}.dashboard-top h1{margin:0;font-size:22px}.dashboard-top p{color:var(--muted);margin:4px 0 0}.kpis-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px;display:grid}.kpi-card{background:var(--card);border-radius:14px;gap:10px;padding:14px;display:flex;box-shadow:0 8px 20px #0000000d}.kpi-card h2{margin:0}.kpi-icon{color:#3b82f6}.floor-scroll{gap:10px;margin-bottom:14px;padding:8px 2px;display:flex;overflow-x:auto}.floor-chip{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:999px;flex:none;align-items:center;gap:6px;padding:8px 12px;font-size:13px;display:flex}.dashboard-card{background:var(--card);border-radius:16px;margin-bottom:14px;padding:16px;box-shadow:0 10px 25px #0000000d}.card-header{align-items:center;gap:8px;margin-bottom:12px;display:flex}.beds-map{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;display:grid}.bed-box{cursor:pointer;border-radius:14px;flex-direction:column;align-items:center;gap:6px;padding:12px;font-weight:600;transition:all .2s;display:flex}.bed-box:hover{transform:translateY(-3px)}.bed-disponible{color:#166534;background:#dcfce7}.bed-ocupada{color:#991b1b;background:#fee2e2}.bed-reservada{color:#5b21b6;background:#ede9fe}.bed-limpieza{color:#854d0e;background:#fef9c3}.bed-mantenimiento{color:#334155;background:#e2e8f0}.areas-table{border-collapse:collapse;width:100%}.areas-table th,.areas-table td{border-bottom:1px solid var(--border);padding:10px}.alert-item{background:#fff7ed;border-left:4px solid #f59e0b;border-radius:10px;margin-bottom:8px;padding:10px}.ocupacion-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;display:grid}.ocupacion-item{background:#fff;border-radius:12px;padding:12px}@media (width<=768px){.hospital-dashboard{padding:12px}.beds-map,.kpis-grid{grid-template-columns:repeat(2,1fr)}}.qr-container{background:linear-gradient(#f6f8fc,#eef2f7);min-height:100vh;padding:24px;font-family:Inter,system-ui}.qr-header h1{align-items:center;gap:10px;font-size:22px;font-weight:900;display:flex}.qr-header p{color:#64748b}.qr-kpis{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin:18px 0;display:grid}.qr-kpi{background:#fff;border-radius:16px;padding:14px;transition:all .2s;box-shadow:0 10px 25px #0000000f}.qr-kpi:hover{transform:translateY(-3px)}.qr-filters{gap:10px;padding:10px 4px;display:flex;overflow-x:auto}.floor-chip{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:999px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;transition:all .2s;display:flex}.floor-chip:hover{transform:scale(1.05)}.floor-chip.active{color:#fff;background:#111827}.qr-map-container{background:#fff;border-radius:18px;padding:16px}.qr-map-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}@media (width<=1100px){.qr-map-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=800px){.qr-map-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=500px){.qr-map-grid{grid-template-columns:1fr}}.qr-bed{cursor:pointer;border:1px solid #e5e7eb;border-radius:14px;flex-direction:column;gap:8px;padding:14px;transition:all .2s;display:flex}.qr-bed:hover{transform:scale(1.03)}.qr-bed.disponible{background:#ecfdf5}.qr-bed.ocupada{background:#fef2f2}.qr-bed.reservada{background:#eff6ff}.qr-bed.en_limpieza{background:#fffbeb}.qr-bed.mantenimiento{background:#f5f3ff}.qr-bed-top{justify-content:space-between;font-weight:700;display:flex}.qr-status{color:#fff;background:#111827;border-radius:999px;width:fit-content;padding:4px 8px;font-size:11px}.qr-modal-bg{background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.qr-modal{background:#fff;border-radius:18px;width:420px;padding:20px;animation:.25s pop}.qr-state-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-top:12px;display:grid}.state-card{cursor:pointer;text-transform:capitalize;color:#0f172a;background:#fff;border:2px solid #e5e7eb;border-radius:14px;justify-content:center;align-items:center;min-height:48px;padding:12px;font-weight:700;transition:all .2s;display:flex}.state-card:hover{transform:translateY(-2px);box-shadow:0 10px 20px #00000014}.state-card.active{color:#fff;background:#111827;border-color:#111827;box-shadow:0 10px 25px #00000040}.state-card.disponible{border-color:#22c55e}.state-card.disponible:hover{box-shadow:0 0 0 3px #22c55e26}.state-card.ocupada{border-color:#ef4444}.state-card.ocupada:hover{box-shadow:0 0 0 3px #ef444426}.state-card.reservada{border-color:#3b82f6}.state-card.reservada:hover{box-shadow:0 0 0 3px #3b82f626}.state-card.en_limpieza{border-color:#eab308}.state-card.en_limpieza:hover{box-shadow:0 0 0 3px #eab30826}.state-card.mantenimiento{border-color:#a855f7}.state-card.mantenimiento:hover{box-shadow:0 0 0 3px #a855f726}.qr-box{justify-content:center;margin:16px 0;display:flex}.qr-close{color:#fff;cursor:pointer;background:#111827;border:none;border-radius:12px;width:100%;padding:10px}:root{--primary:#2563eb;--primary-hover:#1d4ed8;--danger:#dc2626;--danger-hover:#b91c1c;--success:#16a34a;--bg:#f5f7fb;--white:#fff;--text:#111827;--text-light:#6b7280;--border:#e5e7eb;--shadow:0 10px 25px #0000000f;--radius:18px;--transition:all .25s ease;--sidebar-width:260px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.usuarios-container{width:100%;min-height:100vh;padding:30px;animation:.3s fadeIn}.usuarios-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;margin-bottom:28px;display:flex}.usuarios-header h1{color:var(--text);letter-spacing:-.5px;font-size:32px;font-weight:800}.usuarios-header p{color:var(--text-light);margin-top:6px;font-size:15px}.btn-primary{background:var(--primary);color:#fff;cursor:pointer;transition:var(--transition);border:none;border-radius:14px;outline:none;padding:14px 22px;font-size:14px;font-weight:700;box-shadow:0 10px 20px #2563eb33}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-2px)}button{cursor:pointer;transition:var(--transition);border:none;outline:none}.usuarios-toolbar{margin-bottom:28px}.usuarios-toolbar input{border:1px solid var(--border);width:100%;max-width:420px;transition:var(--transition);background:#fff;border-radius:14px;padding:14px 18px;font-size:15px;box-shadow:0 4px 10px #00000008}.usuarios-toolbar input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #2563eb1a}.usuarios-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;display:grid}.usuario-card{background:var(--white);box-shadow:var(--shadow);transition:var(--transition);border:1px solid #ffffffb3;border-radius:22px;padding:22px;position:relative;overflow:hidden}.usuario-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px #0000001a}.usuario-card:before{content:"";background:linear-gradient(90deg, var(--primary), #60a5fa);width:100%;height:5px;position:absolute;top:0;left:0}.usuario-top{align-items:center;gap:16px;margin-bottom:18px;display:flex}.avatar{background:linear-gradient(135deg, var(--primary), #60a5fa);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:62px;height:62px;font-size:24px;font-weight:800;display:flex;box-shadow:0 10px 20px #2563eb40}.usuario-top h3{color:var(--text);margin-bottom:4px;font-size:19px;font-weight:700}.usuario-top p{color:var(--text-light);word-break:break-word;font-size:14px}.rol-badge{color:var(--primary);background:#2563eb1a;border-radius:999px;justify-content:center;align-items:center;margin-bottom:16px;padding:8px 14px;font-size:13px;font-weight:700;display:inline-flex}.usuario-card p{color:var(--text-light);margin-bottom:10px;font-size:14px;line-height:1.5}.actions{gap:12px;margin-top:20px;display:flex}.actions button{border-radius:12px;flex:1;padding:12px;font-size:14px;font-weight:700}.actions button:first-child{color:var(--primary);background:#2563eb1a}.actions button:first-child:hover{background:var(--primary);color:#fff}.actions .danger{color:var(--danger);background:#dc26261a}.actions .danger:hover{background:var(--danger);color:#fff}.loading{text-align:center;color:var(--text-light);box-shadow:var(--shadow);background:#fff;border-radius:20px;padding:50px;font-size:16px;font-weight:600}.overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;background:#0f172a8c;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:26px;width:100%;max-width:520px;padding:30px;animation:.2s scaleIn;box-shadow:0 30px 60px #0003}.modal h2{color:var(--text);margin-bottom:24px;font-size:25px;font-weight:800}.modal input,.modal select{border:1px solid var(--border);width:100%;transition:var(--transition);background:#fafafa;border-radius:14px;margin-bottom:14px;padding:14px 16px;font-size:15px}.modal input:focus,.modal select:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #2563eb1a}.error{color:var(--danger);margin-top:-6px;margin-bottom:14px;font-size:13px;font-weight:600;display:block}.modal-actions{gap:14px;margin-top:22px;display:flex}.modal-actions button{border-radius:14px;flex:1;padding:14px;font-size:15px;font-weight:700}.modal-actions button:first-child{background:var(--primary);color:#fff}.modal-actions button:first-child:hover{background:var(--primary-hover)}.modal-actions button:last-child{color:var(--text);background:#f3f4f6}.modal-actions button:last-child:hover{background:#e5e7eb}.confirm{text-align:center}.confirm p{color:var(--text);margin:20px 0;font-size:18px;font-weight:600}.confirm .danger{background:var(--danger);color:#fff}.confirm .danger:hover{background:var(--danger-hover)}.toast{color:#fff;z-index:9999;background:#111827;border-radius:16px;padding:16px 22px;font-size:14px;font-weight:700;animation:.25s toastIn;position:fixed;bottom:24px;right:24px;box-shadow:0 18px 35px #0003}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width<=1024px){.usuarios-container{padding:24px}.usuarios-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (width<=768px){.usuarios-container{padding:18px}.usuarios-header{flex-direction:column;align-items:stretch}.usuarios-header h1{font-size:26px}.btn-primary{width:100%}.usuarios-toolbar input{max-width:100%}.actions{flex-direction:column}.modal{padding:22px}.modal-actions{flex-direction:column}.toast{text-align:center;bottom:18px;left:18px;right:18px}}@media (width<=480px){.usuarios-grid{grid-template-columns:1fr}.usuario-card{padding:18px}.usuario-top{align-items:flex-start}.avatar{width:54px;height:54px;font-size:20px}.modal h2{font-size:22px}}.solicitudes-page{background:#f4f7fb;min-height:100vh;padding:24px;font-family:Inter,sans-serif}.solicitudes-header h1{color:#0f172a;font-size:26px;font-weight:900}.solicitudes-header p{color:#64748b}.filters-bar{gap:12px;margin:18px 0;display:flex}.filter-box{background:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:8px;padding:10px 12px;display:flex}.filter-box select{background:0 0;border:none;outline:none}.solicitudes-grid{grid-template-columns:380px 1fr;gap:18px;display:grid}.card,.list-card{background:#fff;border-radius:18px;padding:18px;box-shadow:0 10px 30px #02061714}.field{margin-bottom:10px}.field label{color:#334155;font-size:12px;font-weight:700}.field select,textarea{border:1px solid #e2e8f0;border-radius:12px;width:100%;margin-top:4px;padding:10px}button{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:12px;width:100%;padding:12px;font-weight:800}.chips{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.chip{color:#0369a1;background:#e0f2fe;border-radius:999px;align-items:center;gap:5px;padding:5px 10px;font-size:12px;display:flex}.cards-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.sol-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:12px;transition:all .2s}.sol-card:hover{transform:translateY(-3px);box-shadow:0 10px 25px #0206171f}.sol-head{align-items:center;gap:6px;display:flex}.sol-card h3{font-size:14px;font-weight:800}.muted{color:#64748b;font-size:12px}.tags{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.tag{border-radius:999px;padding:4px 8px;font-size:11px}.tag.baja{color:#16a34a;background:#dcfce7}.tag.media{color:#ca8a04;background:#fef9c3}.tag.alta{color:#dc2626;background:#fee2e2}.tag.critica{color:#991b1b;background:#fecaca}.tag.pendiente{color:#0369a1;background:#e0f2fe}.tag.aprobada{color:#16a34a;background:#dcfce7}.tag.rechazada{color:#dc2626;background:#fee2e2}.assigned{color:#0f172a;align-items:center;gap:6px;margin-top:8px;font-size:12px;font-weight:700;display:flex}.assign{border:1px solid #e2e8f0;border-radius:10px;width:100%;margin-top:8px;padding:6px}@media (width<=1200px){.cards-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=700px){.solicitudes-grid,.cards-grid{grid-template-columns:1fr}.filters-bar{flex-direction:column}}.qr-public-container{background:#0f172a;justify-content:center;align-items:center;height:100vh;font-family:Inter;display:flex}.qr-public-card{text-align:center;color:#fff;background:#111827;border-radius:18px;width:320px;padding:25px;box-shadow:0 10px 30px #0006}.estado{text-transform:capitalize;border-radius:8px;margin-top:10px;padding:6px 12px;font-weight:700}.estado.disponible{color:#22c55e;background:#14532d}.estado.ocupada{color:#ef4444;background:#450a0a}.estado.reservada{color:#3b82f6;background:#1e3a8a}.estado.en_limpieza{color:#f59e0b;background:#78350f}.estado.mantenimiento{color:#a855f7;background:#4c1d95}.icono{margin:20px 0}.info{opacity:.8;font-size:13px}:root{--bg:#0f172a;--panel:#111827;--card:#1e293b;--text:#f9fafb;--muted:#94a3b8;--border:#ffffff14;--primary:#2563eb;--primary-hover:#1d4ed8;--hover:#ffffff0f;--shadow:0 10px 40px #00000059}[data-theme=light]{--bg:#f4f6fb;--panel:#fff;--card:#fff;--text:#0f172a;--muted:#64748be8;--border:#0f172a14;--hover:#0f172a0d;--shadow:0 10px 30px #00000014}[data-theme=dark]{--bg:#0b1220;--panel:#0f172a;--text:#e2e8f0;--muted:#94a3b8;--border:#ffffff14;--primary:#3b82f6}.kpi-grid>div{border:1px solid var(--border);box-shadow:var(--shadow);background:var(--card)!important;color:var(--text)!important}svg{color:inherit;stroke:currentColor}*{transition:background .25s,color .25s}body{background:var(--bg);color:var(--text);margin:0;font-family:system-ui,sans-serif}
