.notification-container{position:fixed;top:80px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:12px;max-width:400px;pointer-events:none}.notification{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--hotel-card-background);border-radius:8px;box-shadow:0 4px 12px #00000026,0 0 0 1px #0000000d;min-width:300px;max-width:400px;animation:slideIn .3s ease-out;pointer-events:all;border-left:4px solid}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.notification__icon{flex-shrink:0;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff}.notification__message{flex:1;font-size:14px;line-height:1.4;color:var(--hotel-text)}.notification__close{flex-shrink:0;background:none;border:none;font-size:24px;color:var(--hotel-text-secondary);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.notification__close:hover{background:var(--hotel-surface-light);color:var(--hotel-text)}.notification--success{border-left-color:#10b981}.notification--success .notification__icon{background:#10b981}.notification--error{border-left-color:#ef4444}.notification--error .notification__icon{background:#ef4444}.notification--warning{border-left-color:#f59e0b}.notification--warning .notification__icon{background:#f59e0b}.notification--info{border-left-color:#8b5cf6}.notification--info .notification__icon{background:#8b5cf6}@media (max-width: 768px){.notification-container{top:60px;right:10px;left:10px;max-width:none}.notification{min-width:auto;max-width:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e40af,#3b82f6,#60a5fa);padding:20px;position:relative;overflow:hidden}.floating-icons{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.floating-icon{position:absolute;left:var(--left);bottom:-60px;color:#93c5fd99;animation:floatUp var(--duration) linear infinite;animation-delay:var(--delay);filter:drop-shadow(0 8px 16px rgba(59,130,246,.3))}@keyframes floatUp{0%{bottom:-60px;opacity:0;transform:translate(0) rotate(0) scale(1);filter:drop-shadow(0 8px 16px rgba(59,130,246,.3))}10%{opacity:.85}50%{opacity:1;transform:translate(var(--move-x, 50px)) rotate(180deg) scale(1.15);filter:drop-shadow(0 12px 24px rgba(96,165,250,.4)) drop-shadow(0 0 20px rgba(147,197,253,.3))}90%{opacity:.85}to{bottom:120vh;opacity:0;transform:translate(var(--move-x, -50px)) rotate(360deg) scale(1);filter:drop-shadow(0 8px 16px rgba(59,130,246,.3))}}.bg-shapes{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.shape{position:absolute;border-radius:50%;background:#bfdbfe26;-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);box-shadow:0 8px 32px #93c5fd33}.shape-1{width:500px;height:500px;top:-150px;right:-100px;animation:morph 15s ease-in-out infinite}.shape-2{width:350px;height:350px;bottom:-100px;left:-80px;animation:morph 20s ease-in-out infinite reverse}.shape-3{width:250px;height:250px;top:50%;left:50%;transform:translate(-50%,-50%);animation:pulse 10s ease-in-out infinite}@keyframes morph{0%,to{border-radius:50% 60% 40% 50%;transform:rotate(0)}25%{border-radius:60% 50% 50% 40%}50%{border-radius:40% 50% 60%;transform:rotate(90deg)}75%{border-radius:50% 40% 50% 60%}}@keyframes pulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.05}50%{transform:translate(-50%,-50%) scale(1.2);opacity:.1}}.login-container{width:100%;max-width:450px;position:relative;z-index:2}.login-card{background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;box-shadow:0 25px 100px #0000004d;padding:48px 40px;animation:slideUp .5s cubic-bezier(.4,0,.2,1);border:1px solid rgba(255,255,255,.3)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:40px}.logo-login{margin-bottom:32px;display:flex;justify-content:center;align-items:center}.login-logo-image{height:160px;width:160px;object-fit:contain;padding:1px;background:linear-gradient(135deg,#1e3a8a,#1e40af,#3b82f6);border-radius:20px;box-shadow:0 10px 40px #1e40af66;animation:logoFloat 3s ease-in-out infinite;border:3px solid rgba(255,255,255,.2)}@keyframes logoFloat{0%,to{transform:translateY(0);box-shadow:0 10px 40px #1e40af66}50%{transform:translateY(-10px);box-shadow:0 15px 50px #1e40af80}}.login-header h2{font-size:28px;font-weight:700;margin:0 0 8px;color:var(--color-text-primary)}.login-header p{margin:0;color:var(--color-text-secondary);font-size:14px}.login-form{display:flex;flex-direction:column;gap:24px}.login-error{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:12px;font-size:14px;font-weight:500;border:2px solid #fecaca;animation:shake .5s ease}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--color-text-primary)}.form-group label svg{color:#1e40af}.form-group input{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:15px;color:var(--color-text-primary);transition:all .3s ease;background:#f8fafc}.form-group input:focus{outline:none;border-color:#1e40af;background:#fff;box-shadow:0 0 0 4px #1e40af26}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-group input::placeholder{color:#94a3b8}.btn-login{width:100%;padding:16px;background:linear-gradient(135deg,#1e40af,#1e3a8a);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #1e40af66,0 0 #93c5fd00;margin-top:8px}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #1e40af80,0 0 20px #93c5fd4d;background:linear-gradient(135deg,#1e3a8a,#1e3a8a)}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{opacity:.7;cursor:not-allowed}.login-demo{margin-top:24px;padding:16px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:12px;text-align:center;border:2px solid #bfdbfe}.login-demo p{margin:4px 0;font-size:13px;color:#1e3a8a}.login-demo p:first-child{font-weight:700;margin-bottom:8px}@media (max-width: 768px){.login-page{padding:16px}.login-card{padding:32px 24px}.login-logo-image{height:110px;width:110px;padding:1px}.login-header h2{font-size:24px}.floating-icon{display:none}.shape-1,.shape-2{width:300px;height:300px}.shape-3{width:150px;height:150px}}.db-sidebar{width:220px;flex-shrink:0;background:var(--hotel-card-background);border-right:1px solid var(--hotel-border);display:flex;flex-direction:column;border-radius:12px 0 0 12px;overflow:hidden}.db-sidebar__header{padding:1.25rem 1rem;border-bottom:1px solid var(--hotel-border)}.db-sidebar__title{font-size:1rem;font-weight:700;color:var(--hotel-text);margin:0 0 .25rem}.db-sidebar__fecha{font-size:.75rem;color:var(--hotel-text-secondary);background:var(--hotel-primary);color:#fff;padding:.125rem .5rem;border-radius:4px;display:inline-block}.db-sidebar__nav{display:flex;flex-direction:column;padding:.5rem 0;flex:1}.db-sidebar__item{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;font-size:.8125rem;font-weight:500;color:var(--hotel-text-secondary);cursor:pointer;border:none;background:none;text-align:left;width:100%;border-left:3px solid transparent;transition:all .15s ease}.db-sidebar__item:hover:not(.db-sidebar__item--active){background:var(--hotel-background);color:var(--hotel-text)}.db-sidebar__item--active{color:var(--hotel-primary);background:color-mix(in srgb,var(--hotel-primary) 8%,transparent);border-left-color:var(--hotel-primary);font-weight:600}.db-sidebar__item svg{flex-shrink:0}@media (max-width: 768px){.db-sidebar{width:100%;border-radius:12px 12px 0 0;border-right:none;border-bottom:1px solid var(--hotel-border)}.db-sidebar__header{display:none}.db-sidebar__nav{flex-direction:row;overflow-x:auto;padding:0}.db-sidebar__item{flex-direction:column;gap:.25rem;padding:.625rem .75rem;border-left:none;border-bottom:2px solid transparent;white-space:nowrap;font-size:.6875rem}.db-sidebar__item--active{border-bottom-color:var(--hotel-primary);border-left-color:transparent}.db-sidebar__item-label{display:block}}.tt{display:flex;flex-direction:column;gap:1rem}.tt__header{display:flex;justify-content:space-between;align-items:center}.tt__title{font-size:1.125rem;font-weight:700;color:var(--hotel-text);margin:0}.tt__btn-nueva{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:var(--hotel-primary);color:#fff;border:none;border-radius:8px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:opacity .15s}.tt__btn-nueva:hover{opacity:.9}.tt__filtros{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.tt__filtro-select,.tt__filtro-input{padding:.5rem .75rem;border:1px solid var(--hotel-border);border-radius:8px;font-size:.8125rem;background:var(--hotel-card-background);color:var(--hotel-text)}.tt__busqueda{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;border:1px solid var(--hotel-border);border-radius:8px;background:var(--hotel-card-background);flex:1;min-width:200px}.tt__busqueda input{border:none;background:none;outline:none;font-size:.8125rem;color:var(--hotel-text);width:100%}.tt__busqueda svg{color:var(--hotel-text-secondary);flex-shrink:0}.tt__resumen{display:flex;gap:1rem;flex-wrap:wrap}.tt__resumen-item{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--hotel-text-secondary)}.tt__resumen-item span{font-weight:700}.tt__resumen-item--pendiente span{color:#f59e0b}.tt__resumen-item--progreso span{color:#3b82f6}.tt__resumen-item--completada span{color:#22c55e}.tt__resumen-item--limpieza span{color:#ef4444}.tt__tabla-wrapper{overflow-x:auto;border:1px solid var(--hotel-border);border-radius:10px;background:var(--hotel-card-background)}.tt__tabla{width:100%;border-collapse:collapse;font-size:.8125rem}.tt__tabla th{text-align:left;padding:.75rem 1rem;color:var(--hotel-text-secondary);font-weight:600;border-bottom:1px solid var(--hotel-border);white-space:nowrap}.tt__tabla th:first-child{width:4px;padding:0}.tt__fila td{padding:.75rem 1rem;border-bottom:1px solid var(--hotel-border);vertical-align:middle}.tt__fila td:first-child{padding:0;width:4px}.tt__fila:last-child td{border-bottom:none}.tt__prioridad-bar{width:4px;height:100%;min-height:40px;border-radius:2px}.tt__tarea-info{display:flex;align-items:center;gap:.5rem}.tt__tarea-hab{font-weight:600;color:var(--hotel-text)}.tt__tarea-tipo{color:var(--hotel-text-secondary);font-size:.75rem}.tt__tarea-notas{cursor:help}.tt__responsable{color:var(--hotel-text);font-weight:500}.tt__asignar-select{padding:.25rem .5rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.75rem;background:var(--hotel-card-background);color:var(--hotel-text-secondary)}.tt__fecha{color:var(--hotel-text-secondary)}.tt__acciones{display:flex;gap:.375rem}.tt__btn{padding:.25rem .625rem;border:none;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:opacity .15s}.tt__btn:hover{opacity:.85}.tt__btn--iniciar{background:#3b82f6;color:#fff}.tt__btn--completar{background:#22c55e;color:#fff}.tt__btn--cancelar{background:var(--hotel-border);color:var(--hotel-text)}.tt__btn--crear{background:var(--hotel-primary);color:#fff}.tt__estado-badge{padding:.125rem .5rem;border-radius:4px;font-size:.6875rem;font-weight:600}.tt__estado-badge--completada{background:#dcfce7;color:#166534}.tt__estado-badge--cancelada{background:#fee2e2;color:#991b1b}.tt__loading,.tt__empty{padding:2rem;text-align:center;color:var(--hotel-text-secondary);font-size:.875rem}.tt__modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.tt__modal{background:var(--hotel-card-background);border-radius:12px;padding:1.5rem;width:90%;max-width:480px;box-shadow:var(--shadow-md)}.tt__modal h3{margin:0 0 1rem;font-size:1rem;color:var(--hotel-text)}.tt__modal-field{margin-bottom:.75rem}.tt__modal-field label{display:block;font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary);margin-bottom:.25rem}.tt__modal-field select,.tt__modal-field input,.tt__modal-field textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--hotel-border);border-radius:8px;font-size:.8125rem;background:var(--hotel-background);color:var(--hotel-text);box-sizing:border-box}.tt__modal-field textarea{resize:vertical}.tt__modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}[data-theme=dark] .tt__estado-badge--completada{background:#166534;color:#dcfce7}[data-theme=dark] .tt__estado-badge--cancelada{background:#991b1b;color:#fee2e2}@media (max-width: 768px){.tt__filtros{flex-direction:column}.tt__busqueda{min-width:100%}.tt__header{flex-direction:column;align-items:flex-start;gap:.5rem}}.er{display:flex;flex-direction:column;gap:1.25rem}.er__header{margin-bottom:0}.er__title{font-size:1.125rem;font-weight:700;color:var(--hotel-text);margin:0}.er__subtitle{font-size:.8125rem;color:var(--hotel-text-secondary);margin:.25rem 0 0}.er__fecha-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.er__fecha-label{font-size:.8125rem;color:var(--hotel-text-secondary)}.er__fecha-input{padding:.5rem .75rem;border:1px solid var(--hotel-border);border-radius:8px;font-size:.8125rem;background:var(--hotel-card-background);color:var(--hotel-text)}.er__cards{display:grid;grid-template-columns:2fr 1fr;gap:1rem}.er__card{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:12px;padding:1.25rem;display:flex;flex-direction:column;gap:.5rem}.er__card-label{font-size:.8125rem;color:var(--hotel-text-secondary);font-weight:500}.er__card-value{font-size:1.5rem;font-weight:800;color:var(--hotel-text)}.er__card-value--balance{color:var(--hotel-primary)}.er__card-detail{font-size:.75rem;color:var(--hotel-text-secondary)}.er__card-breakdown{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.er__bar-row{display:flex;align-items:center;gap:.5rem}.er__bar-label{font-size:.75rem;color:var(--hotel-text-secondary);min-width:100px}.er__bar{flex:1;height:8px;background:var(--hotel-border);border-radius:4px;overflow:hidden}.er__bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.er__bar-fill--alojamiento{background:var(--hotel-primary)}.er__bar-fill--extras{background:#94a3b8}.er__bar-fill--gastos{background:#ef4444}.er__bar-fill--compras{background:#f59e0b}.er__bar-value{font-size:.75rem;color:var(--hotel-text-secondary);min-width:100px;text-align:right}.er__card--egresos{border-left:3px solid #ef4444}.er__card-value--egresos,.er__card-value--negativo{color:#ef4444}.er__card--pendientes{border-left:3px solid #f59e0b}.er__card-value--pendientes{color:#f59e0b}.er__card--categorias{padding:1rem 1.25rem}.er__categorias-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.er__cat-row{display:flex;align-items:center;gap:.5rem}.er__cat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.er__cat-name{font-size:.75rem;color:var(--hotel-text-secondary);min-width:100px;flex-shrink:0}.er__cat-bar{flex:1;height:6px;background:var(--hotel-border);border-radius:3px;overflow:hidden}.er__cat-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.er__cat-value{font-size:.75rem;font-weight:600;color:var(--hotel-text);min-width:90px;text-align:right}.er__cat-pct{font-size:.6875rem;color:var(--hotel-text-secondary);min-width:32px;text-align:right}.er__kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.er__kpi{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:12px;padding:1rem;display:flex;align-items:center;gap:.75rem}.er__kpi-icon{color:var(--hotel-primary);flex-shrink:0}.er__kpi-label{font-size:.6875rem;color:var(--hotel-text-secondary);text-transform:uppercase;font-weight:600;display:block}.er__kpi-value{font-size:1rem;font-weight:700;color:var(--hotel-text);display:block}.er__kpi-sub{font-size:.6875rem;color:var(--hotel-text-secondary);display:block}.er__chart-section{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:12px;padding:1.25rem}.er__chart-title{font-size:.875rem;color:var(--hotel-text-secondary);margin:0 0 .25rem;text-align:center}.er__chart-value{font-size:2rem;font-weight:800;color:var(--hotel-text);text-align:center;margin-bottom:1rem}.er__chart{display:flex;align-items:flex-end;gap:4px;height:120px;padding:0 .5rem}.er__chart-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.er__chart-bar{width:100%;max-width:30px;background:var(--hotel-primary);border-radius:3px 3px 0 0;min-height:2px;transition:height .3s ease}.er__chart-label{font-size:.5625rem;color:var(--hotel-text-secondary);margin-top:4px;white-space:nowrap}.er__loading{padding:2rem;text-align:center;color:var(--hotel-text-secondary)}@media (max-width: 768px){.er__cards{grid-template-columns:1fr}.er__kpis{grid-template-columns:repeat(2,1fr)}}.ls{display:flex;flex-direction:column;gap:1rem}.ls__header{display:flex;justify-content:space-between;align-items:flex-start}.ls__header-left{flex:1}.ls__title{font-size:1.125rem;font-weight:700;color:var(--hotel-text);margin:0}.ls__subtitle{font-size:.8125rem;color:var(--hotel-text-secondary);margin:.25rem 0 0}.ls__btn-export{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:#22c55e;color:#fff;border:none;border-radius:8px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:opacity .15s;white-space:nowrap}.ls__btn-export:hover{opacity:.9}.ls__controls{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.ls__date-nav{display:flex;align-items:center;gap:.375rem}.ls__date-btn{width:32px;height:32px;border:1px solid var(--hotel-border);background:var(--hotel-card-background);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--hotel-text)}.ls__date-btn:hover{background:var(--hotel-background)}.ls__date-badge{background:var(--hotel-primary);color:#fff;padding:.375rem 1rem;border-radius:8px;font-size:.8125rem;font-weight:600}.ls__gauges{display:flex;gap:1.5rem}.ls__gauge{display:flex;flex-direction:column;align-items:center;gap:.25rem}.ls__gauge-circle{position:relative;width:64px;height:64px}.ls__gauge-circle svg{width:100%;height:100%;transform:rotate(-90deg)}.ls__gauge-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:1.125rem;font-weight:800;color:var(--hotel-text)}.ls__gauge-label{font-size:.6875rem;color:var(--hotel-text-secondary);font-weight:500}.ls__columns{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;align-items:flex-start}.ls__column{display:flex;flex-direction:column;gap:.75rem}.ls__col-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:var(--hotel-text);margin:0;padding-bottom:.5rem;border-bottom:2px solid var(--hotel-border)}.ls__col-icon--llegada{color:#3b82f6}.ls__col-icon--salida{color:#f59e0b}.ls__col-icon--inhouse{color:#22c55e}.ls__col-badge{font-size:.6875rem;padding:.125rem .5rem;border-radius:4px;font-weight:700;color:#fff}.ls__col-badge--llegada{background:#3b82f6}.ls__col-badge--salida{background:#f59e0b}.ls__col-badge--inhouse{background:#22c55e}.ls__col-empty{padding:1.5rem;text-align:center;color:var(--hotel-text-secondary);font-size:.8125rem;background:var(--hotel-card-background);border:1px dashed var(--hotel-border);border-radius:10px}.ls__card{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:10px;padding:.875rem;display:flex;flex-direction:column;gap:.375rem}.ls__card--checked-in{border-color:#22c55e;background:color-mix(in srgb,#22c55e 5%,var(--hotel-card-background))}.ls__card-header{display:flex;justify-content:space-between;align-items:center}.ls__card-nombre{font-weight:700;color:var(--hotel-text);font-size:.875rem}.ls__card-pax{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--hotel-text-secondary);background:var(--hotel-background);padding:.125rem .5rem;border-radius:4px;font-weight:600}.ls__card-room{font-size:.8125rem;color:var(--hotel-text-secondary);font-weight:500}.ls__card-dates{font-size:.75rem;color:var(--hotel-text-secondary)}.ls__card-checkin-info{font-size:.6875rem;color:#22c55e;font-weight:600}.ls__card-warning{font-size:.6875rem;color:#f59e0b;font-weight:600}.ls__card-warning--overstay{color:#dc2626;background:#fef2f2;padding:.25rem .5rem;border-radius:4px;border-left:3px solid #dc2626}.ls__card-actions{display:flex;gap:.375rem;margin-top:.25rem;flex-wrap:wrap}.ls__card-btn{padding:.3125rem .625rem;border:none;border-radius:6px;font-size:.6875rem;font-weight:600;cursor:pointer;transition:opacity .15s}.ls__card-btn:hover{opacity:.85}.ls__card-btn--checkin{background:#22c55e;color:#fff}.ls__card-btn--checkout{background:#3b82f6;color:#fff}.ls__card-btn--noshow,.ls__card-btn--deshacer{background:#ef4444;color:#fff}.ls__card-btn--detalles{background:var(--hotel-border);color:var(--hotel-text)}.ls__loading{padding:2rem;text-align:center;color:var(--hotel-text-secondary)}@media (max-width: 1024px){.ls__columns{grid-template-columns:1fr}}@media (max-width: 768px){.ls__header{flex-direction:column;gap:.75rem}.ls__controls{flex-direction:column;align-items:flex-start}}.hkp{display:flex;flex-direction:column;gap:1rem}.hkp__header{display:flex;align-items:center;justify-content:space-between}.hkp__title{font-size:1.125rem;font-weight:700;color:var(--hotel-text);margin:0;display:flex;align-items:center;gap:.5rem}.hkp__badge{background:var(--hotel-primary);color:#fff;font-size:.6875rem;padding:.125rem .5rem;border-radius:4px;font-weight:700}.hkp__summary{display:flex;gap:1rem;flex-wrap:wrap}.hkp__stat{font-size:.8125rem;font-weight:600}.hkp__stat--disponible{color:#22c55e}.hkp__stat--ocupada{color:#ef4444}.hkp__stat--limpieza{color:#f59e0b}.hkp__stat--mantenimiento{color:#94a3b8}.hkp__camas-summary{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--hotel-surface-light, #f1f5f9);border:1px solid var(--hotel-border);border-radius:6px;font-size:.8125rem;color:var(--hotel-text);flex-wrap:wrap}.hkp__camas-summary svg{color:var(--hotel-primary);flex-shrink:0}.hkp__camas-summary-sep{color:var(--hotel-border)}.hkp__camas-summary-libres{color:#22c55e;font-weight:600}.hkp__camas-summary-parcial{color:#f59e0b;font-weight:600}.hkp__tabla-wrapper{border:1px solid var(--hotel-border);border-radius:10px;overflow:hidden;background:var(--hotel-card-background)}.hkp__tabla{width:100%;border-collapse:collapse;font-size:.8125rem}.hkp__tabla th{text-align:left;padding:.75rem 1rem;color:var(--hotel-text-secondary);font-weight:600;border-bottom:1px solid var(--hotel-border);background:var(--hotel-background)}.hkp__fila td{padding:.75rem 1rem;border-bottom:1px solid var(--hotel-border);vertical-align:middle}.hkp__fila:last-child td{border-bottom:none}.hkp__hab-tipo{color:var(--hotel-text);font-weight:600}.hkp__hab-sep{color:var(--hotel-text-secondary);margin:0 .25rem}.hkp__hab-num{color:var(--hotel-text);font-weight:600}.hkp__camas-cell{display:flex;align-items:center;gap:.5rem}.hkp__camas-bar{width:50px;height:8px;border-radius:4px;background:#e5e7eb;overflow:hidden;flex-shrink:0}.hkp__camas-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.hkp__camas-bar--libre .hkp__camas-bar-fill{background:#22c55e}.hkp__camas-bar--parcial .hkp__camas-bar-fill{background:#f59e0b}.hkp__camas-bar--llena .hkp__camas-bar-fill{background:#ef4444}.hkp__camas-text{font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary);white-space:nowrap}.hkp__info{color:var(--hotel-text);font-size:.8125rem}.hkp__info--sin{color:var(--hotel-text-secondary)}.hkp__ocupantes-compact{display:flex;flex-wrap:wrap;gap:.375rem}.hkp__ocupante-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .5rem;background:#ef444414;border:1px solid rgba(239,68,68,.15);border-radius:4px;font-size:.6875rem;color:var(--hotel-text);white-space:nowrap}.hkp__ocupante-tag svg{color:#ef4444;flex-shrink:0}.hkp__ocupante-grado{color:#7c3aed;font-weight:600;margin-left:.125rem}.hkp__camas-libres-tag{display:inline-flex;align-items:center;padding:.125rem .5rem;background:#22c55e14;border:1px solid rgba(34,197,94,.2);border-radius:4px;font-size:.6875rem;font-weight:600;color:#16a34a;white-space:nowrap}.hkp__estado-badge{display:inline-flex;padding:.125rem .5rem;border-radius:4px;font-size:.6875rem;font-weight:600}.hkp__estado-badge--ocupada{background:#ef44441a;color:#ef4444}.hkp__estado-badge--reservada{background:#3b82f61a;color:#3b82f6}.hkp__checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--hotel-primary)}.hkp__checkbox:disabled{cursor:default;opacity:.3}.hkp__icon--clean{color:#22c55e}.hkp__icon--manto{color:#94a3b8}.hkp__loading{padding:2rem;text-align:center;color:var(--hotel-text-secondary)}@media (max-width: 768px){.hkp__camas-summary{font-size:.75rem}.hkp__tabla th:nth-child(3),.hkp__tabla td:nth-child(3){display:none}}.ld{max-width:700px;margin:0 auto;padding:1rem}.ld__header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.ld__header-icon{width:56px;height:56px;background:var(--hotel-primary);color:#fff;border-radius:14px;display:flex;align-items:center;justify-content:center}.ld__title{font-size:1.5rem;font-weight:800;color:var(--hotel-text);margin:0}.ld__subtitle{font-size:.875rem;color:var(--hotel-text-secondary);margin:.125rem 0 0}.ld__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}.ld__stat{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:12px;padding:1rem;display:flex;align-items:center;gap:.75rem}.ld__stat--pendiente svg{color:#f59e0b}.ld__stat--progreso svg{color:#3b82f6}.ld__stat--completada svg{color:#22c55e}.ld__stat-num{font-size:1.5rem;font-weight:800;color:var(--hotel-text);display:block;line-height:1}.ld__stat-label{font-size:.75rem;color:var(--hotel-text-secondary);display:block}.ld__tareas{display:flex;flex-direction:column;gap:.75rem}.ld__tarea{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:12px;padding:1rem;border-left:4px solid var(--hotel-border)}.ld__tarea--urgente{border-left-color:#ef4444}.ld__tarea--alta{border-left-color:#f59e0b}.ld__tarea--normal{border-left-color:#22c55e}.ld__tarea--baja{border-left-color:#94a3b8}.ld__tarea--completada{border-left-color:#22c55e;opacity:.7}.ld__tarea-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem}.ld__tarea-room{display:flex;align-items:center;gap:.5rem}.ld__tarea-room svg{color:var(--hotel-primary)}.ld__tarea-num{font-weight:700;color:var(--hotel-text);font-size:.9375rem}.ld__tarea-tipo-hab{color:var(--hotel-text-secondary);font-size:.75rem}.ld__tarea-tipo{font-size:.8125rem;color:var(--hotel-text-secondary);margin-bottom:.25rem}.ld__tarea-notas{font-size:.75rem;color:var(--hotel-text-secondary);background:var(--hotel-background);padding:.375rem .625rem;border-radius:6px;margin-bottom:.5rem}.ld__tarea-actions{display:flex;gap:.5rem;align-items:center}.ld__btn{display:flex;align-items:center;gap:.25rem;padding:.5rem 1rem;border:none;border-radius:8px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:opacity .15s}.ld__btn:hover{opacity:.85}.ld__btn--iniciar{background:#3b82f6;color:#fff}.ld__btn--completar{background:#22c55e;color:#fff}.ld__estado-badge{font-size:.75rem;color:#3b82f6;font-weight:600}.ld__badge{font-size:.6875rem;padding:.125rem .5rem;border-radius:4px;font-weight:700}.ld__badge--urgente{background:#fee2e2;color:#991b1b}.ld__badge--alta{background:#fef3c7;color:#92400e}.ld__badge--normal{background:#dcfce7;color:#166534}.ld__badge--baja{background:#f1f5f9;color:#475569}.ld__badge--completada{background:#dcfce7;color:#166534}.ld__section-title{font-size:.875rem;color:var(--hotel-text-secondary);margin:1rem 0 .5rem;padding-top:.5rem;border-top:1px solid var(--hotel-border)}.ld__icon--done{color:#22c55e}.ld__loading,.ld__empty{padding:3rem;text-align:center;color:var(--hotel-text-secondary)}.ld__empty svg{color:#22c55e;margin-bottom:.5rem}[data-theme=dark] .ld__badge--urgente{background:#991b1b;color:#fee2e2}[data-theme=dark] .ld__badge--alta{background:#92400e;color:#fef3c7}[data-theme=dark] .ld__badge--normal{background:#166534;color:#dcfce7}[data-theme=dark] .ld__badge--baja{background:#334155;color:#cbd5e1}[data-theme=dark] .ld__badge--completada{background:#166534;color:#dcfce7}@media (max-width: 768px){.ld__stats{grid-template-columns:1fr}}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem}.loading--fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;background:#fffffff2;z-index:9999}.loading__spinner{border:3px solid #f3f4f6;border-top-color:#1e40af;border-radius:50%;animation:spin .8s linear infinite}.loading__spinner--small{width:24px;height:24px;border-width:2px}.loading__spinner--medium{width:40px;height:40px;border-width:3px}.loading__spinner--large{width:60px;height:60px;border-width:4px}.loading__text{color:#6b7280;font-size:.875rem;margin:0}.dashboard-panel{display:flex;min-height:calc(100vh - 2rem);background:var(--hotel-card-background);border-radius:12px;border:1px solid var(--hotel-border);box-shadow:var(--shadow-sm);overflow:hidden}.dashboard-panel__content{flex:1;padding:1.25rem 1.5rem;min-width:0;overflow-y:auto}@media (max-width: 768px){.dashboard-panel{flex-direction:column;min-height:auto}.dashboard-panel__content{padding:1rem}}.badge{display:inline-flex;align-items:center;justify-content:center;font-weight:600;border-radius:9999px;white-space:nowrap;text-transform:capitalize}.badge--small{padding:.25rem .625rem;font-size:.6875rem}.badge--medium{padding:.375rem .875rem;font-size:.75rem}.badge--large{padding:.5rem 1rem;font-size:.875rem}.badge--default{background:#f3f4f6;color:#1f2937}.badge--primary{background:#ede9fe;color:#1e3a8a}.badge--success{background:#d1fae5;color:#059669}.badge--warning{background:#fef3c7;color:#d97706}.badge--danger{background:#fee2e2;color:#dc2626}.badge--info{background:#dbeafe;color:#2563eb}.badge--disponible{background:#d1fae5;color:#059669}.badge--ocupada{background:#fee2e2;color:#dc2626}.badge--limpieza{background:#fef3c7;color:#d97706}.badge--mantenimiento{background:#e5e7eb;color:#374151}.badge--reservada{background:#dbeafe;color:#2563eb}.badge--pendiente{background:#fef3c7;color:#d97706}.badge--confirmada{background:#d1fae5;color:#059669}.badge--en_curso{background:#dbeafe;color:#2563eb}.badge--finalizada{background:#e5e7eb;color:#374151}.badge--cancelada{background:#fee2e2;color:#dc2626}.badge--no_show{background:#f3f4f6;color:#6b7280}.badge--activo{background:#d1fae5;color:#059669}.button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:600;border-radius:.5rem;border:none;cursor:pointer;transition:all .2s;font-family:inherit;text-decoration:none}.button:focus{outline:none;ring:2px;ring-offset:2px}.button--small{padding:.5rem 1rem;font-size:.875rem}.button--medium{padding:.625rem 1.25rem;font-size:.875rem}.button--large{padding:.75rem 1.5rem;font-size:1rem}.button--primary{background:#1e40af;color:#fff}.button--primary:hover:not(:disabled){background:#1e3a8a;transform:translateY(-1px);box-shadow:0 4px 6px -1px #8b5cf64d}.button--secondary{background:#06b6d4;color:#fff}.button--secondary:hover:not(:disabled){background:#0891b2;transform:translateY(-1px)}.button--success{background:#10b981;color:#fff}.button--success:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.button--danger{background:#ef4444;color:#fff}.button--danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.button--warning{background:#f59e0b;color:#fff}.button--warning:hover:not(:disabled){background:#d97706;transform:translateY(-1px)}.button--outline{background:transparent;border:2px solid var(--hotel-primary);color:var(--hotel-primary)}.button--outline:hover:not(:disabled){background:var(--hotel-surface-light)}.button--ghost{background:transparent;color:var(--hotel-text-secondary)}.button--ghost:hover:not(:disabled){background:var(--hotel-surface-light)}.button--disabled,.button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.button--loading{cursor:wait;position:relative}.button--full-width{width:100%}.button__spinner{width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.button__icon{display:flex;align-items:center;justify-content:center}.button__text{display:flex;align-items:center}.select-group{display:flex;flex-direction:column;gap:.375rem;min-width:200px;flex:1}.select-group__label{font-size:.875rem;font-weight:500;color:var(--hotel-text)}.select-group__required{color:#ef4444;margin-left:.25rem}.select-group__select{width:100%;padding:.625rem 2.5rem .625rem .875rem;font-size:.875rem;border:1px solid var(--hotel-border);border-radius:.5rem;background:var(--hotel-card-background);color:var(--hotel-text);transition:all .2s;font-family:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em}.select-group__select:focus{outline:none;border-color:var(--hotel-primary);box-shadow:0 0 0 2px #3b82f626}.select-group__select:disabled{background-color:var(--hotel-surface-light);color:var(--hotel-text-light);cursor:not-allowed}.select-group__select--error{border-color:#ef4444}.select-group__select--error:focus{box-shadow:0 0 0 2px #ef444426}.select-group__error{font-size:.8125rem;color:#ef4444}[data-theme=dark] .select-group__select{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23a0a0a0' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e")}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s}.modal{background:var(--hotel-card-background);border-radius:.75rem;box-shadow:var(--shadow-xl);max-height:90vh;display:flex;flex-direction:column;animation:slideUp .2s;border:1px solid var(--hotel-border)}.modal--small{width:100%;max-width:400px}.modal--medium{width:100%;max-width:600px}.modal--large{width:100%;max-width:800px}.modal--xl{width:100%;max-width:1200px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--hotel-border)}.modal__title{font-size:1.25rem;font-weight:600;color:var(--hotel-text);margin:0}.modal__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--hotel-text-secondary);cursor:pointer;border-radius:.375rem;transition:all .2s}.modal__close:hover{background:var(--hotel-surface-light);color:var(--hotel-text)}.modal__body{padding:1.5rem;overflow-y:auto;flex:1}.modal__footer{padding:1.5rem;border-top:1px solid var(--hotel-border);display:flex;gap:.75rem;justify-content:flex-end}@media (max-width: 768px){.modal{max-height:95vh}.modal__header,.modal__body,.modal__footer{padding:1rem}}.confirm-modal{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:1rem 0}.confirm-modal__icon{display:flex;align-items:center;justify-content:center;animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.confirm-modal__message{text-align:center;font-size:1rem;line-height:1.5;color:var(--hotel-text)}.confirm-modal__actions{display:flex;gap:.75rem;width:100%;margin-top:.5rem}@media (max-width: 768px){.confirm-modal__actions{flex-direction:column-reverse}}.success-modal{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:1.5rem 0}.success-modal__icon{display:flex;align-items:center;justify-content:center;animation:successBounce .6s ease-out}@keyframes successBounce{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}70%{transform:scale(.9)}to{transform:scale(1);opacity:1}}.success-modal__message{text-align:center;font-size:1.0625rem;line-height:1.6;color:#374151;max-width:400px}.success-modal__actions{width:100%;margin-top:.5rem}.input-group__label{font-size:.875rem;font-weight:600;color:var(--hotel-text)}.input-group__required{color:#ef4444;margin-left:.25rem}.input-group__wrapper{position:relative;display:flex;align-items:center}.input-group__icon{position:absolute;left:.75rem;color:var(--hotel-text-light);display:flex;align-items:center;pointer-events:none}.input-group__input{width:100%;padding:.625rem .875rem;font-size:.9375rem;border:1px solid var(--hotel-border);border-radius:.5rem;background:var(--hotel-card-background);color:var(--hotel-text);transition:all .2s;font-family:inherit}.input-group__input--with-icon{padding-left:2.5rem}.input-group__input:focus{outline:none;border-color:var(--hotel-primary);box-shadow:0 0 0 2px #3b82f626}.input-group__input::placeholder{color:var(--hotel-text-light)}.input-group__input:disabled{background:var(--hotel-surface-light);color:var(--hotel-text-light);cursor:not-allowed}.input-group__input--error{border-color:#ef4444}.input-group__input--error:focus{box-shadow:0 0 0 2px #ef444426}.input-group__error{font-size:.8125rem;color:#ef4444}.habitacion-form{display:flex;flex-direction:column;gap:1.5rem}.form-section__title{font-size:1rem;font-weight:600;color:var(--hotel-text);margin:0;padding-bottom:.5rem;border-bottom:2px solid var(--hotel-border)}.form-col{display:flex;flex-direction:column}.form-textarea{width:100%;padding:.75rem;border:1px solid var(--hotel-border-dark);border-radius:.375rem;font-family:inherit;font-size:.9375rem;color:var(--hotel-text);background:var(--hotel-card-background);resize:vertical;transition:border-color .2s,box-shadow .2s}.form-textarea:disabled{background-color:var(--hotel-surface-light);cursor:not-allowed;opacity:.6}.form-textarea::placeholder{color:var(--hotel-text-light)}.comodidades-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.comodidad-checkbox{display:flex;align-items:center;gap:.5rem;padding:.625rem .75rem;background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:.375rem;cursor:pointer;transition:all .2s}.comodidad-checkbox:hover{background:var(--hotel-card-background);border-color:var(--hotel-border-dark)}.comodidad-checkbox input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:#1e40af}.comodidad-checkbox input[type=checkbox]:disabled{cursor:not-allowed}.comodidad-label{font-size:.875rem;color:var(--hotel-text);-webkit-user-select:none;user-select:none}.comodidad-checkbox:has(input:checked){background:#f5f3ff;border-color:#1e40af}.comodidad-checkbox:has(input:checked) .comodidad-label{color:#6d28d9;font-weight:500}.error-message{padding:.75rem 1rem;background:#fef2f2;border-left:3px solid #ef4444;border-radius:.375rem;color:#991b1b;font-size:.875rem;line-height:1.5}.error-message--general{margin-bottom:.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--hotel-border);margin-top:.5rem}@media (max-width: 768px){.form-row,.comodidades-grid{grid-template-columns:1fr}.modal-footer{flex-direction:column-reverse}.modal-footer button{width:100%}}.habitacion-detalle{display:flex;flex-direction:column;gap:1.5rem}.habitacion-detalle__header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-radius:.5rem;border:1px solid #ddd6fe}.habitacion-detalle__numero{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:var(--hotel-text)}.habitacion-detalle__numero svg{color:#1e40af}.habitacion-detalle__section{display:flex;flex-direction:column;gap:1rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--hotel-text);margin:0;padding-bottom:.5rem;border-bottom:2px solid var(--hotel-border)}.info-item{display:flex;flex-direction:column;gap:.375rem;padding:.875rem;background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:.375rem}.info-item__label{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:500;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em}.info-item__label svg{color:#1e40af}.info-item__value{font-size:1rem;font-weight:600;color:var(--hotel-text)}.info-item__value--price{font-size:1.125rem;color:#1e40af}.info-item__value--small{font-size:.875rem}.descripcion-text{padding:1rem;background:var(--hotel-surface-light);border-radius:.375rem;border:1px solid var(--hotel-border);color:var(--hotel-text);line-height:1.6;margin:0}.comodidades-list{display:flex;flex-wrap:wrap;gap:.5rem}.comodidad-tag{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:#f5f3ff;border:1px solid #ddd6fe;border-radius:9999px;font-size:.875rem;font-weight:500;color:#6d28d9}.comodidad-tag svg{color:#1e40af}.notas-mantenimiento{margin-top:.75rem;padding:1rem;background:#fef3c7;border-left:3px solid #f59e0b;border-radius:.375rem}.notas-mantenimiento strong{display:block;color:#92400e;font-size:.875rem;margin-bottom:.5rem}.notas-mantenimiento p{color:#78350f;font-size:.9375rem;line-height:1.6;margin:0}.habitacion-imagen{width:100%;max-height:400px;overflow:hidden;border-radius:.5rem;border:1px solid var(--hotel-border)}.habitacion-imagen img{width:100%;height:100%;object-fit:cover}.habitacion-detalle__actions{padding-top:.5rem;border-top:1px solid var(--hotel-border)}.actions-row{display:flex;flex-wrap:wrap;gap:.75rem}.actions-row button{flex:1;min-width:150px}.camas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.cama-card{border-radius:.5rem;padding:.75rem;border:2px solid var(--hotel-border);transition:border-color .2s}.cama-card--ocupada{background:#fef2f2;border-color:#fca5a5}.cama-card--libre{background:#f0fdf4;border-color:#86efac}.cama-card__header{display:flex;align-items:center;gap:.4rem;margin-bottom:.5rem;padding-bottom:.4rem;border-bottom:1px solid var(--hotel-border);font-weight:600;font-size:.8125rem;color:var(--hotel-text)}.cama-card--ocupada .cama-card__header svg{color:#ef4444}.cama-card--libre .cama-card__header svg{color:#22c55e}.cama-card__numero{flex:1}.cama-card__titular{background:#3b82f6;color:#fff;padding:.1rem .4rem;border-radius:4px;font-size:.65rem;font-weight:700}.cama-card__body{display:flex;flex-direction:column;gap:.25rem}.cama-card__nombre{font-size:.875rem;font-weight:600;color:var(--hotel-text)}.cama-card__grado{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#7c3aed}.cama-card__doc{font-size:.7rem;color:var(--hotel-text-secondary);font-family:monospace}.cama-card__precio{font-size:.8rem;font-weight:600;color:#1e40af}.cama-card__body--libre{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.5rem 0}.cama-card__libre-text{font-size:.8125rem;color:#16a34a;font-weight:600}.btn-asignar-cama{display:inline-flex;align-items:center;gap:.3rem;margin-left:auto;padding:.25rem .6rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-asignar-cama:hover{background:#2563eb}.btn-asignar-cama-mini{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .6rem;background:transparent;color:#16a34a;border:1px solid #16a34a;border-radius:6px;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .15s}.btn-asignar-cama-mini:hover{background:#16a34a;color:#fff}.btn-remover-ocupante{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;background:transparent;color:#ef4444;border:1px solid #ef4444;border-radius:4px;font-size:.7rem;font-weight:600;cursor:pointer;margin-top:.25rem;align-self:flex-start;transition:all .15s}.btn-remover-ocupante:hover{background:#ef4444;color:#fff}.btn-remover-ocupante:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .cama-card--ocupada{background:#ef44441a;border-color:#ef44444d}[data-theme=dark] .cama-card--libre{background:#22c55e1a;border-color:#22c55e4d}@media (max-width: 768px){.habitacion-detalle__header{flex-direction:column;align-items:flex-start;gap:.75rem}.habitacion-detalle__numero{font-size:1.25rem}.info-grid{grid-template-columns:1fr}.actions-row{flex-direction:column}.actions-row button{width:100%;min-width:unset}.modal-footer{flex-direction:column-reverse}.modal-footer button{width:100%}}.habitaciones-container{max-width:1400px;margin:0 auto;padding:.75rem}.btn-nueva-habitacion{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #1e40af4d;white-space:nowrap}.btn-nueva-habitacion svg{transition:transform .2s ease}.btn-nueva-habitacion:hover{background:linear-gradient(135deg,#1e3a8a,#2563eb);transform:translateY(-2px);box-shadow:0 6px 20px #1e40af66}.btn-nueva-habitacion:hover svg{transform:rotate(90deg)}.btn-nueva-habitacion:active{transform:translateY(0);box-shadow:0 2px 6px #1e40af4d}.page-subtitle{font-size:.8125rem;color:var(--hotel-text-secondary);font-weight:500}.filters-section{background:var(--hotel-card-background);border-radius:.5rem;padding:.75rem;margin-bottom:.75rem;box-shadow:var(--shadow-sm);display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;align-items:end;border:1px solid var(--hotel-border)}.filter-actions{display:flex;align-self:end;gap:.5rem}.habitaciones-stats{margin-bottom:.75rem;padding:0 .25rem}.habitaciones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:.75rem}.habitacion-card{background:var(--hotel-card-background);border-radius:.5rem;padding:.875rem;box-shadow:var(--shadow-sm);transition:all .2s;border:2px solid transparent}.habitacion-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--hotel-primary)}.habitacion-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.625rem;padding-bottom:.625rem;border-bottom:1px solid var(--hotel-border)}.habitacion-numero{font-size:.9375rem;font-weight:700;color:var(--hotel-text);margin-bottom:.125rem}.habitacion-tipo{font-size:.75rem;color:var(--hotel-text-secondary);text-transform:capitalize}.habitacion-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.625rem}.info-item{display:flex;justify-content:space-between;align-items:center}.info-label{font-size:.75rem;color:var(--hotel-text-secondary);font-weight:500}.info-value{font-size:.75rem;color:var(--hotel-text);font-weight:600}.info-value--price{color:var(--hotel-primary);font-size:.875rem;font-weight:700}.habitacion-descripcion{font-size:.75rem;color:var(--hotel-text-secondary);line-height:1.5;margin-bottom:.625rem;padding:.5rem;background:var(--hotel-surface-light);border-radius:.375rem;border-left:2px solid var(--hotel-primary)}.habitacion-actions{display:flex;gap:.75rem;margin-top:auto}.camas-resumen{display:flex;align-items:center;gap:.75rem;background:var(--hotel-card-background);border-radius:.5rem;padding:.625rem 1rem;margin-bottom:.75rem;border:1px solid var(--hotel-border);box-shadow:var(--shadow-sm)}.camas-resumen__item{display:flex;align-items:center;gap:.4rem;font-size:.8125rem;color:var(--hotel-text);white-space:nowrap}.camas-resumen__item svg{color:var(--hotel-primary)}.camas-resumen__bar{flex:1;height:8px;background:var(--hotel-border);border-radius:4px;overflow:hidden;min-width:100px}.camas-resumen__fill{height:100%;background:linear-gradient(90deg,#3b82f6,#1d4ed8);border-radius:4px;transition:width .5s ease}.camas-resumen__pct{font-size:.8125rem;font-weight:700;color:var(--hotel-primary);white-space:nowrap}.filter-checkbox{display:flex;align-items:center;gap:.4rem;font-size:.8125rem;color:var(--hotel-text);cursor:pointer;white-space:nowrap}.filter-checkbox input[type=checkbox]{accent-color:var(--hotel-primary)}.camas-bar{display:flex;gap:3px;margin-bottom:.5rem}.cama-slot{flex:1;height:6px;border-radius:3px;transition:background .2s}.cama-slot--ocupada{background:#ef4444}.cama-slot--libre{background:#22c55e}.habitacion-card--parcial{border-color:#f59e0b!important}.ocupantes-mini{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.625rem;padding:.5rem;background:var(--hotel-surface-light, #f8fafc);border-radius:.375rem;border-left:2px solid var(--hotel-primary)}.ocupante-mini-item{display:flex;align-items:center;gap:.35rem;font-size:.7rem;color:var(--hotel-text)}.ocupante-mini-item svg{color:var(--hotel-text-secondary);flex-shrink:0}.ocupante-mini-cama{font-weight:700;color:var(--hotel-primary);min-width:20px}.ocupante-mini-nombre{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ocupante-mini-grado{font-size:.65rem;color:var(--hotel-text-secondary);background:var(--hotel-border);padding:.1rem .3rem;border-radius:3px;white-space:nowrap}.ocupantes-mini-more{font-size:.7rem;color:var(--hotel-text-secondary);font-style:italic;padding-left:1.25rem}[data-theme=dark] .habitacion-card{border:1px solid var(--hotel-border)}[data-theme=dark] .habitacion-descripcion{background:var(--hotel-surface-light);border-left-color:var(--hotel-primary-light)}[data-theme=dark] .info-item{background:var(--hotel-surface-light);border-radius:6px;padding:.5rem .625rem}[data-theme=dark] .info-label{color:var(--hotel-text-secondary);font-size:.6875rem;text-transform:uppercase;letter-spacing:.03em}[data-theme=dark] .info-value{color:var(--hotel-text);font-weight:700}[data-theme=dark] .habitacion-actions .btn{border:1px solid var(--hotel-border)}@media (max-width: 768px){.habitaciones-container{padding:1rem}.page-header{flex-direction:column;align-items:stretch}.page-title{font-size:1.5rem}.filters-section{grid-template-columns:1fr}.habitaciones-grid{grid-template-columns:1fr;gap:1rem}.habitacion-actions{flex-direction:column}}@media (max-width: 480px){.habitacion-card{padding:1rem}.empty-state{padding:2rem 1rem}.empty-icon{font-size:3rem}}.reserva-modal-nuevo{display:flex;flex-direction:column;gap:1.5rem;padding:1rem 0}.reserva-modal-empty{text-align:center;padding:3rem 1rem;color:var(--hotel-text-secondary)}.bloque-reserva,.bloque-titular,.bloque-procedencia,.bloque-tarifas,.bloque-notas{background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:8px;padding:1.5rem}.bloque-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--hotel-text);margin-bottom:1rem}.habitaciones-seleccionadas{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.habitacion-item{display:grid;grid-template-columns:180px 1fr auto;gap:1rem;align-items:center;padding:.75rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:6px}.hab-info{display:flex;flex-direction:column;gap:.25rem}.hab-numero{font-weight:600;color:var(--hotel-text);font-size:.9375rem}.hab-tipo{font-size:.75rem;color:var(--hotel-text-secondary);text-transform:capitalize}.hab-fechas{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;color:var(--hotel-text)}.hab-noches{font-size:.75rem;color:#1e40af;font-weight:500}.hab-precio{display:flex;align-items:center;gap:.5rem}.hab-precio input{width:120px;padding:.5rem;border:1px solid var(--hotel-border);border-radius:4px;font-size:.875rem;text-align:right;background:var(--hotel-card-background);color:var(--hotel-text)}.hab-precio input:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.precio-label{font-size:.75rem;color:var(--hotel-text-secondary);white-space:nowrap}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1rem}.cliente-toggle{display:flex;gap:.75rem;margin-bottom:1.5rem}.busqueda-cliente{position:relative}.busqueda-input-wrapper{position:relative;margin-bottom:1rem}.busqueda-input{width:100%;padding:.75rem 2.5rem;border:2px solid var(--hotel-border);border-radius:8px;font-size:.9375rem;transition:all .2s;background:var(--hotel-card-background);color:var(--hotel-text)}.busqueda-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--hotel-text-light);pointer-events:none}.busqueda-clear{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--hotel-text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.busqueda-clear:hover{background:var(--hotel-surface-light);color:var(--hotel-text)}.sugerencias-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--hotel-card-background);border:2px solid var(--hotel-primary);border-radius:8px;box-shadow:0 10px 25px #00000026;max-height:300px;overflow-y:auto;z-index:50;margin-top:.25rem}.sugerencia-item{padding:.75rem 1rem;cursor:pointer;transition:background .2s;border-bottom:1px solid var(--hotel-border)}.sugerencia-item:last-child{border-bottom:none}.sugerencia-item:hover{background:#f5f3ff}.sugerencia-nombre{font-weight:600;color:var(--hotel-text);margin-bottom:.25rem}.sugerencia-detalles{display:flex;gap:1rem;font-size:.75rem;color:var(--hotel-text-secondary)}.sugerencia-detalles span{white-space:nowrap}.cliente-seleccionado{padding:1rem;background:var(--hotel-card-background);border:2px solid var(--hotel-primary);border-radius:8px;font-size:.875rem}.cliente-sel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.cliente-sel-header strong{color:var(--hotel-text);font-size:1rem}.cliente-sel-doc{color:var(--hotel-text-secondary);font-size:.875rem}.cliente-seleccionado>div{color:var(--hotel-text-secondary);margin-bottom:.25rem}.cliente-seleccionado>div:last-child{margin-bottom:0}.form-nuevo-cliente{margin-top:1rem}.input-group{margin-bottom:1rem}.input-label{display:block;font-size:.875rem;font-weight:500;color:var(--hotel-text);margin-bottom:.5rem}.textarea{width:100%;padding:.75rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.875rem;font-family:inherit;resize:vertical;transition:border-color .2s;background:var(--hotel-card-background);color:var(--hotel-text)}.textarea:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.calculo-grid{display:flex;flex-direction:column;gap:1rem}.calculo-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--hotel-card-background);border-radius:6px}.calculo-label{font-size:.9375rem;color:var(--hotel-text-secondary);font-weight:500}.calculo-value{font-size:1.125rem;font-weight:600;color:var(--hotel-text)}.calculo-item.descuento .calculo-value{color:#ef4444}.calculo-item.impuesto .calculo-value{color:#f59e0b}.calculo-item.total{background:#ede9fe;border:2px solid #1e40af}.calculo-item.total .calculo-label{color:var(--hotel-text);font-weight:600;font-size:1rem}.calculo-item.total .calculo-value{color:var(--hotel-primary);font-size:1.5rem}.calculo-item.saldo{background:#fef3c7;border:1px solid #fbbf24}.calculo-item.saldo .calculo-value{color:#92400e}.descuento-row,.impuesto-row{display:flex;align-items:flex-end;gap:1rem}.descuento-row>*,.impuesto-row>*{flex:1}.separator{padding:0 .5rem .5rem;color:var(--hotel-text-light);font-weight:500;flex:0 0 auto}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding-top:1.5rem;border-top:1px solid var(--hotel-border);margin-top:1rem}@media (max-width: 768px){.habitacion-item{grid-template-columns:1fr;gap:.75rem}.hab-precio{justify-content:space-between}.hab-precio input{flex:1}.form-row{grid-template-columns:1fr}.descuento-row,.impuesto-row{flex-direction:column;align-items:stretch}.separator{text-align:center;padding:.5rem 0}.bloque-reserva,.bloque-titular,.bloque-procedencia,.bloque-tarifas,.bloque-notas{padding:1rem}.modal-footer{flex-direction:column-reverse}.modal-footer button{width:100%}}.reserva-modal{display:flex;flex-direction:column;gap:2rem;padding:1rem 0}.reserva-detalle{display:flex;flex-direction:column;gap:1.5rem}.reserva-detalle__header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#1e40af,#3b82f6,#60a5fa);border-radius:12px;color:#fff;gap:1rem}.reserva-detalle__codigo{display:flex;flex-direction:column;gap:.25rem}.codigo-label{font-size:.75rem;opacity:.9;text-transform:uppercase;letter-spacing:.05em;font-weight:500}.codigo-value{font-size:1.125rem;font-weight:700;letter-spacing:.02em}.reserva-detalle__badge{display:flex;align-items:center;gap:.25rem;padding:.375rem .625rem;border-radius:50px;font-weight:600;font-size:.75rem;background:var(--hotel-card-background);white-space:nowrap}.reserva-detalle__section{background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:8px;padding:1.25rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--hotel-text);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid var(--hotel-border)}.section-content{background:var(--hotel-card-background);border-radius:6px;padding:1rem}.info-grid--financial{grid-template-columns:repeat(2,1fr)}.info-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:var(--hotel-surface-light);border-radius:6px;border:1px solid var(--hotel-border)}.info-item--full{grid-column:1 / -1}.info-item--highlight{background:#fef3c7;border-color:#fbbf24}.info-label{font-size:.75rem;font-weight:500;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em}.info-value--highlight{font-size:1.125rem;font-weight:700;color:#1e40af}.info-value--large{font-size:1.25rem;font-weight:700}.info-value--notes{background:var(--hotel-card-background);padding:.75rem;border-radius:4px;border:1px solid var(--hotel-border);margin-top:.25rem;line-height:1.5;white-space:pre-wrap}.info-icon{color:#1e40af;flex-shrink:0}.reserva-detalle__header-right{display:flex;align-items:center;gap:.5rem}.reserva-detalle__edit-btn{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border:1.5px solid rgba(255,255,255,.6);border-radius:50px;background:#ffffff26;color:#fff;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.reserva-detalle__edit-btn:hover{background:#ffffff4d;border-color:#fff;transform:translateY(-1px)}.reserva-detalle__error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;color:#dc2626;font-size:.875rem;font-weight:500}.edit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.edit-grid--single{grid-template-columns:1fr}.edit-field{display:flex;flex-direction:column;gap:.375rem}.edit-field--full{grid-column:1 / -1}.edit-label{font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em}.edit-input,.edit-select{width:100%;padding:.625rem .75rem;border:1.5px solid var(--hotel-border-dark, #d1d5db);border-radius:6px;font-size:.875rem;font-family:inherit;background:var(--hotel-card-background);color:var(--hotel-text);transition:all .2s}.edit-input:focus,.edit-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.edit-textarea{width:100%;padding:.625rem .75rem;border:1.5px solid var(--hotel-border-dark, #d1d5db);border-radius:6px;font-size:.875rem;font-family:inherit;background:var(--hotel-card-background);color:var(--hotel-text);resize:vertical;transition:all .2s}.edit-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.edit-computed{padding:.625rem .75rem;background:var(--hotel-surface-light);border:1.5px solid var(--hotel-border);border-radius:6px;font-size:.875rem;font-weight:600;color:#1e40af}.edit-computed--large{font-size:1.125rem;font-weight:700}.reserva-detalle__actions{display:flex;justify-content:flex-end;gap:.5rem;padding-top:.625rem;border-top:1px solid var(--hotel-border);margin-top:.375rem}@media (max-width: 768px){.reserva-detalle__header{flex-direction:column;align-items:flex-start;padding:1.25rem}.codigo-value{font-size:1.5rem}.reserva-detalle__badge{align-self:flex-start;padding:.625rem 1rem;font-size:.875rem}.info-grid,.info-grid--financial{grid-template-columns:1fr}.reserva-detalle__section{padding:1rem}.section-content{padding:.75rem}.info-item{padding:.625rem}.reserva-detalle__actions{flex-direction:column-reverse;gap:.75rem}.reserva-detalle__actions button{width:100%}.reserva-detalle__header-right{flex-direction:row-reverse;width:100%;justify-content:space-between}.edit-grid{grid-template-columns:1fr}}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.reserva-detalle__section{animation:slideIn .3s ease-out;animation-fill-mode:both}.reserva-detalle__section:nth-child(1){animation-delay:.05s}.reserva-detalle__section:nth-child(2){animation-delay:.1s}.reserva-detalle__section:nth-child(3){animation-delay:.15s}.reserva-detalle__section:nth-child(4){animation-delay:.2s}.reserva-detalle__section:nth-child(5){animation-delay:.25s}.reserva-detalle__section:nth-child(6){animation-delay:.3s}.timeline-container{display:flex;flex-direction:column;gap:0;flex:1;min-height:0}.timeline-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem .25rem;background:transparent;border:none;border-bottom:1px solid var(--hotel-border);border-radius:0;flex-wrap:wrap}.timeline-toolbar__left,.timeline-toolbar__right{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.timeline-toolbar__date{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--hotel-text-secondary)}.timeline-date-input{padding:.3rem .5rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.8125rem;background:var(--hotel-card-background);color:var(--hotel-text);cursor:pointer}.timeline-date-input:focus{outline:none;border-color:var(--hotel-primary)}.timeline-toolbar__nav{display:flex;align-items:center;gap:2px}.timeline-nav-btn{display:flex;align-items:center;justify-content:center;padding:.3rem .5rem;border:1px solid var(--hotel-border);background:var(--hotel-card-background);color:var(--hotel-text-secondary);border-radius:6px;cursor:pointer;font-size:.75rem;font-weight:500;transition:all .15s}.timeline-nav-btn:hover{background:var(--hotel-surface-light);color:var(--hotel-primary);border-color:var(--hotel-primary)}.timeline-nav-btn--today{font-weight:600;padding:.3rem .75rem}.timeline-filter-select{padding:.3rem .5rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.8125rem;background:var(--hotel-card-background);color:var(--hotel-text);cursor:pointer}.timeline-filter-select:focus{outline:none;border-color:var(--hotel-primary)}.timeline-toolbar__density{display:flex;align-items:center;gap:2px;border:1px solid var(--hotel-border);border-radius:6px;overflow:hidden}.timeline-density-btn{display:flex;align-items:center;justify-content:center;padding:.35rem .5rem;border:none;background:var(--hotel-card-background);color:var(--hotel-text-light);cursor:pointer;transition:all .15s}.timeline-density-btn:not(:last-child){border-right:1px solid var(--hotel-border)}.timeline-density-btn:hover{background:var(--hotel-surface-light);color:var(--hotel-primary)}.timeline-density-btn.active{background:var(--hotel-primary);color:#fff}.timeline-toolbar__zoom{display:flex;align-items:center;gap:.375rem;color:var(--hotel-text-light)}.timeline-zoom-slider{width:80px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--hotel-border);border-radius:2px;outline:none;cursor:pointer}.timeline-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--hotel-primary);cursor:pointer;border:2px solid white;box-shadow:0 1px 3px #0003}.timeline-zoom-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--hotel-primary);cursor:pointer;border:2px solid white;box-shadow:0 1px 3px #0003}.timeline-toolbar__search{display:flex;align-items:center;gap:.375rem;padding:.3rem .625rem;border:1px solid var(--hotel-border);border-radius:6px;background:var(--hotel-card-background);color:var(--hotel-text-light);transition:border-color .15s}.timeline-toolbar__search:focus-within{border-color:var(--hotel-primary)}.timeline-search-input{border:none;outline:none;font-size:.8125rem;background:transparent;color:var(--hotel-text);width:160px}.timeline-search-input::placeholder{color:var(--hotel-text-light)}.timeline-toolbar__nueva-btn{padding:.4rem .875rem;font-size:.8125rem;font-weight:600;color:#fff;background:var(--hotel-primary);border:none;border-radius:6px;cursor:pointer;white-space:nowrap;transition:background .2s}.timeline-toolbar__nueva-btn:hover{background:var(--hotel-primary-hover)}.timeline-scroll{overflow:auto;flex:1;min-height:0;border:none;border-radius:0;background:var(--hotel-card-background);position:relative}.timeline-scroll::-webkit-scrollbar{width:8px;height:8px}.timeline-scroll::-webkit-scrollbar-track{background:transparent}.timeline-scroll::-webkit-scrollbar-thumb{background:var(--hotel-border-dark);border-radius:4px}.timeline-scroll::-webkit-scrollbar-thumb:hover{background:var(--hotel-text-light)}.timeline-scroll::-webkit-scrollbar-corner{background:transparent}.timeline-grid{position:relative;min-width:max-content}.timeline-header-row{display:flex;position:sticky;top:0;z-index:5;background:var(--hotel-card-background);border-bottom:2px solid var(--hotel-border)}.timeline-corner{position:sticky;left:0;z-index:6;background:var(--hotel-card-background);border-right:1px solid var(--hotel-border);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8125rem;color:var(--hotel-text-secondary);flex-shrink:0}.timeline-days-header{display:flex;flex-shrink:0}.timeline-day-col{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;border-right:1px solid var(--hotel-border);flex-shrink:0;-webkit-user-select:none;user-select:none}.timeline-day-name{font-size:.6875rem;font-weight:500;color:var(--hotel-text-light);text-transform:uppercase;letter-spacing:.3px}.timeline-day-number{font-size:.875rem;font-weight:600;color:var(--hotel-text);line-height:1}.timeline-day-month{font-size:.625rem;color:var(--hotel-text-light)}.timeline-day-col--today{background:var(--hotel-primary)}.timeline-day-col--today .timeline-day-name,.timeline-day-col--today .timeline-day-number,.timeline-day-col--today .timeline-day-month{color:#fff}.timeline-day-col--weekend{background:#00000005}.timeline-day-col--today.timeline-day-col--weekend{background:var(--hotel-primary)}.timeline-body{position:relative}.timeline-row{display:flex;border-bottom:1px solid var(--hotel-border)}.timeline-row:last-child{border-bottom:none}.timeline-room-label{position:sticky;left:0;z-index:3;background:var(--hotel-card-background);border-right:1px solid var(--hotel-border);display:flex;flex-direction:column;justify-content:center;padding:0 .75rem;flex-shrink:0;gap:2px}.timeline-room-number{font-weight:700;font-size:.875rem;color:var(--hotel-text);line-height:1.1}.timeline-room-type{font-size:.6875rem;color:var(--hotel-text-light);text-transform:uppercase;letter-spacing:.3px;line-height:1.1}.timeline-room-capacity{font-size:.625rem;color:var(--hotel-primary);font-weight:500;line-height:1.1}.timeline-room-track{position:relative;display:flex;flex-shrink:0}.timeline-cell{border-right:1px solid rgba(0,0,0,.04);flex-shrink:0;cursor:crosshair;transition:background-color .1s}.timeline-cell:hover{background:#3b82f60f}.timeline-cell--today{background:#1e40af0a}.timeline-cell--weekend{background:#00000004}.timeline-cell--today.timeline-cell--weekend{background:#1e40af0a}.timeline-cell--selected{background:#3b82f633!important;outline:1px solid rgba(59,130,246,.4);outline-offset:-1px}.reserva-block{border-radius:4px;overflow:hidden;display:flex;align-items:center;padding:0 .5rem;font-size:.75rem;transition:box-shadow .15s,opacity .15s;-webkit-user-select:none;user-select:none;box-shadow:0 1px 2px #0000001a}.reserva-block:hover{box-shadow:0 2px 6px #00000026;z-index:5!important}.reserva-block--dragging{cursor:grabbing!important}.reserva-block--highlight{box-shadow:0 0 0 2px var(--hotel-primary),0 2px 8px #1e40af4d!important;z-index:5!important}.reserva-block__content{display:flex;flex-direction:column;gap:1px;overflow:hidden;min-width:0;flex:1}.reserva-block__name{font-weight:600;font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.reserva-block__detail{font-size:.625rem;opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.reserva-block__resize-handle{position:absolute;right:0;top:0;bottom:0;width:8px;cursor:col-resize;background:transparent;transition:background .15s}.reserva-block:hover .reserva-block__resize-handle{background:#0000001a}.reserva-block__walkin-badge{position:absolute;top:2px;right:4px;font-size:.5625rem;font-weight:800;background:#ffffff4d;padding:0 3px;border-radius:3px;line-height:1.3}.timeline-confirm-detail{text-align:left}.timeline-confirm-detail__reserva{margin-bottom:.75rem;font-size:.9375rem;color:var(--hotel-text)}.timeline-confirm-detail__cambios{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.375rem}.timeline-confirm-detail__cambios li{padding:.5rem .75rem;background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:6px;font-size:.8125rem;color:var(--hotel-text);font-weight:500}.timeline-ghost{border-radius:4px;z-index:20;transition:none}.timeline-ghost--valid{background:#3b82f640;border:2px dashed var(--hotel-primary)}.timeline-ghost--invalid{background:#ef444433;border:2px dashed #ef4444}.timeline-today-line{position:absolute;top:0;bottom:0;width:2px;background:var(--hotel-primary);z-index:4;pointer-events:none;opacity:.6}.timeline-legend{display:flex;align-items:center;gap:1rem;padding:.375rem .5rem;flex-wrap:wrap;font-size:.6875rem;border-top:1px solid var(--hotel-border);flex-shrink:0;color:var(--hotel-text-secondary)}.timeline-legend__item{display:flex;align-items:center;gap:.375rem}.timeline-legend__color{width:14px;height:14px;border-radius:3px;flex-shrink:0}.timeline-legend__color--pendiente{background:#fef3c7;border-left:3px solid #f59e0b}.timeline-legend__color--confirmada{background:#2563eb;border-left:3px solid #3b82f6}.timeline-legend__color--en_curso{background:#059669;border-left:3px solid #10b981}.timeline-legend__color--walkin{background:#7c3aed;border-left:3px solid #8b5cf6}.timeline-legend__color--finalizada{background:#e5e7eb;border-left:3px solid #9ca3af}.timeline-legend__color--selected{background:#3b82f633;border:1px solid rgba(59,130,246,.4)}.timeline-legend__tip{margin-left:auto;font-size:.6875rem;color:var(--hotel-text-light)}@media (max-width: 1024px){.timeline-toolbar{gap:.5rem;padding:.5rem}.timeline-toolbar__left,.timeline-toolbar__right{gap:.5rem}.timeline-search-input{width:120px}}@media (max-width: 768px){.timeline-toolbar{flex-direction:column;align-items:stretch}.timeline-toolbar__left,.timeline-toolbar__right{justify-content:center}.timeline-toolbar__zoom,.timeline-toolbar__density{display:none}.timeline-search-input{width:100%;min-width:100px}.timeline-legend{flex-wrap:wrap;gap:.5rem}.timeline-legend__tip{margin-left:0;width:100%}}[data-theme=dark] .timeline-toolbar{background:var(--hotel-card-background);border-color:var(--hotel-border)}[data-theme=dark] .timeline-date-input,[data-theme=dark] .timeline-filter-select{background:var(--hotel-surface-light);border-color:var(--hotel-border);color:var(--hotel-text)}[data-theme=dark] .timeline-nav-btn{background:var(--hotel-surface-light);border-color:var(--hotel-border);color:var(--hotel-text-secondary)}[data-theme=dark] .timeline-nav-btn:hover{background:var(--hotel-primary);color:#fff}[data-theme=dark] .timeline-density-btn{background:var(--hotel-surface-light);color:var(--hotel-text-light)}[data-theme=dark] .timeline-density-btn.active{background:var(--hotel-primary);color:#fff}[data-theme=dark] .timeline-toolbar__density{border-color:var(--hotel-border)}[data-theme=dark] .timeline-density-btn:not(:last-child){border-right-color:var(--hotel-border)}[data-theme=dark] .timeline-toolbar__search{background:var(--hotel-surface-light);border-color:var(--hotel-border)}[data-theme=dark] .timeline-search-input{color:var(--hotel-text)}[data-theme=dark] .timeline-zoom-slider{background:var(--hotel-border)}[data-theme=dark] .timeline-scroll{background:var(--hotel-card-background);border-color:var(--hotel-border)}[data-theme=dark] .timeline-header-row{background:var(--hotel-card-background);border-bottom-color:var(--hotel-border)}[data-theme=dark] .timeline-corner{background:var(--hotel-card-background);border-right-color:var(--hotel-border)}[data-theme=dark] .timeline-day-col{border-right-color:var(--hotel-border)}[data-theme=dark] .timeline-day-col--weekend{background:#ffffff05}[data-theme=dark] .timeline-day-col--today.timeline-day-col--weekend{background:var(--hotel-primary)}[data-theme=dark] .timeline-row{border-bottom-color:var(--hotel-border)}[data-theme=dark] .timeline-room-label{background:var(--hotel-card-background);border-right-color:var(--hotel-border)}[data-theme=dark] .timeline-cell{border-right-color:#ffffff08}[data-theme=dark] .timeline-cell:hover{background:#3b82f614}[data-theme=dark] .timeline-cell--today{background:#3b82f60f}[data-theme=dark] .timeline-cell--weekend{background:#ffffff04}[data-theme=dark] .timeline-cell--selected{background:#3b82f640!important}[data-theme=dark] .reserva-block{box-shadow:0 1px 3px #0000004d}[data-theme=dark] .reserva-block:hover{box-shadow:0 2px 8px #0006}[data-theme=dark] .reserva-block--highlight{box-shadow:0 0 0 2px var(--hotel-primary),0 2px 8px #3b82f666!important}[data-theme=dark] .timeline-scroll::-webkit-scrollbar-thumb{background:var(--hotel-border-dark)}[data-theme=dark] .timeline-scroll::-webkit-scrollbar-thumb:hover{background:var(--hotel-text-light)}.input-modal{display:flex;flex-direction:column;gap:1.25rem}.input-modal__message{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f3f4f6;border-radius:.5rem;font-size:.9375rem;color:#374151;line-height:1.5}.input-modal__field{display:flex;flex-direction:column;gap:.5rem}.input-modal__textarea{width:100%;padding:.75rem;font-size:.9375rem;color:#1f2937;background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;resize:vertical;min-height:100px;font-family:inherit;transition:all .2s}.input-modal__textarea:hover{border-color:#9ca3af}.input-modal__textarea:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.input-modal__textarea--error{border-color:#ef4444}.input-modal__textarea--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.input-modal__textarea:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.input-modal__error{font-size:.875rem;color:#ef4444;margin-top:.25rem}.input-modal__actions{display:flex;gap:.75rem;margin-top:.5rem}@media (max-width: 768px){.input-modal__actions{flex-direction:column-reverse}}.reservas-container{width:100%;padding:0;display:flex;flex-direction:column;height:calc(100vh - 1rem)}.reservas-tabs{display:flex;align-items:center;gap:0;border-bottom:2px solid var(--hotel-border);margin-bottom:.75rem}.reservas-tab{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.8125rem;font-weight:600;color:var(--hotel-text-secondary);background:transparent;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;cursor:pointer;text-transform:uppercase;letter-spacing:.04em;transition:color .2s,border-color .2s;white-space:nowrap}.reservas-tab svg{flex-shrink:0}.reservas-tab:hover:not(.reservas-tab--active){color:var(--hotel-text)}.reservas-tab--active{color:var(--hotel-primary);border-bottom-color:var(--hotel-primary)}@media (max-width: 480px){.reservas-tab{padding:.625rem .75rem;font-size:.75rem;gap:.375rem}}.filters-section{background:var(--hotel-card-background);border-radius:.5rem;padding:.75rem;margin-bottom:.75rem;box-shadow:var(--shadow-sm);display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:.75rem;align-items:end;border:1px solid var(--hotel-border)}.filter-actions{display:flex;gap:.5rem;align-self:end}.filter-actions .button{border:1px solid transparent}.input-group{display:flex;flex-direction:column;gap:.375rem;min-width:200px;flex:1}.input-label{font-size:.875rem;font-weight:500;color:var(--hotel-text)}.date-input{padding:.625rem .875rem;font-size:.875rem;color:var(--hotel-text);background-color:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:.5rem;transition:all .2s;font-family:inherit}.date-input:hover{border-color:var(--hotel-border-dark)}.date-input:focus{outline:none;border-color:var(--hotel-primary);box-shadow:0 0 0 3px #3b82f626}.reservas-filtros{display:flex;gap:1rem;margin-bottom:.75rem}.reservas-filtros .filtro-busqueda{display:flex;align-items:center;gap:.5rem;flex:1;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:.5rem;padding:.625rem .75rem;transition:border-color .2s}.reservas-filtros .filtro-busqueda:focus-within{border-color:var(--hotel-primary);box-shadow:0 0 0 3px #3b82f626}.reservas-filtros .filtro-busqueda svg{color:var(--hotel-text-secondary);flex-shrink:0}.reservas-filtros .filtro-busqueda input{border:none;outline:none;flex:1;background:transparent;color:var(--hotel-text);font-size:.8125rem;font-family:inherit}.reservas-filtros .filtro-busqueda input::placeholder{color:var(--hotel-text-secondary);opacity:.7}.reservas-filtros .filtro-estado{display:flex;align-items:center;gap:.5rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:.5rem;padding:.625rem .75rem;transition:border-color .2s}.reservas-filtros .filtro-estado:focus-within{border-color:var(--hotel-primary);box-shadow:0 0 0 3px #3b82f626}.reservas-filtros .filtro-estado svg{color:var(--hotel-text-secondary);flex-shrink:0}.reservas-filtros .filtro-estado select{border:none;outline:none;background:transparent;color:var(--hotel-text);cursor:pointer;font-size:.8125rem;font-family:inherit}@media (max-width: 768px){.reservas-filtros{flex-direction:column}}.reservas-stats{margin-bottom:.75rem;padding:0 .25rem}.stats-text{font-size:.75rem;color:var(--hotel-text-secondary);font-weight:500}.reservas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.reserva-card{background:var(--hotel-card-background);border-radius:.375rem;padding:.625rem;box-shadow:var(--shadow-sm);transition:all .2s;border:1px solid var(--hotel-border);display:flex;flex-direction:column}.reserva-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:var(--hotel-primary)}.reserva-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.375rem;border-bottom:1px solid var(--hotel-border)}.reserva-codigo{font-size:.75rem;font-weight:700;color:var(--hotel-primary);line-height:1}.reserva-habitacion{font-size:.625rem;color:var(--hotel-text-secondary);font-weight:500;line-height:1;margin-top:.125rem}.reserva-info{display:grid;grid-template-columns:repeat(3,1fr);gap:.375rem;margin-bottom:.5rem}.info-item{display:flex;flex-direction:column;gap:.125rem;padding:.375rem;background:var(--hotel-surface-light);border-radius:.25rem;border:1px solid var(--hotel-border)}.info-label{font-size:.625rem;color:var(--hotel-text-secondary);font-weight:500;line-height:1;text-transform:uppercase;letter-spacing:.025em}.info-value{font-size:.6875rem;color:var(--hotel-text);font-weight:700;line-height:1.2}.info-value--price{color:var(--hotel-primary);font-size:.75rem;font-weight:700}.info-value--pending{color:#f59e0b;font-weight:700;font-size:.75rem}.reserva-canal{display:none}.canal-label{font-weight:600;color:var(--hotel-text-secondary)}.reserva-actions{display:flex;gap:.25rem;margin-top:auto}.reservas-tabla-container{background:var(--hotel-card-background);border-radius:10px;border:1px solid var(--hotel-border);overflow:hidden;box-shadow:var(--shadow-sm)}.reservas-tabla{width:100%;border-collapse:collapse;font-size:.8125rem}.reservas-tabla thead{position:sticky;top:0;z-index:1}.reservas-tabla th{background:var(--hotel-surface-light);color:var(--hotel-text-secondary);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:.75rem .875rem;text-align:left;border-bottom:2px solid var(--hotel-border);white-space:nowrap}.reservas-tabla td{padding:.625rem .875rem;color:var(--hotel-text);border-bottom:1px solid var(--hotel-border);vertical-align:middle}.reservas-tabla__row{transition:background .15s ease}.reservas-tabla__row:hover{background:var(--hotel-surface-light)}.reservas-tabla__row:last-child td{border-bottom:none}.td-codigo,.td-total{font-weight:700;color:var(--hotel-primary)}.col-center{text-align:center}.tabla-acciones{display:flex;align-items:center;gap:.375rem;justify-content:center}.tabla-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:7px;cursor:pointer;transition:all .15s ease;background:transparent;flex-shrink:0}.tabla-btn:hover{transform:scale(1.1)}.tabla-btn--info{color:var(--hotel-primary-light);background:#3b82f61a}.tabla-btn--info:hover{background:#3b82f633}.tabla-btn--success{color:#10b981;background:#10b9811a}.tabla-btn--success:hover{background:#10b98133}.tabla-btn--danger{color:#ef4444;background:#ef44441a}.tabla-btn--danger:hover{background:#ef444433}.tabla-btn--primary{color:var(--hotel-primary);background:#1e40af1a}.tabla-btn--primary:hover{background:#1e40af33}@media (max-width: 768px){.reservas-tabla-container{overflow-x:auto}.col-noches{display:none}.reservas-tabla th,.reservas-tabla td{padding:.5rem .625rem;font-size:.75rem}}.empty-state{background:var(--hotel-card-background);border-radius:.75rem;padding:3rem 2rem;text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--hotel-border)}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}[data-theme=dark] .error-message{background:#ef44441a;color:#fca5a5}@media (max-width: 768px){.reservas-container{padding:1rem}.page-header{flex-direction:column;align-items:stretch}.page-title{font-size:1.5rem}.filters-section{grid-template-columns:1fr 1fr}.filter-actions{grid-column:1 / -1}.filter-actions button{flex:1}.reservas-grid{grid-template-columns:1fr;gap:1rem}.reserva-actions{flex-direction:column}.reserva-actions button{width:100%}}@media (max-width: 480px){.reserva-card{padding:1rem}.empty-state{padding:2rem 1rem}.empty-icon{font-size:3rem}}.cuenta-corriente{display:flex;flex-direction:column;gap:1rem;background:var(--hotel-card-background);border-radius:.5rem;border:1px solid var(--hotel-border)}.cuenta-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:.5rem .5rem 0 0;color:#fff}.cuenta-titulo{display:flex;align-items:center;gap:.5rem}.cuenta-titulo h3{margin:0;font-size:1.125rem;font-weight:600}.cuenta-codigo{font-size:.875rem;font-weight:600;padding:.375rem .75rem;background:#fff3;border-radius:.25rem}.cuenta-seccion{padding:0 1rem;margin:.5rem 0}.seccion-titulo{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:2px solid var(--hotel-border);color:var(--hotel-primary)}.seccion-titulo h4{margin:0;font-size:1rem;font-weight:600;color:var(--hotel-text)}.seccion-contenido{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.cuenta-item{display:flex;justify-content:space-between;align-items:start;padding:.75rem;background:var(--hotel-surface-light);border-radius:.375rem;transition:all .2s}.cuenta-item:hover{background:var(--hotel-background)}.item-descripcion{font-size:.875rem;color:var(--hotel-text-secondary);font-weight:500}.item-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.item-nombre{font-size:.875rem;font-weight:600;color:var(--hotel-text)}.item-detalle{font-size:.75rem;color:var(--hotel-text-secondary)}.item-fecha{color:var(--hotel-text-light);font-size:.6875rem}.item-valor{font-size:.875rem;font-weight:700;color:#1e40af;white-space:nowrap}.seccion-subtotal{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#ede9fe;border-radius:.375rem;font-size:.875rem;font-weight:600;color:#6b21a8}.subtotal-valor{font-size:1rem;color:#1e3a8a}.consumos-empty{padding:1.5rem;text-align:center;background:var(--hotel-surface-light);border:2px dashed var(--hotel-border-dark);border-radius:.375rem}.consumos-empty p{margin:0;font-size:.875rem;color:var(--hotel-text-secondary)}.cuenta-total{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:linear-gradient(135deg,#ede9fe,#dbeafe);border-radius:0 0 .5rem .5rem;border-top:2px solid #1e40af}.total-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.total-row svg{color:#1e40af}.total-label{flex:1;font-size:1.125rem;font-weight:700;color:var(--hotel-text)}.total-valor{font-size:1.5rem;font-weight:800;color:#1e40af}.total-detalle{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--hotel-card-background);border-radius:.375rem;font-size:.875rem;font-weight:600}.total-detalle span:first-child{color:var(--hotel-text-secondary)}.total-detalle span:last-child{color:var(--hotel-text);font-weight:700}.total-detalle.saldo-pendiente{background:#fef3c7;border:1px solid #fbbf24}.total-detalle.saldo-pendiente span:first-child{color:#92400e}.total-detalle.saldo-pendiente .saldo-valor{color:#f59e0b}.total-detalle.saldo-completo{background:#d1fae5;border:1px solid #10b981}.total-detalle.saldo-completo span:first-child{color:#065f46}.total-detalle.saldo-completo .saldo-valor{color:#10b981}.cuenta-error{padding:1.5rem;text-align:center;background:#fee2e2;border:1px solid #ef4444;border-radius:.5rem;color:#991b1b;font-weight:600}.cuenta-empty{padding:2rem;text-align:center;background:var(--hotel-surface-light);border:2px dashed var(--hotel-border-dark);border-radius:.5rem;color:var(--hotel-text-secondary);font-size:.875rem}@media (max-width: 768px){.cuenta-header{flex-direction:column;gap:.5rem;align-items:flex-start}.cuenta-titulo h3,.total-label{font-size:1rem}.total-valor{font-size:1.25rem}.cuenta-item{flex-direction:column;gap:.5rem}.item-valor{align-self:flex-end;font-size:1rem}}.seleccion-metodos-pago{display:flex;flex-direction:column;gap:1rem}.metodos-pago-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.75rem;border-bottom:2px solid var(--hotel-border)}.header-info{display:flex;align-items:center;gap:.5rem;color:#1e40af}.header-info h3{margin:0;font-size:1rem;font-weight:600;color:var(--hotel-text)}.metodos-pago-loading{padding:2rem;text-align:center;color:var(--hotel-text-secondary)}.metodos-empty{padding:2rem;text-align:center;background:var(--hotel-surface-light);border-radius:.5rem;border:2px dashed var(--hotel-border)}.metodos-empty p{margin:0 0 1rem;color:var(--hotel-text-secondary);font-size:.875rem}.metodos-lista{display:flex;flex-direction:column;gap:.75rem}.metodo-item{display:flex;gap:.75rem;padding:.875rem;background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:.5rem;align-items:start;transition:all .2s}.metodo-item:hover{border-color:#1e40af;box-shadow:0 2px 4px #8b5cf61a}.metodo-numero{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#1e40af;color:#fff;border-radius:50%;font-size:.75rem;font-weight:700;flex-shrink:0}.metodo-campos{flex:1;display:grid;grid-template-columns:2fr 1.5fr;gap:.75rem}.metodo-campos label{display:block;font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary);margin-bottom:.25rem}.metodo-select-wrapper{position:relative;display:flex;align-items:center;gap:.5rem}.metodo-icon{display:flex;align-items:center;justify-content:center;padding:.5rem;background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:.375rem;color:#1e40af;flex-shrink:0}.metodo-select{flex:1;padding:.5rem;border:1px solid var(--hotel-border);border-radius:.375rem;font-size:.875rem;background:var(--hotel-card-background);color:var(--hotel-text);transition:all .2s}.metodo-select:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.campo-referencia{grid-column:span 2}.monto-input-group{display:flex;gap:.5rem}.btn-completar{display:flex;align-items:center;justify-content:center;padding:.5rem;background:#1e40af;color:#fff;border:none;border-radius:.375rem;cursor:pointer;transition:all .2s;flex-shrink:0}.btn-completar:hover{background:#1e3a8a;transform:scale(1.05)}.btn-eliminar-metodo{display:flex;align-items:center;justify-content:center;padding:.5rem;background:transparent;color:#ef4444;border:1px solid #fecaca;border-radius:.375rem;cursor:pointer;transition:all .2s;flex-shrink:0}.btn-eliminar-metodo:hover{background:#fef2f2;border-color:#ef4444;transform:scale(1.05)}.metodos-resumen{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--hotel-surface-light);border-radius:.5rem;border:1px solid var(--hotel-border)}.resumen-item{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.resumen-label{font-weight:500;color:var(--hotel-text-secondary)}.resumen-valor{font-weight:700;color:var(--hotel-text)}.resumen-total{color:#1e40af;font-size:1.125rem}.resumen-saldo{font-size:1rem}.resumen-completo{padding:.5rem;background:#d1fae5;border-radius:.375rem}.resumen-completo .resumen-label{color:#065f46}.resumen-completo .resumen-valor{color:#10b981}.resumen-pendiente{padding:.5rem;background:#fef3c7;border-radius:.375rem}.resumen-pendiente .resumen-label{color:#92400e}.resumen-exceso{padding:.5rem;background:#fee2e2;border-radius:.375rem}.resumen-exceso .resumen-label{color:#991b1b}.resumen-exceso .resumen-valor{color:#ef4444}.metodos-advertencia{padding:.75rem;background:#fef3c7;border:1px solid #fbbf24;border-radius:.375rem;text-align:center}.metodos-advertencia p{margin:0;font-size:.875rem;font-weight:600;color:#92400e}@media (max-width: 768px){.metodo-campos{grid-template-columns:1fr}.campo-referencia{grid-column:span 1}.metodos-pago-header{flex-direction:column;align-items:stretch;gap:.75rem}.metodo-item{flex-direction:column}.btn-eliminar-metodo{align-self:flex-end}}.checkout-form{display:flex;flex-direction:column;gap:1.5rem}.checkout-info{display:flex;flex-wrap:wrap;gap:.75rem;padding:1rem;background:var(--hotel-surface-light);border-radius:.5rem;border:1px solid var(--hotel-border)}.info-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--hotel-card-background);border-radius:.375rem;border:1px solid var(--hotel-border-dark)}.badge-label{font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary)}.badge-valor{font-size:.875rem;font-weight:700;color:#1e40af}.checkout-seccion{display:flex;flex-direction:column;gap:.75rem}.seccion-titulo{display:flex;align-items:center;gap:.5rem;color:var(--hotel-primary);font-size:1rem;font-weight:600;padding-bottom:.5rem;border-bottom:2px solid var(--hotel-border)}.seccion-titulo h3{margin:0;color:var(--hotel-text)}.checkout-textarea{width:100%;padding:.75rem;border:1px solid var(--hotel-border-dark);border-radius:.375rem;font-size:.875rem;font-family:inherit;resize:vertical;transition:all .2s;background:var(--hotel-card-background);color:var(--hotel-text)}.checkout-textarea:focus{outline:none;border-color:var(--hotel-primary);box-shadow:0 0 0 3px #8b5cf61a}.checkout-textarea::placeholder{color:var(--hotel-text-light)}.checkout-advertencia{display:flex;gap:.75rem;padding:1rem;background:#fef3c7;border:1px solid #fbbf24;border-radius:.5rem;align-items:start}.checkout-advertencia svg{color:#f59e0b;flex-shrink:0;margin-top:.125rem}.checkout-advertencia p{margin:0;font-size:.875rem;color:#92400e;line-height:1.5}.checkout-acciones{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem;border-top:2px solid var(--hotel-border)}.checkout-factura{display:flex;flex-direction:column;gap:2rem;padding:1rem}.factura-header{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:.5rem;color:#fff;text-align:center}.factura-header svg{opacity:.9}.factura-header h2{margin:0;font-size:1.5rem;font-weight:700}.factura-numero{font-size:1.125rem;font-weight:600;padding:.5rem 1rem;background:#fff3;border-radius:.375rem}.factura-detalles{display:flex;flex-direction:column;gap:.75rem;padding:1.5rem;background:var(--hotel-surface-light);border-radius:.5rem;border:1px solid var(--hotel-border)}.factura-item{display:flex;justify-content:space-between;align-items:center;font-size:1rem}.factura-item .label{font-weight:500;color:var(--hotel-text-secondary)}.factura-item .valor{font-weight:700;color:var(--hotel-text)}.factura-total{padding-top:.75rem;border-top:2px solid #1e40af;font-size:1.25rem}.factura-total .label{color:#4b5563}.factura-total .valor{color:#1e40af;font-size:1.5rem}.factura-metodos{padding:1.5rem;background:#ede9fe;border-radius:.5rem;border:1px solid #60a5fa}.factura-metodos h4{margin:0 0 1rem;font-size:1rem;color:#6b21a8}.factura-metodos ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.factura-metodos li{padding:.75rem;background:var(--hotel-card-background);border-radius:.375rem;font-size:.875rem;color:var(--hotel-text);font-weight:600;border:1px solid var(--hotel-border)}.factura-acciones{display:flex;gap:.75rem;justify-content:center}.factura-electronica-box{margin-top:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #10b981;border-radius:12px}.fe-box-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #10b981}.fe-box-header h4{font-size:1rem;font-weight:700;color:#065f46;margin:0}.fe-box-content{display:flex;flex-direction:column;gap:1rem}.fe-box-item{display:flex;align-items:center;justify-content:space-between;gap:1rem}.fe-box-item--cufe{flex-direction:column;align-items:flex-start;gap:.5rem}.fe-label{font-size:.75rem;font-weight:600;color:#065f46;text-transform:uppercase;letter-spacing:.05em}.fe-value{font-size:.875rem;font-weight:600;color:var(--hotel-text)}.fe-cufe{width:100%;font-family:Courier New,monospace;font-size:.7rem;color:#065f46;background:var(--hotel-card-background);padding:.5rem;border-radius:6px;border:1px solid #10b981;word-break:break-all}.fe-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.fe-badge--success{background:#d1fae5;color:#065f46;border:1px solid #10b981}.fe-badge--pending{background:#fef3c7;color:#92400e;border:1px solid #f59e0b}.fe-box-downloads{display:flex;gap:.75rem;margin-top:.5rem}.btn-fe-download{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-fe-download--pdf{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-fe-download--pdf:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.btn-fe-download--xml{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.btn-fe-download--xml:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.checkout-penalizacion{padding:1rem;background:#fffbeb;border:2px solid #f59e0b;border-radius:.5rem}.checkout-overstay{padding:1rem;background:#fff7ed;border:2px solid #f97316;border-radius:.5rem}.checkout-overstay .penalizacion-header svg{color:#f97316}.penalizacion-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:#92400e;font-weight:600;font-size:.9375rem}.penalizacion-header svg{color:#f59e0b;flex-shrink:0}.penalizacion-info{font-size:.8125rem;color:#78350f;margin-bottom:1rem;line-height:1.5;padding:.5rem .75rem;background:#f59e0b1a;border-radius:.375rem}.penalizacion-toggle{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--hotel-card-background);border-radius:.375rem;border:1px solid var(--hotel-border);cursor:pointer}.penalizacion-toggle input[type=checkbox]{width:1.125rem;height:1.125rem;accent-color:#f59e0b;cursor:pointer}.toggle-label{font-size:.875rem;font-weight:600;color:var(--hotel-text);cursor:pointer}.penalizacion-campos{display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem;padding:.75rem;background:var(--hotel-card-background);border-radius:.375rem;border:1px solid var(--hotel-border)}.penalizacion-monto,.penalizacion-motivo{display:flex;flex-direction:column;gap:.25rem}.penalizacion-monto label,.penalizacion-motivo label{font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary)}.checkout-input{width:100%;padding:.625rem .75rem;border:1px solid var(--hotel-border-dark);border-radius:.375rem;font-size:.875rem;font-family:inherit;background:var(--hotel-card-background);color:var(--hotel-text);transition:all .2s}.checkout-input:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b26}.penalizacion-total{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;padding:.75rem;background:#fef3c7;border-radius:.375rem;font-weight:700;color:#92400e;font-size:.9375rem}@media (max-width: 768px){.checkout-info{flex-direction:column}.info-badge{flex:1}.checkout-acciones{flex-direction:column-reverse}.checkout-acciones button{width:100%}.factura-header{padding:1.5rem}.factura-header h2,.factura-total .valor{font-size:1.25rem}.factura-acciones{flex-direction:column}}.consumos-list{display:flex;flex-direction:column;gap:1.5rem}.consumos-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;background:var(--hotel-surface-light);border-radius:.75rem;border:2px dashed var(--hotel-border-dark)}.consumos-empty__icon{font-size:3rem;margin-bottom:1rem}.consumos-empty h3{font-size:1.125rem;font-weight:600;color:var(--hotel-text);margin-bottom:.5rem}.consumos-empty p{font-size:.9375rem;color:var(--hotel-text-secondary)}.consumos-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.summary-card{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--hotel-card-background);border-radius:.5rem;border:1px solid var(--hotel-border);box-shadow:var(--shadow-sm)}.summary-label{font-size:.8125rem;font-weight:500;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em}.summary-value{font-size:1.25rem;font-weight:700}.summary-value--total{color:var(--hotel-text)}.summary-value--facturado{color:#10b981}.summary-value--pendiente{color:#f59e0b}.consumos-group{display:flex;flex-direction:column;gap:.75rem}.consumos-group__header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--hotel-surface-light);border-radius:.5rem;font-size:.9375rem;font-weight:600;color:var(--hotel-primary, #1e40af)}.consumos-group__header svg{color:var(--hotel-primary, #1e40af)}.consumos-group__items{display:flex;flex-direction:column;gap:.5rem}.consumo-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:.5rem;transition:all .2s}.consumo-item:hover{box-shadow:var(--shadow-md);border-color:var(--hotel-primary)}.consumo-item--facturado{opacity:.75;background:var(--hotel-surface-light)}.consumo-item__icon{font-size:1.5rem;display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:var(--hotel-surface-light);border-radius:.5rem}.consumo-item__content{flex:1;display:flex;flex-direction:column;gap:.5rem}.consumo-item__header{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.consumo-item__titulo{font-size:.9375rem;font-weight:600;color:var(--hotel-text)}.consumo-item__subtitulo{font-size:.8125rem;color:var(--hotel-primary, #1e40af);font-weight:500}.consumo-item__detalles{display:flex;flex-wrap:wrap;gap:1rem}.detalle-item{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--hotel-text-secondary)}.detalle-item svg{color:var(--hotel-text-light)}.consumo-item__notas{padding:.5rem;background:#fef3c7;border-left:3px solid #f59e0b;border-radius:.25rem;font-size:.8125rem;color:#92400e}.consumo-item__precio{font-size:1.125rem;font-weight:700;color:var(--hotel-primary, #1e40af);white-space:nowrap}.consumo-item__acciones{display:flex;gap:.375rem}.accion-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:.375rem;cursor:pointer;transition:all .2s}.accion-btn:hover{box-shadow:0 2px 4px #0000001a}.accion-btn--editar{color:#3b82f6}.accion-btn--editar:hover{background:#eff6ff;border-color:#3b82f6}.accion-btn--eliminar{color:#ef4444}.accion-btn--eliminar:hover{background:#fee2e2;border-color:#ef4444}@media (max-width: 768px){.consumos-summary{grid-template-columns:1fr}.consumo-item{flex-direction:column}.consumo-item__header{flex-direction:column;align-items:flex-start}.consumo-item__precio{width:100%;text-align:right}.consumo-item__acciones{width:100%;justify-content:flex-end}}.agregar-consumo-modal{display:flex;flex-direction:column;gap:1.5rem}.tipo-consumo-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.tipo-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:var(--hotel-card-background);border:2px solid var(--hotel-border);border-radius:.5rem;cursor:pointer;transition:all .2s;font-size:.875rem;font-weight:500;color:var(--hotel-text-secondary)}.tipo-btn:hover{border-color:var(--hotel-primary);background:var(--hotel-surface-light)}.tipo-btn--active{border-color:#1e40af;background:#f5f3ff;color:#1e40af}.tipo-btn svg{stroke-width:2}.busqueda-section{display:flex;flex-direction:column;gap:.75rem}.busqueda-input-group{position:relative;display:flex;align-items:center}.busqueda-icon{position:absolute;left:.75rem;color:var(--hotel-text-light);pointer-events:none}.busqueda-input{width:100%;padding:.75rem .75rem .75rem 2.75rem;border:1px solid var(--hotel-border-dark);border-radius:.5rem;font-size:.9375rem;transition:all .2s;background:var(--hotel-card-background);color:var(--hotel-text)}.busqueda-input:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.items-list{max-height:250px;overflow-y:auto;border:1px solid var(--hotel-border);border-radius:.5rem;background:var(--hotel-card-background)}.no-results{padding:2rem;text-align:center;color:var(--hotel-text-light);font-size:.9375rem}.item-card{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;border-bottom:1px solid var(--hotel-border);cursor:pointer;transition:all .2s}.item-card:last-child{border-bottom:none}.item-card:hover{background:var(--hotel-surface-light)}.item-card--selected{background:#f5f3ff;border-left:3px solid #1e40af}.item-info{display:flex;flex-direction:column;gap:.25rem}.item-nombre{font-size:.9375rem;font-weight:600;color:var(--hotel-text)}.item-codigo{font-size:.75rem;color:var(--hotel-text-light);font-family:Courier New,monospace}.item-categoria{font-size:.8125rem;color:var(--hotel-text-secondary);text-transform:capitalize}.item-stock{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#10b981;font-weight:500;margin-top:.25rem}.item-stock--bajo{color:#f59e0b}.item-stock--agotado{color:#ef4444}.item-stock svg{width:14px;height:14px}.item-card--sin-stock{opacity:.6;cursor:not-allowed;background:var(--hotel-surface-light)}.item-card--sin-stock:hover{background:var(--hotel-surface-light)}.item-precio{font-size:1rem;font-weight:700;color:#1e40af}.form-label{display:flex;align-items:center;gap:.375rem;font-size:.875rem;font-weight:600;color:var(--hotel-text)}.form-label svg{color:#1e40af}.form-input,.form-textarea{width:100%;padding:.75rem;border:1px solid var(--hotel-border-dark);border-radius:.5rem;font-size:.9375rem;font-family:inherit;transition:all .2s;background:var(--hotel-card-background);color:var(--hotel-text)}.form-input:focus,.form-textarea:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.form-input:disabled{background:var(--hotel-surface-light);cursor:not-allowed;opacity:.6}.form-input--error{border-color:#ef4444}.form-input--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-textarea{resize:vertical;min-height:80px}.form-error{font-size:.8125rem;color:#ef4444;margin-top:-.25rem}.form-error--general{padding:.75rem;background:#fee2e2;border-radius:.375rem;margin-top:0}.precio-total-display{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-radius:.5rem;border:1px solid #ddd6fe}.precio-total-display span{font-size:.9375rem;color:var(--hotel-text-secondary)}.precio-total-display strong{font-size:1.25rem;color:#1e40af}.modal-actions{display:flex;gap:.75rem;margin-top:.5rem}.modal-actions button{flex:1}@media (max-width: 768px){.tipo-consumo-selector,.form-row{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%}}.hospedaje-detalle-modal{display:flex;flex-direction:column;gap:1.5rem}.hospedaje-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--hotel-surface-light);border-radius:.5rem;border:1px solid var(--hotel-border)}.hospedaje-header__info{display:flex;flex-direction:column;gap:.5rem}.hospedaje-header__principal{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;color:var(--hotel-text)}.hospedaje-header__principal svg{color:var(--hotel-primary)}.hospedaje-header__huesped{display:flex;align-items:center;gap:.375rem;font-size:.9375rem;color:var(--hotel-text-secondary)}.hospedaje-header__huesped svg{color:var(--hotel-text-light)}.pestanas-container{display:flex;flex-direction:column;gap:1rem}.pestanas-header{display:flex;border-bottom:2px solid var(--hotel-border);gap:.5rem}.pestana-btn{position:relative;display:flex;align-items:center;gap:.5rem;padding:.875rem 1.25rem;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:.9375rem;font-weight:500;color:var(--hotel-text-secondary);transition:all .2s}.pestana-btn:hover{color:var(--hotel-primary);background:var(--hotel-surface-light)}.pestana-btn--active{color:var(--hotel-primary);border-bottom-color:var(--hotel-primary);background:var(--hotel-surface-light)}.pestana-btn svg{stroke-width:2}.pestana-badge{display:flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .375rem;background:#1e40af;color:#fff;font-size:.75rem;font-weight:600;border-radius:9999px}.pestanas-content{min-height:300px}.info-section{display:flex;flex-direction:column;gap:1.5rem}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.info-card{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:.5rem;box-shadow:var(--shadow-sm)}.info-card__label{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:500;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em}.info-card__label svg{color:var(--hotel-primary)}.info-card__value{font-size:1rem;font-weight:600;color:var(--hotel-text)}.info-card__value--price{font-size:1.125rem;color:var(--hotel-primary)}.observaciones-section,.notas-section{padding:1rem;background:var(--hotel-surface-light);border-left:3px solid #f59e0b;border-radius:.375rem}.observaciones-section h4,.notas-section h4{font-size:.875rem;font-weight:600;color:var(--hotel-text);margin-bottom:.5rem}.observaciones-section p,.notas-section p{font-size:.9375rem;color:var(--hotel-text-secondary);line-height:1.6}.acompanantes-section{padding:1rem;background:var(--hotel-surface-light);border-radius:.5rem;border:1px solid var(--hotel-border)}.acompanantes-section h4{font-size:.9375rem;font-weight:600;color:var(--hotel-text);margin-bottom:.75rem}.acompanantes-list{display:flex;flex-direction:column;gap:.5rem}.acompanante-detail-item{display:flex;align-items:flex-start;gap:.625rem;padding:.75rem;background:var(--hotel-card-background);border-radius:.375rem;border-left:3px solid var(--hotel-primary)}.acompanante-detail-item svg{color:var(--hotel-primary);margin-top:2px;flex-shrink:0}.acompanante-detail-info{display:flex;flex-direction:column;gap:.2rem}.acompanante-detail-nombre{font-size:.9375rem;font-weight:600;color:var(--hotel-text)}.acompanante-detail-doc{font-size:.8125rem;color:var(--hotel-text-secondary);font-weight:500}.acompanante-detail-extra{font-size:.8125rem;color:var(--hotel-text-light)}.consumos-section{display:flex;flex-direction:column;gap:1rem}.consumos-section__header{display:flex;justify-content:flex-end}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--hotel-border)}.submodal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1100}.submodal-content{background:var(--hotel-card-background);border-radius:12px;padding:2rem;max-width:450px;width:90%;box-shadow:0 20px 60px #0000004d;border:1px solid var(--hotel-border)}.submodal-title{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.125rem;color:var(--hotel-text)}.submodal-info{margin-bottom:.5rem;color:var(--hotel-text-secondary);font-size:.9375rem}.submodal-info:last-of-type{margin-bottom:1rem}.submodal-label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--hotel-text);font-size:.9375rem}.submodal-select,.submodal-input{width:100%;padding:.75rem;border-radius:8px;border:1px solid var(--hotel-border);margin-bottom:1rem;font-size:1rem;background:var(--hotel-card-background);color:var(--hotel-text)}.submodal-select:focus,.submodal-input:focus{outline:none;border-color:var(--hotel-primary);box-shadow:0 0 0 3px #4f46e51a}.submodal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem}@media (max-width: 768px){.hospedaje-header{flex-direction:column;align-items:flex-start;gap:.75rem}.pestanas-header{flex-direction:column;border-bottom:none}.pestana-btn{border-bottom:none;border-left:3px solid transparent}.pestana-btn--active{border-bottom-color:transparent;border-left-color:#1e40af}.info-grid{grid-template-columns:1fr}.modal-footer{flex-wrap:wrap;justify-content:center}.modal-footer button{flex:1 1 auto;min-width:120px}}.hospedajes-page{padding:.75rem;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.page-title{display:none}.page-subtitle{margin:0;font-size:.8125rem;color:var(--hotel-text-secondary);font-weight:500}.hospedajes-filtros{display:flex;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap;align-items:flex-end}.filtro-busqueda{flex:1;min-width:300px;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:.5rem;transition:all .2s}.filtro-busqueda:focus-within{border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.filtro-busqueda svg{color:var(--hotel-text-secondary);flex-shrink:0}.filtro-busqueda input{flex:1;border:none;outline:none;font-size:.875rem;color:var(--hotel-text);background:transparent}.filtro-busqueda input::placeholder{color:var(--hotel-text-light)}.filtro-estado{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:.5rem;transition:all .2s}.filtro-estado svg{color:var(--hotel-text-secondary)}.filtro-estado select{border:none;outline:none;font-size:.875rem;font-weight:600;color:var(--hotel-text);background:transparent;cursor:pointer}.hospedajes-contador{margin-bottom:.75rem;font-size:.8125rem;font-weight:600;color:var(--hotel-text-secondary)}.hospedajes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:.75rem}.hospedaje-card{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:.5rem;padding:.875rem;display:flex;flex-direction:column;gap:.75rem;transition:all .2s;box-shadow:var(--shadow-sm)}.hospedaje-card:hover{box-shadow:var(--shadow-md);border-color:var(--hotel-primary)}.card-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.625rem;border-bottom:1px solid var(--hotel-border)}.card-codigo{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:var(--hotel-primary)}.card-codigo svg{color:var(--hotel-primary)}.card-badges{display:flex;align-items:center;gap:.375rem}.card-estado{padding:.25rem .75rem;border-radius:.25rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.badge-tra{padding:.125rem .5rem;border-radius:.25rem;font-size:.625rem;font-weight:800;letter-spacing:.5px;cursor:default}.badge-tra-enviado{background:#d1fae5;color:#065f46;border:1px solid #10b981}.badge-tra-error{background:#fee2e2;color:#991b1b;border:1px solid #ef4444}.badge-tra-no_configurado{background:#f3f4f6;color:#6b7280;border:1px solid #d1d5db}.badge-tra-pendiente{background:#fef3c7;color:#92400e;border:1px solid #f59e0b}.badge-activo{background:#d1fae5;color:#065f46;border:1px solid #10b981}.badge-finalizado{background:var(--hotel-surface-light);color:var(--hotel-text);border:1px solid var(--hotel-border-dark)}.badge-cancelado{background:#fee2e2;color:#991b1b;border:1px solid #ef4444}.card-habitacion{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:linear-gradient(135deg,#ede9fe,#dbeafe);border-radius:.5rem;border:1px solid #60a5fa}.habitacion-numero{font-size:1.25rem;font-weight:700;color:#6b21a8}.habitacion-tipo{font-size:.875rem;font-weight:600;color:#1e3a8a;text-transform:capitalize}.card-huesped{display:flex;flex-direction:column;gap:.25rem}.huesped-nombre{font-size:1rem;font-weight:700;color:var(--hotel-text)}.huesped-documento{font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary);text-transform:uppercase}.card-fechas{display:flex;flex-direction:column;gap:.5rem;padding:.625rem;background:var(--hotel-surface-light);border-radius:.375rem}.fecha-item{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.fecha-label{font-weight:500;color:var(--hotel-text-secondary)}.fecha-valor{font-weight:700;color:var(--hotel-text)}.fecha-noches{text-align:center;padding:.5rem;background:var(--hotel-card-background);border-radius:.25rem;font-size:.875rem;font-weight:700;color:var(--hotel-primary);border:1px solid var(--hotel-border)}.card-precio{display:flex;justify-content:space-between;align-items:center;padding:.625rem;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86efac;border-radius:.375rem}.precio-label{font-size:.875rem;font-weight:600;color:#065f46}.precio-valor{font-size:1.125rem;font-weight:800;color:#16a34a}.card-ocupantes{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary)}.card-ocupantes span{padding:.25rem .5rem;background:var(--hotel-surface-light);border-radius:.25rem}.card-reserva{font-size:.75rem;font-weight:600;color:#6b7280;padding:.5rem;background:#dbeafe;border:1px solid #3b82f6;border-radius:.25rem;text-align:center}.card-acciones{display:flex;gap:.5rem;padding-top:.625rem;border-top:1px solid var(--hotel-border)}.card-acciones button{flex:1}.hospedajes-loading{display:flex;justify-content:center;align-items:center;padding:3rem;font-size:1.125rem;color:var(--hotel-text-secondary)}.hospedajes-error{padding:1.5rem;background:#fee2e2;border:1px solid #ef4444;border-radius:.5rem;color:#991b1b;font-weight:600;text-align:center}.hospedajes-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem 2rem;background:var(--hotel-surface-light);border:2px dashed var(--hotel-border-dark);border-radius:.75rem;text-align:center}.hospedajes-empty svg{color:var(--hotel-text-light)}.hospedajes-empty p{margin:0;font-size:1rem;color:var(--hotel-text-secondary);font-weight:600}[data-theme=dark] .card-habitacion{background:var(--hotel-surface-light);border:1px solid var(--hotel-border-dark)}[data-theme=dark] .habitacion-numero{color:var(--hotel-text)}[data-theme=dark] .habitacion-tipo{color:var(--hotel-text-secondary)}[data-theme=dark] .card-precio{background:var(--hotel-surface-light);border:1px solid var(--color-success)}[data-theme=dark] .precio-label{color:var(--hotel-text-secondary)}[data-theme=dark] .precio-valor{color:#4ade80}[data-theme=dark] .badge-activo{background:#10b98126;color:#6ee7b7;border-color:#10b981}[data-theme=dark] .badge-cancelado{background:#ef444426;color:#fca5a5;border-color:#ef4444}[data-theme=dark] .badge-tra-enviado{background:#10b98126;color:#6ee7b7;border-color:#10b981}[data-theme=dark] .badge-tra-error{background:#ef444426;color:#fca5a5;border-color:#ef4444}[data-theme=dark] .badge-tra-no_configurado{background:#6b728026;color:#9ca3af;border-color:#6b7280}[data-theme=dark] .badge-tra-pendiente{background:#f59e0b26;color:#fcd34d;border-color:#f59e0b}@media (max-width: 1200px){.hospedajes-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width: 768px){.hospedajes-page{padding:1rem}.hospedajes-header{flex-direction:column;align-items:flex-start}.hospedajes-header button{width:100%}.header-titulo h1{font-size:1.5rem}.hospedajes-filtros{flex-direction:column}.filtro-busqueda{min-width:100%}.filtro-estado{width:100%}.hospedajes-grid{grid-template-columns:1fr}.card-acciones{flex-direction:column}.card-acciones button{width:100%}}.BuscadorClienteHuesped{display:flex;flex-direction:column;gap:1.5rem}.paso{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;padding:1.5rem}.paso-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.paso-numero{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.25rem;flex-shrink:0}.paso-header h3{margin:0;font-size:1.25rem;color:var(--hotel-text)}.paso-descripcion{margin:.25rem 0 0;font-size:.875rem;color:var(--hotel-text-secondary)}.busqueda-container{display:flex;gap:.75rem;margin-bottom:1rem}.busqueda-container input{flex:1}.resultados-clientes{margin:1.5rem 0}.resultados-titulo{font-size:.875rem;font-weight:500;color:var(--hotel-text-secondary);margin-bottom:.75rem}.cliente-card{display:flex;align-items:center;justify-content:space-between;padding:1rem;border:1px solid var(--hotel-border);border-radius:6px;margin-bottom:.5rem;cursor:pointer;transition:all .2s}.cliente-card:hover{border-color:#8b5cf6;background:var(--hotel-surface-light);box-shadow:0 2px 8px #8b5cf61a}.cliente-info{display:flex;align-items:center;gap:.75rem}.cliente-info svg{color:#8b5cf6;flex-shrink:0}.cliente-nombre{font-weight:600;color:var(--hotel-text);margin-bottom:.25rem}.check-icon{color:#10b981;opacity:0;transition:opacity .2s}.cliente-card:hover .check-icon{opacity:1}.crear-nuevo-container{margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--hotel-border)}.formulario-nuevo-cliente{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--hotel-border)}.formulario-nuevo-cliente h4{margin:0 0 1rem;font-size:1rem;color:var(--hotel-text)}.cliente-seleccionado{background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:6px;padding:1rem;margin-bottom:1.5rem;text-align:center}.label-small{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--hotel-text-secondary);margin-bottom:.5rem}.cliente-nombre-grande{font-size:1.25rem;font-weight:700;color:var(--hotel-text);margin-bottom:.25rem}.cliente-documento-small{font-size:.875rem;color:var(--hotel-text-secondary);margin-bottom:.75rem}.checkbox-container{background:#ede9fe;border:1px solid #c4b5fd;border-radius:6px;padding:1rem;margin-bottom:1.5rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:500;color:var(--hotel-text);margin-bottom:.5rem}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#8b5cf6}.checkbox-help{margin:0;font-size:.875rem;color:var(--hotel-text-secondary);padding-left:2rem}.formulario-huesped-diferente{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--hotel-border)}.formulario-huesped-diferente h4{margin:0 0 1rem;font-size:1rem;color:var(--hotel-text)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--hotel-border)}.confirmacion-exitosa{display:flex;align-items:center;gap:.75rem;padding:1rem;margin-top:1.5rem;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981;border-radius:8px;color:#065f46;font-weight:500;animation:slideDown .3s ease-out}.confirmacion-exitosa svg{color:#10b981;flex-shrink:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.grado-militar-section{margin-top:1rem;padding:1rem;background:var(--hotel-surface-light, #f8fafc);border:1px solid var(--hotel-border);border-radius:8px}.grado-militar-title{display:flex;align-items:center;gap:.5rem;margin:0 0 .25rem;font-size:.9375rem;font-weight:600;color:var(--hotel-text)}.grado-militar-title svg{color:#7c3aed}.grado-militar-hint{margin:0 0 .75rem;font-size:.8125rem;color:var(--hotel-text-secondary)}.grado-militar-select{width:100%;padding:.625rem .75rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.875rem;background:var(--hotel-card-background);color:var(--hotel-text);cursor:pointer;transition:border-color .2s}.grado-militar-select:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.busqueda-container{flex-direction:column}.paso-header{flex-direction:row;align-items:flex-start}.paso-numero{width:36px;height:36px;font-size:1.125rem}.form-actions{flex-direction:column}.form-actions button{width:100%}}.checkin-page{padding:2rem;max-width:1200px;margin:0 auto}.checkin-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:3px solid var(--hotel-border)}.checkin-titulo{display:flex;align-items:center;gap:.75rem}.checkin-titulo h1{margin:0;font-size:2rem;font-weight:700;color:var(--hotel-text)}.checkin-titulo svg{color:var(--hotel-primary)}.modo-selector{display:flex;gap:.5rem;background:var(--hotel-surface-light);padding:.5rem;border-radius:.5rem;width:fit-content}.modo-btn{padding:.75rem 1.5rem;border:none;background:transparent;border-radius:.375rem;font-size:.875rem;font-weight:600;color:var(--hotel-text-secondary);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.modo-btn:hover{background:var(--hotel-border);color:var(--hotel-text)}.modo-btn.active{background:#1e40af;color:#fff;box-shadow:0 2px 4px #8b5cf64d}.checkin-form{display:flex;flex-direction:column;gap:2rem}.checkin-seccion{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:.5rem;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.seccion-titulo{display:flex;align-items:center;gap:.5rem;color:var(--hotel-primary);font-size:1.125rem;font-weight:600;padding-bottom:.75rem;border-bottom:2px solid var(--hotel-border);margin:0}.seccion-contenido{display:flex;flex-direction:column;gap:1rem}.busqueda-reserva{display:flex;gap:.75rem;align-items:flex-end}.busqueda-reserva .input-group{flex:1}.reserva-info{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#ede9fe,#dbeafe);border:2px solid #1e40af;border-radius:.5rem}[data-theme=dark] .reserva-info{background:var(--hotel-surface-light);border-color:var(--hotel-primary)}.reserva-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.75rem;border-bottom:2px solid #60a5fa}[data-theme=dark] .reserva-header{border-bottom-color:var(--hotel-border)}.reserva-codigo{font-size:1.125rem;font-weight:700;color:#6b21a8}[data-theme=dark] .reserva-codigo{color:var(--hotel-primary)}.reserva-estado{padding:.375rem .75rem;border-radius:.25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;background:#dbeafe;color:#1e40af}[data-theme=dark] .reserva-estado{background:#8b5cf626;color:var(--hotel-primary)}.reserva-detalles{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.reserva-item{display:flex;flex-direction:column;gap:.25rem}.reserva-label{font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary);text-transform:uppercase}.reserva-valor{font-size:.875rem;font-weight:600;color:var(--hotel-text)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-size:.875rem;font-weight:600;color:var(--hotel-text)}.input-group input,.input-group select,.input-group textarea{padding:.75rem;border:1px solid var(--hotel-border);border-radius:.375rem;font-size:.875rem;font-family:inherit;transition:all .2s;background:var(--hotel-card-background);color:var(--hotel-text)}.input-group input:focus,.input-group select:focus,.input-group textarea:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.input-group textarea{resize:vertical;min-height:80px}.input-group small{font-size:.75rem;color:var(--hotel-text-secondary)}.huesped-search{display:flex;gap:.75rem;align-items:flex-end}.huesped-info{padding:1rem;background:#d1fae5;border:1px solid #10b981;border-radius:.375rem;display:flex;flex-direction:column;gap:.5rem}[data-theme=dark] .huesped-info{background:#10b9811a;border-color:#10b981;color:var(--hotel-text)}.huesped-info-item{display:flex;gap:.5rem;font-size:.875rem}.huesped-info-item strong{color:#065f46;font-weight:600}[data-theme=dark] .huesped-info-item strong{color:#34d399}.huesped-info-item span{color:#047857}[data-theme=dark] .huesped-info-item span{color:var(--hotel-text)}.acompanantes-lista{display:flex;flex-direction:column;gap:1rem}.acompanante-card{padding:1rem 1rem 1rem 1.25rem;background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-left:4px solid var(--hotel-primary);border-radius:.5rem;display:flex;flex-direction:column;gap:.75rem;transition:all .2s}.acompanante-card:hover{border-left-color:#1e40af;box-shadow:0 2px 8px #0000000f}.acompanante-card__header{display:flex;justify-content:space-between;align-items:center}.acompanante-numero{font-size:.8rem;font-weight:700;color:var(--hotel-primary);text-transform:uppercase;letter-spacing:.5px}.acompanante-card__row{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;align-items:flex-start}.agregar-acompanante-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:var(--hotel-surface-light);border:2px dashed var(--hotel-border-dark);border-radius:.375rem;color:var(--hotel-text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s}.agregar-acompanante-btn:hover{background:var(--hotel-border);border-color:var(--hotel-primary);color:var(--hotel-primary)}.checkin-acciones{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:2px solid var(--hotel-border);margin-top:1rem}.btn-cancelar{padding:.875rem 1.5rem;border:2px solid var(--hotel-border-dark);background:var(--hotel-card-background);border-radius:.5rem;font-weight:600;font-size:.875rem;color:var(--hotel-text-secondary);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.btn-cancelar:hover{border-color:var(--hotel-text-light);background:var(--hotel-surface-light);color:var(--hotel-text)}.btn-checkin{padding:.875rem 2rem;border:none;background:linear-gradient(135deg,#1e40af,#1e3a8a);border-radius:.5rem;font-weight:600;font-size:.875rem;color:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;box-shadow:0 2px 4px #8b5cf64d}.btn-checkin:hover{background:linear-gradient(135deg,#1e3a8a,#6d28d9);box-shadow:0 4px 8px #8b5cf666;transform:translateY(-1px)}.btn-checkin:disabled,.btn-cancelar:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-checkin:disabled:hover{transform:none;box-shadow:0 2px 4px #8b5cf64d}.checkin-loading{display:flex;justify-content:center;align-items:center;padding:3rem;font-size:1.125rem;color:var(--hotel-text-secondary)}.checkin-error{padding:1.5rem;background:#fee2e2;border:1px solid #ef4444;border-radius:.5rem;color:#991b1b;font-weight:600;text-align:center}[data-theme=dark] .checkin-error{background:#ef44441a;color:#fca5a5}.checkin-empty{padding:3rem;text-align:center;background:var(--hotel-surface-light);border:2px dashed var(--hotel-border-dark);border-radius:.5rem;color:var(--hotel-text-secondary);font-size:.875rem}.btn-icon{padding:.5rem;border:none;background:transparent;color:var(--hotel-text-secondary);cursor:pointer;border-radius:.25rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--hotel-surface-light);color:var(--hotel-text)}.btn-icon.danger{color:#ef4444}.btn-icon.danger:hover{background:#fee2e2;color:#dc2626}[data-theme=dark] .btn-icon.danger:hover{background:#ef444426;color:#f87171}@media (max-width: 768px){.checkin-page{padding:1rem}.checkin-titulo h1{font-size:1.5rem}.modo-selector{width:100%}.modo-btn{flex:1;justify-content:center}.form-grid,.form-grid-2,.reserva-detalles{grid-template-columns:1fr}.busqueda-reserva,.huesped-search{flex-direction:column;align-items:stretch}.busqueda-reserva button,.huesped-search button{width:100%}.acompanante-card__row{grid-template-columns:1fr 1fr}.checkin-acciones{flex-direction:column-reverse}.checkin-acciones button{width:100%}.reserva-header{flex-direction:column;align-items:flex-start;gap:.5rem}}@media (max-width: 480px){.acompanante-card__row{grid-template-columns:1fr}}.huesped-modal-form{display:flex;flex-direction:column;gap:1.5rem;max-height:70vh;overflow-y:auto;padding:.5rem}.form-section{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--hotel-surface-light);border-radius:.5rem;border:1px solid var(--hotel-border)}.section-title{font-size:1rem;font-weight:600;color:var(--hotel-text);margin:0 0 .5rem;display:flex;align-items:center;gap:.5rem}.section-title svg{color:#1e40af}.cliente-toggle{display:flex;gap:.5rem;margin-bottom:1rem}.toggle-btn{flex:1;padding:.625rem 1rem;border:1px solid var(--hotel-border-dark);background:var(--hotel-card-background);border-radius:.375rem;font-size:.875rem;font-weight:500;color:var(--hotel-text-secondary);cursor:pointer;transition:all .2s}.toggle-btn:hover{border-color:var(--hotel-primary);color:var(--hotel-primary)}.toggle-btn.active{background:#1e40af;border-color:#1e40af;color:#fff}.cliente-search{position:relative}.clientes-sugerencias{position:absolute;top:100%;left:0;right:0;background:var(--hotel-card-background);border:1px solid var(--hotel-border-dark);border-radius:.375rem;box-shadow:var(--shadow-md);max-height:200px;overflow-y:auto;z-index:10;margin-top:.25rem}.cliente-sugerencia{padding:.75rem;cursor:pointer;border-bottom:1px solid var(--hotel-border);transition:background .2s}.cliente-sugerencia:last-child{border-bottom:none}.cliente-sugerencia:hover{background:var(--hotel-surface-light)}.cliente-sugerencia-nombre{font-weight:600;color:var(--hotel-text);font-size:.875rem;margin-bottom:.25rem}.cliente-sugerencia-documento{font-size:.75rem;color:var(--hotel-text-secondary)}.cliente-seleccionado{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#dbeafe;border:1px solid #3b82f6;border-radius:.375rem;font-size:.875rem;color:#1e40af;margin-top:.5rem}.cliente-seleccionado svg{color:#3b82f6;flex-shrink:0}.nuevo-cliente-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.form-label{font-size:.875rem;font-weight:600;color:var(--hotel-text)}.form-textarea{padding:.625rem .875rem;font-size:.875rem;color:var(--hotel-text);background-color:var(--hotel-card-background);border:1px solid var(--hotel-border-dark);border-radius:.375rem;transition:all .2s;font-family:inherit;resize:vertical}.form-textarea:hover{border-color:var(--hotel-text-light)}.form-textarea:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--hotel-border);margin-top:.5rem}@media (max-width: 768px){.huesped-modal-form{max-height:60vh}.form-row{grid-template-columns:1fr}.modal-actions{flex-direction:column}.modal-actions button{width:100%}.cliente-toggle{flex-direction:column}}.huesped-modal-form::-webkit-scrollbar{width:6px}.huesped-modal-form::-webkit-scrollbar-track{background:var(--hotel-surface-light);border-radius:10px}.huesped-modal-form::-webkit-scrollbar-thumb{background:var(--hotel-primary);border-radius:10px}.huesped-modal-form::-webkit-scrollbar-thumb:hover{background:var(--hotel-primary-hover)}.huesped-detalle-container{display:flex;flex-direction:column;gap:1.5rem;max-height:70vh;overflow-y:auto}.huesped-detalle-header{padding:1rem;background:linear-gradient(135deg,#1e40af,#3b82f6,#60a5fa);border-radius:.5rem;color:#fff}.header-info{display:flex;flex-direction:column;gap:.75rem}.huesped-detalle-nombre{font-size:1.5rem;font-weight:700;margin:0;color:#fff}.header-badges{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.documento-numero{display:flex;align-items:center;gap:.375rem;padding:.25rem .625rem;background:#fff3;border-radius:.25rem;font-size:.875rem;font-weight:500}.header-fecha{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;opacity:.9}.huesped-detalle-body{display:flex;flex-direction:column;gap:1rem;padding:0 .5rem}.info-section{padding:1rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:.5rem}.info-section-title{font-size:1rem;font-weight:600;color:var(--hotel-text);margin:0 0 1rem;display:flex;align-items:center;gap:.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--hotel-border)}.info-section-title svg{color:#1e40af}.info-grid{display:flex;flex-direction:column;gap:.75rem}.info-row{display:grid;grid-template-columns:180px 1fr;gap:1rem;align-items:flex-start}.info-label{font-size:.875rem;font-weight:600;color:var(--hotel-text-secondary);display:flex;align-items:center;gap:.375rem}.info-label svg{color:#1e40af;flex-shrink:0}.info-value{font-size:.875rem;color:var(--hotel-text)}.info-row.clickable .info-value-link{color:#1e40af;text-decoration:none;transition:color .2s}.info-row.clickable .info-value-link:hover{color:#1e3a8a;text-decoration:underline}.emergency-section{background:#fef3c7;border-color:#f59e0b}.emergency-section .info-section-title svg{color:#f59e0b}.observaciones-content{padding:.75rem;background:var(--hotel-surface-light);border-radius:.375rem;font-size:.875rem;color:var(--hotel-text-secondary);line-height:1.6}.observaciones-content p{margin:0}.preferencias-badges{display:flex;flex-wrap:wrap;gap:.5rem}.historial-placeholder{padding:2rem;background:var(--hotel-surface-light);border:1px dashed var(--hotel-border);border-radius:.375rem;text-align:center;color:var(--hotel-text-secondary);font-size:.875rem}.huesped-detalle-footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--hotel-border);margin-top:.5rem}@media (max-width: 768px){.huesped-detalle-container{max-height:60vh}.huesped-detalle-nombre{font-size:1.25rem}.info-row{grid-template-columns:1fr;gap:.375rem}.info-label{font-weight:700}.huesped-detalle-footer{flex-direction:column}.huesped-detalle-footer button{width:100%}}.huesped-detalle-container::-webkit-scrollbar{width:6px}.huesped-detalle-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.huesped-detalle-container::-webkit-scrollbar-thumb{background:#1e40af;border-radius:10px}.huesped-detalle-container::-webkit-scrollbar-thumb:hover{background:#1e3a8a}.huespedes-container{max-width:1400px;margin:0 auto;padding:.75rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:.75rem}.page-title{font-size:1.875rem;font-weight:700;color:var(--hotel-text);margin:0;display:flex;align-items:center;gap:.625rem}.page-title svg{color:var(--hotel-primary)}.page-subtitle{font-size:.875rem;color:var(--hotel-text-secondary);font-weight:500;margin-top:.25rem}.filters-section{background:var(--hotel-card-background);border-radius:.5rem;padding:.75rem;margin-bottom:.75rem;box-shadow:var(--shadow-sm);display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}.input-group{display:flex;flex-direction:column;gap:.25rem;min-width:180px;flex:1}.input-label{font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary);display:flex;align-items:center;gap:.25rem}.search-input,.text-input,.select-input,.date-input{padding:.5rem .75rem;font-size:.875rem;color:var(--hotel-text);background-color:var(--hotel-card-background);border:1px solid var(--hotel-border-dark);border-radius:.375rem;transition:all .2s;font-family:inherit}.search-input:hover,.text-input:hover,.select-input:hover,.date-input:hover{border-color:var(--hotel-text-light)}.search-input:focus,.text-input:focus,.select-input:focus,.date-input:focus{outline:none;border-color:var(--hotel-primary, #1e40af);box-shadow:0 0 0 3px #8b5cf61a}.filter-actions{display:flex;align-items:flex-end;gap:.5rem;flex-shrink:0}.huespedes-stats{margin-bottom:.75rem;padding:0 .25rem}.stats-text{font-size:.8125rem;color:var(--hotel-text-secondary);font-weight:500}.huespedes-table-wrapper{background:var(--hotel-card-background);border-radius:.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--hotel-border);overflow-x:auto}.huespedes-table{width:100%;border-collapse:collapse;min-width:700px}.huespedes-table thead th{padding:.75rem 1rem;font-size:.75rem;font-weight:700;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em;text-align:left;background:var(--hotel-surface-light);border-bottom:2px solid var(--hotel-border);position:sticky;top:0;white-space:nowrap}.huespedes-table tbody tr{transition:background .15s;border-bottom:1px solid var(--hotel-border)}.huespedes-table tbody tr:last-child{border-bottom:none}.huespedes-table tbody tr:hover{background:var(--hotel-surface-light)}.huespedes-table td{padding:.75rem 1rem;font-size:.875rem;color:var(--hotel-text);vertical-align:middle}.td-nombre{font-weight:600;white-space:nowrap}.td-documento{display:flex;align-items:center;gap:.5rem;white-space:nowrap}.td-email{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-actions{display:flex;gap:.5rem;align-items:center}.table-action-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border:1px solid var(--hotel-border-dark);background:var(--hotel-card-background);border-radius:.375rem;font-size:.8125rem;font-weight:500;color:var(--hotel-text-secondary);cursor:pointer;transition:all .2s;white-space:nowrap}.table-action-btn:hover{border-color:var(--hotel-primary);color:var(--hotel-primary);background:var(--hotel-surface-light)}.empty-state{background:var(--hotel-card-background);border-radius:.75rem;padding:3rem 2rem;text-align:center;box-shadow:var(--shadow-sm)}.empty-icon{display:flex;justify-content:center;align-items:center;margin-bottom:1rem;opacity:.5;color:var(--hotel-text-light)}.empty-state h3{font-size:1.25rem;font-weight:600;color:var(--hotel-text);margin-bottom:.5rem}.empty-state p{font-size:1rem;color:var(--hotel-text-secondary);margin-bottom:1.5rem}.error-message{background:#fee2e2;border:1px solid #ef4444;border-radius:.5rem;padding:1rem;color:#dc2626;text-align:center;margin:2rem}[data-theme=dark] .huespedes-table-wrapper,[data-theme=dark] .table-action-btn{border-color:var(--hotel-border)}[data-theme=dark] .table-action-btn:hover{background:#8b5cf61a}@media (max-width: 768px){.huespedes-container{padding:1rem}.page-header{flex-direction:column;align-items:stretch}.page-title{font-size:1.5rem}.filters-section{flex-direction:column;align-items:stretch}.input-group{min-width:100%}.filter-actions{width:100%}.filter-actions button{flex:1}}@media (max-width: 480px){.empty-state{padding:2rem 1rem}}.categorias-modal{background:var(--hotel-card-background);border-radius:12px;width:90%;max-width:900px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.categorias-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;border-bottom:1px solid rgba(255,255,255,.1)}.categorias-modal-header h2{margin:0;font-size:1.5rem;font-weight:600}.categorias-modal-body{padding:1.5rem;overflow-y:auto;flex:1}.btn-nueva-categoria{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#1e40af;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:.95rem;margin-bottom:1.5rem;transition:all .2s}.btn-nueva-categoria:hover{background:#1e3a8a;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.categoria-form{background:var(--hotel-surface-light);padding:1.5rem;border-radius:8px;margin-bottom:2rem;border:1px solid var(--hotel-border)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.form-group input,.form-group select{padding:.75rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.95rem;transition:all .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.form-group select:disabled{background:#e5e7eb;cursor:not-allowed}.color-picker-container{position:relative}.color-preview{width:50px;height:40px;border-radius:6px;border:2px solid var(--hotel-border);cursor:pointer;transition:all .2s}.color-preview:hover{border-color:#1e40af;transform:scale(1.05)}.color-picker-palette{position:absolute;top:45px;left:0;background:var(--hotel-card-background);padding:.75rem;border-radius:8px;box-shadow:0 10px 30px #0003;display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;z-index:1000;border:1px solid var(--hotel-border)}.color-option{width:35px;height:35px;border-radius:6px;cursor:pointer;transition:all .2s;border:2px solid transparent}.color-option:hover{transform:scale(1.1);box-shadow:0 4px 8px #0003}.color-option.selected{border-color:#1f2937;transform:scale(1.15)}.icon-picker-container{position:relative}.icon-preview{width:50px;height:40px;border-radius:6px;border:2px solid var(--hotel-border);display:flex;align-items:center;justify-content:center;font-size:1.5rem;cursor:pointer;transition:all .2s;background:var(--hotel-card-background)}.icon-preview:hover{border-color:#1e40af;color:#1e40af;transform:scale(1.05)}.icon-picker-palette{position:absolute;top:45px;left:0;background:var(--hotel-card-background);padding:.75rem;border-radius:8px;box-shadow:0 10px 30px #0003;display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;z-index:1000;border:1px solid var(--hotel-border);max-width:280px}.icon-option{width:35px;height:35px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:all .2s;border:2px solid transparent;background:var(--hotel-surface-light)}.icon-option:hover{background:var(--hotel-border);color:#1e40af;transform:scale(1.1)}.icon-option.selected{background:#ede9fe;color:#1e40af;border-color:#1e40af;transform:scale(1.15)}.btn-guardar{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#10b981;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.btn-guardar:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.btn-cancelar{padding:.75rem 1.5rem;background:#6b7280;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.btn-cancelar:hover{background:#4b5563}.categorias-lista{margin-top:2rem}.categorias-lista h3{margin-bottom:1rem;color:var(--hotel-text);font-size:1.1rem}.categorias-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.categoria-card{background:var(--hotel-card-background);border:2px solid var(--hotel-border);border-radius:8px;padding:1rem;display:flex;align-items:center;gap:1rem;transition:all .2s;position:relative}.categoria-card:hover{border-color:#1e40af;box-shadow:0 4px 12px #8b5cf626;transform:translateY(-2px)}.categoria-card.editing{border-color:#f59e0b;background:#fffbeb}.categoria-card.inactiva{opacity:.6;background:var(--hotel-surface-light)}.categoria-drag{color:#9ca3af;cursor:move;font-size:1.2rem}.categoria-color{width:6px;height:60px;border-radius:3px}.categoria-icon{font-size:2rem;width:50px;display:flex;align-items:center;justify-content:center}.categoria-info{flex:1}.categoria-info h4{margin:0 0 .25rem;color:var(--hotel-text);font-size:1rem;font-weight:600}.categoria-descripcion{margin:0 0 .5rem;color:var(--hotel-text-secondary);font-size:.85rem}.categoria-meta{display:flex;gap:.5rem;flex-wrap:wrap}.tipo-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase}.tipo-badge.tipo-ambos{background:#fef3c7;color:#92400e}.orden-badge{padding:.25rem .75rem;background:var(--hotel-surface-light);border-radius:12px;font-size:.75rem;color:var(--hotel-text-secondary)}.categoria-actions{display:flex;gap:.5rem}.btn-icon{width:36px;height:36px;border-radius:6px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:.9rem}.btn-edit{background:#eff6ff;color:#3b82f6}.btn-edit:hover{background:#3b82f6;color:#fff;transform:scale(1.1)}.btn-delete{background:#fef2f2;color:#ef4444}.btn-delete:hover{background:#ef4444;color:#fff;transform:scale(1.1)}.no-data{text-align:center;color:#9ca3af;padding:3rem;font-style:italic}@media (max-width: 768px){.categorias-modal{width:95%;max-height:95vh}.categorias-grid,.form-row{grid-template-columns:1fr}.color-picker-palette{grid-template-columns:repeat(4,1fr)}.icon-picker-palette{grid-template-columns:repeat(5,1fr);max-width:240px}}.item-form-modal{background:var(--hotel-card-background);border-radius:12px;width:90%;max-width:800px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.item-form-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;border-bottom:1px solid rgba(255,255,255,.1)}.item-form-header h2{margin:0;font-size:1.5rem;font-weight:600;display:flex;align-items:center;gap:.75rem}.item-form{padding:2rem;overflow-y:auto;flex:1}.form-section:last-of-type{border-bottom:none}.form-section h3{margin:0 0 1.25rem;color:var(--hotel-text);font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:1.25rem}.form-group label{font-weight:500;color:var(--hotel-text);font-size:.9rem}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:1px solid var(--hotel-border-dark);border-radius:6px;font-size:.95rem;font-family:inherit;transition:all .2s;background:var(--hotel-card-background);color:var(--hotel-text)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.help-text{font-size:.8rem;color:var(--hotel-text-secondary);font-style:italic;margin-top:-.25rem}.precio-calculado{padding:.75rem;background:#f0fdf4;border:2px solid #10b981;border-radius:6px;font-weight:700;font-size:1.1rem;color:#065f46;text-align:center}.form-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:2px solid var(--hotel-border)}.btn-cancelar{padding:.875rem 2rem;background:var(--hotel-card-background);color:var(--hotel-text-secondary);border:2px solid var(--hotel-border-dark);border-radius:8px;cursor:pointer;font-weight:500;font-size:1rem;transition:all .2s}.btn-cancelar:hover{background:var(--hotel-surface-light);border-color:var(--hotel-text-light);color:var(--hotel-text)}@media (max-width: 768px){.item-form-modal{width:95%;max-height:95vh}.item-form{padding:1.5rem}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-guardar,.btn-cancelar{width:100%}}.inventario-page{padding:2rem;max-width:1400px;margin:0 auto}.inventario-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.header-titulo{display:flex;align-items:center;gap:1rem}.header-icon{font-size:2.5rem;color:#1e40af}.header-titulo h1{margin:0;font-size:1.8rem;color:var(--hotel-text)}.header-titulo p{margin:.25rem 0 0;color:var(--hotel-text-secondary);font-size:.9rem}.btn-primary,.btn-secondary{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:.9rem;transition:all .2s}.btn-primary{background:#1e40af;color:#fff}.btn-primary:hover{background:#1e3a8a;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.btn-secondary{background:var(--hotel-card-background);color:#4b5563;border:1px solid var(--hotel-border)}.btn-secondary:hover{background:var(--hotel-surface-light);border-color:#1e40af;color:#1e40af}.inventario-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.inventario-toolbar{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.btn-toolbar{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--hotel-card-background);color:var(--hotel-text);border:1px solid var(--hotel-border);border-radius:8px;cursor:pointer;font-weight:500;font-size:.875rem;transition:all .2s}.btn-toolbar:hover{background:var(--hotel-surface-light);border-color:#1e40af;color:#1e40af;transform:translateY(-1px);box-shadow:0 2px 8px #1e40af26}.btn-toolbar svg{font-size:1rem}.stat-card{background:var(--hotel-card-background);padding:1.5rem;border-radius:12px;border:2px solid var(--hotel-border);cursor:pointer;transition:all .2s}.stat-card:hover{border-color:#1e40af;transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf626}.stat-card.stat-warning{border-color:#f59e0b;background:#fffbeb}.stat-card.stat-warning:hover{border-color:#d97706}.stat-value{font-size:2rem;font-weight:700;color:var(--hotel-text);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.warning-icon{font-size:1.5rem;color:#f59e0b}.stat-label{color:var(--hotel-text-secondary);font-size:.9rem;font-weight:500}.inventario-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--hotel-border);flex-wrap:wrap}.tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-weight:500;color:var(--hotel-text-secondary);transition:all .2s;position:relative;bottom:-2px}.tab:hover{color:#1e40af;background:var(--hotel-surface-light)}.tab.active{color:#1e40af;border-bottom-color:#1e40af}.tab.tab-warning.active{color:#f59e0b;border-bottom-color:#f59e0b}.inventario-filtros{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:flex-end}.filtro-busqueda{flex:1;min-width:250px;display:flex;align-items:center;gap:.75rem;background:var(--hotel-card-background);padding:.75rem 1rem;border:1px solid var(--hotel-border);border-radius:8px}.filtro-busqueda svg{color:#9ca3af;font-size:1.1rem}.filtro-busqueda input{flex:1;border:none;outline:none;font-size:.95rem}.filtro-select{padding:.75rem 1rem;border:1px solid var(--hotel-border);border-radius:8px;background:var(--hotel-card-background);cursor:pointer;font-size:.95rem;min-width:200px}.filtro-select:focus{outline:none;border-color:#1e40af}.filtro-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#4b5563;cursor:pointer;-webkit-user-select:none;user-select:none}.filtro-checkbox input{width:18px;height:18px;cursor:pointer}.inventario-tabla-container{background:var(--hotel-card-background);border-radius:12px;border:1px solid var(--hotel-border);overflow:hidden}.inventario-tabla{width:100%;border-collapse:collapse}.inventario-tabla thead{background:var(--hotel-surface-light);border-bottom:2px solid var(--hotel-border)}.inventario-tabla th{padding:1rem;text-align:left;font-weight:600;color:var(--hotel-text);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.inventario-tabla td{padding:1rem;border-bottom:1px solid var(--hotel-border)}.inventario-tabla tbody tr{transition:background .15s}.inventario-tabla tbody tr:hover{background:var(--hotel-surface-light)}.inventario-tabla tbody tr.row-inactiva{opacity:.5;background:#fafafa}.codigo{font-family:Courier New,monospace;background:var(--hotel-surface-light);padding:.25rem .5rem;border-radius:4px;font-size:.85rem;color:var(--hotel-text-secondary)}.item-nombre{display:flex;flex-direction:column;gap:.25rem}.item-nombre strong{color:var(--hotel-text);font-size:.95rem}.item-nombre small{color:var(--hotel-text-secondary);font-size:.8rem}.tipo-badge{display:inline-block;padding:.35rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.tipo-badge.tipo-producto{background:#dbeafe;color:#1e40af}.tipo-badge.tipo-servicio{background:#d1fae5;color:#065f46}.categoria-badge{display:inline-block;padding:.35rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;color:#fff}.stock-cantidad{font-weight:600;color:var(--hotel-text)}.stock-unidad{font-size:.8rem;color:var(--hotel-text-secondary)}.stock-na{color:#9ca3af;font-style:italic}.stock-badge{display:inline-block;padding:.35rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.stock-badge.stock-ok{background:#d1fae5;color:#065f46}.stock-badge.stock-bajo,.stock-badge.stock-agotado{background:#fee2e2;color:#991b1b}.stock-badge.stock-servicio{background:#f3f4f6;color:#6b7280}.acciones{display:flex;gap:.5rem}.btn-accion{padding:.5rem .75rem;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s}.btn-editar{background:#eff6ff;color:#3b82f6}.btn-editar:hover{background:#3b82f6;color:#fff}.btn-stock{background:#f0fdf4;color:#16a34a}.btn-stock:hover{background:#16a34a;color:#fff}.btn-historial{background:#ede9fe;color:#1e3a8a}.btn-historial:hover{background:#1e3a8a;color:#fff}.loading-state,.empty-state{padding:4rem 2rem;text-align:center;color:#9ca3af}.empty-state{display:flex;flex-direction:column;align-items:center;gap:1rem}.empty-state svg{font-size:4rem;color:#d1d5db}.empty-state p{font-size:1.1rem;margin:0}@media (max-width: 1200px){.inventario-tabla{font-size:.9rem}.inventario-tabla th,.inventario-tabla td{padding:.75rem .5rem}}@media (max-width: 768px){.inventario-page{padding:1rem}.inventario-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%;justify-content:flex-start}.inventario-stats{grid-template-columns:repeat(2,1fr)}.inventario-filtros{flex-direction:column}.filtro-busqueda,.filtro-select{width:100%}.inventario-tabla-container{overflow-x:auto}.inventario-tabla{min-width:900px}}.ajustar-stock-modal{background:var(--hotel-card-background);border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.ajustar-stock-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#10b981,#34d399);color:#fff;border-bottom:1px solid rgba(255,255,255,.1)}.ajustar-stock-header h2{margin:0;font-size:1.5rem;font-weight:600}.item-info-card{background:var(--hotel-surface-light);padding:1.5rem;border-bottom:1px solid var(--hotel-border)}.item-info-card h3{margin:0 0 .5rem;color:var(--hotel-text);font-size:1.25rem}.item-codigo{margin:0 0 1rem;color:var(--hotel-text-secondary);font-size:.9rem;font-family:Courier New,monospace}.stock-actual-display,.stock-minimo-display{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--hotel-card-background);border-radius:6px;margin-bottom:.5rem}.stock-actual-display .label,.stock-minimo-display .label{font-weight:500;color:var(--hotel-text-secondary)}.stock-actual-display .valor{font-weight:700;font-size:1.1rem;color:var(--hotel-text)}.stock-minimo-display .valor{font-weight:600;color:var(--hotel-text-secondary)}.ajustar-stock-form{padding:1.5rem;overflow-y:auto;flex:1}.form-group label{display:block;font-weight:500;color:var(--hotel-text);font-size:.9rem;margin-bottom:.5rem}.tipo-movimiento-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.tipo-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;border:2px solid var(--hotel-border);background:var(--hotel-card-background);border-radius:8px;cursor:pointer;font-weight:500;color:var(--hotel-text-secondary);transition:all .2s}.tipo-btn:hover{border-color:var(--hotel-border);background:var(--hotel-surface-light)}.tipo-btn.active{font-weight:600;color:#fff}.tipo-btn.active.entrada{background:#10b981;border-color:#10b981}.tipo-btn.active.salida{background:#ef4444;border-color:#ef4444}.tipo-btn.active.ajuste{background:#f59e0b;border-color:#f59e0b}.tipo-btn.active.devolucion{background:#3b82f6;border-color:#3b82f6}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.95rem;font-family:inherit;transition:all .2s;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.preview-card{background:#f0fdf4;border:2px solid #10b981;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.preview-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.preview-row span{color:#065f46;font-weight:500}.preview-row strong{font-size:1.1rem;color:#065f46}.preview-row.diferencia{border-top:1px solid #86efac;border-bottom:1px solid #86efac;padding:.75rem 0;margin:.5rem 0}.preview-row.diferencia.positiva strong{color:#10b981}.preview-row.diferencia.negativa strong{color:#ef4444}.preview-row.nuevo-stock{padding-top:.75rem}.preview-row.nuevo-stock strong{font-size:1.3rem;color:#059669}.preview-row.nuevo-stock strong.stock-bajo{color:#f59e0b}.alerta-stock-bajo{background:#fef3c7;color:#92400e;padding:.75rem;border-radius:6px;margin-top:.75rem;font-weight:500;font-size:.9rem;text-align:center}.motivos-sugeridos{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.motivo-sugerido{padding:.5rem .75rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:6px;cursor:pointer;font-size:.85rem;color:var(--hotel-text-secondary);transition:all .2s}.motivo-sugerido:hover{background:var(--hotel-surface-light);border-color:#10b981;color:#10b981}.form-actions{display:flex;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--hotel-border)}.btn-guardar{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 2rem;background:#10b981;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;transition:all .2s}.btn-guardar:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.btn-cancelar{padding:.875rem 2rem;background:var(--hotel-card-background);color:var(--hotel-text-secondary);border:2px solid var(--hotel-border);border-radius:8px;cursor:pointer;font-weight:500;font-size:1rem;transition:all .2s}.btn-cancelar:hover{background:var(--hotel-surface-light);border-color:#9ca3af;color:var(--hotel-text)}@media (max-width: 768px){.ajustar-stock-modal{width:95%}.tipo-movimiento-buttons{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-guardar,.btn-cancelar{width:100%}}.ingreso-masivo-modal{background:var(--hotel-card-background);border-radius:12px;width:95%;max-width:1400px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.ingreso-masivo-modal .modal-header{padding:1.5rem 2rem;border-bottom:1px solid var(--hotel-border);display:flex;justify-content:space-between;align-items:flex-start}.ingreso-masivo-modal .modal-title{font-size:1.5rem;font-weight:700;color:var(--hotel-text);margin:0 0 .25rem;display:flex;align-items:center;gap:.75rem}.ingreso-masivo-modal .modal-subtitle{color:var(--hotel-text-secondary);font-size:.95rem;margin:0}.ingreso-masivo-modal .btn-icon{background:transparent;border:none;cursor:pointer;color:var(--hotel-text-secondary);padding:.5rem;border-radius:6px;transition:all .2s}.ingreso-masivo-modal .btn-icon:hover{background:var(--hotel-surface-light);color:var(--hotel-text)}.ingreso-masivo-modal .modal-tabs{display:flex;gap:.5rem;padding:0 2rem;border-bottom:1px solid var(--hotel-border)}.ingreso-masivo-modal .modal-tabs .tab{background:transparent;border:none;padding:1rem 1.5rem;font-size:1rem;font-weight:600;color:var(--hotel-text-secondary);cursor:pointer;border-bottom:3px solid transparent;transition:all .2s}.ingreso-masivo-modal .modal-tabs .tab:hover{color:#1e40af}.ingreso-masivo-modal .modal-tabs .tab.active{color:#1e40af;border-bottom-color:#1e40af}.ingreso-masivo-modal .alert{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;margin:0;border-bottom:1px solid #e5e7eb;font-size:.95rem}.ingreso-masivo-modal .alert-success{background:#d1fae5;color:#065f46}.ingreso-masivo-modal .alert-error{background:#fee2e2;color:#991b1b}.ingreso-masivo-modal .instrucciones{padding:1rem 2rem;background:var(--hotel-surface-light);border-bottom:1px solid var(--hotel-border)}.ingreso-masivo-modal .instrucciones p{margin:0;font-size:.9rem;color:var(--hotel-text-secondary)}.ingreso-masivo-modal .requerido{color:#ef4444;font-weight:700}.ingreso-masivo-modal .tabla-container{flex:1;overflow:auto;padding:1.5rem 2rem;background:#fafafa}.tabla-masiva{width:100%;border-collapse:separate;border-spacing:0;background:var(--hotel-card-background);border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.tabla-masiva thead{background:var(--hotel-surface-light);position:sticky;top:0;z-index:10}.tabla-masiva th{padding:.75rem;text-align:left;font-size:.85rem;font-weight:700;color:var(--hotel-text);text-transform:uppercase;border-bottom:2px solid var(--hotel-border)}.tabla-masiva tbody tr{border-bottom:1px solid var(--hotel-border);transition:background .2s}.tabla-masiva tbody tr:hover{background:var(--hotel-surface-light)}.tabla-masiva tbody tr.fila-error{background:#fef2f2}.tabla-masiva td{padding:.5rem .75rem;vertical-align:top}.tabla-masiva .num-fila{text-align:center;color:#9ca3af;font-weight:600;font-size:.85rem}.input-tabla{width:100%;padding:.5rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.9rem;transition:all .2s}.input-tabla:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.input-tabla.error{border-color:#ef4444;background:#fef2f2}.input-tabla.error:focus{box-shadow:0 0 0 3px #ef44441a}.error-msg{display:block;font-size:.75rem;color:#ef4444;margin-top:.25rem;font-weight:500}.tabla-masiva select.input-tabla{cursor:pointer}.tabla-masiva .btn-delete{color:#ef4444;padding:.375rem}.tabla-masiva .btn-delete:hover{background:#fee2e2;color:#b91c1c}.ingreso-masivo-modal .acciones-tabla{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;border-top:1px solid var(--hotel-border);background:var(--hotel-card-background)}.ingreso-masivo-modal .contador-filas{font-size:.9rem;color:var(--hotel-text-secondary);font-weight:600}.ingreso-masivo-modal .modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid var(--hotel-border);background:var(--hotel-surface-light)}.ingreso-masivo-modal .btn-primary,.ingreso-masivo-modal .btn-secondary{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;border:none;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.ingreso-masivo-modal .btn-primary{background:#1e40af;color:#fff}.ingreso-masivo-modal .btn-primary:hover:not(:disabled){background:#1e3a8a;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.ingreso-masivo-modal .btn-primary:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed}.ingreso-masivo-modal .btn-secondary{background:var(--hotel-card-background);color:var(--hotel-text);border:1px solid var(--hotel-border)}.ingreso-masivo-modal .btn-secondary:hover:not(:disabled){background:var(--hotel-surface-light);border-color:#9ca3af}.ingreso-masivo-modal .btn-secondary:disabled{color:#9ca3af;cursor:not-allowed}@media (max-width: 768px){.ingreso-masivo-modal{width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0}.ingreso-masivo-modal .modal-header,.ingreso-masivo-modal .instrucciones,.ingreso-masivo-modal .tabla-container,.ingreso-masivo-modal .acciones-tabla,.ingreso-masivo-modal .modal-footer{padding-left:1rem;padding-right:1rem}.tabla-masiva{font-size:.85rem}.tabla-masiva th,.tabla-masiva td{padding:.5rem}.input-tabla{font-size:.85rem;padding:.375rem}}.historial-modal{background:var(--hotel-card-background);border-radius:12px;width:90%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.historial-modal .modal-header{padding:1.5rem 2rem;border-bottom:1px solid var(--hotel-border);display:flex;justify-content:space-between;align-items:flex-start}.historial-modal .modal-title{font-size:1.5rem;font-weight:700;color:var(--hotel-text);margin:0 0 .25rem;display:flex;align-items:center;gap:.75rem}.historial-modal .modal-subtitle{color:var(--hotel-text-secondary);font-size:.95rem;margin:0;font-weight:500}.historial-modal .btn-icon{background:transparent;border:none;cursor:pointer;color:var(--hotel-text-secondary);padding:.5rem;border-radius:6px;transition:all .2s}.historial-modal .btn-icon:hover{background:var(--hotel-surface-light);color:var(--hotel-text)}.filtros-container{padding:1rem 2rem;background:var(--hotel-surface-light);border-bottom:1px solid var(--hotel-border)}.filtros-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-weight:600;color:var(--hotel-text);font-size:.95rem}.btn-limpiar{margin-left:auto;background:transparent;border:1px solid var(--hotel-border);padding:.375rem .875rem;border-radius:6px;font-size:.85rem;color:var(--hotel-text-secondary);cursor:pointer;transition:all .2s}.btn-limpiar:hover{background:var(--hotel-card-background);border-color:#9ca3af;color:var(--hotel-text)}.filtros-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.filtro-field{display:flex;flex-direction:column;gap:.375rem}.filtro-field label{font-size:.85rem;font-weight:600;color:#4b5563}.filtro-field select,.filtro-field input[type=date]{padding:.5rem .75rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.9rem;transition:all .2s}.filtro-field select:focus,.filtro-field input[type=date]:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.historial-modal .modal-content{flex:1;overflow-y:auto;padding:2rem}.loading-state,.empty-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;color:var(--hotel-text-secondary)}.loading-state .spinner{animation:spin 1s linear infinite;color:#1e40af}.empty-state svg{color:#d1d5db;margin-bottom:1rem}.empty-state h3{color:var(--hotel-text);margin:.5rem 0;font-size:1.25rem}.empty-state p{margin:0;font-size:.95rem}.error-state .error-text{color:#ef4444;font-weight:600}.timeline{position:relative;padding-left:2rem}.timeline-item{position:relative;padding-bottom:2rem}.timeline-line{position:absolute;left:20px;top:50px;bottom:0;width:2px;background:var(--hotel-border)}.timeline-dot{position:absolute;left:0;top:8px;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--hotel-card-background);border:3px solid;z-index:1}.timeline-dot--entrada{border-color:#10b981;color:#10b981}.timeline-dot--salida{border-color:#ef4444;color:#ef4444}.timeline-dot--ajuste{border-color:#f59e0b;color:#f59e0b}.timeline-dot--devolucion{border-color:#06b6d4;color:#06b6d4}.timeline-content{margin-left:3.5rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;padding:1rem 1.25rem;transition:all .2s}.timeline-content:hover{border-color:var(--hotel-border);box-shadow:0 4px 12px #00000014}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--hotel-border)}.timeline-header-left{display:flex;align-items:center;gap:.75rem}.tipo-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase}.tipo-badge--entrada{background:#d1fae5;color:#065f46}.tipo-badge--salida{background:#fee2e2;color:#991b1b}.tipo-badge--ajuste{background:#fef3c7;color:#92400e}.tipo-badge--devolucion{background:#cffafe;color:#164e63}.timeline-cantidad{font-size:.95rem;font-weight:700;color:var(--hotel-text)}.timeline-fecha{display:flex;align-items:center;gap:.375rem;font-size:.85rem;color:var(--hotel-text-secondary)}.timeline-body{display:flex;flex-direction:column;gap:.75rem}.timeline-stock{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--hotel-surface-light);border-radius:6px}.stock-info{display:flex;flex-direction:column;gap:.25rem}.stock-label{font-size:.75rem;color:var(--hotel-text-secondary);font-weight:600;text-transform:uppercase}.stock-value{font-size:1.25rem;font-weight:700;color:var(--hotel-text)}.stock-value--destacado{color:#1e40af}.stock-arrow{font-size:1.5rem;color:#d1d5db;font-weight:300}.timeline-motivo{font-size:.9rem;color:var(--hotel-text-secondary);padding:.5rem .75rem;background:var(--hotel-surface-light);border-left:3px solid #1e40af;border-radius:4px}.timeline-usuario{display:flex;align-items:center;gap:.375rem;font-size:.85rem;color:var(--hotel-text-secondary)}.historial-modal .modal-footer{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.5rem 2rem;border-top:1px solid var(--hotel-border);background:var(--hotel-surface-light)}.stats-footer{display:flex;gap:2rem}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.8rem;color:var(--hotel-text-secondary);font-weight:600;text-transform:uppercase}.stat-value{font-size:1.125rem;font-weight:700;color:var(--hotel-text)}.historial-modal .btn-primary{padding:.75rem 1.5rem;background:#1e40af;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.historial-modal .btn-primary:hover{background:#1e3a8a;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}@media (max-width: 768px){.historial-modal{width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0}.filtros-grid{grid-template-columns:1fr}.timeline{padding-left:1rem}.timeline-content{margin-left:2.5rem}.timeline-stock{flex-direction:column;align-items:flex-start}.stock-arrow{transform:rotate(90deg)}.stats-footer{flex-direction:column;gap:1rem}.historial-modal .modal-footer{flex-direction:column-reverse}.historial-modal .btn-primary{width:100%}}.Modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto}.Modal__content{background:var(--hotel-card-background);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.Modal__header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,#8b5cf6,#a78bfa)}.Modal__header-title{display:flex;align-items:center;gap:.75rem;color:#fff}.Modal__header-title h2{margin:0;font-size:1.5rem;font-weight:600}.Modal__close{background:#fff3;border:none;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:background-color .2s}.Modal__close:hover{background:#ffffff4d}.Modal__form{padding:1.5rem;overflow-y:auto;flex:1}.Modal__section{margin-bottom:2rem}.Modal__section:last-of-type{margin-bottom:0}.Modal__section-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-border)}.Modal__section-header svg{color:var(--color-primary)}.Modal__section-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--color-text-primary)}.Modal__form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.Modal__form-row:last-child{margin-bottom:0}.Modal__form-group{display:flex;flex-direction:column;gap:.5rem}.Modal__form-group--full{grid-column:1 / -1}.Modal__form-group label{font-size:.875rem;font-weight:500;color:var(--color-text-primary);display:flex;align-items:center;gap:.5rem}.Modal__form-group label svg{color:var(--color-primary)}.Modal__form-group label .required{color:#ef4444}.Modal__form-group input,.Modal__form-group select,.Modal__form-group textarea{padding:.625rem;border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.Modal__form-group input:focus,.Modal__form-group select:focus,.Modal__form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #8b5cf61a}.Modal__form-group input:disabled,.Modal__form-group select:disabled{background-color:var(--color-background);cursor:not-allowed;opacity:.6}.Modal__form-group input.error,.Modal__form-group select.error{border-color:#ef4444}.Modal__form-group input.error:focus,.Modal__form-group select.error:focus{box-shadow:0 0 0 3px #ef44441a}.error-message{color:#ef4444;font-size:.75rem;margin-top:-.25rem}.Modal__footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid var(--color-border);background:var(--color-background)}.input-disabled{background-color:var(--hotel-surface-light);color:var(--hotel-text-secondary);cursor:not-allowed}.input-small{max-width:80px}.help-text{display:block;margin-top:4px;font-size:12px;color:var(--hotel-text-secondary)}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;margin-top:.5rem}.checkbox-label input[type=checkbox]{width:auto;margin:0;cursor:pointer}.checkbox-label span{font-size:.875rem;color:var(--color-text-primary)}.municipio-selector{position:relative}.municipio-input-wrapper{position:relative;display:flex;align-items:center}.municipio-input-wrapper input{flex:1;padding-right:35px}.btn-clear-municipio{position:absolute;right:10px;background:transparent;border:none;color:var(--hotel-text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.btn-clear-municipio:hover{color:#ef4444}.municipios-dropdown{position:absolute;top:100%;left:0;right:0;max-height:300px;overflow-y:auto;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;box-shadow:var(--shadow-md);z-index:1000;margin-top:4px}.municipio-item{width:100%;padding:12px 16px;background:var(--hotel-card-background);border:none;border-bottom:1px solid var(--hotel-border);text-align:left;cursor:pointer;transition:background .15s}.municipio-item:hover{background:var(--hotel-surface-light)}.municipio-item:last-child{border-bottom:none}.municipio-nombre{font-size:14px;font-weight:500;color:var(--hotel-text);margin-bottom:4px}.municipio-codigo{font-size:12px;color:var(--hotel-text-secondary)}.loading-small,.no-results-small{padding:16px;text-align:center;color:var(--hotel-text-secondary);font-size:14px}@media (max-width: 768px){.Modal{padding:0;align-items:flex-end}.Modal__content{max-width:100%;max-height:95vh;border-radius:12px 12px 0 0}.Modal__form-row{grid-template-columns:1fr}.Modal__header-title h2{font-size:1.25rem}}.ClienteDetalle__overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;overflow-y:auto}.ClienteDetalle__modal{background:var(--hotel-card-background);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.ClienteDetalle__header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,#8b5cf6,#a78bfa)}.ClienteDetalle__header-title{display:flex;align-items:center;gap:.75rem;color:#fff}.ClienteDetalle__header-title h2{margin:0;font-size:1.5rem;font-weight:600}.ClienteDetalle__close{background:#fff3;border:none;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:background-color .2s}.ClienteDetalle__close:hover{background:#ffffff4d}.ClienteDetalle__content{padding:1.5rem;overflow-y:auto;flex:1}.ClienteDetalle__section{margin-bottom:2rem;background:var(--hotel-surface-light);padding:1.5rem;border-radius:12px}.ClienteDetalle__section:last-child{margin-bottom:0}.ClienteDetalle__section-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--hotel-border)}.ClienteDetalle__section-header svg{color:var(--color-primary)}.ClienteDetalle__section-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--hotel-text)}.ClienteDetalle__info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.ClienteDetalle__info-item{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:var(--hotel-card-background);border-radius:8px;border:1px solid var(--hotel-border)}.ClienteDetalle__info-item .label{font-weight:500;color:var(--hotel-text-secondary);font-size:.875rem}.ClienteDetalle__info-item .value{color:var(--hotel-text);font-size:.875rem}.ClienteDetalle__info-item .icon{color:var(--color-primary);flex-shrink:0}.badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-success{background-color:#d1fae5;color:#10b981}.badge-neutral{background-color:var(--hotel-surface-light);color:var(--hotel-text-secondary)}.ClienteDetalle__observaciones{margin-top:1rem;padding:1rem;background:var(--hotel-card-background);border-radius:8px;border:1px solid var(--hotel-border)}.ClienteDetalle__observaciones strong{display:block;margin-bottom:.5rem;color:var(--hotel-text-secondary);font-size:.875rem}.ClienteDetalle__observaciones p{margin:0;color:var(--hotel-text);font-size:.875rem;line-height:1.5}.ClienteDetalle__huespedes-list{display:flex;flex-direction:column;gap:.75rem}.ClienteDetalle__huesped-card{background:var(--hotel-card-background);padding:1rem;border-radius:8px;border:1px solid var(--hotel-border);transition:box-shadow .2s}.ClienteDetalle__huesped-card:hover{box-shadow:0 4px 6px -1px #0000001a}.huesped-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.huesped-header h4{font-size:.938rem;font-weight:600;color:var(--hotel-text);margin:0}.huesped-fecha{font-size:.75rem;color:var(--hotel-text-secondary)}.huesped-info{display:flex;flex-wrap:wrap;gap:1rem;font-size:.813rem;color:var(--hotel-text-secondary)}.huesped-info span{display:flex;align-items:center;gap:.25rem}.ClienteDetalle__loading,.ClienteDetalle__error,.ClienteDetalle__no-data{text-align:center;padding:2rem;font-size:.875rem}.ClienteDetalle__loading{color:var(--hotel-text-secondary)}.ClienteDetalle__error{color:#ef4444}.ClienteDetalle__no-data{color:var(--hotel-text-secondary);font-style:italic}@media (max-width: 768px){.ClienteDetalle__overlay{padding:0;align-items:flex-end}.ClienteDetalle__modal{max-width:100%;max-height:95vh;border-radius:12px 12px 0 0}.ClienteDetalle__info-grid{grid-template-columns:1fr}.ClienteDetalle__header-title h2{font-size:1.25rem}.huesped-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.ClientesPage{padding:2rem;max-width:1400px;margin:0 auto}.ClientesPage__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.ClientesPage__header-title{display:flex;align-items:center;gap:1rem}.ClientesPage__header-title svg{color:var(--hotel-primary)}.ClientesPage__header-title h1{margin:0;font-size:1.75rem;color:var(--hotel-text)}.ClientesPage__header-title p{margin:.25rem 0 0;font-size:.875rem;color:var(--hotel-text-secondary)}.ClientesPage__filters{background:var(--hotel-card-background);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}.ClientesPage__filters-row{display:grid;grid-template-columns:2fr 1.5fr auto 1fr;gap:1rem;align-items:end}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:500;color:var(--hotel-text);display:flex;align-items:center;gap:.5rem}.filter-group label svg{color:var(--hotel-primary)}.filter-group input[type=text],.filter-group select{padding:.625rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.875rem;transition:border-color .2s;background:var(--hotel-card-background);color:var(--hotel-text)}.filter-group input[type=text]:focus,.filter-group select:focus{outline:none;border-color:var(--hotel-primary);box-shadow:0 0 0 3px #8b5cf61a}.filter-group--checkbox{flex-direction:row;align-items:center}.filter-group--checkbox label{flex-direction:row;cursor:pointer;-webkit-user-select:none;user-select:none}.filter-group--checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--hotel-primary)}.filter-actions{display:flex;gap:.625rem;align-self:end}.filter-actions .button{padding:.5rem 1rem;font-weight:600;font-size:.8125rem;border-radius:6px;letter-spacing:.3px}.ClientesPage__results{background:var(--hotel-card-background);border-radius:8px;box-shadow:var(--shadow-sm);overflow:hidden}.ClientesPage__results-header{padding:1rem 1.5rem;border-bottom:1px solid var(--hotel-border);background:var(--hotel-background)}.ClientesPage__results-header p{margin:0;font-size:.875rem;color:var(--hotel-text-secondary);font-weight:500}.ClientesPage__table-container{overflow-x:auto}.ClientesPage__table{width:100%;border-collapse:collapse;font-size:.875rem}.ClientesPage__table thead{background:var(--hotel-background);border-bottom:2px solid var(--hotel-border)}.ClientesPage__table th{padding:.875rem 1rem;text-align:left;font-weight:600;color:var(--hotel-text);font-size:.8125rem;text-transform:uppercase;letter-spacing:.5px}.ClientesPage__table tbody tr{border-bottom:1px solid var(--hotel-border);transition:background-color .2s}.ClientesPage__table tbody tr:hover{background-color:var(--hotel-surface-light)}.ClientesPage__table tbody tr:last-child{border-bottom:none}.ClientesPage__table td{padding:1rem;color:var(--hotel-text)}.ClientesPage__table-row--inactive{opacity:.6;background-color:#fee2e2!important}[data-theme=dark] .ClientesPage__table-row--inactive{background-color:#ef44441a!important}.ClientesPage__table-cell--nombre{display:flex;align-items:center;gap:.5rem;font-weight:500}.ClientesPage__table-cell--nombre svg{color:var(--hotel-primary);flex-shrink:0}.ClientesPage__table-cell--email,.ClientesPage__table-cell--phone{display:flex;align-items:center;gap:.5rem;color:var(--hotel-text-secondary)}.ClientesPage__table-cell--email svg,.ClientesPage__table-cell--phone svg{color:var(--hotel-primary);flex-shrink:0}.ClientesPage__table-empty{text-align:center;padding:3rem 1rem!important;color:var(--hotel-text-secondary);font-style:italic}.ClientesPage__table-actions{display:flex;gap:.5rem;justify-content:flex-end}.action-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;transition:all .2s;background:transparent}.action-btn:hover{transform:translateY(-1px)}.action-btn--info{color:#06b6d4;background:#06b6d41a}.action-btn--info:hover{background:#06b6d433}.action-btn--edit{color:var(--hotel-primary);background:#8b5cf61a}.action-btn--edit:hover{background:#8b5cf633}.action-btn--delete{color:#ef4444;background:#ef44441a}.action-btn--delete:hover{background:#ef444433}@media (max-width: 1200px){.ClientesPage__filters-row{grid-template-columns:1fr 1fr}.filter-actions{grid-column:1 / -1;justify-content:flex-start}}@media (max-width: 768px){.ClientesPage{padding:1rem}.ClientesPage__header{flex-direction:column;align-items:stretch}.ClientesPage__header-title h1{font-size:1.5rem}.ClientesPage__filters-row{grid-template-columns:1fr}.ClientesPage__table{font-size:.8125rem}.ClientesPage__table th,.ClientesPage__table td{padding:.75rem .5rem}.ClientesPage__table th:nth-child(4),.ClientesPage__table td:nth-child(4),.ClientesPage__table th:nth-child(6),.ClientesPage__table td:nth-child(6){display:none}}.filtros-reporte{background:var(--hotel-card-background);padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.filtros-reporte__campos{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap}.filtros-reporte__rapidos{display:flex;gap:.75rem;align-items:center;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--hotel-border)}.filtros-reporte__rapidos-label{font-size:.875rem;color:var(--hotel-text-secondary);font-weight:500}.filtros-reporte__rapidos button{padding:.5rem 1rem;border:1px solid #d1d5db;background:var(--hotel-card-background);border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s}.filtros-reporte__rapidos button:hover{background:var(--hotel-surface-light);border-color:#1e40af;color:#1e40af}.filtros-reporte__error{margin-top:.75rem;padding:.75rem;background:#fee2e2;color:#dc2626;border-radius:6px;font-size:.875rem}.composicion-ingresos{display:grid;gap:1.5rem;background:var(--hotel-card-background);padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a}.composicion-item{display:flex;flex-direction:column;gap:.5rem}.composicion-item__header{display:flex;justify-content:space-between;align-items:center}.composicion-item__label{font-weight:600;color:var(--hotel-text)}.composicion-item__porcentaje{font-size:.875rem;color:var(--hotel-text-secondary);font-weight:500}.composicion-item__barra{height:32px;background:var(--hotel-surface-light);border-radius:6px;overflow:hidden}.composicion-item__fill{height:100%;transition:width .3s ease}.composicion-item__fill--primary{background:linear-gradient(90deg,#1e40af,#3b82f6)}.composicion-item__fill--success{background:linear-gradient(90deg,#10b981,#34d399)}.composicion-item__valor{font-size:1.25rem;font-weight:700;color:var(--hotel-text)}@media (max-width: 768px){.composicion-ingresos{padding:1rem}.composicion-item__barra{height:24px}.composicion-item__valor{font-size:1rem}}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600}.badge--primary{background:#ede9fe;color:#1e40af}.badge--success{background:#d1fae5;color:#10b981}.badge--warning{background:#fef3c7;color:#f59e0b}.reporte-card__icon--warning{background:linear-gradient(135deg,#f59e0b,#fbbf24)}@media (max-width: 768px){.badge{padding:.2rem .5rem;font-size:.75rem}}.badge--danger{background:#fee2e2;color:#ef4444}.reporte-card__icon--danger{background:linear-gradient(135deg,#ef4444,#f87171)}.reporte-card--wide{grid-column:span 1}.porcentaje-bar{position:relative;width:100%;height:24px;background:var(--hotel-surface-light);border-radius:4px;overflow:hidden}.porcentaje-bar__fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#1e40af,#3b82f6);transition:width .3s ease}.porcentaje-bar__label{position:relative;display:flex;align-items:center;justify-content:center;height:100%;font-size:.875rem;font-weight:600;color:var(--hotel-text);z-index:1}@media (max-width: 768px){.reporte-card--wide{grid-column:span 1}.porcentaje-bar{height:20px}.porcentaje-bar__label{font-size:.75rem}}.badge--info{background:#dbeafe;color:#3b82f6}code{background:var(--hotel-surface-light);padding:.25rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.875rem;color:var(--hotel-text)}.stock-actual{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-weight:600}.stock-actual--bajo{background:#fee2e2;color:#ef4444}.diferencia{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-weight:600}.diferencia--negativa{background:#fef3c7;color:#f59e0b}.cantidad-consumida{font-weight:700;color:#1e40af;font-size:1.1rem}.reporte-seccion__titulo{display:flex;align-items:center}@media (max-width: 768px){code{font-size:.75rem;padding:.2rem .4rem}.stock-actual,.diferencia{padding:.2rem .5rem;font-size:.875rem}.cantidad-consumida{font-size:1rem}}.reporte-metodos-pago{padding:0}@media (max-width: 768px){.reporte-cards{grid-template-columns:1fr;gap:1rem}.reporte-section{padding:1.25rem}.reporte-section-title{font-size:1.125rem}.reporte-card__value{font-size:1.5rem}.reporte-card__value-small{font-size:1.125rem}.reporte-table{font-size:.8125rem}.reporte-table th,.reporte-table td{padding:.75rem .5rem}}.reporte-cierre-caja{padding:0}.filtros-cierre-caja{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:var(--hotel-card-background);border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.filtro-fecha{display:flex;align-items:center;gap:.75rem}.filtro-fecha label{font-weight:600;color:var(--hotel-text);font-size:.9375rem}.filtro-fecha input[type=date]{padding:.625rem 1rem;border:2px solid var(--hotel-border);border-radius:8px;font-size:.9375rem;transition:all .2s}.filtro-fecha input[type=date]:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.btn-generar{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s}.btn-generar:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf64d}.btn-generar:active{transform:translateY(0)}.reporte-header-cierre{margin-bottom:2rem}.reporte-header-cierre h2{font-size:1.75rem;font-weight:700;color:var(--hotel-text);text-align:center;text-transform:capitalize}.reporte-card__icon--primary{background:#1e40af1a;color:#1e40af}.reporte-card__value-small{font-size:1.125rem;font-weight:700;color:var(--hotel-text);line-height:1.3}.resumen-final{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:2px solid #8b5cf6}.resumen-final h3{font-size:1.25rem;font-weight:700;color:var(--hotel-text);margin-bottom:1.5rem;text-align:center}.resumen-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.resumen-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:var(--hotel-card-background);border-radius:10px;box-shadow:0 2px 6px #0000000d}.resumen-label{font-size:1rem;font-weight:600;color:var(--hotel-text)}.resumen-valor{font-size:1.5rem;font-weight:700;color:var(--hotel-text)}.resumen-pendiente{border-left:4px solid #f59e0b}.resumen-pendiente .resumen-valor{color:#f59e0b}.resumen-cuadrado{border-left:4px solid #10b981}.resumen-cuadrado .resumen-valor{color:#10b981}.reporte-placeholder p{font-size:.9375rem;color:#9ca3af}@media (max-width: 768px){.reporte-cards{grid-template-columns:1fr;gap:1rem}.reporte-section{padding:1.25rem}.reporte-section-title{font-size:1.125rem}.reporte-card__value{font-size:1.5rem}.reporte-card__value-small{font-size:1rem}.reporte-table{font-size:.8125rem}.reporte-table th,.reporte-table td{padding:.75rem .5rem}.filtros-cierre-caja{flex-direction:column;align-items:stretch}.resumen-grid{grid-template-columns:1fr}.resumen-valor{font-size:1.25rem}}.reporte-adr{padding:0}.reporte-card__value-small{font-size:1.25rem;font-weight:700;color:var(--hotel-text);line-height:1.3}.badge--warning{background-color:#fef3c7;color:#92400e}.explicacion-indicadores{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:2px solid #8b5cf6}.explicacion-indicadores h3{font-size:1.25rem;font-weight:700;color:var(--hotel-text);margin-bottom:1.5rem;text-align:center}.indicadores-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.indicador-card{display:flex;gap:1rem;padding:1.5rem;background:var(--hotel-card-background);border-radius:10px;box-shadow:0 2px 6px #0000000d}.indicador-card__icon{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.indicador-card__content{flex:1}.indicador-card__content h4{font-size:1rem;font-weight:700;color:var(--hotel-text);margin-bottom:.5rem}.indicador-card__content p{font-size:.875rem;color:var(--hotel-text-secondary);margin-bottom:.5rem;line-height:1.5}.indicador-card__content p strong{color:var(--hotel-text)}.reporte-placeholder p{font-size:.9375rem;color:#9ca3af;margin-bottom:2rem}.indicadores-info{max-width:600px;margin-top:2rem}.indicador-desc{padding:1rem 1.5rem;background:var(--hotel-surface-light);border-left:4px solid #8b5cf6;border-radius:8px;margin-bottom:1rem;text-align:left;font-size:.9375rem;color:var(--hotel-text)}.indicador-desc strong{color:#8b5cf6;font-weight:700}@media (max-width: 768px){.reporte-cards{grid-template-columns:1fr;gap:1rem}.reporte-section{padding:1.25rem}.reporte-section-title{font-size:1.125rem}.reporte-card__value{font-size:1.5rem}.reporte-card__value-small{font-size:1.125rem}.reporte-table{font-size:.8125rem}.reporte-table th,.reporte-table td{padding:.75rem .5rem}.indicadores-grid{grid-template-columns:1fr}.indicador-card{flex-direction:column;text-align:center}.indicador-card__icon{margin:0 auto}}.reporte-comparativo{padding:0}.selectores-periodo{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.periodo-selector{background:var(--hotel-card-background);border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.periodo-selector h3{font-size:1rem;font-weight:600;color:var(--hotel-text);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.periodo-selector h3 svg{color:#8b5cf6}.periodo-fechas{display:flex;gap:1rem;align-items:center}.fecha-input{flex:1}.fecha-input label{display:block;font-size:.8125rem;color:var(--hotel-text-secondary);margin-bottom:.375rem}.fecha-input input[type=date]{width:100%;padding:.625rem 1rem;border:2px solid var(--hotel-border);border-radius:8px;font-size:.9375rem;transition:all .2s}.fecha-input input[type=date]:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.quick-buttons{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.quick-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--hotel-surface-light);border:2px solid transparent;border-radius:8px;font-size:.875rem;font-weight:500;color:var(--hotel-text);cursor:pointer;transition:all .2s}.quick-btn:hover{background:#e5e7eb}.quick-btn.active{background:#8b5cf61a;border-color:#8b5cf6;color:#8b5cf6}.btn-comparar{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.btn-comparar:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf64d}.btn-comparar:active{transform:translateY(0)}.btn-comparar:disabled{opacity:.6;cursor:not-allowed;transform:none}.resumen-periodos{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}.periodo-card{background:var(--hotel-card-background);border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.periodo-card--anterior{border-left:4px solid #6b7280}.periodo-card h4{font-size:.875rem;font-weight:600;color:var(--hotel-text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.periodo-card .periodo-fechas-info{font-size:.9375rem;color:var(--hotel-text);font-weight:500;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--hotel-border)}.periodo-metricas{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.metrica-item{display:flex;flex-direction:column;gap:.25rem}.metrica-item span:first-child{font-size:.8125rem;color:var(--hotel-text-secondary)}.metrica-item span:last-child{font-size:1.125rem;font-weight:700;color:var(--hotel-text)}.reporte-card__value{font-size:1.5rem;font-weight:700;color:var(--hotel-text);line-height:1.2;display:flex;align-items:center;gap:.5rem}.variacion{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:6px;font-size:.875rem;font-weight:600}.variacion--positiva{background:#10b9811a;color:#10b981}.variacion--negativa{background:#ef44441a;color:#ef4444}.variacion--neutral{background:#6b72801a;color:var(--hotel-text-secondary)}.graficas-comparativas{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2.5rem}.grafica-section{margin-bottom:0}.grafica-section .reporte-section-header{margin-bottom:1rem;padding-bottom:.75rem}.grafica-section .reporte-section-title{font-size:1rem;display:flex;align-items:center;gap:.5rem}.grafica-section .reporte-chart-container{padding:.5rem 0}@media (max-width: 1200px){.graficas-comparativas{grid-template-columns:1fr;gap:1.5rem}.grafica-section{margin-bottom:0}}.reporte-table th{padding:.875rem 1rem;text-align:left;font-weight:600;color:var(--hotel-text);font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em}.reporte-placeholder p{font-size:.9375rem;color:#9ca3af;max-width:400px}.filtros-comparativo{background:var(--hotel-card-background);border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.filtros-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--hotel-surface-light)}.filtros-header h3{font-size:1.125rem;font-weight:700;color:var(--hotel-text);margin:0}.periodos-rapidos{display:flex;gap:.75rem}.periodos-rapidos button{padding:.5rem 1rem;background:var(--hotel-surface-light);border:2px solid transparent;border-radius:8px;font-size:.875rem;font-weight:500;color:var(--hotel-text);cursor:pointer;transition:all .2s}.periodos-rapidos button:hover{background:#8b5cf61a;border-color:#8b5cf6;color:#8b5cf6}.filtros-form{display:grid;grid-template-columns:1fr 1fr auto;gap:1.5rem;align-items:end}.filtros-form--compact{gap:1rem}.periodo-group{display:flex;flex-direction:column;gap:.5rem}.periodo-group--inline{flex-direction:row;align-items:center;gap:.75rem}.periodo-group--inline label{font-size:.875rem;font-weight:600;color:var(--hotel-text);white-space:nowrap}.periodo-label{font-size:.875rem;font-weight:600;color:var(--hotel-text);margin-bottom:.25rem}.periodo-fechas{display:flex;gap:.75rem;align-items:center}.periodo-fechas input[type=date]{flex:1;padding:.625rem 1rem;border:2px solid var(--hotel-border);border-radius:8px;font-size:.875rem;transition:all .2s}.periodo-fechas input[type=date]:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.periodo-fechas span{color:var(--hotel-text-secondary);font-size:.875rem}.btn-comparar--small{padding:.625rem 1.25rem;font-size:.875rem}.periodos-resumen{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}.periodo-card{display:flex;gap:1rem;background:var(--hotel-card-background);border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.periodo-card--actual{border-left:4px solid #8b5cf6}.periodo-card--anterior{border-left:4px solid #94a3b8}.periodo-card svg{flex-shrink:0;color:#8b5cf6}.periodo-card--anterior svg{color:#94a3b8}.periodo-card>div{display:flex;flex-direction:column;gap:.25rem}.periodo-etiqueta{font-size:.8125rem;font-weight:600;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em}.periodo-fechas-texto{font-size:.9375rem;font-weight:500;color:var(--hotel-text)}.periodo-dias{font-size:.8125rem;color:#9ca3af}.metricas-principales{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2.5rem}.metrica-card{background:var(--hotel-card-background);border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:all .2s}.metrica-card:hover{box-shadow:0 4px 12px #8b5cf626;transform:translateY(-2px)}.metrica-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;color:#8b5cf6}.metrica-header span{font-size:.875rem;font-weight:600;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em}.metrica-valores{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.75rem}.metrica-actual{font-size:1.75rem;font-weight:700;color:var(--hotel-text)}.metrica-anterior{font-size:1.125rem;font-weight:500;color:#9ca3af}.metrica-variacion{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:8px;font-size:.875rem;font-weight:600}.metrica-variacion.up{background:#10b9811a;color:#10b981}.metrica-variacion.down{background:#ef44441a;color:#ef4444}.metrica-variacion.stable{background:#6b72801a;color:var(--hotel-text-secondary)}.text-success{color:#10b981;font-weight:600}.text-danger{color:#ef4444;font-weight:600}@media (max-width: 1024px){.selectores-periodo{grid-template-columns:1fr;gap:1.5rem}.resumen-periodos,.periodos-resumen,.filtros-form{grid-template-columns:1fr}.metricas-principales{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}@media (max-width: 768px){.reporte-cards{grid-template-columns:1fr;gap:1rem}.reporte-section{padding:1.25rem}.reporte-section-title{font-size:1.125rem}.reporte-card__value{font-size:1.25rem}.periodo-fechas,.quick-buttons{flex-direction:column}.quick-btn{justify-content:center}.periodo-metricas{grid-template-columns:1fr}.reporte-table{font-size:.8125rem}.reporte-table th,.reporte-table td{padding:.75rem .5rem}}.reporte-fuentes-reserva{padding:0}.text-success{color:#10b981}.canal-cell{display:flex;align-items:center;gap:.75rem}.canal-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.comision-tag{display:inline-block;padding:.25rem .5rem;background:#ef44441a;color:#ef4444;border-radius:6px;font-size:.8125rem;font-weight:600}.resumen-canales{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:2px solid #8b5cf6}.resumen-canales h3{font-size:1.25rem;font-weight:700;color:var(--hotel-text);margin-bottom:1.5rem;text-align:center}.comparacion-canales{display:flex;align-items:center;justify-content:center;gap:2rem}.canal-grupo{flex:1;max-width:300px;padding:1.5rem;background:var(--hotel-card-background);border-radius:12px;text-align:center;box-shadow:0 2px 8px #0000000d}.canal-grupo--directo{border-left:4px solid #10b981}.canal-grupo--otas{border-left:4px solid #ef4444}.canal-grupo__header{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1rem}.canal-grupo__icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center}.canal-grupo--directo .canal-grupo__icon{background:#10b9811a;color:#10b981}.canal-grupo--otas .canal-grupo__icon{background:#ef44441a;color:#ef4444}.canal-grupo__titulo{font-size:.9375rem;font-weight:600;color:var(--hotel-text)}.canal-grupo__valor{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.canal-grupo--directo .canal-grupo__valor{color:#10b981}.canal-grupo--otas .canal-grupo__valor{color:#ef4444}.canal-grupo__descripcion{font-size:.875rem;color:var(--hotel-text-secondary)}.vs-divider{font-size:1.25rem;font-weight:700;color:#9ca3af;padding:0 1rem}.canales-preview{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.canal-badge{display:inline-block;padding:.5rem 1rem;border-radius:20px;font-size:.8125rem;font-weight:600;color:#fff}@media (max-width: 1024px){.comparacion-canales{flex-direction:column;gap:1rem}.canal-grupo{max-width:100%;width:100%}.vs-divider{padding:.5rem 0}}@media (max-width: 768px){.reporte-cards{grid-template-columns:1fr;gap:1rem}.reporte-section{padding:1.25rem}.reporte-section-title{font-size:1.125rem}.reporte-card__value{font-size:1.5rem}.reporte-table{font-size:.8125rem}.reporte-table th,.reporte-table td{padding:.75rem .5rem}.canal-grupo__valor{font-size:2rem}}.reporte-cancelaciones{padding:0}.reporte-card__icon--purple{background:#8b5cf61a;color:#8b5cf6}.reporte-chart-container{width:100%;padding:1rem 0}.text-danger{color:#ef4444}.tasa-badge{display:inline-block;padding:.25rem .5rem;border-radius:6px;font-size:.8125rem;font-weight:600}.tasa-badge--baja{background:#10b9811a;color:#10b981}.tasa-badge--media{background:#f59e0b1a;color:#f59e0b}.tasa-badge--alta{background:#ef44441a;color:#ef4444}.resumen-impacto{background:linear-gradient(135deg,#fef2f2,#fef3f3);border:2px solid #ef4444}.resumen-impacto h3{font-size:1.25rem;font-weight:700;color:var(--hotel-text);margin-bottom:1.5rem;text-align:center}.impacto-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.impacto-item{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--hotel-card-background);border-radius:10px;box-shadow:0 2px 6px #0000000d}.impacto-item__icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center}.impacto-item--perdido .impacto-item__icon{background:#ef44441a;color:#ef4444}.impacto-item--anticipos .impacto-item__icon{background:#f59e0b1a;color:#f59e0b}.impacto-item--tiempo .impacto-item__icon{background:#3b82f61a;color:#3b82f6}.impacto-item__content{display:flex;flex-direction:column}.impacto-item__label{font-size:.8125rem;color:var(--hotel-text-secondary);margin-bottom:.25rem}.impacto-item__valor{font-size:1.5rem;font-weight:700;color:var(--hotel-text)}.impacto-item--perdido .impacto-item__valor{color:#ef4444}.impacto-item--anticipos .impacto-item__valor{color:#f59e0b}.reporte-placeholder p{font-size:.9375rem;color:#9ca3af;max-width:400px;margin-bottom:1.5rem}.metricas-preview{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.metrica-badge{display:inline-block;padding:.5rem 1rem;border-radius:20px;font-size:.8125rem;font-weight:600}.metrica-badge--cancelada{background:#ef44441a;color:#ef4444}.metrica-badge--noshow{background:#f59e0b1a;color:#f59e0b}.metrica-badge--ingresos{background:#8b5cf61a;color:#8b5cf6}@media (max-width: 768px){.reporte-cards{grid-template-columns:1fr;gap:1rem}.reporte-section{padding:1.25rem}.reporte-section-title{font-size:1.125rem}.reporte-card__value{font-size:1.5rem}.reporte-table{font-size:.8125rem}.reporte-table th,.reporte-table td{padding:.75rem .5rem}.impacto-grid{grid-template-columns:1fr}.impacto-item__valor{font-size:1.25rem}}.reporte-libro-ventas{padding:0}.reporte-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-bottom:2.5rem}.reporte-card:hover{box-shadow:0 4px 12px #ef444426;transform:translateY(-2px)}.reporte-card__icon--primary{background:#ef44441a;color:#ef4444}.reporte-card__value{font-size:2rem;font-weight:700;color:var(--hotel-text);line-height:1.2}.reporte-section{margin-bottom:2.5rem;background:var(--hotel-card-background);border-radius:12px;padding:1.75rem;box-shadow:0 1px 3px #0000001a}.reporte-section-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--hotel-surface-light)}.reporte-section-title{font-size:1.375rem;font-weight:700;color:var(--hotel-text);margin-bottom:.25rem}.resumen-estados{background:linear-gradient(135deg,#fef2f2,#fef3f3);border:2px solid #ef4444}.estados-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.estado-card{background:var(--hotel-card-background);border-radius:10px;overflow:hidden;box-shadow:0 2px 6px #0000000d;transition:all .2s}.estado-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.estado-card__header{padding:1rem;background:var(--hotel-surface-light);border-bottom:1px solid var(--hotel-border)}.estado-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600}.estado-card__body{padding:1.25rem}.estado-stat{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--hotel-surface-light)}.estado-stat:last-child{border-bottom:none}.estado-stat--total{padding-top:1rem;margin-top:.5rem;border-top:2px solid #e5e7eb;border-bottom:none}.estado-stat__label{font-size:.875rem;color:var(--hotel-text-secondary)}.estado-stat__value{font-size:1rem;font-weight:600;color:var(--hotel-text)}.estado-stat--total .estado-stat__value{font-size:1.25rem;font-weight:700;color:#ef4444}.reporte-table tfoot{background:var(--hotel-surface-light);border-top:2px solid #ef4444}.badge{display:inline-block;padding:.375rem .75rem;border-radius:12px;font-size:.8125rem;font-weight:600}.badge--success{background-color:#d1fae5;color:#065f46}.badge--warning{background-color:#fef3c7;color:#78350f}.badge--danger{background-color:#fee2e2;color:#7f1d1d}.badge--gray{background-color:#f3f4f6;color:var(--hotel-text-secondary)}.doc-badge{display:inline-block;padding:.25rem .5rem;background:var(--hotel-surface-light);color:var(--hotel-text);border-radius:6px;font-size:.8125rem;font-weight:500}.cufe-text{font-family:Courier New,monospace;font-size:.75rem;color:var(--hotel-text-secondary);cursor:help}.info-normativa{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-left:4px solid #3b82f6}.info-normativa li{padding:.75rem 0 .75rem 1.5rem;position:relative;color:var(--hotel-text);line-height:1.6;border-bottom:1px solid rgba(59,130,246,.1)}.info-normativa li:before{content:"•";position:absolute;left:0;color:#3b82f6;font-weight:700;font-size:1.25rem}.spinner{width:48px;height:48px;border:4px solid var(--hotel-surface-light);border-top-color:#ef4444;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 768px){.reporte-header-actions{flex-direction:column;align-items:stretch}.reporte-header-actions .filtros-reporte{min-width:100%}.btn-descargar-xml{justify-content:center;padding:1rem}.reporte-cards{grid-template-columns:1fr;gap:1rem}.estados-grid{grid-template-columns:1fr}.reporte-section{padding:1.25rem}.reporte-section-title{font-size:1.125rem}.reporte-card__value{font-size:1.5rem}.reporte-table{font-size:.8125rem}.reporte-table th,.reporte-table td{padding:.75rem .5rem}}.reporte-iva{padding:0}.reporte-card:hover{box-shadow:0 4px 12px #8b5cf626;transform:translateY(-2px)}.reporte-card__icon--primary{background:#8b5cf61a;color:#8b5cf6}.reporte-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}@media (max-width: 1024px){.reporte-grid-2{grid-template-columns:1fr}}.tarifa-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.tarifa-card{background:var(--hotel-surface-light);border-radius:10px;overflow:hidden;border:1px solid var(--hotel-border)}.tarifa-card__header{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;background:linear-gradient(135deg,#8b5cf6,#a78bfa)}.tarifa-badge{font-size:1.125rem;font-weight:700;color:#fff}.tarifa-cantidad{font-size:.75rem;color:#ffffffd9}.tarifa-card__body{padding:1rem}.tarifa-stat{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.tarifa-stat:not(:last-child){border-bottom:1px solid var(--hotel-border)}.tarifa-stat__label{font-size:.8125rem;color:var(--hotel-text-secondary)}.tarifa-stat__value{font-size:.9375rem;font-weight:600;color:var(--hotel-text)}.tarifa-stat--highlight .tarifa-stat__value{color:#8b5cf6;font-size:1rem}.categoria-cards{display:flex;flex-direction:column;gap:1rem}.categoria-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--hotel-surface-light);border-radius:10px;border-left:4px solid #6b7280}.categoria-card.categoria--hospedaje{border-left-color:#8b5cf6;background:#8b5cf60d}.categoria-card.categoria--pos{border-left-color:#10b981;background:#10b9810d}.categoria-card.categoria--otro{border-left-color:#f59e0b;background:#f59e0b0d}.categoria-card__icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--hotel-card-background);color:var(--hotel-text-secondary)}.categoria--hospedaje .categoria-card__icon{color:#8b5cf6}.categoria--pos .categoria-card__icon{color:#10b981}.categoria--otro .categoria-card__icon{color:#f59e0b}.categoria-card__content{flex:1}.categoria-card__title{font-size:1rem;font-weight:600;color:var(--hotel-text);margin-bottom:.5rem}.categoria-card__stats{display:flex;gap:1.5rem}.categoria-stat{display:flex;flex-direction:column}.categoria-stat__label{font-size:.75rem;color:var(--hotel-text-secondary)}.categoria-stat__value{font-size:.9375rem;font-weight:600;color:var(--hotel-text)}.categoria-stat__value--highlight{color:#8b5cf6}.categoria-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:6px;font-size:.8125rem;font-weight:500;background:var(--hotel-surface-light);color:var(--hotel-text)}.categoria-badge.categoria--hospedaje{background:#8b5cf61a;color:#7c3aed}.categoria-badge.categoria--pos{background:#10b9811a;color:#059669}.categoria-badge.categoria--otro{background:#f59e0b1a;color:#d97706}.tarifa-mini-badge{display:inline-block;padding:.25rem .5rem;background:#8b5cf61a;color:#8b5cf6;border-radius:4px;font-size:.8125rem;font-weight:600}.reporte-table tbody tr:hover{background-color:#f9fafb}.reporte-table tfoot{background:var(--hotel-surface-light);border-top:2px solid #8b5cf6}.text-warning{color:#f59e0b}.info-normativa{background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-left:4px solid #8b5cf6}.info-normativa li{padding:.75rem 0 .75rem 1.5rem;position:relative;color:var(--hotel-text);line-height:1.6;border-bottom:1px solid rgba(139,92,246,.1)}.info-normativa li:before{content:"•";position:absolute;left:0;color:#8b5cf6;font-weight:700;font-size:1.25rem}.spinner{width:48px;height:48px;border:4px solid var(--hotel-surface-light);border-top-color:#8b5cf6;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 768px){.reporte-header-actions{flex-direction:column;align-items:stretch}.reporte-header-actions .filtros-reporte{min-width:100%}.btn-descargar-excel{justify-content:center;padding:1rem}.reporte-cards{grid-template-columns:1fr;gap:1rem}.reporte-card__value{font-size:1.5rem}.tarifa-cards{grid-template-columns:1fr}.categoria-card__stats{flex-wrap:wrap;gap:1rem}.reporte-table{font-size:.8125rem}.reporte-table th,.reporte-table td{padding:.75rem .5rem}}.reporte-ica{padding:0}.reporte-header-actions{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.reporte-header-actions .filtros-reporte{flex:1;min-width:300px}.btn-descargar-excel{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #10b9814d;transition:all .3s ease;white-space:nowrap}.btn-descargar-excel:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.btn-descargar-excel:active{transform:translateY(0);box-shadow:0 2px 8px #10b9814d}.btn-descargar-excel svg{flex-shrink:0}.alerta-ica{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:10px;margin-bottom:1.5rem;color:#92400e;font-size:.9375rem}.alerta-ica svg{flex-shrink:0;color:#f59e0b}.reporte-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.reporte-card{display:flex;gap:1rem;padding:1.5rem;background:var(--hotel-card-background);border-radius:12px;box-shadow:0 1px 3px #0000001a;transition:all .2s}.reporte-card:hover{box-shadow:0 4px 12px #06b6d426;transform:translateY(-2px)}.reporte-card__icon{width:52px;height:52px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.reporte-card__icon--primary{background:#06b6d41a;color:#06b6d4}.reporte-card__content{flex:1;display:flex;flex-direction:column;justify-content:center}.reporte-card__label{font-size:.875rem;color:var(--hotel-text-secondary);margin-bottom:.25rem;font-weight:500}.reporte-card__value{font-size:1.75rem;font-weight:700;color:var(--hotel-text);line-height:1.2}.reporte-card__extra{font-size:.8125rem;color:#9ca3af;margin-top:.25rem}.reporte-section{margin-bottom:2rem;background:var(--hotel-card-background);border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.reporte-section-header{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:2px solid var(--hotel-surface-light)}.reporte-section-title{font-size:1.25rem;font-weight:700;color:var(--hotel-text);margin-bottom:.25rem}.reporte-section-subtitle{font-size:.9375rem;color:var(--hotel-text-secondary)}.meses-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.mes-card{background:var(--hotel-surface-light);border-radius:10px;overflow:hidden;border:1px solid var(--hotel-border);transition:all .2s}.mes-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.mes-card__header{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff}.mes-nombre{font-weight:600;font-size:.9375rem;text-transform:capitalize}.mes-card__body{padding:1rem}.mes-stat{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.mes-stat:not(:last-child){border-bottom:1px solid var(--hotel-border)}.mes-stat__label{font-size:.8125rem;color:var(--hotel-text-secondary)}.mes-stat__value{font-size:.9375rem;font-weight:600;color:var(--hotel-text)}.mes-stat--highlight .mes-stat__value{color:#06b6d4;font-size:1rem}.reporte-table-container{overflow-x:auto}.reporte-table{width:100%;border-collapse:collapse;font-size:.875rem}.reporte-table thead{background:var(--hotel-surface-light);border-bottom:2px solid var(--hotel-border)}.reporte-table th{padding:.875rem 1rem;text-align:left;font-weight:600;color:var(--hotel-text);font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.reporte-table tbody tr{border-bottom:1px solid var(--hotel-surface-light);transition:background-color .15s}.reporte-table tbody tr:hover{background-color:var(--hotel-surface-light)}.reporte-table tbody tr:last-child{border-bottom:none}.reporte-table td{padding:1rem;color:var(--hotel-text)}.reporte-table tfoot{background:var(--hotel-surface-light);border-top:2px solid #06b6d4}.reporte-table tfoot td{padding:1rem;font-weight:600;color:var(--hotel-text)}.text-gray{color:#9ca3af}.text-ica{color:#06b6d4}.font-medium{font-weight:500}.info-normativa{background:linear-gradient(135deg,#ecfeff,#cffafe);border-left:4px solid #06b6d4}.info-normativa h4{font-size:1.125rem;font-weight:700;color:var(--hotel-text);margin-bottom:1rem}.info-normativa ul{list-style:none;padding:0;margin:0}.info-normativa li{padding:.75rem 0 .75rem 1.5rem;position:relative;color:var(--hotel-text);line-height:1.6;border-bottom:1px solid rgba(6,182,212,.1)}.info-normativa li:last-child{border-bottom:none}.info-normativa li:before{content:"•";position:absolute;left:0;color:#06b6d4;font-weight:700;font-size:1.25rem}.reporte-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background:var(--hotel-card-background);border-radius:12px;box-shadow:0 1px 3px #0000001a;text-align:center;color:#9ca3af}.reporte-placeholder svg{margin-bottom:1.5rem;color:#d1d5db}.reporte-placeholder h3{font-size:1.25rem;font-weight:600;color:var(--hotel-text-secondary);margin-bottom:.5rem}.reporte-placeholder p{font-size:.9375rem;color:#9ca3af;max-width:500px;margin-bottom:1.5rem}.info-dian{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.info-item{padding:.75rem 1rem;background:var(--hotel-surface-light);border-radius:8px;font-size:.875rem;color:var(--hotel-text);text-align:left}.info-item strong{color:var(--hotel-text);margin-right:.5rem}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background:var(--hotel-card-background);border-radius:12px;box-shadow:0 1px 3px #0000001a}.spinner{width:48px;height:48px;border:4px solid var(--hotel-surface-light);border-top-color:#06b6d4;border-radius:50%;animation:spin .8s linear infinite}.loading p{margin-top:1.5rem;color:var(--hotel-text-secondary);font-size:1rem}.error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background:var(--hotel-card-background);border-radius:12px;box-shadow:0 1px 3px #0000001a;text-align:center}.error svg{color:#ef4444;margin-bottom:1.5rem}.error h3{font-size:1.25rem;font-weight:600;color:var(--hotel-text);margin-bottom:.5rem}.error p{color:var(--hotel-text-secondary);font-size:.9375rem}@media (max-width: 768px){.reporte-header-actions{flex-direction:column;align-items:stretch}.reporte-header-actions .filtros-reporte{min-width:100%}.btn-descargar-excel{justify-content:center;padding:1rem}.reporte-cards{grid-template-columns:1fr;gap:1rem}.reporte-card__value{font-size:1.5rem}.meses-grid{grid-template-columns:1fr}.reporte-table{font-size:.8125rem}.reporte-table th,.reporte-table td{padding:.75rem .5rem}}.text-warning{color:#f59e0b!important}.fila-total{background:var(--hotel-surface-light, #f8fafc);font-weight:600}.fila-total td{border-top:2px solid var(--hotel-border, #e2e8f0)}.fe-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;background:var(--hotel-card-background);padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a}.fe-stat{display:flex;flex-direction:column;gap:.25rem;text-align:center}.fe-stat__label{font-size:.8rem;color:var(--hotel-text-secondary);font-weight:500}.fe-stat__value{font-size:1.25rem;font-weight:700;color:var(--hotel-text)}.reporte-export-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-bottom:1.5rem}.reporte-export-actions button{min-width:180px}.reporte-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.reporte-card{display:flex;gap:1rem;padding:1.5rem;background:var(--hotel-card-background);border-radius:8px;box-shadow:0 1px 3px #0000001a}.reporte-card__icon{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.reporte-card__icon--primary{background:#8b5cf61a;color:#1e40af}.reporte-card__icon--success{background:#10b9811a;color:#10b981}.reporte-card__icon--danger{background:#ef44441a;color:#ef4444}.reporte-card__icon--warning{background:#f59e0b1a;color:#f59e0b}.reporte-card__icon--info{background:#3b82f61a;color:#3b82f6}.reporte-card__label{font-size:.875rem;color:var(--hotel-text-secondary);margin-bottom:.25rem}.reporte-card__value{font-size:2rem;font-weight:700;color:var(--hotel-text)}.reporte-seccion{margin-bottom:2rem}.reporte-seccion__titulo{font-size:1.25rem;font-weight:600;color:var(--hotel-text);margin-bottom:1rem}.tabla-scroll{overflow-x:auto}.reporte-tabla{width:100%;border-collapse:collapse;font-size:.875rem;background:var(--hotel-card-background);box-shadow:0 1px 3px #0000001a;border-radius:8px;overflow:hidden}.reporte-tabla th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--hotel-text);background:var(--hotel-surface-light);border-bottom:2px solid var(--hotel-border)}.reporte-tabla td{padding:.75rem 1rem;border-bottom:1px solid var(--hotel-border)}.reporte-tabla tbody tr:hover{background:var(--hotel-surface-light)}.reporte-tabla tbody tr:last-child td{border-bottom:none}.porcentaje{padding:.25rem .75rem;border-radius:4px;font-weight:600;font-size:.875rem;display:inline-block}.porcentaje--alto{background:#10b9811a;color:#10b981}.porcentaje--medio{background:#f59e0b1a;color:#f59e0b}.porcentaje--bajo{background:#ef44441a;color:#ef4444}.reporte-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background:var(--hotel-card-background);border-radius:8px;box-shadow:0 1px 3px #0000001a;color:#9ca3af;text-align:center}.reporte-placeholder svg{margin-bottom:1rem;opacity:.5}.reporte-placeholder p{font-size:1rem;margin:0}.error-message{padding:1rem;background:#fee2e2;color:#dc2626;border-radius:8px;margin-bottom:1rem}@media (max-width: 768px){.reporte-cards{grid-template-columns:1fr}.reporte-card__value{font-size:1.5rem}.reporte-export-actions{flex-direction:column}.reporte-export-actions button{width:100%}}.text-success{color:#10b981!important}.text-danger{color:#ef4444!important}.reporte-card__extra{font-size:.75rem;color:#9ca3af;margin-top:.25rem}.reporte-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.reporte-card--clickable{cursor:pointer;position:relative;transition:transform .15s ease,box-shadow .15s ease}.reporte-card--clickable:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000004d}.reporte-card--clickable:active{transform:translateY(0)}.reporte-card__download{position:absolute;top:.75rem;right:.75rem;color:#9ca3af;opacity:.5;transition:opacity .15s ease}.reporte-card--clickable:hover .reporte-card__download{opacity:1}.reporte-card__download .spin{animation:spin 1s linear infinite}@media (max-width: 768px){.reporte-grid-2{grid-template-columns:1fr}}.reportes-page{padding:2rem;max-width:1400px;margin:0 auto}.reportes-header{margin-bottom:2.5rem}.reportes-title{font-size:2rem;font-weight:700;color:var(--hotel-text);margin-bottom:.5rem}.reportes-subtitle{color:var(--hotel-text-secondary);font-size:1rem;line-height:1.5}.reportes-back-button{display:inline-flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;color:#fff;font-weight:600;font-size:1rem;cursor:pointer;padding:.875rem 1.5rem;margin-bottom:1.5rem;border-radius:10px;box-shadow:0 4px 12px #8b5cf640;transition:all .3s ease}.reportes-back-button:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf659}.reportes-back-button:active{transform:translateY(0);box-shadow:0 2px 8px #8b5cf640}.reportes-back-button .back-icon{font-size:1.25rem;font-weight:700;transition:transform .2s}.reportes-back-button:hover .back-icon{transform:translate(-4px)}.reportes-back-button .back-text{font-size:.9375rem;letter-spacing:.01em}.reportes-content{min-height:400px}.reportes-section{margin-bottom:3rem}.reportes-section-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--hotel-border)}.reportes-section-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.reportes-section-icon--operativo{background:linear-gradient(135deg,#10b981,#34d399);color:#fff}.reportes-section-icon--financiero{background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff}.reportes-section-icon--gerencial{background:linear-gradient(135deg,#3b82f6,#60a5fa);color:#fff}.reportes-section-icon--fiscal{background:linear-gradient(135deg,#ef4444,#f87171);color:#fff}.reportes-section-title{font-size:1.5rem;font-weight:700;color:var(--hotel-text);margin-bottom:.25rem}.reportes-section-description{font-size:.875rem;color:var(--hotel-text-secondary)}.reportes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.reporte-card{background:var(--hotel-card-background);border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .3s ease;border:2px solid transparent;display:flex;flex-direction:column;gap:1rem}.reporte-card:hover{box-shadow:0 10px 25px #8b5cf626;border-color:#8b5cf6;transform:translateY(-4px)}.reporte-card__header{display:flex;align-items:flex-start;gap:1rem}.reporte-card__icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.reporte-card__icon--primary{background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff}.reporte-card__icon--success{background:linear-gradient(135deg,#10b981,#34d399);color:#fff}.reporte-card__icon--info{background:linear-gradient(135deg,#3b82f6,#60a5fa);color:#fff}.reporte-card__icon--warning{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff}.reporte-card__icon--danger{background:linear-gradient(135deg,#ef4444,#f87171);color:#fff}.reporte-card__icon--secondary{background:linear-gradient(135deg,#06b6d4,#22d3ee);color:#fff}.reporte-card__icon--purple{background:linear-gradient(135deg,#a855f7,#c084fc);color:#fff}.reporte-card__icon--violet{background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff}.reporte-card__icon--teal{background:linear-gradient(135deg,#14b8a6,#2dd4bf);color:#fff}.reporte-card__content{flex:1}.reporte-card__title{font-size:1.125rem;font-weight:600;color:var(--hotel-text);margin-bottom:.5rem}.reporte-card__description{font-size:.875rem;color:var(--hotel-text-secondary);line-height:1.5}.reporte-card__footer{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem;border-top:1px solid var(--hotel-border)}.reporte-card__action{font-size:.875rem;font-weight:600;color:#8b5cf6;display:flex;align-items:center;gap:.5rem}.reporte-card__badge{font-size:.75rem;padding:.25rem .75rem;border-radius:12px;font-weight:600}.reporte-card__badge--development{background:#fef3c7;color:#f59e0b}.reporte-card__badge--planned{background:#dbeafe;color:#3b82f6}@media (max-width: 1024px){.reportes-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width: 768px){.reportes-page{padding:1rem}.reportes-title{font-size:1.5rem}.reportes-section{margin-bottom:2rem}.reportes-section-header{margin-bottom:1rem}.reportes-section-icon{width:45px;height:45px}.reportes-section-title{font-size:1.25rem}.reportes-grid{grid-template-columns:1fr;gap:1rem}.reporte-card{padding:1.25rem}.reporte-card__icon{width:50px;height:50px}.reporte-card__title{font-size:1rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto}.modal-config{background:var(--hotel-card-background);border-radius:12px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;animation:modalSlideIn .3s ease-out}.modal-config--large{max-width:900px}.modal-config--xlarge{max-width:1200px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-config__header{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem;border-bottom:1px solid var(--hotel-border);position:relative}.modal-config__header-icon{flex-shrink:0;width:48px;height:48px;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.modal-config__title{font-size:1.5rem;font-weight:700;color:var(--hotel-text);margin:0}.modal-config__subtitle{font-size:.875rem;color:var(--hotel-text-secondary);margin:.25rem 0 0}.modal-config__close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:var(--hotel-text-secondary);cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-config__close:hover{background:var(--hotel-surface-light);color:var(--hotel-text)}.modal-config__form{overflow-y:auto;padding:1.5rem;flex:1}.form-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media (min-width: 768px){.form-grid{grid-template-columns:repeat(2,1fr)}}.form-section{display:flex;flex-direction:column;gap:1rem}.form-section--full{grid-column:1 / -1}.form-section__title{font-size:1rem;font-weight:600;color:var(--hotel-text);margin:0 0 .5rem;padding-bottom:.5rem;border-bottom:2px solid #1e40af}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-size:.875rem;font-weight:500;color:var(--hotel-text)}.form-field input,.form-field select,.form-field textarea{padding:.75rem;border:1px solid var(--hotel-border);border-radius:8px;font-size:.875rem;transition:all .2s;font-family:inherit;background:var(--hotel-card-background);color:var(--hotel-text)}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #8b5cf61a}.form-field input[type=number]{-moz-appearance:textfield}.form-field input[type=number]::-webkit-inner-spin-button,.form-field input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.form-field textarea{resize:vertical;min-height:80px}.form-field__help{font-size:.75rem;color:var(--hotel-text-secondary);margin-top:-.25rem}.form-checkboxes{display:flex;flex-direction:column;gap:.75rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--hotel-text);cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#1e40af}.logo-preview{margin-top:1rem;padding:1rem;background:var(--hotel-surface-light);border:2px dashed var(--hotel-border);border-radius:8px;display:flex;align-items:center;justify-content:center}.logo-preview img{max-width:200px;max-height:100px;object-fit:contain}.modal-config__footer{padding:1rem 1.5rem;border-top:1px solid var(--hotel-border);display:flex;justify-content:flex-end;gap:1rem;background:var(--hotel-surface-light);border-radius:0 0 12px 12px}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;border:none;display:flex;align-items:center;gap:.5rem}.btn-primary{background:linear-gradient(135deg,#1e40af,#1e3a8a);color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#1e3a8a,#6d28d9);transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--hotel-card-background);color:var(--hotel-text-secondary);border:1px solid var(--hotel-border)}.btn-secondary:hover:not(:disabled){background:var(--hotel-surface-light);border-color:var(--hotel-text-secondary)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{background:#ef4444;color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;border:none;display:flex;align-items:center;gap:.5rem}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.spinner{animation:spin 1s linear infinite}.alert{padding:1rem;border-radius:8px;display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;font-size:.875rem;font-weight:500}.alert--success{background:#d1fae5;color:#065f46;border:1px solid #10b981}.alert--error{background:#fee2e2;color:#991b1b;border:1px solid #ef4444}.alert--warning{background:#fef3c7;color:#92400e;border:1px solid #f59e0b}.alert--info{background:#dbeafe;color:#1e40af;border:1px solid #3b82f6}.config-table{width:100%;border-collapse:collapse;font-size:.875rem}.config-table th{background:var(--hotel-surface-light);padding:.75rem;text-align:left;font-weight:600;color:var(--hotel-text);border-bottom:2px solid var(--hotel-border)}.config-table td{padding:.75rem;border-bottom:1px solid var(--hotel-border);color:var(--hotel-text-secondary)}.config-table tr:hover{background:var(--hotel-surface-light)}.config-table__actions{display:flex;gap:.5rem;align-items:center}.config-table__btn{padding:.5rem;background:transparent;border:none;cursor:pointer;border-radius:6px;color:var(--hotel-text-secondary);transition:all .2s;display:flex;align-items:center;justify-content:center}.config-table__btn:hover{background:var(--hotel-surface-light);color:var(--hotel-text)}.config-table__btn--edit:hover{color:#3b82f6;background:#dbeafe}.config-table__btn--delete:hover{color:#ef4444;background:#fee2e2}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.badge--success{background:#d1fae5;color:#065f46}.badge--danger{background:#fee2e2;color:#991b1b}.badge--warning{background:#fef3c7;color:#92400e}.badge--info{background:#dbeafe;color:#1e40af}.empty-state{text-align:center;padding:3rem 1rem;color:var(--hotel-text-secondary)}.empty-state svg{margin:0 auto 1rem;color:var(--hotel-border)}.empty-state h3{font-size:1.125rem;font-weight:600;color:var(--hotel-text);margin:0 0 .5rem}.empty-state p{font-size:.875rem;margin:0 0 1.5rem}.modal-config__tabs{display:flex;border-bottom:1px solid var(--hotel-border);padding:0 1.5rem}.modal-config__tab{padding:.75rem 1.5rem;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;color:var(--hotel-text-secondary);font-weight:400;font-size:.875rem;transition:all .2s;font-family:inherit}.modal-config__tab--active{border-bottom-color:var(--hotel-primary);color:var(--hotel-primary);font-weight:600}.modal-config__tab:hover:not(.modal-config__tab--active){color:var(--hotel-text);background:var(--hotel-surface-light)}.modal-config__tab--teal.modal-config__tab--active{border-bottom-color:#0d9488;color:#0d9488}.modal-config__body{padding:1.5rem;overflow-y:auto;flex:1}.toggle-switch{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:1rem;border-radius:8px;border:1px solid var(--hotel-border);transition:all .2s;margin-top:1rem}.toggle-switch:hover{background:var(--hotel-surface-light)}.toggle-switch__track{position:relative;width:44px;height:24px;background:#d1d5db;border-radius:12px;transition:background .2s;flex-shrink:0}.toggle-switch__track--active{background:#0d9488}.toggle-switch__thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle-switch__track--active .toggle-switch__thumb{transform:translate(20px)}.toggle-switch__text{display:flex;flex-direction:column;gap:.125rem}.toggle-switch__label{font-weight:500;font-size:.875rem;color:var(--hotel-text)}.toggle-switch__description{font-size:.75rem;color:var(--hotel-text-secondary)}.stats-grid{display:flex;gap:1rem;margin-top:1.5rem}.stats-card{text-align:center;flex:1;padding:1rem;border-radius:8px;background:var(--hotel-surface-light);border:1px solid var(--hotel-border)}.stats-card__value{font-size:1.5rem;font-weight:700}.stats-card__value--success{color:#10b981}.stats-card__value--danger{color:#ef4444}.stats-card__value--info{color:var(--hotel-primary)}.stats-card__label{font-size:.75rem;color:var(--hotel-text-secondary);margin-top:.25rem}.info-card{padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.85rem;display:flex;gap:.75rem;align-items:flex-start;line-height:1.5}.info-card--teal{background:#f0fdfa;border:1px solid #99f6e4;color:#0f766e}.info-card__icon{flex-shrink:0;margin-top:2px}.info-card a{font-weight:600;text-decoration:none}.info-card--teal a{color:#0d9488}.info-card--teal a:hover{text-decoration:underline}.input-with-action{position:relative}.input-with-action input{padding-right:80px;width:100%;box-sizing:border-box}.input-with-action__btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:1px solid var(--hotel-border);border-radius:4px;padding:.25rem .5rem;cursor:pointer;color:var(--hotel-text-secondary);font-size:.75rem;transition:all .2s;display:flex;align-items:center;gap:.25rem}.input-with-action__btn:hover{background:var(--hotel-surface-light);color:var(--hotel-text)}.btn-teal{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;border:1px solid #0d9488;background:#f0fdfa;color:#0d9488;display:flex;align-items:center;gap:.5rem;margin-top:1.5rem}.btn-teal:hover:not(:disabled){background:#0d9488;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0d94884d}.btn-teal:disabled{opacity:.5;cursor:not-allowed}.btn-primary--teal{background:linear-gradient(135deg,#0d9488,#0f766e)}.btn-primary--teal:hover:not(:disabled){background:linear-gradient(135deg,#0f766e,#115e59);box-shadow:0 4px 12px #0d94884d}.form-section__title--teal{border-bottom-color:#0d9488}[data-theme=dark] .modal-config__tab:hover:not(.modal-config__tab--active){background:#ffffff0d}[data-theme=dark] .info-card--teal{background:#042f2e;border-color:#115e59;color:#5eead4}[data-theme=dark] .info-card--teal a{color:#2dd4bf}[data-theme=dark] .toggle-switch{border-color:#ffffff1a}[data-theme=dark] .toggle-switch:hover{background:#ffffff0d}[data-theme=dark] .stats-card{background:#ffffff0d;border-color:#ffffff1a}[data-theme=dark] .btn-teal{background:#0d94881a;border-color:#0d9488}[data-theme=dark] .btn-teal:hover:not(:disabled){background:#0d9488;color:#fff}[data-theme=dark] .input-with-action__btn{border-color:#ffffff1a}@media (max-width: 768px){.modal-config{max-width:100%;max-height:100vh;border-radius:0}.form-grid,.form-row{grid-template-columns:1fr}.modal-config__footer{flex-direction:column-reverse}.btn-primary,.btn-secondary,.btn-danger{width:100%;justify-content:center}}.logo-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem;border:2px dashed #cbd5e1;border-radius:12px;background:#f8fafc;cursor:pointer;transition:all .2s ease;color:#64748b}.logo-upload-zone:hover{border-color:#6366f1;background:#eef2ff;color:#4f46e5}.logo-upload-zone span{font-size:.9rem;font-weight:500}.logo-upload-zone small{font-size:.75rem;color:#94a3b8}.logo-preview{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem;border:1px solid #e2e8f0;border-radius:12px;background:#f8fafc}.logo-preview__img{max-width:220px;max-height:100px;object-fit:contain;border-radius:6px}.logo-preview__actions{display:flex;gap:.5rem}.btn-sm{padding:.35rem .75rem!important;font-size:.8rem!important;gap:.3rem}.btn-danger{background:#ef4444;color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;cursor:pointer;display:flex;align-items:center;gap:.4rem;font-size:.85rem;transition:background .2s}.btn-danger:hover{background:#dc2626}.permisos-tabs{display:flex;gap:0;padding:0 1.5rem;border-bottom:1px solid var(--hotel-border);background:var(--hotel-surface-light)}.permisos-tab{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--hotel-text-secondary);transition:all .2s}.permisos-tab:hover{color:var(--hotel-text);background:#8b5cf60d}.permisos-tab--activo{color:#8b5cf6;border-bottom-color:#8b5cf6;background:#8b5cf60d}.permisos-selector{margin-bottom:1.5rem}.permisos-selector label{display:block;font-size:.875rem;font-weight:600;color:var(--hotel-text);margin-bottom:.75rem}.roles-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.rol-button{display:flex;flex-direction:column;align-items:flex-start;padding:1rem;background:var(--hotel-card-background);border:2px solid var(--hotel-border);border-radius:10px;cursor:pointer;transition:all .2s;text-align:left}.rol-button:hover:not(:disabled){border-color:var(--rol-color, var(--hotel-border));background:var(--hotel-surface-light)}.rol-button:disabled{opacity:.6;cursor:not-allowed}.rol-button--activo{border-width:2px;box-shadow:0 2px 8px #0000001a}.rol-button__nombre{font-weight:600;color:var(--hotel-text);font-size:.9375rem;margin-bottom:.25rem}.rol-button__desc{font-size:.75rem;color:var(--hotel-text-secondary)}.rol-tag{margin-top:.5rem;font-size:.6875rem;padding:.25rem .5rem;background:#f3f4f6;color:#6b7280;border-radius:4px;font-weight:500}.usuario-select{width:100%;padding:.875rem;border:1px solid var(--hotel-border);border-radius:8px;font-size:.875rem;font-family:inherit;background:var(--hotel-card-background);color:var(--hotel-text);cursor:pointer;transition:all .2s}.usuario-select:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.usuario-select:disabled{opacity:.6;cursor:not-allowed}.usuario-info-box{background:linear-gradient(135deg,#8b5cf61a,#a78bfa1a);border:1px solid rgba(139,92,246,.2);border-radius:10px;padding:1rem;margin-bottom:1rem}.usuario-info-box__header{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--hotel-text);margin-bottom:.5rem}.usuario-info-box__header svg{color:#8b5cf6}.usuario-info-box__rol{font-size:.875rem;color:var(--hotel-text-secondary)}.usuario-info-box__rol strong{color:#8b5cf6;text-transform:capitalize}.permisos-leyenda{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;padding:.75rem 1rem;background:var(--hotel-surface-light);border-radius:8px}.leyenda-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--hotel-text-secondary)}.leyenda-dot{width:10px;height:10px;border-radius:50%}.leyenda-item--rol .leyenda-dot{background:#3b82f6}.leyenda-item--agregado .leyenda-dot{background:#10b981}.leyenda-item--quitado .leyenda-dot{background:#ef4444}.permisos-lista{display:flex;flex-direction:column;gap:.75rem}.modulo-permisos{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:10px;overflow:hidden}.modulo-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--hotel-surface-light);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.modulo-header:hover{background:#8b5cf60d}.modulo-header__left{display:flex;align-items:center;gap:.5rem}.modulo-header__left svg{color:var(--hotel-text-secondary)}.modulo-nombre{font-weight:600;font-size:.9375rem;color:var(--hotel-text)}.modulo-contador{font-size:.75rem;padding:.25rem .625rem;background:var(--hotel-border);color:var(--hotel-text-secondary);border-radius:9999px;font-weight:500}.modulo-contador--full{background:#d1fae5;color:#065f46}.modulo-permisos-lista{padding:.5rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.5rem}.permiso-item{padding:.75rem;border-radius:8px;transition:all .2s;background:transparent}.permiso-item:hover{background:var(--hotel-surface-light)}.permiso-item--modificado{background:#fef3c7!important;border-left:3px solid #f59e0b}.permiso-item--rol{border-left:3px solid #3b82f6}.permiso-item--usuario_agregado{border-left:3px solid #10b981}.permiso-item--usuario_quitado{border-left:3px solid #ef4444;opacity:.7}.permiso-checkbox{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;width:100%}.permiso-checkbox input[type=checkbox]{flex-shrink:0;width:18px;height:18px;margin-top:2px;cursor:pointer;accent-color:#8b5cf6}.permiso-checkbox input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.permiso-info{flex:1;min-width:0}.permiso-nombre{display:block;font-size:.875rem;font-weight:500;color:var(--hotel-text);line-height:1.3}.permiso-descripcion{display:block;font-size:.75rem;color:var(--hotel-text-secondary);margin-top:.125rem;line-height:1.3}.permiso-badge{flex-shrink:0;font-size:.625rem;padding:.125rem .5rem;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.permiso-badge--rol{background:#dbeafe;color:#1e40af}.permiso-badge--agregado{background:#d1fae5;color:#065f46}.permiso-badge--quitado{background:#fee2e2;color:#991b1b}.loading-center{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--hotel-text-secondary)}.loading-center p{margin-top:1rem;font-size:.875rem}.loading-inline{display:flex;align-items:center;gap:.5rem;padding:.75rem;color:var(--hotel-text-secondary);font-size:.875rem}@media (max-width: 768px){.permisos-tabs{padding:0}.permisos-tab{flex:1;justify-content:center;padding:.875rem}.roles-buttons,.modulo-permisos-lista{grid-template-columns:1fr}.permisos-leyenda{flex-direction:column;gap:.5rem}}.password-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.password-modal{background:var(--hotel-card-background);border-radius:12px;box-shadow:0 20px 50px #0000004d;width:100%;max-width:380px;padding:2rem;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.password-modal--shake{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.password-modal__close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:var(--hotel-text-secondary);cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s}.password-modal__close:hover{background:var(--hotel-surface-light);color:var(--hotel-text)}.password-modal__header{text-align:center;margin-bottom:1.5rem}.password-modal__icon{width:64px;height:64px;margin:0 auto 1rem;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.password-modal__title{font-size:1.25rem;font-weight:700;color:var(--hotel-text);margin:0 0 .5rem}.password-modal__subtitle{font-size:.875rem;color:var(--hotel-text-secondary);margin:0;line-height:1.4}.password-modal__form{display:flex;flex-direction:column;gap:1.25rem}.password-modal__input-group{display:flex;flex-direction:column;gap:.5rem}.password-modal__input{width:100%;padding:.875rem 1rem;font-size:1rem;border:2px solid var(--hotel-border);border-radius:8px;background:var(--hotel-card-background);color:var(--hotel-text);transition:all .2s;box-sizing:border-box}.password-modal__input:focus{outline:none;border-color:var(--hotel-primary);box-shadow:0 0 0 3px #1e40af1a}.password-modal__input--error{border-color:#ef4444}.password-modal__input--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.password-modal__input::placeholder{color:var(--hotel-text-light)}.password-modal__error{font-size:.8125rem;color:#ef4444;display:flex;align-items:center;gap:.25rem}.password-modal__actions{display:flex;gap:.75rem}.password-modal__btn{flex:1;padding:.75rem 1rem;font-size:.9375rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.password-modal__btn--cancel{background:var(--hotel-surface-light);color:var(--hotel-text)}.password-modal__btn--cancel:hover{background:var(--hotel-border)}.password-modal__btn--submit{background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff}.password-modal__btn--submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1e40af4d}.password-modal__btn--submit:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 480px){.password-modal{margin:1rem;padding:1.5rem}.password-modal__icon{width:56px;height:56px}.password-modal__icon svg{width:28px;height:28px}.password-modal__title{font-size:1.125rem}}.configuracion-page{padding:2rem;max-width:1400px;margin:0 auto;isolation:isolate}.configuracion-header{margin-bottom:2rem}.configuracion-title{font-size:2rem;font-weight:700;color:var(--hotel-text);margin-bottom:.5rem}.configuracion-subtitle{font-size:1rem;color:var(--hotel-text-secondary)}.config-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:2rem}.config-card{background:var(--hotel-card-background);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm);cursor:pointer;transition:all .3s ease;border:2px solid transparent;display:flex;flex-direction:column;gap:1rem}.config-card:hover{box-shadow:var(--shadow-lg);border-color:var(--hotel-primary, #1e40af);transform:translateY(-4px)}.config-card__header{display:flex;align-items:center;gap:1rem}.config-card__icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.config-card__icon--primary{background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff}.config-card__icon--success{background:linear-gradient(135deg,#10b981,#34d399);color:#fff}.config-card__icon--info{background:linear-gradient(135deg,#3b82f6,#60a5fa);color:#fff}.config-card__icon--warning{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff}.config-card__icon--danger{background:linear-gradient(135deg,#ef4444,#f87171);color:#fff}.config-card__icon--secondary{background:linear-gradient(135deg,#06b6d4,#22d3ee);color:#fff}.config-card__icon--purple{background:linear-gradient(135deg,#a855f7,#c084fc);color:#fff}.config-card__icon--violet{background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff}.config-card__icon--teal{background:linear-gradient(135deg,#14b8a6,#2dd4bf);color:#fff}.config-card__icon--pink{background:linear-gradient(135deg,#ec4899,#f472b6);color:#fff}.config-card__content{flex:1}.config-card__title{font-size:1.25rem;font-weight:600;color:var(--hotel-text);margin-bottom:.5rem}.config-card__description{font-size:.875rem;color:var(--hotel-text-secondary);line-height:1.5}.config-card__footer{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem;border-top:1px solid var(--hotel-border)}.config-card__action{font-size:.875rem;font-weight:600;color:var(--hotel-primary, #1e40af);display:flex;align-items:center;gap:.5rem}.config-card__badge{font-size:.75rem;padding:.25rem .75rem;border-radius:12px;font-weight:600}.config-card__badge--admin{background:#fef3c7;color:#f59e0b}.config-card__badge--all{background:#dbeafe;color:#3b82f6}.config-card__badge--superadmin{background:#ede9fe;color:#7c3aed}.config-card--wide{grid-column:span 2}@media (max-width: 1024px){.config-card--wide{grid-column:span 1}}@media (max-width: 768px){.configuracion-page{padding:1rem}.configuracion-title{font-size:1.5rem}.config-grid{grid-template-columns:1fr;gap:1rem}.config-card{padding:1.25rem}.config-card__icon{width:50px;height:50px}.config-card__title{font-size:1.125rem}}.pos-container{display:flex;flex-direction:column;height:100vh;background-color:var(--hotel-background)}.pos-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:linear-gradient(135deg,#8b5cf6,#a78bfa,#c4b5fd);color:#fff;box-shadow:0 2px 8px #8b5cf633}.pos-header-left h1{margin:0;font-size:1.5rem;font-weight:600}.turno-info{display:block;margin-top:.25rem;font-size:.875rem;opacity:.9}.tipo-cliente-select{padding:.5rem 1rem;font-size:1rem;border:2px solid white;border-radius:8px;background:#fff3;color:#fff;cursor:pointer;transition:all .2s}.tipo-cliente-select:hover{background:#ffffff4d}.tipo-cliente-select option{background:#8b5cf6;color:#fff}.pos-content{display:grid;grid-template-columns:60% 40%;flex:1;overflow:hidden}.pos-left{display:flex;flex-direction:column;background:var(--hotel-card-background);border-right:1px solid var(--hotel-border);overflow:hidden}.search-bar{padding:1.5rem;border-bottom:1px solid var(--hotel-border)}.search-input{width:100%;padding:.75rem 1rem;font-size:1rem;border:2px solid var(--hotel-border);border-radius:8px;transition:border-color .2s;background:var(--hotel-card-background);color:var(--hotel-text)}.search-input:focus{outline:none;border-color:#8b5cf6}.category-tabs{display:flex;gap:.5rem;padding:1rem 1.5rem;border-bottom:1px solid var(--hotel-border);overflow-x:auto}.tab{padding:.5rem 1rem;font-size:.875rem;font-weight:500;border:1px solid var(--hotel-border);border-radius:6px;background:var(--hotel-card-background);color:var(--hotel-text-secondary);cursor:pointer;transition:all .2s;white-space:nowrap}.tab:hover{background:var(--hotel-surface-light);color:#8b5cf6;border-color:#8b5cf6}.tab.active{background:#8b5cf6;color:#fff;border-color:#8b5cf6}.product-grid{flex:1;padding:1.5rem;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;align-content:start}.empty-products{grid-column:1 / -1;display:flex;justify-content:center;align-items:center;padding:4rem;color:var(--hotel-text-light);text-align:center}.pos-right{display:flex;flex-direction:column;background:var(--hotel-surface-light);overflow:hidden}.cart-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--hotel-border)}.cart-header h3{margin:0;font-size:1.25rem;color:var(--hotel-text)}.btn-limpiar{padding:.5rem 1rem;font-size:.875rem;color:#ef4444;background:var(--hotel-card-background);border:1px solid #ef4444;border-radius:6px;cursor:pointer;transition:all .2s}.btn-limpiar:hover{background:#fef2f2}.cart-items{flex:1;padding:1rem;overflow-y:auto}.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--hotel-text-light);text-align:center}.cart-empty p{font-size:1.5rem;margin-bottom:.5rem}.cart-empty small{font-size:.875rem}.cart-item{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;padding:1rem;margin-bottom:.75rem}.cart-item-info{display:flex;justify-content:space-between;margin-bottom:.75rem}.cart-item-name{font-weight:500;color:var(--hotel-text)}.cart-item-precio{color:var(--hotel-text-secondary)}.cart-item-controls{display:flex;gap:.5rem;align-items:center}.cart-item-controls button{width:32px;height:32px;border:1px solid var(--hotel-border);border-radius:6px;background:var(--hotel-card-background);color:var(--hotel-text);cursor:pointer;transition:all .2s}.cart-item-controls button:hover{background:var(--hotel-surface-light);border-color:#8b5cf6;color:#8b5cf6}.cart-item-controls input{width:60px;text-align:center;padding:.5rem;border:1px solid var(--hotel-border);border-radius:6px;background:var(--hotel-card-background);color:var(--hotel-text)}.btn-eliminar{margin-left:auto;color:#ef4444}.btn-eliminar:hover{background:#fef2f2!important;border-color:#ef4444!important}.cart-item-total{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--hotel-border);text-align:right;font-weight:600;font-size:1.125rem;color:#8b5cf6}.cart-descuentos{padding:1rem 1.5rem;border-top:1px solid var(--hotel-border);background:var(--hotel-card-background)}.cart-descuentos h4{margin:0 0 .5rem;font-size:1rem;color:var(--hotel-text)}.cart-propina{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-top:1px solid var(--hotel-border);background:var(--hotel-card-background)}.cart-propina label{font-weight:500;color:var(--hotel-text)}.cart-propina input{flex:1;padding:.5rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:1rem;background:var(--hotel-card-background);color:var(--hotel-text)}.cart-totales{padding:1rem 1.5rem;border-top:1px solid var(--hotel-border);background:var(--hotel-card-background)}.total-row{display:flex;justify-content:space-between;padding:.5rem 0;color:var(--hotel-text-secondary)}.total-row.descuento{color:#10b981}.total-row.total-final{padding-top:1rem;border-top:2px solid var(--hotel-border);font-size:1.5rem;font-weight:700;color:var(--hotel-text)}.total-final span:last-child{color:#8b5cf6}.cart-actions{padding:1rem 1.5rem;border-top:1px solid var(--hotel-border);background:var(--hotel-card-background)}.btn-pagar{width:100%;padding:1rem;font-size:1.125rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:8px;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #8b5cf64d}.btn-pagar:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #8b5cf666}.btn-pagar:disabled{opacity:.5;cursor:not-allowed}.pos-sin-turno{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;text-align:center;padding:2rem;background:linear-gradient(135deg,#fef3c7,#fde68a)}.pos-sin-turno h2{font-size:2rem;color:#92400e;margin-bottom:1rem}.pos-sin-turno p{font-size:1.125rem;color:#78350f;margin-bottom:2rem}.pos-sin-turno button{padding:1rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:#f59e0b;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.pos-sin-turno button:hover{background:#d97706;transform:translateY(-2px)}.modal-content{background:var(--hotel-card-background);padding:2rem;border-radius:12px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto}.pos-loading,.pos-error{display:flex;align-items:center;justify-content:center;height:100vh;font-size:1.25rem;color:var(--hotel-text-secondary)}.pos-error{color:#ef4444}.pos-header-right{display:flex;align-items:center;gap:1rem}.cliente-info{display:flex;align-items:center;gap:.5rem}.cliente-seleccionado{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff3;border-radius:8px;font-size:.875rem}.btn-clear{background:none;border:none;color:#fff;font-size:1.25rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.btn-clear:hover{background:#fff3}.btn-seleccionar-cliente{padding:.5rem 1rem;background:#fff3;border:2px solid white;color:#fff;border-radius:8px;font-size:.875rem;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-seleccionar-cliente:hover{background:var(--hotel-card-background);color:#8b5cf6}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:var(--hotel-card-background);border-radius:12px;max-width:500px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0003}.modal-content.modal-large{max-width:700px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--hotel-border)}.modal-header h2{margin:0;font-size:1.25rem;color:var(--hotel-text)}.btn-close{background:none;border:none;font-size:2rem;color:var(--hotel-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.btn-close:hover{background:var(--hotel-surface-light);color:var(--hotel-text)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.search-bar-modal{display:flex;gap:1rem;margin-bottom:1rem}.search-bar-modal .search-input{flex:1}.btn-primary{padding:.75rem 1.5rem;background:#8b5cf6;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap}.btn-primary:hover{background:#7c3aed}.btn-secondary{padding:.75rem 1.5rem;background:var(--hotel-surface-light);color:var(--hotel-text);border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:var(--hotel-border)}.clientes-list,.huespedes-list{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto}.cliente-item,.huesped-item{padding:1rem;border:2px solid var(--hotel-border);border-radius:8px;cursor:pointer;transition:all .2s;background:var(--hotel-card-background)}.cliente-item:hover,.huesped-item:hover{border-color:#8b5cf6;background:#f5f3ff;transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf626}.cliente-info-main,.huesped-info-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.cliente-info-main strong,.huesped-info-main strong{font-size:1rem;color:var(--hotel-text)}.cliente-documento{font-size:.875rem;color:var(--hotel-text-secondary)}.cliente-info-secondary,.huesped-info-secondary{display:flex;justify-content:space-between;font-size:.875rem;color:var(--hotel-text-secondary)}.habitacion-badge{padding:.25rem .75rem;background:#8b5cf6;color:#fff;border-radius:12px;font-size:.75rem;font-weight:600}.hospedaje-codigo{font-family:monospace;background:var(--hotel-surface-light);padding:.125rem .5rem;border-radius:4px;color:var(--hotel-text)}.form-cliente{display:flex;flex-direction:column;gap:1.5rem}.form-cliente h3{margin:0 0 1rem;color:var(--hotel-text)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--hotel-text)}.form-control{padding:.75rem;border:2px solid var(--hotel-border);border-radius:8px;font-size:.875rem;transition:border-color .2s;background:var(--hotel-card-background);color:var(--hotel-text)}.form-control:focus{outline:none;border-color:#8b5cf6}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}@media (max-width: 1024px){.pos-content{grid-template-columns:1fr}.pos-right{display:none}.form-row{grid-template-columns:1fr}.modal-overlay{padding:1rem}.search-bar-modal{flex-direction:column}.pos-header-right{flex-direction:column;align-items:flex-end;gap:.5rem}}.payment-modal{max-width:800px}.payment-summary{background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.2)}.summary-row:last-child{border-bottom:none;padding-top:1rem;font-size:1.1rem;font-weight:600}.total-amount{font-size:1.5rem;font-weight:700}.paid-amount,.pending-amount{font-size:1.25rem;font-weight:600}.paid-amount.success,.pending-amount.success{color:#10b981;text-shadow:0 0 10px rgba(16,185,129,.5)}.add-payment-section{background:var(--hotel-surface-light);padding:1.5rem;border-radius:8px;margin-bottom:1.5rem}.add-payment-section h3{margin:0 0 1rem;color:var(--hotel-text);font-size:1rem}.payment-form{display:flex;flex-direction:column;gap:1rem}.payments-list{margin-bottom:1.5rem}.payments-list h3{margin:0 0 1rem;color:var(--hotel-text);font-size:1rem}.payments-items{display:flex;flex-direction:column;gap:.75rem}.payment-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--hotel-surface-light);border-radius:8px;border:2px solid var(--hotel-border)}.payment-info{display:flex;flex-direction:column;gap:.25rem}.payment-info strong{color:var(--hotel-text);font-size:1rem}.payment-reference{font-size:.75rem;color:var(--hotel-text-secondary);font-family:monospace;background:var(--hotel-card-background);padding:.125rem .5rem;border-radius:4px}.payment-amount{font-size:1.25rem;font-weight:600;color:#8b5cf6}.btn-remove{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s}.btn-remove:hover{background:#fee2e2}.change-calculator{background:#ecfdf5;padding:1.5rem;border-radius:8px;border:2px solid #10b981;margin-bottom:1.5rem}.change-calculator h3{margin:0 0 1rem;color:#065f46;font-size:1rem}.change-display{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding:1rem;background:var(--hotel-card-background);border-radius:8px;border:2px solid #10b981}.change-display span:first-child{color:#065f46;font-weight:500}.change-amount{font-size:1.75rem;font-weight:700;color:#10b981}.payment-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem;border-top:2px solid var(--hotel-border)}.btn-success{padding:.75rem 1.5rem;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-success:hover:not(:disabled){background:#059669}.btn-success:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}@media (max-width: 768px){.payment-summary{padding:1rem}.total-amount{font-size:1.25rem}.paid-amount,.pending-amount{font-size:1rem}.add-payment-section{padding:1rem}.change-amount{font-size:1.5rem}.payment-actions{flex-direction:column}.payment-actions button{width:100%}}.modal-detalle-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001;padding:1rem}.modal-detalle-content{background:var(--hotel-card-background);border-radius:12px;width:95%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0000004d}.modal-detalle-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff}.header-info{display:flex;align-items:center;gap:1rem}.header-icon{font-size:1.75rem;opacity:.9}.modal-detalle-header h2{margin:0;font-size:1.25rem;font-weight:600}.codigo-turno{font-size:.875rem;opacity:.85;font-family:Courier New,monospace}.modal-detalle-body{flex:1;overflow-y:auto;padding:1.5rem}.detalle-loading,.detalle-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:1rem;color:var(--hotel-text-secondary)}.detalle-error{color:#ef4444}.spinner{width:40px;height:40px;border:3px solid var(--hotel-border);border-top-color:#8b5cf6;border-radius:50%;animation:spin .8s linear infinite}.seccion-info-general{margin-bottom:1.5rem}.info-card{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;background:var(--hotel-surface-light);padding:1rem;border-radius:10px}.info-label{font-size:.75rem;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:.9375rem;font-weight:500;color:var(--hotel-text)}.seccion-resumen,.seccion-ventas-metodo,.seccion-arqueo,.seccion-movimientos,.seccion-notas{margin-bottom:1.5rem}.seccion-resumen h3,.seccion-ventas-metodo h3,.seccion-arqueo h3,.seccion-movimientos h3,.seccion-notas h3{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--hotel-text);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--hotel-border)}.seccion-resumen h3 svg,.seccion-ventas-metodo h3 svg,.seccion-arqueo h3 svg,.seccion-movimientos h3 svg,.seccion-notas h3 svg{color:#8b5cf6}.resumen-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.resumen-card{background:var(--hotel-surface-light);padding:1rem;border-radius:8px;text-align:center}.resumen-label{display:block;font-size:.75rem;color:var(--hotel-text-secondary);margin-bottom:.25rem}.resumen-value{display:flex;align-items:center;justify-content:center;gap:.375rem;font-size:1.125rem;font-weight:700;color:var(--hotel-text)}.resumen-ventas .resumen-value{color:#8b5cf6}.resumen-ingresos .resumen-value{color:#10b981}.resumen-egresos .resumen-value{color:#ef4444}.resumen-checkouts .resumen-value{color:#3b82f6}.resumen-sub{font-size:.7rem;color:#9ca3af;margin-top:2px}.montos-cierre{background:var(--hotel-surface-light);padding:1rem;border-radius:8px;display:flex;flex-direction:column;gap:.75rem}.monto-item{display:flex;justify-content:space-between;align-items:center;font-size:.9375rem}.monto-esperado,.monto-real{font-weight:600}.monto-item.diferencia{padding-top:.75rem;border-top:1px dashed var(--hotel-border);font-weight:700}.monto-diferencia{display:flex;align-items:center;gap:.5rem}.monto-diferencia small{font-size:.75rem;font-weight:500}.diferencia-cero .monto-diferencia{color:#10b981}.diferencia-positiva .monto-diferencia{color:#3b82f6}.diferencia-negativa .monto-diferencia{color:#ef4444}.ventas-metodo-lista{display:flex;flex-direction:column;gap:.5rem}.ventas-metodo-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--hotel-surface-light);border-radius:8px}.metodo-info{display:flex;flex-direction:column}.metodo-nombre{font-weight:500;color:var(--hotel-text)}.metodo-transacciones{font-size:.75rem;color:var(--hotel-text-secondary)}.metodo-monto{font-weight:700;color:#10b981;font-size:1rem}.arqueo-tabla{width:100%;border-collapse:collapse;font-size:.875rem}.arqueo-tabla th{padding:.625rem .75rem;text-align:left;font-weight:600;color:var(--hotel-text-secondary);border-bottom:2px solid var(--hotel-border);font-size:.75rem;text-transform:uppercase}.arqueo-tabla td{padding:.625rem .75rem;color:var(--hotel-text);border-bottom:1px solid var(--hotel-border)}.arqueo-tabla tfoot td{padding:.75rem;background:var(--hotel-surface-light);border-top:2px solid #8b5cf6}.movimientos-lista{display:flex;flex-direction:column;gap:.5rem}.movimiento-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--hotel-surface-light);border-radius:8px;border-left:3px solid}.movimiento-ingreso{border-left-color:#10b981}.movimiento-egreso{border-left-color:#ef4444}.movimiento-icono{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem}.movimiento-ingreso .movimiento-icono{background:#10b9811a;color:#10b981}.movimiento-egreso .movimiento-icono{background:#ef44441a;color:#ef4444}.movimiento-info{flex:1;display:flex;flex-direction:column}.movimiento-concepto{font-weight:500;color:var(--hotel-text);text-transform:capitalize}.movimiento-descripcion{font-size:.75rem;color:var(--hotel-text-secondary)}.movimiento-monto{font-weight:700;font-size:.9375rem}.movimiento-monto.ingreso{color:#10b981}.movimiento-monto.egreso{color:#ef4444}.notas-contenido{background:var(--hotel-surface-light);padding:1rem;border-radius:8px;color:var(--hotel-text);font-size:.9375rem;line-height:1.6;white-space:pre-wrap}.seccion-estado{margin-top:1rem;padding-top:1rem;border-top:2px solid var(--hotel-border)}.estado-badge{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;border-radius:10px;font-weight:600;font-size:1rem}.estado-badge.cuadrado{background:#10b9811a;color:#10b981;border:1px solid #10b981}.estado-badge.sobrante{background:#3b82f61a;color:#3b82f6;border:1px solid #3b82f6}.estado-badge.faltante{background:#ef44441a;color:#ef4444;border:1px solid #ef4444}@media (max-width: 600px){.modal-detalle-content{width:100%;max-height:95vh;border-radius:8px}.modal-detalle-header,.modal-detalle-body{padding:1rem}.info-card,.resumen-grid{grid-template-columns:1fr 1fr}.resumen-value{font-size:1rem}.movimiento-item{flex-wrap:wrap}.movimiento-monto{width:100%;text-align:right;margin-top:.5rem}}@media (max-width: 400px){.info-card,.resumen-grid{grid-template-columns:1fr}}.modal-historial-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-historial-content{background:var(--hotel-card-background);border-radius:12px;width:95%;max-width:1100px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0000004d}.modal-historial-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff}.modal-historial-header h2{margin:0;font-size:1.375rem;font-weight:600}.btn-close-modal{width:36px;height:36px;border:none;background:#fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s}.btn-close-modal:hover{background:#ffffff4d}.modal-historial-filtros{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem 1.5rem;background:var(--hotel-surface-light);border-bottom:1px solid var(--hotel-border);align-items:flex-end}.filtro-grupo{display:flex;flex-direction:column;gap:.375rem}.filtro-grupo label{font-size:.75rem;font-weight:500;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em}.filtro-input,.filtro-select{padding:.625rem .875rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:6px;color:var(--hotel-text);font-size:.875rem;min-width:140px;transition:border-color .2s}.filtro-input:focus,.filtro-select:focus{outline:none;border-color:#8b5cf6}.filtro-select{min-width:160px;cursor:pointer}.filtro-acciones{display:flex;gap:.5rem;margin-left:auto}.btn-filtrar,.btn-limpiar{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-filtrar{background:#8b5cf6;color:#fff}.btn-filtrar:hover{background:#7c3aed}.btn-limpiar{background:var(--hotel-surface-light);color:var(--hotel-text)}.btn-limpiar:hover{background:var(--hotel-border)}.modal-historial-body{flex:1;overflow-y:auto;padding:0;min-height:300px}.historial-loading,.historial-error,.historial-empty{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--hotel-text-secondary);font-size:1rem}.historial-error{color:#ef4444}.historial-tabla{width:100%;border-collapse:collapse;font-size:.875rem}.historial-tabla thead{position:sticky;top:0;background:var(--hotel-surface-light);z-index:1}.historial-tabla th{padding:.875rem 1rem;text-align:left;font-weight:600;color:var(--hotel-text-secondary);border-bottom:2px solid var(--hotel-border);white-space:nowrap;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}.historial-tabla td{padding:.875rem 1rem;color:var(--hotel-text);border-bottom:1px solid var(--hotel-border)}.historial-tabla tbody tr{transition:background-color .15s}.historial-tabla tbody tr:hover{background:var(--hotel-surface-light)}.col-codigo{font-family:Courier New,monospace;font-size:.8rem;color:#8b5cf6;font-weight:600}.col-fecha{white-space:nowrap;font-size:.8rem;color:var(--hotel-text-secondary)}.col-cajero{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-ventas{text-align:center;font-weight:600}.col-total{text-align:right;font-weight:600;color:#10b981}.col-diferencia{text-align:right;font-weight:600}.col-diferencia.diferencia-cero{color:#10b981}.col-diferencia.diferencia-positiva{color:#3b82f6}.col-diferencia.diferencia-negativa{color:#ef4444}.col-estado{text-align:center}.badge-estado{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:capitalize}.badge-abierto{background:#fef3c7;color:#92400e;border:1px solid #f59e0b}.badge-cerrado{background:#d1fae5;color:#065f46;border:1px solid #10b981}.col-acciones-header{text-align:center;width:100px}.col-acciones{text-align:center;white-space:nowrap}.btn-accion{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:.875rem;transition:all .2s;margin:0 .125rem}.btn-ver-detalle{background:#8b5cf61a;color:#8b5cf6}.btn-ver-detalle:hover{background:#8b5cf633;transform:scale(1.05)}.btn-reimprimir{background:#10b9811a;color:#10b981}.btn-reimprimir:hover:not(:disabled){background:#10b98133;transform:scale(1.05)}.btn-reimprimir:disabled{opacity:.5;cursor:not-allowed}.spinner-mini{width:14px;height:14px;border:2px solid rgba(16,185,129,.3);border-top-color:#10b981;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-historial-paginacion{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--hotel-surface-light);border-top:1px solid var(--hotel-border)}.btn-pagina{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:6px;color:var(--hotel-text);font-size:.875rem;cursor:pointer;transition:all .2s}.btn-pagina:hover:not(:disabled){background:var(--hotel-surface-light);border-color:var(--hotel-text-secondary)}.btn-pagina:disabled{opacity:.5;cursor:not-allowed}.pagina-info{color:var(--hotel-text-secondary);font-size:.875rem}@media (max-width: 768px){.modal-historial-content{width:100%;max-height:95vh;border-radius:8px}.modal-historial-filtros{flex-direction:column;gap:.75rem}.filtro-grupo{width:100%}.filtro-input,.filtro-select{width:100%;min-width:unset}.filtro-acciones{width:100%;margin-left:0;justify-content:stretch}.filtro-acciones button{flex:1;justify-content:center}.historial-tabla{font-size:.75rem}.historial-tabla th,.historial-tabla td{padding:.625rem .5rem}.col-cierre,.col-diferencia{display:none}}@media (max-width: 480px){.modal-historial-header h2{font-size:1.125rem}.modal-historial-paginacion{flex-direction:column;gap:.75rem}.btn-pagina{width:100%;justify-content:center}}.caja-page{min-height:100vh;background-color:var(--hotel-background);padding:2rem}.caja-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.header-left h1{font-size:2rem;color:var(--hotel-text);margin:0 0 .25rem}.header-subtitle{font-size:.875rem;color:var(--hotel-text-secondary);margin:0}.header-actions{display:flex;gap:.75rem;flex-wrap:wrap}.badges-container{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:9999px;font-size:.8125rem;font-weight:500}.badge-open{background:#d1fae5;color:#065f46;border:1px solid #10b981;font-weight:600}[data-theme=dark] .badge-open{background:#10b98126;color:#34d399;border-color:#10b981}.badge-time,.badge-user,.badge-date{background:var(--hotel-surface-light);color:var(--hotel-text);border:1px solid var(--hotel-border)}.badge svg{font-size:.875rem}.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.metric-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--hotel-card-background);border-radius:12px;box-shadow:var(--shadow-sm);transition:transform .2s;border:1px solid var(--hotel-border)}.metric-card:hover{transform:translateY(-2px)}.metric-icon{width:56px;height:56px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.metric-green .metric-icon{background:#10b981;color:#fff}.metric-green-light .metric-icon{background:#22c55e;color:#fff}.metric-blue .metric-icon{background:#3b82f6;color:#fff}.metric-yellow .metric-icon{background:#eab308;color:#fff}.metric-content{display:flex;flex-direction:column;gap:.125rem}.metric-label{font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:1.5rem;font-weight:700;color:var(--hotel-text)}.metric-sub{font-size:.75rem;color:var(--hotel-text-light)}.metodos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.metodo-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--hotel-card-background);border-radius:12px;box-shadow:var(--shadow-sm);border:1px solid var(--hotel-border)}.metodo-icon{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.metodo-efectivo .metodo-icon{background:#10b981;color:#fff}.metodo-tarjeta .metodo-icon{background:#eab308;color:#fff}.metodo-transferencia .metodo-icon{background:#3b82f6;color:#fff}.metodo-content{display:flex;flex-direction:column;gap:.125rem}.metodo-label{font-size:.6875rem;font-weight:600;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em}.metodo-value{font-size:1.375rem;font-weight:700;color:var(--hotel-text)}.sin-turno-card{background:var(--hotel-card-background);border-radius:16px;padding:4rem 2rem;text-align:center;max-width:500px;margin:4rem auto;box-shadow:var(--shadow-sm);border:1px solid var(--hotel-border)}.sin-turno-icon{width:80px;height:80px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-size:2rem;color:#fff}.sin-turno-card h2{font-size:1.5rem;color:var(--hotel-text);margin:0 0 .75rem}.sin-turno-card p{font-size:1rem;color:var(--hotel-text-secondary);margin:0 0 2rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-lg{padding:.875rem 2rem;font-size:1rem}.btn-primary{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf64d}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.btn-dark{background:#374151;color:#fff}.btn-dark:hover:not(:disabled){background:#1f2937}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.btn-secondary{background:var(--hotel-surface-light);color:var(--hotel-text)}.btn-secondary:hover:not(:disabled){background:var(--hotel-border)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--hotel-card-background);border-radius:12px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-large{max-width:700px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--hotel-border)}.modal-header h2{margin:0;font-size:1.5rem;color:var(--hotel-text)}.btn-close{width:32px;height:32px;border:none;background:var(--hotel-surface-light);border-radius:6px;font-size:1.5rem;color:var(--hotel-text-secondary);cursor:pointer;transition:all .2s}.btn-close:hover{background:var(--hotel-border);color:var(--hotel-text)}.modal-body{padding:2rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--hotel-text)}.form-group .required{color:#ef4444}.form-group small{display:block;margin-top:.25rem;font-size:.875rem;color:var(--hotel-text-secondary)}.form-control,.form-control-sm{width:100%;padding:.75rem;font-size:1rem;border:1px solid var(--hotel-border);border-radius:6px;transition:border-color .2s;background:var(--hotel-card-background);color:var(--hotel-text)}.form-control:focus,.form-control-sm:focus{outline:none;border-color:#8b5cf6}.form-control-sm{padding:.5rem;font-size:.875rem}textarea.form-control{resize:vertical;font-family:inherit}.arqueo-section h3{margin:0 0 .5rem;font-size:1.25rem;color:var(--hotel-text)}.arqueo-grid{margin-top:1.5rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.arqueo-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:6px}.arqueo-item label{font-weight:600;color:var(--hotel-text)}.arqueo-item .subtotal{font-size:.875rem;color:#8b5cf6;font-weight:600;text-align:right}.arqueo-totales{margin-top:2rem;padding:1.5rem;background:var(--hotel-surface-light);border-radius:8px}.total-row{display:flex;justify-content:space-between;padding:.75rem 0;font-size:1.125rem}.total-row.diferencia{padding-top:1rem;margin-top:.5rem;border-top:2px solid var(--hotel-border);font-size:1.5rem;font-weight:700}.total-row.diferencia.exacta{color:#10b981}.total-row.diferencia.positiva{color:#3b82f6}.total-row.diferencia.negativa{color:#ef4444}.monto-real{font-weight:700;color:#8b5cf6}.alert{padding:1rem;border-radius:6px;margin-top:1rem}.alert-info{background:#dbeafe;color:#1e40af;border-left:4px solid #3b82f6}[data-theme=dark] .alert-info{background:#3b82f61a;color:#93c5fd}.alert-warning{background:#fef3c7;color:#92400e;border-left:4px solid #f59e0b}[data-theme=dark] .alert-warning{background:#f59e0b1a;color:#fcd34d}.text-muted{color:var(--hotel-text-light);font-size:.875rem}.caja-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.25rem;color:var(--hotel-text-secondary)}@media (max-width: 1024px){.metrics-grid,.metodos-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.caja-page{padding:1rem}.caja-header{flex-direction:column;align-items:stretch}.header-actions{justify-content:stretch}.header-actions .btn{flex:1;justify-content:center}.metrics-grid,.metodos-grid{grid-template-columns:1fr}.badges-container{flex-direction:column}.badge{justify-content:center}.arqueo-grid{grid-template-columns:repeat(2,1fr)}.modal-content{width:95%}}@media (max-width: 480px){.header-left h1{font-size:1.5rem}.metric-icon,.metodo-icon{width:44px;height:44px;font-size:1.125rem}.metric-value{font-size:1.25rem}.metodo-value{font-size:1.125rem}.sin-turno-card{padding:2rem 1rem}.sin-turno-icon{width:64px;height:64px;font-size:1.5rem}}.user-info-group{margin-bottom:1.5rem}.user-info-display{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:6px;color:var(--hotel-text);font-weight:500}.user-info-display svg{color:#8b5cf6;font-size:1.125rem}input[type=password].form-control:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.filtros-factubox{background:var(--hotel-card-background);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.filtros-factubox__row{display:grid;grid-template-columns:150px 150px 1fr 150px;gap:1rem;align-items:end}.filtro-grupo{display:flex;flex-direction:column;gap:.5rem}.filtro-grupo label{font-size:.875rem;font-weight:600;color:var(--hotel-text)}.filtro-grupo input,.filtro-grupo select{padding:.625rem .875rem;border:1px solid var(--hotel-border);border-radius:8px;font-size:.875rem;transition:border-color .2s ease;background:var(--hotel-card-background);color:var(--hotel-text)}.filtro-grupo input:focus,.filtro-grupo select:focus{outline:none;border-color:var(--factubox-primary, #8b5cf6);box-shadow:0 0 0 3px #8b5cf61a}.filtro-grupo input::placeholder{color:#9ca3af}.filtro-grupo--busqueda{grid-column:span 1}.input-with-icon{position:relative}.input-with-icon svg{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.input-with-icon input{padding-left:2.75rem;width:100%}@media (max-width: 1024px){.filtros-factubox__row{grid-template-columns:1fr 1fr}.filtro-grupo--busqueda{grid-column:span 2}}@media (max-width: 768px){.filtros-factubox{padding:1.25rem}.filtros-factubox__row{grid-template-columns:1fr;gap:1rem}.filtro-grupo--busqueda{grid-column:span 1}.filtro-grupo label{font-size:.8125rem}.filtro-grupo input,.filtro-grupo select{padding:.5rem .75rem;font-size:.8125rem}.input-with-icon input{padding-left:2.5rem}.input-with-icon svg{left:.75rem}}.paginacion{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--hotel-card-background);border-top:1px solid var(--hotel-border);border-radius:0 0 12px 12px;margin-top:-1px}.paginacion-info{color:var(--hotel-text-secondary);font-size:.875rem;font-weight:500}.paginacion-controles{display:flex;align-items:center;gap:.5rem}.btn-paginacion{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:6px;color:var(--hotel-text);cursor:pointer;transition:all .2s ease}.btn-paginacion:hover:not(:disabled){background:var(--hotel-surface-light);border-color:#8b5cf6;color:#8b5cf6;transform:translateY(-1px)}.btn-paginacion:active:not(:disabled){transform:translateY(0)}.btn-paginacion:disabled{opacity:.4;cursor:not-allowed;background:var(--hotel-surface-light)}.pagina-actual{padding:0 1rem;font-size:.875rem;font-weight:600;color:var(--hotel-text);white-space:nowrap;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.paginacion{flex-direction:column;gap:1rem;padding:1rem}.paginacion-info{order:2;text-align:center}.paginacion-controles{order:1}}@media (max-width: 480px){.btn-paginacion{width:32px;height:32px}.pagina-actual{font-size:.8125rem;padding:0 .5rem}.paginacion-info{font-size:.8125rem}}.tabla-factubox{background:var(--hotel-card-background);border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a;position:relative;min-height:200px}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--hotel-text-secondary)}.loading-overlay .spinner{animation:spin 1s linear infinite}.tabla-facturas{width:100%;border-collapse:collapse;min-width:700px;table-layout:fixed}.tabla-facturas thead{background:var(--hotel-surface-light);border-bottom:2px solid var(--hotel-border)}.tabla-facturas th{padding:1rem;text-align:center;font-size:.75rem;font-weight:700;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.5px;vertical-align:middle}.tabla-facturas td{padding:1rem;border-bottom:1px solid var(--hotel-border);font-size:.875rem;color:var(--hotel-text);vertical-align:middle;text-align:center}.tabla-facturas tbody tr{transition:background-color .15s ease}.tabla-facturas tbody tr:hover{background:var(--hotel-surface-light)}.tabla-facturas tbody tr:last-child td{border-bottom:none}.th-checkbox{width:50px}.th-prefijo{width:100px}.th-numero{width:120px}.th-cliente{width:auto;text-align:center}.th-fecha{width:110px}.th-total{width:130px}.th-estado{width:140px}.th-acciones{width:220px}.td-checkbox{text-align:center}.td-prefijo{font-family:Courier New,monospace;font-weight:700;color:#8b5cf6;font-size:.9375rem}.td-numero{font-family:Courier New,Consolas,monospace;font-weight:600;color:var(--hotel-text-secondary)}.td-cliente{text-align:left!important}.td-cliente .cliente-info{display:flex;flex-direction:column;gap:.25rem}.td-cliente strong{font-weight:600;color:var(--hotel-text)}.td-cliente small{font-size:.8125rem;color:var(--hotel-text-secondary)}.td-fecha{color:var(--hotel-text-secondary)}.td-total{font-weight:600;color:var(--hotel-text);font-size:.9375rem}.td-estado{text-align:center}.badge{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;padding:.375rem .75rem;border-radius:12px;font-size:.8125rem;font-weight:600;white-space:nowrap;line-height:1}.badge--aceptada{background:#d1fae5;color:#065f46}.badge--rechazada{background:#fee2e2;color:#7f1d1d}.badge--pendiente{background:#fef3c7;color:#78350f}.badge--no-transmitida{background:var(--hotel-border);color:var(--hotel-text)}.td-acciones{text-align:center}.acciones-grupo{display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-accion{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid var(--hotel-border);border-radius:8px;background:var(--hotel-card-background);color:var(--hotel-text-secondary);cursor:pointer;transition:all .2s ease;text-decoration:none}.btn-accion:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.btn-accion--ver{color:var(--factubox-primary, #8b5cf6);border-color:var(--factubox-primary, #8b5cf6)}.btn-accion--ver:hover{background:var(--factubox-primary, #8b5cf6);color:#fff}.btn-accion--pdf{color:#ef4444;border-color:#ef4444}.btn-accion--pdf:hover{background:#ef4444;color:#fff}.btn-accion--xml{color:#8b5cf6;border-color:#8b5cf6}.btn-accion--xml:hover{background:#8b5cf6;color:#fff}.btn-accion--transmitir{color:#10b981;border-color:#10b981}.btn-accion--transmitir:hover{background:#10b981;color:#fff}.btn-accion--imprimir{color:#f59e0b;border-color:#f59e0b}.btn-accion--imprimir:hover{background:#f59e0b;color:#fff}.btn-accion--zip{color:#3b82f6;border-color:#3b82f6}.btn-accion--zip:hover{background:#3b82f6;color:#fff}.btn-accion--zip:disabled{opacity:.5;cursor:not-allowed;transform:none}.tabla-footer{padding:1rem 1.5rem;background:var(--hotel-surface-light);border-top:1px solid var(--hotel-border)}.contador-documentos{font-size:.875rem;color:var(--hotel-text-secondary);margin:0}.contador-documentos strong{font-weight:700;color:var(--hotel-text);font-size:1rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}@media (max-width: 1200px){.tabla-facturas{font-size:.8125rem}.tabla-facturas th,.tabla-facturas td{padding:.75rem .5rem}.btn-accion{width:32px;height:32px}.btn-accion svg{width:14px;height:14px}}@media (max-width: 768px){.tabla-wrapper{-webkit-overflow-scrolling:touch}.tabla-facturas{min-width:650px}.tabla-facturas th,.tabla-facturas td{padding:.625rem .5rem;font-size:.8125rem}.tabla-facturas th{font-size:.6875rem}.tabla-footer{padding:.875rem 1rem}.contador-documentos{font-size:.8125rem}.contador-documentos strong{font-size:.9375rem}.acciones-grupo{gap:.375rem}}.tabla-facturas input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#8b5cf6;margin:0 auto;display:block}.tabla-facturas tr.seleccionada{background:#f0f4ff}.tabla-facturas tr.seleccionada:hover{background:#e5edff}:root{--factubox-primary: #3b82f6;--factubox-primary-hover: #2563eb;--factubox-gradient: linear-gradient(135deg, #1e40af 0%, #3b82f6 50%, #60a5fa 100%)}.factubox-page{padding:1.5rem;background:var(--hotel-background)}.factubox-page-header{margin-bottom:1.5rem}.factubox-page-header h1{font-size:1.75rem;font-weight:700;color:var(--hotel-text);margin:0 0 .25rem}.factubox-page-header p{font-size:.9rem;color:var(--hotel-text-secondary);margin:0}.factubox-header{background:var(--factubox-gradient);color:#fff;padding:.75rem 2rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #3b82f626}.factubox-header__logo{display:flex;align-items:center}.factubox-header__logo .logo-factubox{height:65px;width:auto;object-fit:contain}.factubox-header__user{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff26;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.factubox-header__user span{font-size:.875rem;opacity:.9}.factubox-header__user strong{font-weight:600}.btn-volver{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;background:linear-gradient(135deg,#fff,#dbeafe);color:#1e3a8a;border:none;border-radius:50px;font-weight:700;cursor:pointer;transition:all .25s ease;font-size:.9375rem;letter-spacing:.01em;box-shadow:0 4px 16px #0003,0 0 0 1px #ffffff4d}.btn-volver svg{transition:transform .25s ease}.btn-volver:hover{background:#fff;transform:translateY(-2px);box-shadow:0 8px 30px #0000004d,0 0 20px #fff3}.btn-volver:hover svg{transform:translate(-3px)}.btn-volver:active{transform:translateY(0);box-shadow:0 2px 8px #00000026}.factubox-header__actions{display:flex;align-items:center;gap:1rem}.factubox-theme-toggle{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:8px;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.2);cursor:pointer;transition:all .2s ease;flex-shrink:0}.factubox-theme-toggle:hover{background:#ffffff40;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.factubox-theme-toggle svg{transition:transform .3s ease}.factubox-theme-toggle:hover svg{transform:rotate(15deg)}.factubox-tabs{display:flex;background:var(--hotel-card-background);border-bottom:2px solid var(--hotel-border);padding:0 2rem}.tab{padding:1rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;font-size:.9375rem;font-weight:600;color:var(--hotel-text-secondary);cursor:pointer;transition:all .2s ease;position:relative;bottom:-2px}.tab:hover{color:var(--factubox-primary)}.tab--activo{color:var(--factubox-primary);border-bottom-color:var(--factubox-primary)}.factubox-content{padding:2rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:var(--hotel-card-background);border-radius:12px;box-shadow:var(--shadow-sm);border:1px solid var(--hotel-border)}.empty-state__title{font-size:1.125rem;font-weight:600;color:var(--hotel-text);margin-top:1rem;margin-bottom:.5rem}.empty-state__subtitle{font-size:.875rem;color:var(--hotel-text-secondary);margin-top:0}.factubox-actions{display:flex;justify-content:flex-end;margin-bottom:1rem;padding:0}.btn-crear-nc{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--factubox-primary);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.9375rem}.btn-crear-nc:hover{background:var(--factubox-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf640}.btn-crear-nc:active{transform:translateY(0)}.factubox-acciones-lote{position:sticky;bottom:0;left:0;right:0;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;padding:1rem 2rem;box-shadow:0 -4px 12px #00000026;z-index:100;animation:slideUp .3s ease;margin-top:1rem;border-radius:12px}.acciones-lote-content{display:flex;align-items:center;justify-content:center;gap:1.5rem;max-width:1400px;margin:0 auto}.contador-seleccionadas{font-size:1rem;font-weight:600;color:#fff}.btn-transmitir-lote{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--hotel-card-background);color:#8b5cf6;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.9375rem}.btn-transmitir-lote:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ffffff4d}.btn-limpiar-seleccion{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;color:#fff;border:2px solid white;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.9375rem}.btn-limpiar-seleccion:hover{background:var(--hotel-card-background);color:#8b5cf6}@media (max-width: 768px){.factubox-header{flex-direction:column;align-items:flex-start;gap:1rem;padding:1.25rem}.factubox-header__logo .logo-factubox{height:50px}.factubox-header__user,.btn-volver{align-self:flex-start}.factubox-tabs{padding:0 1rem;overflow-x:auto}.tab{padding:.875rem 1.25rem;font-size:.875rem;white-space:nowrap}.factubox-content{padding:1rem}.empty-state{padding:3rem 1.5rem}.acciones-lote-content{flex-direction:column;gap:.75rem;align-items:stretch}.btn-transmitir-lote,.btn-limpiar-seleccion{justify-content:center;width:100%}}@media (max-width: 480px){.factubox-header__logo .logo-factubox{height:42px}.factubox-header__user span{font-size:.8125rem}.btn-volver{font-size:.875rem;padding:.5rem 1rem}.tab{padding:.75rem 1rem;font-size:.8125rem}}.mi-licencia{max-width:1000px;margin:0 auto;padding:24px}.mi-licencia__header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.mi-licencia__back{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--hotel-text-secondary);font-size:.9rem;cursor:pointer;padding:8px 12px;border-radius:8px;transition:all .2s}.mi-licencia__back:hover{background:var(--hotel-hover);color:var(--hotel-text)}.mi-licencia__header h1{display:flex;align-items:center;gap:12px;margin:0;font-size:1.75rem;color:var(--hotel-text)}.mi-licencia__loading,.mi-licencia__error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:80px 24px;color:var(--hotel-text-secondary)}.mi-licencia__error button{background:#8b5cf6;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer}.mi-licencia__estado{display:flex;align-items:center;padding:28px;border-radius:16px;margin-bottom:24px;gap:24px}.estado--verde{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981}.estado--verde .mi-licencia__estado-icono{color:#059669}.estado--azul{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #3b82f6}.estado--azul .mi-licencia__estado-icono{color:#2563eb}.estado--amarillo{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b}.estado--amarillo .mi-licencia__estado-icono{color:#d97706}.estado--naranja{background:linear-gradient(135deg,#ffedd5,#fed7aa);border:2px solid #f97316}.estado--naranja .mi-licencia__estado-icono{color:#ea580c}.estado--rojo{background:linear-gradient(135deg,#fee2e2,#fecaca);border:2px solid #ef4444}.estado--rojo .mi-licencia__estado-icono{color:#dc2626}.estado--gris{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:2px solid #9ca3af}.estado--gris .mi-licencia__estado-icono{color:#6b7280}.mi-licencia__estado-icono{flex-shrink:0}.mi-licencia__estado-info h2{margin:0 0 8px;font-size:1.5rem;color:var(--hotel-text)}.mi-licencia__estado-info p{margin:0;color:var(--hotel-text-secondary);font-size:1rem}.mi-licencia__seccion{background:var(--hotel-card-background);border-radius:16px;padding:24px;margin-bottom:20px;border:1px solid var(--hotel-border)}.mi-licencia__seccion h3{display:flex;align-items:center;gap:10px;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid var(--hotel-border);color:var(--hotel-text);font-size:1.1rem}.mi-licencia__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}.mi-licencia__campo{display:flex;flex-direction:column}.mi-licencia__campo label{font-size:.85rem;color:var(--hotel-text-secondary);margin-bottom:6px;font-weight:500}.mi-licencia__campo span{font-size:1rem;color:var(--hotel-text);font-weight:500}.mi-licencia__codigo{font-family:JetBrains Mono,Fira Code,monospace;background:var(--hotel-hover);padding:6px 10px;border-radius:6px;font-size:.9rem!important;letter-spacing:.5px}.mi-licencia__modulos-seccion{background:var(--hotel-card-background);border-radius:16px;padding:24px;margin-bottom:20px;border:1px solid var(--hotel-border)}.mi-licencia__modulos-seccion--incluidos{background:linear-gradient(180deg,#f0fdf4,#fff);border-color:#bbf7d0}.mi-licencia__modulos-seccion--premium{background:linear-gradient(180deg,#fffbeb,#fff);border-color:#fde68a}.mi-licencia__modulos-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.mi-licencia__modulos-titulo{display:flex;align-items:center;gap:12px}.mi-licencia__modulos-titulo h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--hotel-text);border:none;padding:0}.mi-licencia__modulos-seccion--incluidos .mi-licencia__modulos-titulo svg{color:#10b981}.mi-licencia__modulos-seccion--premium .mi-licencia__modulos-titulo svg{color:#f59e0b}.mi-licencia__modulos-contador{font-size:.875rem;font-weight:500;padding:4px 12px;border-radius:20px}.mi-licencia__modulos-contador--verde{background:#d1fae5;color:#065f46}.mi-licencia__modulos-contador--amarillo{background:#fef3c7;color:#92400e}.mi-licencia__modulos-subtitulo{color:var(--hotel-text-secondary);font-size:.9rem;margin:0 0 20px;font-style:italic}.mi-licencia__modulos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.mi-licencia__modulo-card{display:flex;align-items:center;padding:14px 16px;border-radius:12px;gap:12px;position:relative;transition:all .2s}.mi-licencia__modulo-card--core{background:#fff;border:1px solid #d1fae5}.mi-licencia__modulo-card--core:hover{border-color:#10b981;box-shadow:0 2px 8px #10b98126}.mi-licencia__modulo-card--premium{background:#fff;border:1px solid #e5e7eb}.mi-licencia__modulo-card--premium:hover{border-color:#f59e0b;box-shadow:0 2px 8px #f59e0b26}.mi-licencia__modulo-card--premium.mi-licencia__modulo-card--activo{border-color:#10b981;background:linear-gradient(135deg,#f0fdf4,#fff)}.mi-licencia__modulo-badge{position:absolute;top:-8px;right:12px;display:flex;align-items:center;gap:4px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:.65rem;font-weight:700;padding:3px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}.mi-licencia__modulo-icono{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mi-licencia__modulo-icono--verde{background:#d1fae5;color:#059669}.mi-licencia__modulo-icono--gris{background:#f3f4f6;color:#6b7280}.mi-licencia__modulo-card--activo .mi-licencia__modulo-icono--gris{background:#d1fae5;color:#059669}.mi-licencia__modulo-info{display:flex;flex-direction:column;gap:2px;min-width:0}.mi-licencia__modulo-nombre{font-weight:600;font-size:.9rem;color:var(--hotel-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mi-licencia__modulo-estado{font-size:.75rem;font-weight:500}.mi-licencia__modulo-estado--incluido,.mi-licencia__modulo-estado--activo{color:#10b981}.mi-licencia__modulo-estado--inactivo{color:#9ca3af}.mi-licencia__cta-seccion{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:16px;padding:28px;margin-bottom:20px;text-align:left}.mi-licencia__cta-seccion h3{margin:0 0 12px;font-size:1.25rem;font-weight:600;color:#1e40af}.mi-licencia__cta-seccion p{margin:0 0 20px;color:#1e3a8a;font-size:.95rem;line-height:1.5}.mi-licencia__cta-btn{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:12px 24px;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.mi-licencia__cta-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.mi-licencia__acciones{margin-top:28px;text-align:center}.mi-licencia__activacion{max-width:450px;margin:0 auto}.mi-licencia__formulario{background:var(--hotel-card-background);padding:28px;border-radius:16px;border:1px solid var(--hotel-border)}.mi-licencia__formulario h4{margin:0 0 20px;text-align:center;color:var(--hotel-text);font-size:1.1rem}.mi-licencia__input{width:100%;padding:16px;font-size:1.1rem;font-family:JetBrains Mono,Fira Code,monospace;text-align:center;letter-spacing:3px;border:2px solid var(--hotel-border);border-radius:10px;text-transform:uppercase;box-sizing:border-box;background:var(--hotel-background);color:var(--hotel-text);transition:all .2s}.mi-licencia__input:focus{border-color:#8b5cf6;outline:none;box-shadow:0 0 0 3px #8b5cf633}.mi-licencia__input:disabled{background:var(--hotel-hover);opacity:.7}.mi-licencia__contador{text-align:right;font-size:.85rem;color:var(--hotel-text-secondary);margin:8px 0 20px}.mi-licencia__botones{display:flex;gap:12px;justify-content:center}.mi-licencia__btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:10px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.mi-licencia__btn--primary{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.mi-licencia__btn--primary:hover:not(:disabled){background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.mi-licencia__btn--primary:disabled{background:#a5b4fc;cursor:not-allowed;transform:none;box-shadow:none}.mi-licencia__btn--secondary{background:var(--hotel-hover);color:var(--hotel-text);border:1px solid var(--hotel-border)}.mi-licencia__btn--secondary:hover:not(:disabled){background:var(--hotel-border)}.mi-licencia__btn--secondary:disabled{opacity:.6;cursor:not-allowed}[data-theme=dark] .estado--verde{background:#10b9811a;border-color:#10b981}[data-theme=dark] .estado--azul{background:#3b82f61a;border-color:#3b82f6}[data-theme=dark] .estado--amarillo{background:#f59e0b1a;border-color:#f59e0b}[data-theme=dark] .estado--naranja{background:#f973161a;border-color:#f97316}[data-theme=dark] .estado--rojo{background:#ef44441a;border-color:#ef4444}[data-theme=dark] .estado--gris{background:#9ca3af1a;border-color:#9ca3af}[data-theme=dark] .estado--verde .mi-licencia__estado-icono{color:#6ee7b7}[data-theme=dark] .estado--azul .mi-licencia__estado-icono{color:#93c5fd}[data-theme=dark] .estado--amarillo .mi-licencia__estado-icono{color:#fcd34d}[data-theme=dark] .estado--naranja .mi-licencia__estado-icono{color:#fdba74}[data-theme=dark] .estado--rojo .mi-licencia__estado-icono{color:#fca5a5}[data-theme=dark] .estado--gris .mi-licencia__estado-icono{color:#d1d5db}[data-theme=dark] .mi-licencia__modulos-seccion--incluidos{background:var(--hotel-card-background);border-color:#10b9814d}[data-theme=dark] .mi-licencia__modulos-seccion--premium{background:var(--hotel-card-background);border-color:#f59e0b4d}[data-theme=dark] .mi-licencia__modulos-contador--verde{background:#10b98126;color:#6ee7b7}[data-theme=dark] .mi-licencia__modulos-contador--amarillo{background:#f59e0b26;color:#fcd34d}[data-theme=dark] .mi-licencia__modulo-card--core{background:var(--hotel-surface-light);border-color:#10b9814d}[data-theme=dark] .mi-licencia__modulo-card--premium{background:var(--hotel-surface-light);border-color:var(--hotel-border)}[data-theme=dark] .mi-licencia__modulo-card--premium.mi-licencia__modulo-card--activo{background:var(--hotel-surface-light);border-color:#10b981}[data-theme=dark] .mi-licencia__modulo-icono--verde{background:#10b98133;color:#6ee7b7}[data-theme=dark] .mi-licencia__modulo-icono--gris{background:var(--hotel-border);color:var(--hotel-text-secondary)}[data-theme=dark] .mi-licencia__modulo-card--activo .mi-licencia__modulo-icono--gris{background:#10b98133;color:#6ee7b7}[data-theme=dark] .mi-licencia__cta-seccion{background:#3b82f61a;border:1px solid rgba(59,130,246,.3)}[data-theme=dark] .mi-licencia__cta-seccion h3{color:#93c5fd}[data-theme=dark] .mi-licencia__cta-seccion p{color:#bfdbfe}@media (max-width: 768px){.mi-licencia{padding:16px}.mi-licencia__header h1{font-size:1.4rem}.mi-licencia__estado{flex-direction:column;text-align:center;padding:20px}.mi-licencia__grid{grid-template-columns:1fr}.mi-licencia__modulos-grid{grid-template-columns:repeat(2,1fr)}.mi-licencia__modulos-header{flex-direction:column;align-items:flex-start;gap:8px}.mi-licencia__botones{flex-direction:column}.mi-licencia__btn{width:100%;justify-content:center}.mi-licencia__cta-seccion{text-align:center}.mi-licencia__cta-btn{width:100%;justify-content:center}}@media (max-width: 480px){.mi-licencia__modulos-grid{grid-template-columns:1fr}.mi-licencia__input{font-size:.95rem;letter-spacing:1px;padding:14px}.mi-licencia__modulo-card{padding:12px}.mi-licencia__modulo-nombre{font-size:.85rem}}.impresoras-container{padding:24px;max-width:1400px;margin:0 auto;min-height:calc(100vh - 64px)}.impresoras-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:16px;border-bottom:2px solid var(--hotel-border)}.header-title{display:flex;align-items:center;gap:12px}.header-title svg{color:#8b5cf6}.header-title h1{margin:0;font-size:1.75rem;font-weight:600;color:var(--hotel-text)}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px;color:var(--hotel-text-secondary)}.loading-state svg{color:#8b5cf6}.error-state svg{color:#ef4444}.spin{animation:spin 1s linear infinite}.seccion-tipo{background:var(--hotel-card-background);border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.seccion-tipo h2{display:flex;align-items:center;gap:10px;margin:0 0 20px;font-size:1.25rem;font-weight:600;color:var(--hotel-text)}.tipo-icon{font-size:1.5rem}.sin-impresoras{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px;color:var(--hotel-text-light);background:var(--hotel-background);border-radius:8px;border:2px dashed var(--hotel-border)}.sin-impresoras svg{opacity:.5}.grid-impresoras{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.tarjeta-impresora{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:12px;overflow:hidden;transition:all .2s ease}.tarjeta-impresora:hover{border-color:#8b5cf6;box-shadow:0 4px 12px #8b5cf626}.tarjeta-impresora.inactiva{opacity:.6;background:var(--hotel-background)}.tarjeta-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff}.impresora-info{display:flex;align-items:center;gap:10px}.impresora-nombre{font-weight:600;font-size:1.1rem}.badge-predeterminada{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#fff3;border-radius:20px;font-size:.75rem;font-weight:500}.tarjeta-body{padding:16px}.tarjeta-body .detalle{display:flex;align-items:center;gap:8px;color:var(--hotel-text-secondary);font-size:.9rem;margin-bottom:8px}.tarjeta-body .descripcion{color:var(--hotel-text-secondary);font-size:.85rem;margin:8px 0}.detalles-extras{display:flex;align-items:center;gap:12px;margin-top:12px}.badge-estado{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:500}.badge-estado.activa{background:#d1fae5;color:#065f46}.badge-estado.inactiva{background:#fee2e2;color:#991b1b}.ancho-papel{padding:4px 10px;background:var(--hotel-surface-light);border-radius:20px;font-size:.75rem;color:var(--hotel-text-secondary)}.tarjeta-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;background:var(--hotel-background);border-top:1px solid var(--hotel-border)}.seccion-sistema{background:var(--hotel-card-background);border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.header-sistema{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.header-sistema h2{display:flex;align-items:center;gap:10px;margin:0;font-size:1.25rem;font-weight:600;color:var(--hotel-text)}.header-sistema h2 svg{color:#8b5cf6}.lista-sistema{display:flex;flex-direction:column;gap:8px}.impresora-sistema{display:flex;align-items:center;gap:16px;padding:14px 16px;background:var(--hotel-background);border-radius:8px;border:1px solid var(--hotel-border)}.sistema-info{display:flex;align-items:center;gap:10px;flex:1}.sistema-info svg{color:var(--hotel-text-secondary)}.sistema-info .nombre{font-weight:500;color:var(--hotel-text)}.impresora-sistema .driver{color:var(--hotel-text-secondary);font-size:.85rem;flex:1}.impresora-sistema .estado{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:500}.impresora-sistema .estado.ok{background:#d1fae5;color:#065f46}.impresora-sistema .estado.error{background:#fee2e2;color:#991b1b}.btn-primario{display:flex;align-items:center;gap:8px;background:#8b5cf6;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease}.btn-primario:hover:not(:disabled){background:#7c3aed}.btn-primario:disabled{opacity:.6;cursor:not-allowed}.btn-secundario{display:flex;align-items:center;gap:6px;background:#6b7280;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease}.btn-secundario:hover:not(:disabled){background:#4b5563}.btn-peligro{display:flex;align-items:center;gap:6px;background:#ef4444;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease}.btn-peligro:hover:not(:disabled){background:#dc2626}.btn-sm{padding:8px 12px;font-size:.85rem}.btn-link{background:none;border:none;color:#8b5cf6;cursor:pointer;padding:8px;border-radius:6px;transition:all .2s ease}.btn-link:hover{background:#8b5cf61a}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--hotel-card-background);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{padding:20px 24px;border-bottom:1px solid var(--hotel-border);background:linear-gradient(135deg,#8b5cf6,#a78bfa);border-radius:16px 16px 0 0}.modal-header h2{display:flex;align-items:center;gap:10px;margin:0;color:#fff;font-size:1.25rem;font-weight:600}.modal-content form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--hotel-text)}.form-group input[type=text],.form-group select,.form-group textarea{width:100%;padding:12px;border:1px solid var(--hotel-border);border-radius:8px;font-size:1rem;transition:all .2s ease;background:var(--hotel-background);color:var(--hotel-text)}.form-group input[type=text]:focus,.form-group select:focus,.form-group textarea:focus{border-color:#8b5cf6;outline:none;box-shadow:0 0 0 3px #8b5cf61a}.form-group small{display:block;margin-top:6px;color:var(--hotel-text-secondary);font-size:.8rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-row.checkboxes{margin-top:8px}.form-group.checkbox label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:400}.form-group.checkbox input[type=checkbox]{width:18px;height:18px;accent-color:#8b5cf6}.modal-acciones{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--hotel-border);margin-top:8px}[data-theme=dark] .badge-estado.activa{background:#10b98126;color:#6ee7b7}[data-theme=dark] .badge-estado.inactiva{background:#ef444426;color:#fca5a5}[data-theme=dark] .impresora-sistema .estado.ok{background:#10b98126;color:#6ee7b7}[data-theme=dark] .impresora-sistema .estado.error{background:#ef444426;color:#fca5a5}@media (max-width: 768px){.impresoras-container{padding:16px}.impresoras-header{flex-direction:column;gap:16px;align-items:stretch}.grid-impresoras,.form-row{grid-template-columns:1fr}.modal-content{margin:10px;max-height:calc(100vh - 20px)}.impresora-sistema{flex-wrap:wrap}.impresora-sistema .driver{width:100%;order:3;margin-top:8px}}.housekeeping{max-width:1600px;margin:0 auto}.hk__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.hk__title-group{display:flex;flex-direction:column;gap:.125rem}.hk__title{font-size:1.375rem;font-weight:700;color:var(--hotel-text);display:flex;align-items:center;gap:.5rem}.hk__subtitle{font-size:.8125rem;color:var(--hotel-text-secondary)}.hk__header-actions{display:flex;align-items:center;gap:.5rem}.hk__date-input{padding:.4375rem .625rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.8125rem;background:var(--hotel-card-background);color:var(--hotel-text)}.hk__btn{display:inline-flex;align-items:center;gap:.375rem;padding:.4375rem .75rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s;background:var(--hotel-card-background);color:var(--hotel-text)}.hk__btn:hover{background:var(--hotel-background)}.hk__btn--primary{background:var(--hotel-primary);color:#fff;border-color:var(--hotel-primary)}.hk__btn--primary:hover{background:var(--hotel-primary-dark, #1d4ed8)}.hk__btn--sm{padding:.25rem .5rem;font-size:.75rem}.hk__btn--success{background:#10b981;color:#fff;border-color:#10b981}.hk__btn--success:hover{background:#059669}.hk__summary{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;margin-bottom:1.25rem}.hk__stat{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;padding:.75rem;display:flex;align-items:center;gap:.75rem}.hk__stat-icon{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hk__stat-icon--yellow{background:#f59e0b1a;color:#f59e0b}.hk__stat-icon--blue{background:#3b82f61a;color:#3b82f6}.hk__stat-icon--green{background:#10b9811a;color:#10b981}.hk__stat-icon--red{background:#ef44441a;color:#ef4444}.hk__stat-icon--purple{background:#8b5cf61a;color:#8b5cf6}.hk__stat-info{display:flex;flex-direction:column;gap:.0625rem}.hk__stat-value{font-size:1.25rem;font-weight:700;color:var(--hotel-text)}.hk__stat-label{font-size:.6875rem;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.03em}.hk__filters{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.hk__filter-select{padding:.375rem .625rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.8125rem;background:var(--hotel-card-background);color:var(--hotel-text)}.hk__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem;margin-bottom:1.25rem}.hk__card{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;overflow:hidden;transition:box-shadow .15s}.hk__card:hover{box-shadow:var(--shadow-md, 0 4px 12px rgba(0,0,0,.08))}.hk__card-header{display:flex;align-items:center;justify-content:space-between;padding:.625rem .75rem;border-bottom:1px solid var(--hotel-border)}.hk__card-room{display:flex;align-items:center;gap:.5rem}.hk__card-room-num{font-size:1rem;font-weight:700;color:var(--hotel-text)}.hk__card-room-type{font-size:.6875rem;color:var(--hotel-text-secondary);text-transform:uppercase}.hk__card-priority{display:inline-flex;align-items:center;padding:.125rem .375rem;border-radius:4px;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.hk__card-priority--urgente{background:#fecaca;color:#991b1b}.hk__card-priority--alta{background:#fed7aa;color:#9a3412}.hk__card-priority--normal{background:#dbeafe;color:#1e40af}.hk__card-priority--baja{background:#e5e7eb;color:#6b7280}.hk__card-body{padding:.625rem .75rem;display:flex;flex-direction:column;gap:.5rem}.hk__card-tipo{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:500;color:var(--hotel-text)}.hk__card-asignado{font-size:.75rem;color:var(--hotel-text-secondary);display:flex;align-items:center;gap:.25rem}.hk__card-notas{font-size:.75rem;color:var(--hotel-text-secondary);font-style:italic}.hk__card-estado{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .5rem;border-radius:999px;font-size:.6875rem;font-weight:600;width:fit-content}.hk__card-estado--pendiente{background:#fef3c7;color:#92400e}.hk__card-estado--en_progreso{background:#dbeafe;color:#1e40af}.hk__card-estado--completada{background:#dcfce7;color:#166534}.hk__card-estado--cancelada{background:#fecaca;color:#991b1b}.hk__card-actions{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;border-top:1px solid var(--hotel-border);background:var(--hotel-background)}.hk__staff{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;overflow:hidden}.hk__staff-header{padding:.625rem .75rem;border-bottom:1px solid var(--hotel-border);font-size:.8125rem;font-weight:600;color:var(--hotel-text)}.hk__staff-list{padding:.5rem .75rem;display:flex;flex-direction:column;gap:.5rem}.hk__staff-item{display:flex;align-items:center;justify-content:space-between;padding:.375rem 0}.hk__staff-name{font-size:.8125rem;font-weight:500;color:var(--hotel-text)}.hk__staff-counts{display:flex;gap:.5rem;font-size:.6875rem}.hk__staff-count{padding:.125rem .375rem;border-radius:4px}.hk__staff-count--pending{background:#fef3c7;color:#92400e}.hk__staff-count--progress{background:#dbeafe;color:#1e40af}.hk__staff-count--done{background:#dcfce7;color:#166534}.hk__empty{text-align:center;padding:3rem;color:var(--hotel-text-secondary);font-size:.875rem}.hk__loading{display:flex;align-items:center;justify-content:center;padding:4rem;color:var(--hotel-text-secondary);font-size:.875rem;gap:.5rem}.hk__modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.hk__modal{background:var(--hotel-card-background);border-radius:8px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.hk__modal-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;border-bottom:1px solid var(--hotel-border)}.hk__modal-title{font-size:.9375rem;font-weight:600;color:var(--hotel-text)}.hk__modal-close{background:none;border:none;cursor:pointer;color:var(--hotel-text-secondary);padding:.25rem}.hk__modal-body{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.hk__field{display:flex;flex-direction:column;gap:.25rem}.hk__field label{font-size:.75rem;font-weight:500;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.03em}.hk__field select,.hk__field textarea{padding:.5rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.8125rem;background:var(--hotel-background);color:var(--hotel-text);font-family:inherit}.hk__field textarea{min-height:60px;resize:vertical}.hk__modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--hotel-border)}.hk__content{display:grid;grid-template-columns:1fr 280px;gap:1rem}@media (max-width: 1200px){.hk__content{grid-template-columns:1fr}.hk__summary{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.hk__summary{grid-template-columns:repeat(2,1fr)}.hk__grid{grid-template-columns:1fr}.hk__header{flex-direction:column;align-items:flex-start}}.grados-militares{max-width:1200px;margin:0 auto}.gm__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.gm__title-group{display:flex;flex-direction:column;gap:.125rem}.gm__title{font-size:1.375rem;font-weight:700;color:var(--hotel-text);display:flex;align-items:center;gap:.5rem;margin:0}.gm__title svg{color:var(--hotel-primary)}.gm__subtitle{font-size:.8125rem;color:var(--hotel-text-secondary);margin:0}.gm__btn{display:inline-flex;align-items:center;gap:.375rem;padding:.4375rem .75rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s;background:var(--hotel-card-background);color:var(--hotel-text);font-family:inherit}.gm__btn:hover:not(:disabled){background:var(--hotel-background)}.gm__btn:disabled{opacity:.6;cursor:not-allowed}.gm__btn--primary{background:var(--hotel-primary);color:#fff;border-color:var(--hotel-primary)}.gm__btn--primary:hover:not(:disabled){background:var(--hotel-primary-dark, #1d4ed8);border-color:var(--hotel-primary-dark, #1d4ed8)}.gm__btn--danger{background:#ef4444;color:#fff;border-color:#ef4444}.gm__btn--danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.gm__filters{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.gm__toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.gm__toggle input{position:absolute;opacity:0;width:0;height:0}.gm__toggle-track{position:relative;width:34px;height:18px;background:var(--hotel-border);border-radius:999px;transition:background .2s;flex-shrink:0}.gm__toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0003}.gm__toggle input:checked+.gm__toggle-track{background:var(--hotel-primary)}.gm__toggle input:checked+.gm__toggle-track:after{transform:translate(16px)}.gm__toggle-label{font-size:.8125rem;color:var(--hotel-text-secondary)}.gm__count{font-size:.75rem;color:var(--hotel-text-secondary);margin-left:auto}.gm__table-container{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;overflow:hidden;margin-bottom:1.25rem}.gm__table{width:100%;border-collapse:collapse}.gm__table th{text-align:left;padding:.625rem 1rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--hotel-text-secondary);background:var(--hotel-background);border-bottom:1px solid var(--hotel-border);white-space:nowrap}.gm__table td{padding:.75rem 1rem;font-size:.8125rem;color:var(--hotel-text);border-bottom:1px solid var(--hotel-border);vertical-align:middle}.gm__table tbody tr:last-child td{border-bottom:none}.gm__table tbody tr:hover td{background:var(--hotel-background)}.gm__row--inactivo td{opacity:.55}.gm__row--inactivo:hover td{opacity:.75}.gm__orden-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--hotel-background);border:1px solid var(--hotel-border);font-size:.75rem;font-weight:700;color:var(--hotel-text-secondary);font-variant-numeric:tabular-nums}.gm__codigo{display:inline-block;padding:.1875rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700;font-family:Courier New,Courier,monospace;letter-spacing:.04em;background:#2563eb14;color:var(--hotel-primary);white-space:nowrap;border:1px solid rgba(37,99,235,.18)}[data-theme=dark] .gm__codigo{background:#3b82f61f;color:#60a5fa;border-color:#3b82f640}.gm__nombre{font-weight:500;color:var(--hotel-text)}.gm__descripcion{font-size:.8125rem;color:var(--hotel-text-secondary);font-style:italic;cursor:default}.gm__empty-cell{color:var(--hotel-text-secondary);opacity:.45}.gm__precio{font-weight:600;color:var(--hotel-text);font-variant-numeric:tabular-nums;white-space:nowrap}.gm__badge{display:inline-flex;align-items:center;gap:.25rem;padding:.1875rem .5625rem;border-radius:999px;font-size:.6875rem;font-weight:600;white-space:nowrap;cursor:pointer;border:1px solid transparent;transition:all .15s;font-family:inherit}.gm__badge--activo{background:#dcfce7;color:#166534;border-color:#bbf7d0}.gm__badge--activo:hover:not(:disabled){background:#bbf7d0}.gm__badge--inactivo{background:#fef2f2;color:#991b1b;border-color:#fecaca}.gm__badge--inactivo:hover:not(:disabled){background:#fecaca}.gm__badge:disabled{cursor:not-allowed;opacity:.6}[data-theme=dark] .gm__badge--activo{background:#10b9811f;color:#34d399;border-color:#10b98140}[data-theme=dark] .gm__badge--activo:hover:not(:disabled){background:#10b98133}[data-theme=dark] .gm__badge--inactivo{background:#ef44441f;color:#f87171;border-color:#ef444440}[data-theme=dark] .gm__badge--inactivo:hover:not(:disabled){background:#ef444433}.gm__actions-cell{display:flex;align-items:center;gap:.375rem}.gm__action-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:1px solid var(--hotel-border);background:var(--hotel-card-background);cursor:pointer;transition:all .15s;color:var(--hotel-text-secondary)}.gm__action-btn--edit:hover{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.gm__action-btn--delete:hover{background:#fecaca;border-color:#fca5a5;color:#b91c1c}[data-theme=dark] .gm__action-btn--edit:hover{background:#3b82f626;border-color:#3b82f64d;color:#60a5fa}[data-theme=dark] .gm__action-btn--delete:hover{background:#ef444426;border-color:#ef44444d;color:#f87171}.gm__empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:3.5rem 2rem;gap:.75rem;color:var(--hotel-text-secondary)}.gm__empty svg{opacity:.35}.gm__empty-title{font-size:.9375rem;font-weight:600;color:var(--hotel-text);margin:0}.gm__empty-desc{font-size:.8125rem;color:var(--hotel-text-secondary);max-width:420px;line-height:1.5;margin:0}.gm__modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.gm__modal{background:var(--hotel-card-background);border-radius:8px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000002e}.gm__modal--sm{max-width:400px}.gm__modal-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;border-bottom:1px solid var(--hotel-border)}.gm__modal-title{font-size:.9375rem;font-weight:600;color:var(--hotel-text);display:flex;align-items:center;gap:.4rem}.gm__modal-title svg{color:var(--hotel-primary);flex-shrink:0}.gm__modal-close{background:none;border:none;cursor:pointer;color:var(--hotel-text-secondary);padding:.25rem;display:flex;align-items:center;transition:color .15s}.gm__modal-close:hover{color:var(--hotel-text)}.gm__modal-body{padding:1rem;display:flex;flex-direction:column;gap:.875rem}.gm__modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--hotel-border)}.gm__field{display:flex;flex-direction:column;gap:.25rem;flex:1}.gm__field label{font-size:.75rem;font-weight:500;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.03em}.gm__field input,.gm__field select,.gm__field textarea{padding:.5rem .625rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.8125rem;background:var(--hotel-background);color:var(--hotel-text);font-family:inherit;transition:border-color .15s,box-shadow .15s}.gm__field input:focus,.gm__field select:focus,.gm__field textarea:focus{outline:none;border-color:var(--hotel-primary);box-shadow:0 0 0 2px #2563eb1f}.gm__field textarea{min-height:72px;resize:vertical}.gm__field-hint{font-size:.6875rem;color:var(--hotel-primary);font-weight:500;padding-top:.125rem}.gm__field-row{display:grid;grid-template-columns:1fr 80px;gap:.75rem}.gm__field--inline{flex-direction:row;align-items:center;padding:.5rem .625rem;border:1px solid var(--hotel-border);border-radius:6px;background:var(--hotel-background)}.gm__inline-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;width:100%}.gm__inline-toggle input{position:absolute;opacity:0;width:0;height:0}.gm__inline-label{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:500;color:var(--hotel-text)}.gm__confirm-icon{width:48px;height:48px;border-radius:50%;background:#ef44441a;color:#ef4444;display:flex;align-items:center;justify-content:center;margin:0 auto .75rem}.gm__confirm-text{font-size:.875rem;color:var(--hotel-text);text-align:center;line-height:1.5;margin:0}.gm__confirm-text strong{color:var(--hotel-text)}.gm__loading{display:flex;align-items:center;justify-content:center;padding:4rem;color:var(--hotel-text-secondary);font-size:.875rem;gap:.5rem}@keyframes gm-spin{to{transform:rotate(360deg)}}.gm__spin{animation:gm-spin .8s linear infinite}@media (max-width: 768px){.gm__header{flex-direction:column;align-items:flex-start}.gm__count{margin-left:0}.gm__table thead{display:none}.gm__table,.gm__table tbody,.gm__table tr,.gm__table td{display:block;width:100%}.gm__table tr{border-bottom:1px solid var(--hotel-border);padding:.75rem 1rem}.gm__table tr:last-child{border-bottom:none}.gm__table td{border-bottom:none;padding:.1875rem 0;display:flex;align-items:flex-start;gap:.5rem}.gm__table td:before{content:attr(data-label);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--hotel-text-secondary);min-width:90px;flex-shrink:0;padding-top:.125rem}.gm__actions-cell{justify-content:flex-start}.gm__field-row{grid-template-columns:1fr}.gm__modal{max-width:100%;margin:0;border-radius:12px 12px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:85vh}.gm__modal-overlay{align-items:flex-end;padding:0}}@media (max-width: 480px){.gm__filters{gap:.5rem}}.cuentas-cobro-page{padding:1.5rem;background:var(--hotel-background)}.cuentas-cobro-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.cuentas-cobro-header__titulo{display:flex;align-items:center;gap:.75rem}.cuentas-cobro-header__titulo svg{color:var(--hotel-primary)}.cuentas-cobro-header__titulo h1{font-size:1.75rem;font-weight:700;color:var(--hotel-text);margin:0}.cuentas-cobro-header__titulo p{font-size:.85rem;color:var(--hotel-text-secondary);margin:0}.btn-generar-cuentas{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--hotel-primary);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s}.btn-generar-cuentas:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.cuentas-cobro-periodo{display:flex;gap:1rem;margin-bottom:1.5rem}.periodo-selector{display:flex;flex-direction:column;gap:.25rem}.periodo-selector label{font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary);text-transform:uppercase}.periodo-selector select{padding:.5rem .75rem;border:1px solid var(--hotel-border);border-radius:6px;background:var(--hotel-card-background);color:var(--hotel-text);font-size:.9rem;font-weight:600}.cuentas-cobro-resumen{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.resumen-card{display:flex;flex-direction:column;padding:1rem 1.25rem;border-radius:10px;background:var(--hotel-card-background);border:1px solid var(--hotel-border);box-shadow:var(--shadow-sm)}.resumen-card__label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--hotel-text-secondary);margin-bottom:.25rem}.resumen-card__valor{font-size:1.5rem;font-weight:700;color:var(--hotel-text)}.resumen-card__detalle{font-size:.8rem;color:var(--hotel-text-secondary);margin-top:.25rem}.resumen-card--emitido{border-left:3px solid #3b82f6}.resumen-card--cobrado{border-left:3px solid #22c55e}.resumen-card--pendiente{border-left:3px solid #f59e0b}.resumen-card--cobro{border-left:3px solid #8b5cf6}.barra-progreso{width:100%;height:6px;background:var(--hotel-border);border-radius:3px;margin-top:.5rem;overflow:hidden}.barra-progreso__fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#a78bfa);border-radius:3px;transition:width .5s ease}.cuentas-cobro-filtros{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.cuentas-cobro-filtros .filtro-grupo{display:flex;flex-direction:column;gap:.25rem}.cuentas-cobro-filtros .filtro-grupo label{font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary);text-transform:uppercase}.cuentas-cobro-filtros .filtro-grupo select,.cuentas-cobro-filtros .filtro-grupo input{padding:.5rem .75rem;border:1px solid var(--hotel-border);border-radius:6px;background:var(--hotel-card-background);color:var(--hotel-text);font-size:.875rem}.cuentas-cobro-filtros .filtro-grupo--busqueda{flex:1;min-width:200px}.cuentas-cobro-filtros .input-with-icon{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid var(--hotel-border);border-radius:6px;background:var(--hotel-card-background)}.cuentas-cobro-filtros .input-with-icon svg{color:var(--hotel-text-secondary);flex-shrink:0}.cuentas-cobro-filtros .input-with-icon input{border:none;padding:0;background:transparent;flex:1;outline:none;color:var(--hotel-text)}.cuentas-cobro-tabla-container{background:var(--hotel-card-background);border-radius:10px;border:1px solid var(--hotel-border);overflow:hidden;position:relative}.tabla-wrapper{overflow-x:auto}.tabla-cuentas{width:100%;border-collapse:collapse}.tabla-cuentas th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--hotel-text-secondary);background:var(--hotel-background);border-bottom:2px solid var(--hotel-border);white-space:nowrap}.tabla-cuentas td{padding:.75rem 1rem;border-bottom:1px solid var(--hotel-border);font-size:.875rem;color:var(--hotel-text)}.tabla-cuentas tbody tr:hover{background:var(--hotel-background)}.font-bold{font-weight:700}.td-codigo{font-family:monospace;font-size:.8rem;color:var(--hotel-text-secondary)}.soldado-info{display:flex;flex-direction:column}.soldado-info strong{font-size:.875rem}.soldado-info small{font-size:.75rem;color:var(--hotel-text-secondary)}.badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap}.badge--emitida{background:#dbeafe;color:#1e40af}.badge--parcial{background:#fef3c7;color:#92400e}.badge--pagada{background:#dcfce7;color:#166534}.badge--cancelada{background:#f3f4f6;color:#6b7280}.acciones-grupo{display:flex;gap:.4rem}.btn-accion{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--hotel-border);border-radius:6px;background:var(--hotel-card-background);color:var(--hotel-text-secondary);cursor:pointer;transition:all .15s;font-weight:700;font-size:.875rem}.btn-accion:hover{background:var(--hotel-primary);color:#fff;border-color:var(--hotel-primary)}.btn-accion--pagar{color:#22c55e;border-color:#22c55e}.btn-accion--pagar:hover{background:#22c55e;color:#fff}.tabla-footer{padding:.75rem 1rem;border-top:1px solid var(--hotel-border)}.tabla-footer p{margin:0;font-size:.8rem;color:var(--hotel-text-secondary)}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:.75rem}.loading-overlay p{color:var(--hotel-text-secondary);font-size:.875rem}.spinner{animation:spin 1s linear infinite;color:var(--hotel-primary)}.empty-state{display:flex;flex-direction:column;align-items:center;padding:3rem 2rem;text-align:center}.empty-state__title{font-size:1rem;font-weight:600;color:var(--hotel-text);margin:.75rem 0 .25rem}.empty-state__subtitle{font-size:.85rem;color:var(--hotel-text-secondary);margin:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-cc{background:var(--hotel-card-background);border-radius:12px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-cc--sm{max-width:480px}.modal-cc--md{max-width:640px}.modal-cc--lg{max-width:800px}.modal-cc__header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--hotel-border)}.modal-cc__header h2{margin:0;font-size:1.25rem;font-weight:700;color:var(--hotel-text)}.modal-cc__body{padding:1.5rem}.modal-cc__footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--hotel-border)}.btn-modal{padding:.6rem 1.25rem;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .15s;border:1px solid var(--hotel-border);background:var(--hotel-card-background);color:var(--hotel-text)}.btn-modal:hover{background:var(--hotel-background)}.btn-modal--primary{background:var(--hotel-primary);color:#fff;border-color:var(--hotel-primary)}.btn-modal--primary:hover{opacity:.9}.btn-modal--primary:disabled{opacity:.5;cursor:not-allowed}.btn-modal--danger{background:#ef4444;color:#fff;border-color:#ef4444}.btn-modal--danger:hover{background:#dc2626}.btn-cerrar{background:none;border:none;color:var(--hotel-text-secondary);cursor:pointer;padding:.25rem;display:flex}.btn-cerrar:hover{color:var(--hotel-text)}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--hotel-text-secondary);text-transform:uppercase;margin-bottom:.35rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--hotel-border);border-radius:6px;background:var(--hotel-card-background);color:var(--hotel-text);font-size:.9rem;box-sizing:border-box}.form-group textarea{resize:vertical;min-height:60px}@media (max-width: 1024px){.cuentas-cobro-resumen{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.cuentas-cobro-header{flex-direction:column;align-items:flex-start}.cuentas-cobro-resumen{grid-template-columns:1fr 1fr}.cuentas-cobro-filtros{flex-direction:column}.modal-cc--lg{max-width:100%}}@media (max-width: 480px){.cuentas-cobro-resumen{grid-template-columns:1fr}.resumen-card__valor{font-size:1.25rem}}.activacion-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a365d,#0c1929);padding:2rem}.activacion-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:600px;padding:2.5rem}.activacion-logo{text-align:center;margin-bottom:2rem;display:flex;flex-direction:column;align-items:center}.activacion-logo-image{height:140px;width:140px;object-fit:contain;padding:1px;background:linear-gradient(135deg,#1a365d,#2c5282,#3182ce);border-radius:20px;box-shadow:0 10px 40px #1a365d66;animation:logoFloat 3s ease-in-out infinite;border:3px solid rgba(255,255,255,.2);margin-bottom:1rem}@keyframes logoFloat{0%,to{transform:translateY(0);box-shadow:0 10px 40px #1a365d66}50%{transform:translateY(-8px);box-shadow:0 15px 50px #1a365d80}}.activacion-logo p{color:#6b7280;margin:0;font-size:1rem}@media (max-width: 500px){.activacion-logo-image{height:100px;width:100px}}.activacion-opciones h2{text-align:center;font-size:1.5rem;margin:0 0 .5rem;color:#1f2937}.activacion-descripcion{text-align:center;color:#6b7280;margin:0 0 2rem}.opciones-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}@media (max-width: 500px){.opciones-grid{grid-template-columns:1fr}}.opcion-card{background:#f8fafc;border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;text-align:center;cursor:pointer;transition:all .2s}.opcion-card:hover{border-color:#3182ce;background:#ebf8ff;transform:translateY(-2px)}.opcion-icon{font-size:2.5rem;margin-bottom:.75rem}.opcion-card h3{font-size:1rem;font-weight:600;margin:0 0 .5rem;color:#1f2937}.opcion-card p{font-size:.85rem;color:#6b7280;margin:0}.activacion-form-container{position:relative}.activacion-form-container h2{text-align:center;font-size:1.5rem;margin:0 0 .5rem;color:#1f2937}.form-descripcion{text-align:center;color:#6b7280;margin:0 0 1.5rem;font-size:.9rem}.btn-volver{background:none;border:none;color:#3182ce;font-size:.9rem;cursor:pointer;padding:0;margin-bottom:1rem}.btn-volver:hover{text-decoration:underline}.activacion-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 500px){.form-row{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.875rem;font-weight:500;color:#374151}.form-group input,.form-group select{padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a}.form-group input::placeholder{color:#9ca3af}.form-group small{font-size:.75rem;color:#6b7280}.codigo-input{font-family:Monaco,Menlo,Ubuntu Mono,monospace;letter-spacing:1px;text-transform:uppercase}.form-note{background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;padding:.75rem 1rem;font-size:.85rem;color:#92400e}.btn-submit{background:#3182ce;color:#fff;border:none;padding:.875rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:background .2s;margin-top:.5rem}.btn-submit:hover:not(:disabled){background:#2b6cb0}.btn-submit:disabled{background:#9ca3af;cursor:not-allowed}.alert{padding:.875rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.codigo-input-group{display:flex;gap:.5rem}.codigo-input-group .codigo-input{flex:1}.btn-validar{background:#10b981;color:#fff;border:none;padding:.75rem 1.25rem;font-size:.9rem;font-weight:600;border-radius:8px;cursor:pointer;transition:background .2s;white-space:nowrap}.btn-validar:hover:not(:disabled){background:#059669}.btn-validar:disabled{background:#9ca3af;cursor:not-allowed}.comercio-info-card{background:#f8fafc;border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;margin-top:1.5rem}.comercio-info-card h3{font-size:1.1rem;font-weight:600;color:#1f2937;margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 500px){.info-grid{grid-template-columns:1fr}}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:.95rem;color:#1f2937;font-weight:500}.licencia-info{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb;display:flex;gap:2rem;flex-wrap:wrap}.badge-tipo{background:#3182ce;color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500}.form-note.success{background:#f0fdf4;border-color:#22c55e;color:#16a34a;margin-top:1rem}.comercio-info-card .btn-submit{width:100%;margin-top:1rem}.sp__page{min-height:100vh;display:flex;flex-direction:column;background:var(--hotel-background);color:var(--hotel-text)}.sp__header{display:flex;align-items:center;gap:14px;padding:14px 28px;background:var(--hotel-card-background);border-bottom:1px solid var(--hotel-border);box-shadow:var(--shadow-sm);position:relative;z-index:10}.sp__header-logo{height:38px;width:auto;object-fit:contain;flex-shrink:0}.sp__header-title{flex:1;font-size:1rem;font-weight:700;color:var(--hotel-text);letter-spacing:-.01em;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp__btn-logout{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border:1.5px solid var(--hotel-border);border-radius:var(--border-radius-md);background:transparent;color:var(--hotel-text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast);flex-shrink:0;white-space:nowrap}.sp__btn-logout:hover,.sp__btn-logout:focus-visible{color:var(--color-danger);border-color:var(--color-danger);background:#e74c3c0f;outline:none}.sp__btn-logout:focus-visible{box-shadow:0 0 0 3px #e74c3c33}.sp__main{flex:1;display:flex;flex-direction:column;align-items:center;padding:40px 24px 60px;width:100%}.sp__intro{text-align:center;margin-bottom:32px}.sp__intro-text{font-size:.9375rem;color:var(--hotel-text-secondary);margin:0}.sp__grid{list-style:none;margin:0;padding:0;width:100%;max-width:1080px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.sp__card{-moz-appearance:none;appearance:none;-webkit-appearance:none;border:none;font-family:inherit;cursor:pointer;text-align:left;position:relative;display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;padding:28px 24px 24px;overflow:hidden;background:var(--hotel-card-background);border:1.5px solid var(--hotel-border);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-sm);transition:transform .23s cubic-bezier(.34,1.56,.64,1),box-shadow .23s ease,border-color .23s ease}.sp__card-accent-bar{position:absolute;top:0;left:0;right:0;height:4px;background:var(--sp-accent, var(--hotel-primary));border-radius:var(--border-radius-xl) var(--border-radius-xl) 0 0;transition:height .23s ease}.sp__card:hover,.sp__card:focus-visible{transform:translateY(-4px) scale(1.015);box-shadow:0 12px 32px -4px #0000001f,0 4px 8px -2px #0000000f;border-color:var(--sp-accent, var(--hotel-primary));outline:none}[data-theme=dark] .sp__card:hover,[data-theme=dark] .sp__card:focus-visible{box-shadow:0 12px 32px -4px #00000073,0 4px 8px -2px #0000004d}.sp__card:focus-visible{box-shadow:0 0 0 3px var(--sp-accent, var(--hotel-primary)),0 12px 32px -4px #0000001f}.sp__card:hover .sp__card-accent-bar{height:5px}.sp__card-avatar-wrap{width:72px;height:72px;border-radius:18px;overflow:hidden;flex-shrink:0;box-shadow:0 4px 14px #0000001f}.sp__card-logo{width:100%;height:100%;object-fit:cover}.sp__card-initials{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#fff;letter-spacing:-.02em;background:linear-gradient(135deg,#1e40af,#3b82f6)}.sp__card-body{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;width:100%;text-align:center}.sp__card-name{font-size:1rem;font-weight:700;color:var(--hotel-text);margin:0;line-height:1.25;overflow-wrap:break-word;word-break:break-word}.sp__card-meta{display:flex;align-items:center;justify-content:center;gap:5px;font-size:.8125rem;color:var(--hotel-text-secondary);margin:0}.sp__card-meta svg{flex-shrink:0;color:var(--hotel-text-light)}.sp__card-role{display:inline-flex;align-items:center;gap:5px;margin-top:6px;padding:4px 10px;border-radius:999px;background:#3b82f61a;color:var(--hotel-primary);font-size:.75rem;font-weight:600;letter-spacing:.01em;background:color-mix(in srgb,var(--sp-accent, var(--hotel-primary)) 12%,transparent);color:var(--sp-accent, var(--hotel-primary));border:1px solid color-mix(in srgb,var(--sp-accent, var(--hotel-primary)) 25%,transparent)}[data-theme=dark] .sp__card-role{background:color-mix(in srgb,var(--sp-accent, var(--hotel-primary)) 18%,transparent)}.sp__card-arrow{position:absolute;bottom:14px;right:18px;font-size:1.125rem;color:var(--hotel-text-light);opacity:0;transform:translate(-6px);transition:opacity .2s ease,transform .2s ease,color .2s ease;pointer-events:none;line-height:1}.sp__card:hover .sp__card-arrow,.sp__card:focus-visible .sp__card-arrow{opacity:1;transform:translate(0);color:var(--sp-accent, var(--hotel-primary))}.sp__state-wrapper{display:flex;flex-direction:column;align-items:center;gap:14px;padding:60px 24px;text-align:center}.sp__spinner{color:var(--hotel-primary);animation:sp__spin .9s linear infinite;flex-shrink:0}@keyframes sp__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sp__state-icon{flex-shrink:0}.sp__state-icon--error{color:var(--color-danger)}.sp__state-icon--empty{color:var(--hotel-text-light)}.sp__state-text{font-size:1rem;font-weight:600;color:var(--hotel-text);margin:0}.sp__state-text--error{color:var(--color-danger)}.sp__state-subtext{font-size:.875rem;color:var(--hotel-text-secondary);margin:0;max-width:380px}.sp__btn-retry{margin-top:4px;padding:9px 22px;border:1.5px solid var(--hotel-primary);border-radius:var(--border-radius-md);background:transparent;color:var(--hotel-primary);font-size:.875rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.sp__btn-retry:hover,.sp__btn-retry:focus-visible{background:var(--hotel-primary);color:#fff;outline:none}.sp__btn-retry:focus-visible{box-shadow:0 0 0 3px #1e40af40}@media (max-width: 768px){.sp__header{padding:12px 16px;gap:10px}.sp__header-logo{height:32px}.sp__header-title{font-size:.9375rem}.sp__btn-logout span{display:none}.sp__btn-logout{padding:8px 10px}.sp__main{padding:28px 16px 48px}.sp__grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.sp__card{padding:24px 18px 20px}.sp__card-avatar-wrap{width:60px;height:60px;border-radius:14px}.sp__card-initials{font-size:1.25rem}}@media (max-width: 480px){.sp__grid{grid-template-columns:1fr;gap:12px}.sp__card{flex-direction:row;align-items:center;text-align:left;padding:18px 16px;gap:14px}.sp__card-body{align-items:flex-start;text-align:left}.sp__card-meta{justify-content:flex-start}.sp__card-role{margin-top:4px}.sp__card-avatar-wrap{width:52px;height:52px;flex-shrink:0}.sp__card-initials{font-size:1.125rem}.sp__card-arrow{bottom:50%;transform:translateY(50%) translate(-6px);right:14px}.sp__card:hover .sp__card-arrow,.sp__card:focus-visible .sp__card-arrow{transform:translateY(50%) translate(0)}}@media (min-width: 1100px){.sp__grid{grid-template-columns:repeat(3,1fr)}}.gp__page{max-width:1400px;margin:0 auto;padding:1.75rem 1.5rem}.gp__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.75rem;padding-bottom:1.25rem;border-bottom:2px solid var(--hotel-border);flex-wrap:wrap}.gp__header-title-group{display:flex;flex-direction:column;gap:.25rem}.gp__title{font-size:1.5rem;font-weight:700;color:var(--hotel-text);display:flex;align-items:center;gap:.625rem;margin:0}.gp__title svg{color:#8b5cf6}.gp__subtitle{font-size:.875rem;color:var(--hotel-text-secondary);margin:0}.gp__superadmin-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.3125rem .75rem;background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff;border-radius:999px;font-size:.75rem;font-weight:600;white-space:nowrap;flex-shrink:0}.gp__tabs{display:flex;gap:0;border-bottom:2px solid var(--hotel-border);margin-bottom:1.5rem}.gp__tab{display:inline-flex;align-items:center;gap:.4rem;padding:.625rem 1.25rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:.875rem;font-weight:500;color:var(--hotel-text-secondary);cursor:pointer;transition:color .15s,border-color .15s;font-family:inherit}.gp__tab:hover{color:var(--hotel-text)}.gp__tab--active{color:#8b5cf6;border-bottom-color:#8b5cf6;font-weight:600}.gp__section-header{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.gp__section-title{font-size:1rem;font-weight:600;color:var(--hotel-text);margin:0 0 .125rem}.gp__section-subtitle{font-size:.8125rem;color:var(--hotel-text-secondary);margin:0}.gp__btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px solid var(--hotel-border);border-radius:7px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;background:var(--hotel-card-background);color:var(--hotel-text);font-family:inherit;line-height:1;white-space:nowrap}.gp__btn:hover:not(:disabled){background:var(--hotel-background)}.gp__btn:disabled{opacity:.55;cursor:not-allowed}.gp__btn--primary{background:#8b5cf6;color:#fff;border-color:#8b5cf6}.gp__btn--primary:hover:not(:disabled){background:#7c3aed;border-color:#7c3aed}.gp__btn--danger{background:var(--hotel-danger, #ef4444);color:#fff;border-color:var(--hotel-danger, #ef4444)}.gp__btn--danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.gp__table-container{background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:10px;overflow:hidden}.gp__table{width:100%;border-collapse:collapse}.gp__table th{text-align:left;padding:.625rem 1rem;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--hotel-text-secondary);background:var(--hotel-background);border-bottom:1px solid var(--hotel-border);white-space:nowrap}.gp__th--actions{text-align:right}.gp__table td{padding:.75rem 1rem;font-size:.875rem;color:var(--hotel-text);border-bottom:1px solid var(--hotel-border);vertical-align:middle}.gp__table tbody tr:last-child td{border-bottom:none}.gp__table tbody tr:hover td{background:var(--hotel-background)}.gp__prop-name-cell{display:flex;align-items:center;gap:.5rem}.gp__color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;border:1px solid rgba(0,0,0,.12)}.gp__prop-nombre{font-weight:600;color:var(--hotel-text)}.gp__prop-corto{font-size:.75rem;color:var(--hotel-text-secondary);background:var(--hotel-surface-light, #f3f4f6);border-radius:4px;padding:.1rem .4rem}.gp__empty-val{color:var(--hotel-text-light, #9ca3af)}.gp__usuario-handle{font-family:monospace;font-size:.8125rem;color:var(--hotel-text-secondary)}.gp__actions-cell{display:flex;align-items:center;justify-content:flex-end;gap:.375rem}.gp__action-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:1px solid var(--hotel-border);background:var(--hotel-card-background);cursor:pointer;transition:all .15s;color:var(--hotel-text-secondary)}.gp__action-btn:disabled{opacity:.4;cursor:not-allowed}.gp__action-btn--edit:hover:not(:disabled){background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.gp__action-btn--delete:hover:not(:disabled){background:#fecaca;border-color:#fca5a5;color:#b91c1c}[data-theme=dark] .gp__action-btn--edit:hover:not(:disabled){background:#3b82f626;border-color:#3b82f64d;color:#60a5fa}[data-theme=dark] .gp__action-btn--delete:hover:not(:disabled){background:#ef444426;border-color:#ef44444d;color:#f87171}.gp__badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .55rem;border-radius:999px;font-size:.6875rem;font-weight:600;white-space:nowrap}.gp__badge--activo{background:#dcfce7;color:#166534}.gp__badge--inactivo{background:#fecaca;color:#991b1b}[data-theme=dark] .gp__badge--activo{background:#10b98126;color:#34d399}[data-theme=dark] .gp__badge--inactivo{background:#ef444426;color:#f87171}.gp__badge--rol{background:var(--hotel-surface-light, #f3f4f6);color:var(--hotel-text-secondary);text-transform:capitalize;border-radius:4px;font-size:.75rem}.gp__badge--rol-admin,.gp__badge--rol-gerente{background:#dbeafe;color:#1d4ed8}.gp__badge--rol-recepcionista{background:#d1fae5;color:#065f46}.gp__badge--rol-limpieza,.gp__badge--rol-mantenimiento{background:#fef3c7;color:#92400e}[data-theme=dark] .gp__badge--rol-admin,[data-theme=dark] .gp__badge--rol-gerente{background:#3b82f626;color:#60a5fa}[data-theme=dark] .gp__badge--rol-recepcionista{background:#10b98126;color:#34d399}[data-theme=dark] .gp__badge--rol-limpieza,[data-theme=dark] .gp__badge--rol-mantenimiento{background:#f59e0b26;color:#fbbf24}.gp__prop-selector{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;flex-wrap:wrap}.gp__prop-selector-label{display:flex;align-items:center;gap:.375rem;font-size:.875rem;font-weight:600;color:var(--hotel-text);white-space:nowrap;flex-shrink:0}.gp__prop-selector-label svg{color:#8b5cf6}.gp__select-wrap{position:relative;display:inline-flex;align-items:center}.gp__select-wrap select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:.5rem 2rem .5rem .75rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.875rem;background:var(--hotel-background);color:var(--hotel-text);font-family:inherit;cursor:pointer;transition:border-color .15s,box-shadow .15s}.gp__select-wrap select:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf626}.gp__select-icon{position:absolute;right:.5rem;color:var(--hotel-text-secondary);pointer-events:none}.gp__select-wrap--large{flex:1;min-width:260px}.gp__select-wrap--large select{width:100%}.gp__empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:4rem 2rem;gap:.625rem;color:var(--hotel-text-secondary);background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:10px}.gp__empty svg{opacity:.3}.gp__empty-title{font-size:.9375rem;font-weight:600;color:var(--hotel-text);margin:0}.gp__empty-desc{font-size:.8125rem;color:var(--hotel-text-secondary);max-width:380px;line-height:1.5;margin:0}.gp__state{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3.5rem;color:var(--hotel-text-secondary);font-size:.875rem}.gp__state--error{color:var(--hotel-danger, #ef4444)}.gp__loading-text{font-size:.875rem;color:var(--hotel-text-secondary);margin:.25rem 0}.gp__spin{animation:gp-spin .8s linear infinite}@keyframes gp-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.gp__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000007a;display:flex;align-items:center;justify-content:center;z-index:1100;padding:1rem}.gp__modal{background:var(--hotel-card-background);border-radius:10px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #00000038}.gp__modal--sm{max-width:420px}.gp__modal--lg{max-width:620px}.gp__modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--hotel-border);background:linear-gradient(135deg,#8b5cf6,#a78bfa);border-radius:10px 10px 0 0}.gp__modal-title-row{display:flex;align-items:center;gap:.5rem;color:#fff}.gp__modal-title{font-size:1.0625rem;font-weight:600;margin:0;color:#fff}.gp__modal-close{background:#ffffff26;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:.3125rem;display:flex;align-items:center;transition:background .15s;flex-shrink:0}.gp__modal-close:hover{background:#ffffff47}.gp__modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:.875rem}.gp__modal-body--center{align-items:center;text-align:center;padding:1.75rem 1.5rem 1rem}.gp__modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.875rem 1.25rem;border-top:1px solid var(--hotel-border)}.gp__field{display:flex;flex-direction:column;gap:.3125rem}.gp__field label{font-size:.75rem;font-weight:600;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.04em}.gp__field input[type=text],.gp__field input[type=email],.gp__field select{padding:.5625rem .75rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.875rem;background:var(--hotel-background);color:var(--hotel-text);font-family:inherit;transition:border-color .15s,box-shadow .15s}.gp__field input[type=text]:focus,.gp__field input[type=email]:focus,.gp__field select:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf626}.gp__field-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.gp__field-hint{font-size:.75rem;color:var(--hotel-text-secondary);margin:.25rem 0 0}.gp__color-field{display:flex;align-items:center;gap:.625rem;padding:.375rem .625rem;border:1px solid var(--hotel-border);border-radius:6px;background:var(--hotel-background);cursor:pointer;transition:border-color .15s}.gp__color-field:focus-within{border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf626}.gp__color-field input[type=color]{width:28px;height:28px;padding:0;border:none;border-radius:4px;cursor:pointer;background:none}.gp__color-value{font-family:monospace;font-size:.8125rem;color:var(--hotel-text-secondary);text-transform:uppercase}.gp__confirm-icon{width:52px;height:52px;border-radius:50%;background:#ef44441a;color:#ef4444;display:flex;align-items:center;justify-content:center;margin-bottom:.75rem}.gp__confirm-text{font-size:.875rem;color:var(--hotel-text);line-height:1.6;max-width:340px;margin:0}.gp__icon--danger{color:#ef4444}@media (max-width: 768px){.gp__page{padding:1.25rem 1rem}.gp__header,.gp__section-header{flex-direction:column;align-items:flex-start}.gp__field-row{grid-template-columns:1fr}.gp__prop-selector{flex-direction:column;align-items:flex-start}.gp__select-wrap--large{width:100%}.gp__table thead{display:none}.gp__table,.gp__table tbody,.gp__table tr,.gp__table td{display:block;width:100%}.gp__table tr{border-bottom:1px solid var(--hotel-border);padding:.75rem 1rem}.gp__table tr:last-child{border-bottom:none}.gp__table td{border-bottom:none;padding:.25rem 0;display:flex;align-items:center;gap:.5rem}.gp__table td:before{content:attr(data-label);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--hotel-text-secondary);min-width:100px;flex-shrink:0}.gp__actions-cell{justify-content:flex-start}.gp__overlay{align-items:flex-end;padding:0}.gp__modal{max-width:100%;border-radius:12px 12px 0 0;max-height:88vh;position:fixed;bottom:0;left:0;right:0}.gp__modal-header{border-radius:12px 12px 0 0}}@media (max-width: 480px){.gp__tabs{gap:0}.gp__tab{padding:.5rem .875rem;font-size:.8125rem}}.proveedor-form-modal{background:var(--hotel-card-background);border-radius:12px;width:90%;max-width:860px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .2s ease}.proveedor-form-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;flex-shrink:0}.proveedor-form-header h2{margin:0;font-size:1.4rem;font-weight:600;display:flex;align-items:center;gap:.75rem}.proveedor-form{padding:1.75rem;overflow-y:auto;flex:1}.form-section h3{margin:0 0 1.25rem;color:var(--hotel-text);font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#1e40af}.form-group--small{max-width:90px}.form-group input:disabled,.form-group select:disabled{background:var(--hotel-surface-light);cursor:not-allowed;color:var(--hotel-text-secondary)}.form-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:1.75rem;border-top:2px solid var(--hotel-border);flex-shrink:0}@media (max-width: 768px){.proveedor-form-modal{width:95%;max-height:95vh}.proveedor-form{padding:1.25rem}.form-row{grid-template-columns:1fr}.form-group--wide{grid-column:span 1}.form-actions{flex-direction:column}}.proveedor-stat-currency{font-size:1.4rem!important}.proveedor-categoria-tag{display:inline-block;padding:.2rem .5rem;border-radius:10px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:#dbeafe;color:#1e40af;width:fit-content}.proveedor-contacto{display:flex;flex-direction:column;gap:.2rem}.contacto-nombre{font-weight:600;color:var(--hotel-text);font-size:.9rem}.contacto-info{font-size:.82rem;color:var(--hotel-text-secondary)}.contacto-email{color:#3b82f6}.proveedor-condiciones{display:flex;flex-direction:column;gap:.2rem}.dias-credito{font-size:.78rem;color:var(--hotel-text-secondary)}.estado-inactivo{background:#fee2e2;color:#991b1b}.btn-eliminar{background:#fee2e2;color:#dc2626;padding:.5rem .65rem;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s}@media (max-width: 768px){.proveedor-stat-currency{font-size:1.1rem!important}}.gasto-form-modal{background:var(--hotel-card-background);border-radius:12px;width:90%;max-width:780px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .2s ease}.gasto-form-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;flex-shrink:0}.gasto-form-header h2{margin:0;font-size:1.4rem;font-weight:600;display:flex;align-items:center;gap:.75rem}.gasto-form{padding:1.75rem;overflow-y:auto;flex:1}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.1rem;margin-bottom:1.1rem}.form-group--inline{max-width:280px;margin-top:1rem}.form-group textarea{resize:vertical;min-height:80px}.monto-calculado{padding:.7rem .875rem;border-radius:6px;font-weight:700;font-size:1rem;text-align:right}.monto-calculado--iva{background:#fef3c7;border:2px solid #f59e0b;color:#92400e}.monto-calculado--total{background:#f0fdf4;border:2px solid #10b981;color:#065f46;font-size:1.1rem}.recurrente-toggle{margin-bottom:1rem}.toggle-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-label input[type=checkbox]{display:none}.toggle-track{position:relative;width:44px;height:24px;background:var(--hotel-border);border-radius:12px;transition:background .2s;flex-shrink:0}.toggle-track:after{content:"";position:absolute;width:18px;height:18px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 3px #0000004d}.toggle-label input:checked+.toggle-track{background:#1e40af}.toggle-label input:checked+.toggle-track:after{transform:translate(20px)}.toggle-text{display:flex;align-items:center;gap:.4rem;font-weight:500;color:var(--hotel-text);font-size:.9rem}@media (max-width: 768px){.gasto-form-modal{width:95%;max-height:95vh}.gasto-form{padding:1.25rem}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}}.file-upload{display:flex;flex-direction:column;gap:6px}.file-upload__label{font-size:.85rem;font-weight:600;color:#555}.file-upload__input{display:none}.file-upload__dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:20px;border:2px dashed #ccc;border-radius:8px;cursor:pointer;transition:border-color .2s,background .2s;color:#888;text-align:center}.file-upload__dropzone:hover{border-color:#2563eb;background:#f0f7ff;color:#2563eb}.file-upload__dropzone--uploading{pointer-events:none;opacity:.7}.file-upload__icon{font-size:2rem}.file-upload__dropzone small{font-size:.75rem;color:#aaa}.file-upload__spinner{font-size:1.5rem;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.file-upload__preview{position:relative;display:flex;align-items:center;gap:10px;padding:8px;border:1px solid #ddd;border-radius:8px;background:#fafafa}.file-upload__image{width:80px;height:80px;object-fit:cover;border-radius:6px;cursor:pointer;transition:opacity .2s}.file-upload__image:hover{opacity:.8}.file-upload__pdf-icon{display:flex;flex-direction:column;align-items:center;justify-content:center;width:80px;height:80px;background:#fee;border-radius:6px;color:#c0392b;font-size:1.8rem}.file-upload__pdf-icon span{font-size:.65rem;margin-top:4px;font-weight:600}.file-upload__actions{display:flex;flex-direction:column;gap:4px}.file-upload__btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:6px;cursor:pointer;font-size:.8rem;transition:background .2s;text-decoration:none;color:#fff}.file-upload__btn--view{background:#2563eb}.file-upload__btn--view:hover{background:#1d4ed8}.file-upload__btn--change{background:#f59e0b;color:#fff}.file-upload__btn--change:hover{background:#d97706}.file-upload__btn--remove{background:#ef4444;color:#fff}.file-upload__btn--remove:hover{background:#dc2626}.file-upload__lightbox{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;cursor:pointer}.file-upload__lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:8px;box-shadow:0 4px 30px #00000080}.catgasto-modal{background:var(--hotel-card-background);border-radius:12px;width:90%;max-width:700px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .2s ease}.catgasto-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;flex-shrink:0}.catgasto-header h2{margin:0;font-size:1.4rem;font-weight:600;display:flex;align-items:center;gap:.75rem}.catgasto-body{padding:1.75rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:1.5rem}.catgasto-toolbar{display:flex;align-items:center}.btn-nueva-cat{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:#1e40af;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s}.btn-nueva-cat:hover{background:#1d3a9e;transform:translateY(-1px)}.catgasto-form-title{font-size:.9rem;font-weight:600;color:#1e40af}.catgasto-form{background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:10px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.catgasto-form-row{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap}.form-group--flex{flex:1;min-width:160px}.form-group input{padding:.65rem .875rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.9rem;font-family:inherit;background:var(--hotel-card-background);color:var(--hotel-text);transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #1e40af1a}.form-group input::placeholder{color:var(--hotel-text-secondary);opacity:.7}.color-picker-wrapper{position:relative}.color-preview-btn{width:44px;height:40px;border:2px solid var(--hotel-border);border-radius:6px;cursor:pointer;transition:border-color .2s,transform .1s}.color-preview-btn:hover{border-color:#1e40af;transform:scale(1.05)}.color-palette{position:absolute;top:calc(100% + 6px);left:0;z-index:100;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;padding:.75rem;display:grid;grid-template-columns:repeat(6,24px);gap:6px;box-shadow:0 8px 24px #00000026}.color-swatch{width:24px;height:24px;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s}.color-swatch:hover{transform:scale(1.2)}.color-swatch--active{border-color:#fff;box-shadow:0 0 0 2px #1e40af}.catgasto-form-actions{display:flex;gap:.75rem}.btn-guardar-cat{display:flex;align-items:center;gap:.4rem;padding:.6rem 1.25rem;background:#10b981;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s}.btn-guardar-cat:hover:not(:disabled){background:#059669}.btn-guardar-cat:disabled{background:#9ca3af;cursor:not-allowed}.btn-cancelar-cat{padding:.6rem 1rem;background:var(--hotel-card-background);color:var(--hotel-text-secondary);border:1px solid var(--hotel-border);border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.btn-cancelar-cat:hover{background:var(--hotel-surface-light);color:var(--hotel-text)}.catgasto-lista h3{font-size:.9rem;font-weight:700;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 1rem}.catgasto-loading{padding:1.5rem;text-align:center;color:var(--hotel-text-secondary);font-size:.9rem}.catgasto-empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2.5rem;text-align:center;color:var(--hotel-text-secondary)}.catgasto-empty svg{font-size:2rem;opacity:.4}.catgasto-empty p{margin:0;font-size:.9rem}.catgasto-items{display:flex;flex-direction:column;gap:.5rem}.catgasto-item{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;transition:border-color .2s,box-shadow .2s}.catgasto-item:hover{border-color:#93c5fd;box-shadow:0 2px 8px #1e40af14}.catgasto-item--inactiva{opacity:.55}.catgasto-item--editing{border-color:#1e40af;background:#eff6ff}.catgasto-color-swatch{width:18px;height:36px;border-radius:4px;flex-shrink:0}.catgasto-item-info{flex:1;min-width:0}.catgasto-item-nombre{font-weight:600;color:var(--hotel-text);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.catgasto-item-descripcion{font-size:.8rem;color:var(--hotel-text-secondary);margin-top:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.catgasto-item-stats{display:flex;gap:.5rem;align-items:center}.stat-badge{padding:.2rem .6rem;background:#eff6ff;color:#1e40af;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap}.inactiva-badge{padding:.2rem .6rem;background:#fef3c7;color:#92400e;border-radius:12px;font-size:.75rem;font-weight:600}.catgasto-item-actions{display:flex;gap:.25rem;flex-shrink:0}.btn-icon{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:all .2s}.btn-icon:disabled{opacity:.4;cursor:not-allowed}.btn-icon--edit{background:#eff6ff;color:#1e40af}.btn-icon--edit:hover:not(:disabled){background:#dbeafe}.btn-icon--delete{background:#fee2e2;color:#ef4444}.btn-icon--delete:hover:not(:disabled){background:#fecaca}@media (max-width: 600px){.catgasto-modal{width:95%;max-height:95vh}.catgasto-body{padding:1rem}.catgasto-form-row{flex-direction:column}.color-palette{grid-template-columns:repeat(6,24px)}}.gasto-stat-currency{font-size:1.35rem!important}.filtro-select-sm{min-width:140px}.gasto-categoria-badge{display:inline-flex;align-items:center;gap:.45rem;font-size:.88rem;color:var(--hotel-text)}.categoria-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}.sin-categoria{color:#9ca3af;font-style:italic;font-size:.85rem}.estado-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .65rem;border-radius:12px;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.estado-activo{background:#d1fae5;color:#065f46}.btn-pagar{display:inline-flex;align-items:center;gap:.35rem;background:#dcfce7;color:#16a34a;padding:.4rem .75rem;border:none;border-radius:6px;cursor:pointer;font-size:.82rem;font-weight:600;transition:all .2s;white-space:nowrap}.btn-pagar:hover{background:#16a34a;color:#fff}.btn-ver-adjunto{background:#f3e8ff;color:#7c3aed;padding:.5rem .65rem;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.btn-eliminar{background:#fee2e2;color:#dc2626;padding:.5rem .65rem;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.btn-eliminar:hover{background:#dc2626;color:#fff}@media (max-width: 768px){.gasto-stat-currency{font-size:1.1rem!important}.inventario-filtros{flex-direction:column}.filtro-fecha,.filtro-select-sm,.gasto-filtro-fechas{width:100%}}.compra-form-modal{background:var(--hotel-card-background);border-radius:12px;width:95%;max-width:1100px;max-height:92vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .2s ease}.compra-form-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;flex-shrink:0}.compra-form-header h2{margin:0;font-size:1.4rem;font-weight:600;display:flex;align-items:center;gap:.75rem}.close-button{background:#ffffff26;border:none;color:#fff;width:36px;height:36px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:background .2s}.compra-form{padding:1.75rem;overflow-y:auto;flex:1}.form-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--hotel-border)}.form-section--last{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section h3{margin:0 0 1.25rem;font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#1e40af}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.1rem;margin-bottom:1.1rem}.form-row:last-child{margin-bottom:0}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group--wide{grid-column:span 2}.form-group label{font-weight:500;color:var(--hotel-text);font-size:.875rem}.form-group input,.form-group select,.form-group textarea{padding:.7rem .875rem;border:1px solid var(--hotel-border);border-radius:6px;font-size:.9rem;font-family:inherit;background:var(--hotel-card-background);color:var(--hotel-text);transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#1e40af;box-shadow:0 0 0 3px #1e40af1a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--hotel-text-secondary);opacity:.7}.form-group textarea{resize:vertical;min-height:70px}.detalles-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.detalles-header h3{margin:0}.btn-add-linea{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:#1e40af;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:background .2s}.btn-add-linea:hover{background:#1d3a9e}.detalles-table-wrapper{overflow-x:auto;border:1px solid var(--hotel-border);border-radius:8px;margin-bottom:1.5rem}.detalles-table{width:100%;border-collapse:collapse;font-size:.875rem;min-width:900px}.detalles-table thead tr{background:var(--hotel-surface-light)}.detalles-table th{padding:.75rem .625rem;text-align:left;font-weight:600;color:var(--hotel-text-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;border-bottom:2px solid var(--hotel-border)}.detalles-table td{padding:.5rem;border-bottom:1px solid var(--hotel-border);vertical-align:middle}.detalles-table tbody tr:last-child td{border-bottom:none}.detalles-table tbody tr:hover{background:var(--hotel-surface-light)}.detalles-table input,.detalles-table select{width:100%;padding:.45rem .5rem;border:1px solid var(--hotel-border);border-radius:4px;font-size:.875rem;font-family:inherit;background:var(--hotel-card-background);color:var(--hotel-text);transition:border-color .2s}.detalles-table input:focus,.detalles-table select:focus{outline:none;border-color:#1e40af}.input-number{text-align:right;min-width:80px}.input-number--small{min-width:60px}.select-small{min-width:70px}.monto-subtotal{color:var(--hotel-text-secondary);font-weight:500;white-space:nowrap}.monto-total{font-weight:700;color:var(--hotel-text);white-space:nowrap}.btn-remove-linea{background:none;border:none;color:#ef4444;cursor:pointer;padding:.4rem;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-remove-linea:hover{background:#fee2e2}.compra-totales{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;padding:1rem 0}.total-row{display:flex;gap:2rem;justify-content:flex-end;font-size:.9rem;color:var(--hotel-text-secondary)}.total-row span:last-child{min-width:140px;text-align:right;font-weight:600;color:var(--hotel-text)}.total-row--grand{font-size:1.15rem;font-weight:700;color:var(--hotel-text);border-top:2px solid var(--hotel-border);padding-top:.5rem;margin-top:.25rem}.total-row--grand span{color:#1e40af!important;font-weight:800}.form-actions{display:flex;gap:1rem;margin-top:2rem;padding-top:1.75rem;border-top:2px solid var(--hotel-border)}@media (max-width: 768px){.compra-form-modal{width:98%;max-height:98vh}.compra-form{padding:1rem}.form-row{grid-template-columns:1fr}.form-group--wide{grid-column:span 1}.form-actions{flex-direction:column}}.recibir-compra-modal{background:var(--hotel-card-background);border-radius:12px;width:92%;max-width:900px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.recibir-compra-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;flex-shrink:0}.header-info h2{margin:0 0 .25rem;font-size:1.4rem;font-weight:600;display:flex;align-items:center;gap:.75rem}.header-codigo{font-size:.9rem;opacity:.85;font-weight:400}.close-button{background:#ffffff26;border:none;color:#fff;width:36px;height:36px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:background .2s;flex-shrink:0}.close-button:hover{background:#ffffff4d}.recibir-compra-form{padding:1.75rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:1.5rem}.recibir-info-banner{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;color:#1e40af;font-size:.875rem}.recibir-info-banner svg{font-size:1.25rem;flex-shrink:0;margin-top:.1rem}.recibir-info-banner p{margin:0;line-height:1.5}.recibir-table-wrapper{border:1px solid var(--hotel-border);border-radius:8px;overflow:hidden;overflow-x:auto}.recibir-table{width:100%;border-collapse:collapse;font-size:.9rem;min-width:620px}.recibir-table thead tr{background:var(--hotel-surface-light)}.recibir-table th{padding:.75rem .875rem;text-align:left;font-weight:600;color:var(--hotel-text-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid var(--hotel-border);white-space:nowrap}.recibir-table td{padding:.75rem .875rem;border-bottom:1px solid var(--hotel-border);vertical-align:middle}.recibir-table tbody tr:last-child td{border-bottom:none}.recibir-row:hover{background:var(--hotel-surface-light)}.recibir-row--completo{opacity:.6}.item-nombre{display:flex;align-items:center;gap:.5rem}.completo-icon{color:#10b981;font-size:1rem;flex-shrink:0}.item-codigo{font-size:.8rem;color:var(--hotel-text-secondary);font-style:italic}.cantidad-badge{font-weight:600;color:var(--hotel-text)}.recibido-badge{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.875rem;font-weight:600;background:var(--hotel-surface-light);color:var(--hotel-text-secondary)}.recibido-badge--some{background:#d1fae5;color:#065f46}.pendiente-badge{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.875rem;font-weight:600}.pendiente-badge--active{background:#fef3c7;color:#92400e}.pendiente-badge--zero{background:#d1fae5;color:#065f46}.cantidad-input{width:90px;padding:.5rem;border:2px solid #1e40af;border-radius:6px;font-size:.9rem;font-family:inherit;text-align:center;background:var(--hotel-card-background);color:var(--hotel-text);font-weight:600;transition:border-color .2s,box-shadow .2s}.cantidad-input:focus{outline:none;box-shadow:0 0 0 3px #1e40af26}.cantidad-input:disabled{border-color:var(--hotel-border);background:var(--hotel-surface-light);cursor:not-allowed;color:var(--hotel-text-secondary);font-weight:400}.recibir-actions-cell{display:flex;gap:.25rem}.btn-max,.btn-cero{padding:.3rem .5rem;border:1px solid;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .2s}.btn-max{background:#eff6ff;border-color:#93c5fd;color:#1e40af}.btn-max:hover{background:#dbeafe}.btn-cero{background:var(--hotel-surface-light);border-color:var(--hotel-border);color:var(--hotel-text-secondary)}.btn-cero:hover{background:var(--hotel-border);color:var(--hotel-text)}.recibir-footer-info{text-align:right;font-size:.9rem;color:var(--hotel-text-secondary);padding:.5rem 0}.recibir-footer-info strong{color:var(--hotel-text);font-size:1rem}.form-actions{display:flex;gap:1rem;padding-top:1.5rem;border-top:2px solid var(--hotel-border);margin-top:auto}.btn-guardar{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:#1e40af;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s}.btn-guardar:hover:not(:disabled){background:#1d3a9e;transform:translateY(-1px);box-shadow:0 4px 12px #1e40af4d}.btn-guardar:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.btn-cancelar{padding:.875rem 1.5rem;background:var(--hotel-card-background);color:var(--hotel-text-secondary);border:2px solid var(--hotel-border);border-radius:8px;cursor:pointer;font-weight:500;font-size:.95rem;transition:all .2s}.btn-cancelar:hover{background:var(--hotel-surface-light);color:var(--hotel-text);border-color:var(--hotel-text-secondary)}@media (max-width: 768px){.recibir-compra-modal{width:98%;max-height:95vh}.recibir-compra-form{padding:1rem}.form-actions{flex-direction:column}.cantidad-input{width:70px}}.compra-stat-currency{font-size:1.35rem!important}.gasto-filtro-fechas{display:flex;flex-direction:column;gap:.25rem}.gasto-fecha-label{font-size:.78rem;font-weight:600;color:var(--hotel-text-secondary);text-transform:uppercase;letter-spacing:.04em;padding-left:.25rem}.filtro-fecha{padding:.75rem 1rem;border:1px solid var(--hotel-border);border-radius:8px;background:var(--hotel-card-background);cursor:pointer;font-size:.95rem;color:var(--hotel-text);min-width:155px}.filtro-fecha:focus{outline:none;border-color:#1e40af}.compra-tabla .col-expand{width:40px;padding:.75rem .5rem}.btn-expand{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:6px;cursor:pointer;color:var(--hotel-text-secondary);transition:all .2s;font-size:.8rem}.btn-expand:hover{background:#1e40af;color:#fff;border-color:#1e40af}.compra-row-expandida{background:var(--hotel-surface-light)!important}.compra-detalle-row td{padding:0!important;border-bottom:2px solid #1e40af}.compra-detalle-container{padding:1.25rem 1.5rem;background:var(--hotel-surface-light);border-left:4px solid #1e40af}.compra-detalle-titulo{margin:0 0 1rem;font-size:.9rem;font-weight:700;color:#1e40af;text-transform:uppercase;letter-spacing:.05em}.compra-sin-detalles{color:#9ca3af;font-style:italic;margin:0;font-size:.9rem}.compra-detalle-tabla{width:100%;border-collapse:collapse;font-size:.88rem}.compra-detalle-tabla th{padding:.5rem .75rem;text-align:left;font-weight:600;color:var(--hotel-text-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--hotel-border)}.compra-detalle-tabla td{padding:.5rem .75rem;border-bottom:1px solid var(--hotel-border);color:var(--hotel-text)}.compra-detalle-tabla tbody tr:last-child td{border-bottom:none}.recibido-completo{font-weight:700;color:#10b981}.recibido-parcial{font-weight:700;color:#f59e0b}.recibido-pendiente{color:#9ca3af}.compra-estado-badge{display:inline-block;padding:.3rem .65rem;border-radius:12px;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.compra-items-count{font-size:.88rem;color:var(--hotel-text-secondary)}.compra-acciones{display:flex;align-items:center;gap:.4rem}.compra-acciones .btn-accion{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.btn-confirmar{background:#eff6ff;color:#3b82f6}.btn-confirmar:hover{background:#3b82f6;color:#fff}.btn-recibir{background:#f0fdf4;color:#16a34a}.btn-recibir:hover{background:#16a34a;color:#fff}.btn-ver-adjunto{background:#f3e8ff;color:#7c3aed}.btn-ver-adjunto:hover{background:#7c3aed;color:#fff}.btn-anular{background:#fee2e2;color:#dc2626}.btn-anular:hover{background:#dc2626;color:#fff}.comprobante-lightbox{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;cursor:pointer}.comprobante-lightbox__content{position:relative;width:90vw;height:90vh;display:flex;align-items:center;justify-content:center;cursor:default}.comprobante-lightbox__close{position:absolute;top:-10px;right:-10px;width:36px;height:36px;border-radius:50%;border:none;background:#fff;color:#333;font-size:1.2rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000004d;z-index:1;transition:background .2s}.comprobante-lightbox__close:hover{background:#ef4444;color:#fff}.comprobante-lightbox__iframe{width:100%;height:100%;border:none;border-radius:8px;background:#fff}.comprobante-lightbox__img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 4px 30px #00000080}.gasto-paginacion{display:flex;justify-content:space-between;align-items:center;margin-top:1.25rem;padding:.75rem 1rem;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;flex-wrap:wrap;gap:.75rem}.paginacion-info{font-size:.88rem;color:var(--hotel-text-secondary)}.paginacion-controles{display:flex;align-items:center;gap:.75rem}.btn-paginacion{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--hotel-surface-light);border:1px solid var(--hotel-border);border-radius:6px;cursor:pointer;color:var(--hotel-text);transition:all .2s}.btn-paginacion:hover:not(:disabled){background:#1e40af;color:#fff;border-color:#1e40af}.btn-paginacion:disabled{opacity:.4;cursor:not-allowed}.paginacion-pagina{font-size:.9rem;font-weight:600;color:var(--hotel-text);min-width:60px;text-align:center}@media (max-width: 1200px){.compra-tabla{font-size:.85rem}}@media (max-width: 768px){.compra-stat-currency{font-size:1.1rem!important}.inventario-filtros{flex-direction:column}.filtro-fecha,.gasto-filtro-fechas{width:100%}.inventario-tabla-container{overflow-x:auto}.compra-tabla{min-width:1000px}}.sidebar{--sidebar-width: 240px;--sidebar-collapsed-width: 68px;--sidebar-transition: .3s cubic-bezier(.4, 0, .2, 1)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--hotel-card-background);border-right:1px solid var(--hotel-border);display:flex;flex-direction:column;z-index:100;transition:width var(--sidebar-transition);overflow:hidden}.sidebar--collapsed{width:var(--sidebar-collapsed-width)}.sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-bottom:1px solid var(--hotel-border);min-height:60px;flex-shrink:0}.sidebar--collapsed .sidebar__header{justify-content:center;padding:.75rem .5rem}.sidebar__logo-section{display:flex;align-items:center;cursor:pointer;overflow:hidden}.sidebar__logo{height:42px;width:auto;object-fit:contain}.sidebar__toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:none;background:transparent;color:var(--hotel-text-secondary);cursor:pointer;transition:all .2s;flex-shrink:0}.sidebar__toggle:hover{background:var(--hotel-surface-light);color:var(--hotel-primary)}.sidebar__property{padding:.5rem;border-bottom:1px solid var(--hotel-border);flex-shrink:0}.sidebar__property-button{display:flex;align-items:center;gap:.625rem;width:100%;padding:.5rem .625rem;border:1px solid var(--hotel-border);background:var(--hotel-surface-light);color:var(--hotel-text);cursor:pointer;border-radius:8px;font-size:.8125rem;font-weight:600;transition:all .2s;position:relative;overflow:hidden}.sidebar__property-button:hover{border-color:var(--hotel-primary);background:#1e40af0f;color:var(--hotel-primary)}.sidebar--collapsed .sidebar__property-button{justify-content:center;padding:.625rem}.sidebar__property-icon{flex-shrink:0;color:var(--hotel-primary)}.sidebar__property-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;min-width:0}.sidebar__property-switch{flex-shrink:0;color:var(--hotel-text-light);transition:color .2s}.sidebar__property-button:hover .sidebar__property-switch{color:var(--hotel-primary)}.sidebar__nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:.5rem 0}.sidebar__menu{list-style:none;padding:0;margin:0}.sidebar__menu-item{position:relative;margin-bottom:1px}.sidebar__link{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;margin:0 .5rem;color:var(--hotel-text-secondary);text-decoration:none;font-size:.875rem;font-weight:500;border-radius:8px;transition:all .2s;position:relative;white-space:nowrap;border:none;background:none;cursor:pointer;width:calc(100% - 1rem);text-align:left}.sidebar__link:hover{background:var(--hotel-surface-light);color:var(--hotel-primary)}.sidebar__link--active{background:linear-gradient(135deg,#1e40af1a,#3b82f614);color:var(--hotel-primary);font-weight:600}.sidebar__link--active:before{content:"";position:absolute;left:-.5rem;top:4px;bottom:4px;width:3px;background:var(--hotel-primary);border-radius:0 3px 3px 0}.sidebar--collapsed .sidebar__link{justify-content:center;padding:.75rem;margin:0 .375rem;width:calc(100% - .75rem)}.sidebar__icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar__label{flex:1;overflow:hidden;text-overflow:ellipsis}.sidebar__badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#ef4444;color:#fff;font-size:.7rem;font-weight:700;border-radius:10px;animation:sidebar-pulse 2s infinite;flex-shrink:0}.sidebar--collapsed .sidebar__badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;font-size:.6rem;padding:0 4px}@keyframes sidebar-pulse{0%,to{opacity:1}50%{opacity:.7}}.sidebar__chevron{flex-shrink:0;transition:transform .2s;color:var(--hotel-text-light)}.sidebar__chevron--open{transform:rotate(180deg)}.sidebar__submenu{list-style:none;padding:.25rem 0 .25rem 1rem;margin:0}.sidebar__submenu--popup{position:absolute;left:calc(var(--sidebar-collapsed-width) - .5rem);top:0;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:.5rem 0;min-width:180px;z-index:200}.sidebar__submenu-link{display:flex;align-items:center;gap:.625rem;padding:.5rem .875rem;color:var(--hotel-text-secondary);text-decoration:none;font-size:.8125rem;font-weight:500;border-radius:6px;transition:all .2s;margin:0 .25rem}.sidebar__submenu-link:hover{background:var(--hotel-surface-light);color:var(--hotel-primary)}.sidebar__submenu-link--active{color:var(--hotel-primary);font-weight:600;background:#1e40af0f}.sidebar--collapsed .sidebar__property-button[data-tooltip]:hover:after,.sidebar--collapsed .sidebar__link[data-tooltip]:hover:after,.sidebar--collapsed .sidebar__theme-toggle[data-tooltip]:hover:after,.sidebar--collapsed .sidebar__user-button[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);background:var(--hotel-text);color:var(--hotel-card-background);padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:500;white-space:nowrap;z-index:300;pointer-events:none;box-shadow:0 2px 8px #00000026}.sidebar--collapsed .sidebar__property-button[data-tooltip]:hover:before,.sidebar--collapsed .sidebar__link[data-tooltip]:hover:before,.sidebar--collapsed .sidebar__theme-toggle[data-tooltip]:hover:before,.sidebar--collapsed .sidebar__user-button[data-tooltip]:hover:before{content:"";position:absolute;left:calc(100% + 6px);top:50%;transform:translateY(-50%);border:5px solid transparent;border-right-color:var(--hotel-text);z-index:300;pointer-events:none}.sidebar__footer{border-top:1px solid var(--hotel-border);padding:.5rem;flex-shrink:0}.sidebar__theme-toggle{display:flex;align-items:center;gap:.75rem;width:100%;padding:.5rem .625rem;border:none;background:transparent;color:var(--hotel-text-secondary);cursor:pointer;border-radius:8px;font-size:.8125rem;font-weight:500;transition:all .2s;position:relative}.sidebar__theme-toggle:hover{background:var(--hotel-surface-light);color:var(--hotel-primary)}.sidebar--collapsed .sidebar__theme-toggle{justify-content:center;padding:.625rem}.sidebar__user{position:relative;margin-top:.25rem}.sidebar__user-button{display:flex;align-items:center;gap:.625rem;width:100%;padding:.5rem .625rem;border:none;background:transparent;cursor:pointer;border-radius:8px;transition:all .2s;color:var(--hotel-text);position:relative}.sidebar__user-button:hover{background:var(--hotel-surface-light)}.sidebar--collapsed .sidebar__user-button{justify-content:center;padding:.5rem}.sidebar__user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--hotel-primary),var(--hotel-primary-light));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.75rem;overflow:hidden;flex-shrink:0}.sidebar__user-avatar img{width:100%;height:100%;object-fit:cover}.sidebar__user-info{display:flex;flex-direction:column;align-items:flex-start;overflow:hidden;min-width:0}.sidebar__user-name{font-weight:600;font-size:.8125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.sidebar__user-role{font-size:.6875rem;color:var(--hotel-text-light);text-transform:capitalize}.sidebar__user-menu{position:absolute;bottom:calc(100% + .5rem);left:0;right:0;background:var(--hotel-card-background);border:1px solid var(--hotel-border);border-radius:8px;box-shadow:0 -4px 12px #0000001a;padding:.375rem 0;z-index:200;animation:sidebar-slide-up .15s ease-out}.sidebar__user-menu--popup{left:calc(var(--sidebar-collapsed-width) - .5rem);bottom:0;right:auto;min-width:180px;box-shadow:0 4px 12px #0000001a}@keyframes sidebar-slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sidebar__user-menu-item{display:flex;align-items:center;gap:.625rem;width:100%;padding:.625rem .875rem;border:none;background:none;color:var(--hotel-text);cursor:pointer;font-size:.8125rem;font-weight:500;transition:background .2s;text-align:left}.sidebar__user-menu-item:hover{background:var(--hotel-surface-light)}.sidebar__user-menu-item--logout{color:#ef4444}.sidebar__user-menu-item--logout:hover{background:#ef444414}.sidebar__user-menu-divider{height:1px;background:var(--hotel-border);margin:.25rem 0}.sidebar__nav::-webkit-scrollbar{width:4px}.sidebar__nav::-webkit-scrollbar-track{background:transparent}.sidebar__nav::-webkit-scrollbar-thumb{background:var(--hotel-border-dark);border-radius:2px}.sidebar__nav::-webkit-scrollbar-thumb:hover{background:var(--hotel-text-light)}.sidebar__overlay,.sidebar__mobile-toggle{display:none}@media (max-width: 1024px){.sidebar{--sidebar-width: 220px}}@media (max-width: 768px){.sidebar{--sidebar-width: 260px;transform:translate(-100%);transition:transform var(--sidebar-transition);box-shadow:none;z-index:300}.sidebar--mobile-open{transform:translate(0);box-shadow:4px 0 24px #00000026}.sidebar--collapsed{width:var(--sidebar-width)}.sidebar__overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:250;animation:sidebar-fade-in .2s ease-out}@keyframes sidebar-fade-in{0%{opacity:0}to{opacity:1}}.sidebar__mobile-toggle{display:flex;align-items:center;justify-content:center;position:fixed;top:.75rem;left:.75rem;z-index:90;width:40px;height:40px;border-radius:8px;border:1px solid var(--hotel-border);background:var(--hotel-card-background);color:var(--hotel-text);cursor:pointer;box-shadow:0 2px 8px #00000014}.sidebar__toggle{display:none}.sidebar--collapsed .sidebar__link{justify-content:flex-start;padding:.625rem .875rem;margin:0 .5rem;width:calc(100% - 1rem)}.sidebar--collapsed .sidebar__theme-toggle,.sidebar--collapsed .sidebar__user-button{justify-content:flex-start}}[data-theme=dark] .sidebar{background:var(--hotel-card-background);border-right-color:var(--hotel-border)}[data-theme=dark] .sidebar__header{border-bottom-color:var(--hotel-border)}[data-theme=dark] .sidebar__footer{border-top-color:var(--hotel-border)}[data-theme=dark] .sidebar__submenu--popup,[data-theme=dark] .sidebar__user-menu{background:var(--hotel-card-background);border-color:var(--hotel-border);box-shadow:0 4px 12px #0000004d}[data-theme=dark] .sidebar__mobile-toggle{background:var(--hotel-card-background);border-color:var(--hotel-border);color:var(--hotel-text)}[data-theme=dark] .sidebar__overlay{background:#0009}.alerta-licencia{display:flex;align-items:center;padding:12px 20px;font-size:.9rem;gap:12px;position:relative;z-index:100}.alerta-licencia--critico{background:linear-gradient(90deg,#dc2626,#b91c1c);color:#fff}.alerta-licencia--critico .alerta-licencia__link{color:#fff;border-color:#ffffff4d}.alerta-licencia--critico .alerta-licencia__link:hover{background:#ffffff1a}.alerta-licencia--urgente{background:linear-gradient(90deg,#ea580c,#c2410c);color:#fff}.alerta-licencia--urgente .alerta-licencia__link{color:#fff;border-color:#ffffff4d}.alerta-licencia--urgente .alerta-licencia__link:hover{background:#ffffff1a}.alerta-licencia--advertencia{background:linear-gradient(90deg,#f59e0b,#d97706);color:#1f2937}.alerta-licencia--advertencia .alerta-licencia__link{color:#1f2937;border-color:#0003}.alerta-licencia--advertencia .alerta-licencia__link:hover{background:#0000001a}.alerta-licencia--advertencia .alerta-licencia__cerrar{color:#1f2937}.alerta-licencia__icono{flex-shrink:0;display:flex;align-items:center}.alerta-licencia__contenido{flex:1;cursor:pointer}.alerta-licencia__mensaje{font-weight:500}.alerta-licencia__link{display:flex;align-items:center;gap:4px;background:none;border:1px solid;padding:6px 12px;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s}.alerta-licencia__cerrar{background:none;border:none;padding:4px;cursor:pointer;opacity:.7;color:inherit;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.alerta-licencia__cerrar:hover{opacity:1;background:#0000001a}@media (max-width: 768px){.alerta-licencia{padding:10px 16px;gap:10px}.alerta-licencia__mensaje{font-size:.85rem}.alerta-licencia__link{padding:5px 10px;font-size:.8rem}.alerta-licencia__link span{display:none}}@media (max-width: 480px){.alerta-licencia{flex-wrap:wrap;padding:10px 12px}.alerta-licencia__contenido{order:3;width:100%;margin-top:6px}.alerta-licencia__link{order:2;margin-left:auto}.alerta-licencia__cerrar{order:4;position:absolute;top:8px;right:8px}}.layout{display:flex;min-height:100vh;background:var(--hotel-background)}.layout__content{flex:1;margin-left:240px;transition:margin-left .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;min-height:100vh;min-width:0}.sidebar--collapsed~.layout__content{margin-left:68px}.layout__main{flex:1;padding:1rem 1.25rem;max-width:1920px;width:100%}@media (max-width: 1024px){.layout__content{margin-left:220px}.sidebar--collapsed~.layout__content{margin-left:68px}.layout__main{padding:.75rem}}@media (max-width: 768px){.layout__content{margin-left:0}.sidebar--collapsed~.layout__content{margin-left:0}.layout__main{padding:3.5rem .75rem .75rem}}@media (max-width: 480px){.layout__main{padding:3.5rem .5rem .5rem}}*{margin:0;padding:0;box-sizing:border-box}#root{width:100%;min-height:100vh}:root{--color-primary: #2c3e50;--color-primary-dark: #1a252f;--color-secondary: #34495e;--color-accent: #3498db;--color-info: #3498db;--color-success: #27ae60;--color-warning: #f39c12;--color-danger: #e74c3c;--color-background: #ffffff;--color-surface: #f8f9fa;--color-surface-dark: #e9ecef;--color-text-primary: #2c3e50;--color-text-secondary: #7f8c8d;--color-text-light: #95a5a6;--color-border: #dee2e6;--hotel-primary: #1e40af;--hotel-primary-hover: #1e3a8a;--hotel-primary-light: #3b82f6;--hotel-secondary: #06b6d4;--hotel-secondary-hover: #0891b2;--hotel-secondary-light: #67e8f9;--hotel-accent: #f59e0b;--hotel-accent-hover: #d97706;--hotel-accent-light: #fbbf24;--hotel-background: #eff6ff;--hotel-card-background: #ffffff;--hotel-surface-light: #dbeafe;--hotel-text: #1f2937;--hotel-text-secondary: #6b7280;--hotel-text-light: #9ca3af;--hotel-border: #e5e7eb;--hotel-border-dark: #d1d5db;--room-disponible-bg: #d1fae5;--room-disponible-border: #10b981;--room-disponible-text: #047857;--room-ocupada-bg: #fee2e2;--room-ocupada-border: #ef4444;--room-ocupada-text: #dc2626;--room-limpieza-bg: #fef3c7;--room-limpieza-border: #f59e0b;--room-limpieza-text: #d97706;--room-mantenimiento-bg: #e5e7eb;--room-mantenimiento-border: #6b7280;--room-mantenimiento-text: #374151;--room-reservada-bg: #dbeafe;--room-reservada-border: #3b82f6;--room-reservada-text: #1e40af;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-size-base: 13px;--font-size-small: 11px;--font-size-large: 14px;--font-size-h1: 18px;--font-size-h2: 14px;--font-size-h3: 13px;--spacing-xs: 2px;--spacing-sm: 5px;--spacing-md: 8px;--spacing-lg: 12px;--spacing-xl: 16px;--spacing-xxl: 20px;--border-radius-sm: 4px;--border-radius-md: 6px;--border-radius-lg: 10px;--border-radius-xl: 14px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--transition-fast: .15s ease-in-out;--transition-normal: .25s ease-in-out;--transition-slow: .35s ease-in-out}*,*:before,*:after{box-sizing:border-box}html{font-size:var(--font-size-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;font-family:var(--font-family);color:var(--hotel-text);background-color:var(--hotel-background);line-height:1.6}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.2}h1{font-size:var(--font-size-h1)}h2{font-size:var(--font-size-h2)}h3{font-size:var(--font-size-h3)}p{margin:0}a{color:var(--hotel-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--hotel-primary-hover)}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all var(--transition-fast)}input,textarea,select{font-family:inherit;font-size:inherit}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.text-center{text-align:center}.text-right{text-align:right}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--hotel-surface-light)}::-webkit-scrollbar-thumb{background:var(--hotel-primary-light);border-radius:var(--border-radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--hotel-primary)}[data-theme=dark]{--color-primary: #3b82f6;--color-primary-dark: #60a5fa;--color-secondary: #64748b;--color-accent: #60a5fa;--color-info: #60a5fa;--color-success: #22c55e;--color-warning: #fbbf24;--color-danger: #f87171;--color-background: #1a1a2e;--color-surface: #16213e;--color-surface-dark: #0f3460;--color-text-primary: #e5e5e5;--color-text-secondary: #a0a0a0;--color-text-light: #6b7280;--color-border: #374151;--hotel-primary: #3b82f6;--hotel-primary-hover: #60a5fa;--hotel-primary-light: #93c5fd;--hotel-secondary: #22d3ee;--hotel-secondary-hover: #67e8f9;--hotel-secondary-light: #a5f3fc;--hotel-accent: #fbbf24;--hotel-accent-hover: #fcd34d;--hotel-accent-light: #fde68a;--hotel-background: #1a1a2e;--hotel-card-background: #16213e;--hotel-surface-light: #1e2d4a;--hotel-surface-lighter: rgba(255, 255, 255, .1);--hotel-text: #e5e5e5;--hotel-text-secondary: #b0b8c4;--hotel-text-light: #8891a0;--hotel-border: #374151;--hotel-border-dark: #4b5563;--room-disponible-bg: #065f46;--room-disponible-border: #10b981;--room-disponible-text: #6ee7b7;--room-ocupada-bg: #7f1d1d;--room-ocupada-border: #ef4444;--room-ocupada-text: #fca5a5;--room-limpieza-bg: #78350f;--room-limpieza-border: #f59e0b;--room-limpieza-text: #fcd34d;--room-mantenimiento-bg: #374151;--room-mantenimiento-border: #6b7280;--room-mantenimiento-text: #d1d5db;--room-reservada-bg: #1e3a8a;--room-reservada-border: #3b82f6;--room-reservada-text: #93c5fd;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6)}html,body,.header,.layout,.card,.modal,.modal__overlay,.modal__content,input,select,textarea,button,table,th,td{transition:background-color .3s ease,color .3s ease,border-color .3s ease}
