:root{--primary: #4f46e5;--primary-hover: #4338ca;--secondary: #64748b;--bg-main: #f1f5f9;--bg-card: #ffffff;--text-main: #0f172a;--text-muted: #64748b;--border: #e2e8f0;--danger: #ef4444;--success: #22c55e;--warning: #f59e0b;--radius: 8px;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg-main);color:var(--text-main);line-height:1.5;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}ul{list-style:none}button,input,select,textarea{font-family:inherit;font-size:100%}img{display:block;max-width:100%}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;border:1px solid var(--border)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top right,#e0e7ff,var(--bg-main))}.login-container{width:100%;max-width:420px;background:var(--bg-card);border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;padding:2.5rem;animation:slideUp .5s ease-out;border:1px solid var(--border)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.logo-icon{width:48px;height:48px;background:var(--primary);color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 4px 6px -1px #4f46e54d}.logo-icon svg{width:24px;height:24px}.login-header h1{font-size:1.5rem;color:var(--text-main);margin-bottom:.5rem}.login-header p{color:var(--text-muted);font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-main)}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;color:var(--text-muted);pointer-events:none}input{width:100%;padding:.75rem 1rem .75rem 2.5rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-main);transition:all .2s;font-size:.95rem}input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a;background:#fff}.btn-primary{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem;background:var(--primary);color:#fff;border-radius:8px;font-weight:600;margin-top:.5rem;transition:all .2s}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.error-message{background:#fef2f2;color:var(--danger);padding:.75rem;border-radius:8px;font-size:.875rem;border:1px solid #fee2e2;text-align:center}.login-footer{text-align:center;margin-top:2rem;font-size:.75rem;color:var(--text-muted)}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.layout{display:flex;min-height:100vh;background-color:var(--bg-main)}.sidebar{width:260px;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;height:100vh;z-index:50;transition:transform .3s ease}.sidebar-header{padding:1.5rem;display:flex;align-items:center;gap:.75rem;border-bottom:1px solid var(--border)}.logo-box{width:32px;height:32px;background:var(--primary);color:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center}.logo-box svg{width:20px;height:20px}.sidebar-header h2{font-size:1.1rem;color:var(--text-main);font-weight:700}.user-info{padding:1.5rem;display:flex;align-items:center;gap:.75rem;background:#f8fafc;margin:1rem;border-radius:12px}.avatar-placeholder{width:40px;height:40px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem;overflow:hidden}.user-details{overflow:hidden}.user-name{font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.75rem;color:var(--text-muted);text-transform:capitalize}.sidebar-nav{flex:1;padding:0 1rem;display:flex;flex-direction:column;gap:.25rem;overflow-y:auto}.sidebar-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;color:var(--text-muted);font-weight:500;font-size:.95rem;transition:all .2s}.sidebar-item:hover{background:#f1f5f9;color:var(--text-main)}.sidebar-item.active{background:#e0e7ff;color:var(--primary)}.sidebar-footer{padding:1rem;border-top:1px solid var(--border)}.logout-btn{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:transparent;color:var(--danger);border-radius:8px;font-weight:500;transition:background .2s}.logout-btn:hover{background:#fef2f2}.main-content{flex:1;margin-left:260px;padding:2rem;width:calc(100% - 260px)}.content-wrapper{max-width:1200px;margin:0 auto}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:60px;background:#fff;border-bottom:1px solid var(--border);align-items:center;padding:0 1rem;z-index:40}.menu-btn{background:none;padding:.5rem;margin-right:.5rem}.backdrop{display:none;position:fixed;inset:0;background:#0000004d;z-index:45}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;width:100%;padding-top:80px}.mobile-header{display:flex}.backdrop{display:block}}.modal-backdrop{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;width:100%;max-width:500px;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;animation:slideUpModal .3s ease-out;max-height:90vh;display:flex;flex-direction:column}@keyframes slideUpModal{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:1.1rem;color:var(--text-main);margin:0}.close-btn{background:transparent;color:var(--text-muted);padding:.25rem;border-radius:4px;display:flex}.close-btn:hover{background:#f1f5f9;color:var(--text-main)}.modal-body{padding:1.5rem;overflow-y:auto}.modal-footer{padding:1.25rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.75rem;background:#f8fafc;border-radius:0 0 12px 12px}.inventory-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.filters-bar{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.filter-group{display:flex;gap:.5rem;background:#fff;padding:.25rem;border-radius:8px;border:1px solid var(--border);height:fit-content}.filter-chip{padding:.4rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;color:var(--text-muted);background:transparent;border:none;cursor:pointer;transition:all .2s}.filter-chip.active{background:#eff6ff;color:var(--primary)}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.5rem}.product-card{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:transform .2s,box-shadow .2s}.product-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.product-image{height:160px;background:#f1f5f9;position:relative;display:flex;align-items:center;justify-content:center}.product-image img{width:100%;height:100%;object-fit:cover}.no-image{color:#cbd5e1}.product-type-badge{position:absolute;top:.5rem;right:.5rem;font-size:.7rem;padding:.25rem .5rem;border-radius:999px;font-weight:700;text-transform:uppercase;background:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.product-type-badge.activo{color:var(--primary)}.product-type-badge.consumible{color:#f59e0b}.product-info{padding:1rem}.product-info h3{font-size:1rem;margin-bottom:.25rem;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.description{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem;line-height:1.4;height:2.8em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2}.meta{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-muted);font-weight:500;margin-bottom:1rem}.actions{padding-top:.5rem;border-top:1px solid #f1f5f9}.product-form{display:flex;flex-direction:column;gap:1rem}.form-image-preview{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.form-image-preview img,.form-image-preview .placeholder{width:80px;height:80px;border-radius:8px;object-fit:cover;background:#f1f5f9;display:flex;align-items:center;justify-content:center}.upload-btn{font-size:.85rem;color:var(--primary);cursor:pointer;font-weight:500}.form-row{display:flex;gap:1rem}.form-group{flex:1;display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.9rem;font-weight:500}.form-group select,.form-group input,.form-group textarea{padding:.6rem;border-radius:6px;border:1px solid var(--border)}.floating-cart-btn{position:fixed;bottom:2rem;right:2rem;width:60px;height:60px;border-radius:30px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #4f46e566;border:none;cursor:pointer;transition:transform .2s;z-index:90}.floating-cart-btn:hover{transform:scale(1.1)}.floating-cart-btn .badge{position:absolute;top:0;right:0;background:var(--danger);color:#fff;width:24px;height:24px;border-radius:12px;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid white}.reservations-list{display:flex;flex-direction:column;gap:1.25rem}.reservation-card{display:flex;background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;align-items:center;box-shadow:0 1px 3px #0000001a;transition:transform .2s,box-shadow .2s}.reservation-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a;border-color:var(--primary-light)}.res-time{background:#f8fafc;padding:1.5rem;text-align:center;border-right:1px solid #e2e8f0;min-width:160px;display:flex;flex-direction:column;justify-content:center}.res-time .date{font-size:1.1rem;font-weight:700;color:#1e293b;margin-bottom:.25rem}.res-time .time{font-size:.9rem;font-weight:500;color:#64748b}.res-info{flex:1;padding:1.5rem}.res-info h4{margin:0 0 .5rem;font-size:1.25rem;color:#0f172a;font-weight:600}.user-label{font-size:.95rem;color:#475569;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.status-badge{display:inline-flex;align-items:center;padding:.35rem .85rem;border-radius:999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em}.status-badge.pendiente{background:#fef9c3;color:#854d0e;border:1px solid #fde047}.status-badge.aceptada{background:#dcfce7;color:#166534;border:1px solid #86efac}.status-badge.rechazada{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.status-badge.cancelada{background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0}.vigente-badge{background:#ef4444;color:#fff;font-size:.65rem;font-weight:800;padding:.15rem .5rem;border-radius:4px;letter-spacing:.05em;animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.res-actions{padding:1rem 1.5rem;display:flex;gap:.75rem;flex-direction:row}.stats-container{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.25rem;border-radius:16px;border:1px solid #e2e8f0;display:flex;flex-direction:column;gap:.25rem;box-shadow:0 1px 2px #0000000d}.stat-label{font-size:.85rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.025em}.stat-value{font-size:1.75rem;font-weight:800;color:#1e293b}.tabs-container{display:flex;gap:.5rem;background:#f1f5f9;padding:.4rem;border-radius:12px;margin-bottom:1.5rem;width:fit-content}.tab-btn{padding:.6rem 1.25rem;border-radius:8px;border:none;background:transparent;color:#64748b;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s}.tab-btn:hover{color:#1e293b}.tab-btn.active{background:#fff;color:var(--primary);box-shadow:0 1px 3px #0000001a}.empty-state{text-align:center;padding:4rem 2rem;background:#fff;border:2px dashed #e2e8f0;border-radius:20px}.step-indicator{display:flex;align-items:center;justify-content:center;margin-bottom:2.5rem;padding:0 1rem}.step-dot{width:32px;height:32px;border-radius:50%;background:#f1f5f9;color:#64748b;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;transition:all .3s;border:2px solid transparent}.step-dot.active{background:var(--primary);color:#fff;box-shadow:0 0 0 4px #4f46e51a}.step-line{flex:1;height:2px;background:#f1f5f9;margin:0 10px}.step-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin-bottom:1.5rem;text-align:center}.resource-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.resource-card-select{padding:1.25rem;border:2px solid #f1f5f9;border-radius:12px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.resource-card-select:hover{border-color:#e2e8f0;background:#f8fafc}.resource-card-select.active{border-color:var(--primary);background:#f5f3ff}.resource-icon{width:48px;height:48px;background:#f8fafc;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--primary)}.resource-card-select.active .resource-icon{background:var(--primary);color:#fff}.resource-info-select h4{margin:0;font-size:1rem;color:#1e293b}.resource-info-select span{font-size:.8rem;color:#64748b}.modern-input{width:100%;padding:.75rem 1rem;border:2px solid #f1f5f9;border-radius:10px;font-size:1rem;outline:none;transition:all .2s}.modern-input:focus{border-color:var(--primary)}.time-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.time-slot{padding:.75rem;border:2px solid #f1f5f9;border-radius:10px;background:#fff;cursor:pointer;font-weight:600;transition:all .2s}.time-slot:hover:not(:disabled){border-color:var(--primary-light);background:#f8fafc}.time-slot.active{background:var(--primary);color:#fff;border-color:var(--primary)}.time-slot:disabled{background:#f8fafc;border-color:#f1f5f9;color:#cbd5e1;cursor:not-allowed;position:relative;padding-bottom:1.5rem}.booked-label{position:absolute;bottom:4px;left:0;right:0;font-size:.65rem;color:#ef4444}.form-label{display:block;margin-bottom:.5rem;font-weight:600;color:#475569}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow);display:flex;align-items:center;gap:1rem}.stat-card h3{font-size:1.8rem;margin:0;color:var(--text-main);line-height:1}.stat-card p{margin:.25rem 0 0;color:var(--text-muted);font-size:.9rem}.icon-box{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.icon-box.blue{background:#3b82f6}.icon-box.indigo{background:#6366f1}.icon-box.emerald{background:#10b981}.icon-box.orange{background:#f97316}.export-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.5rem}.export-card{background:#f8fafc;padding:1.5rem;border-radius:12px;border:1px solid var(--border)}.export-card h3{font-size:1.1rem;margin-bottom:.5rem}.export-card p{color:var(--text-muted);font-size:.9rem;margin-bottom:1rem}.dashboard-container{padding:2rem;max-width:1400px;margin:0 auto;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.5rem}.header-text h1{font-size:2.2rem;font-weight:800;color:var(--text-main);margin-bottom:.5rem;letter-spacing:-.02em}.header-text p{color:var(--text-muted);font-size:1.1rem}.highlight{color:var(--primary);font-weight:600}.header-actions{display:flex;gap:1rem}.primary-btn{padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px -1px #4f46e533}.primary-btn:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 10px 15px -3px #4f46e54d}.secondary-btn{padding:.75rem 1.5rem;background:#fff;color:var(--text-main);border:1px solid var(--border);border-radius:10px;font-weight:500;cursor:pointer;transition:all .2s ease}.secondary-btn:hover{background:#f8fafc;border-color:#cbd5e1}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff;padding:1.5rem;border-radius:16px;border:1px solid var(--border);display:flex;align-items:center;gap:1.25rem;text-decoration:none;color:inherit;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background-color:var(--accent);opacity:.8}.stat-card:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000000d,0 10px 10px -5px #00000005;border-color:var(--accent)}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background-color:#00000008;color:var(--accent)}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-main)}.stat-title{font-size:.9rem;color:var(--text-muted);font-weight:500}.stat-subtitle{font-size:.75rem;color:var(--text-muted);opacity:.8}.stat-arrow{margin-left:auto;color:var(--text-muted);opacity:0;transition:all .2s ease}.stat-card:hover .stat-arrow{opacity:1;transform:translate(4px)}.dashboard-main-grid{display:grid;grid-template-columns:2fr 1fr;gap:2rem}@media(max-width:1024px){.dashboard-main-grid{grid-template-columns:1fr}}.section-title{font-size:1.25rem;font-weight:700;margin-bottom:1.5rem;color:var(--text-main)}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.action-card{background:#fff;padding:1.25rem;border-radius:14px;border:1px solid var(--border);display:flex;align-items:center;gap:1rem;text-decoration:none;color:inherit;transition:all .2s ease}.action-card:hover{border-color:var(--primary);background:#fcfcff}.action-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center}.action-info h4{margin:0;font-size:1rem;color:var(--text-main)}.action-info p{margin:4px 0 0;font-size:.85rem;color:var(--text-muted)}.action-arrow{margin-left:auto;color:var(--text-muted);opacity:.5}.action-card:hover .action-arrow{color:var(--primary);opacity:1}.info-box{background:#fff;padding:1.5rem;border-radius:16px;border:1px solid var(--border);display:flex;flex-direction:column;gap:1.5rem}.info-item{display:flex;gap:1rem}.info-icon{color:var(--primary);padding-top:2px}.info-text strong{display:block;font-size:.95rem;margin-bottom:4px}.info-text p{font-size:.85rem;color:var(--text-muted);margin:0}
