:root{--font-main: "Outfit", "Inter", -apple-system, sans-serif;--bg-color: #05060b;--panel-color: rgba(13, 15, 25, .82);--accent-primary: #7c3aed;--accent-secondary: #2563eb;--accent-gradient: linear-gradient(135deg, #7c3aed 0%, #2563eb 100%);--accent-glow: 0 0 25px rgba(124, 58, 237, .3);--text-primary: #ffffff;--text-secondary: #94a3b8;--text-muted: #64748b;--border-color: rgba(255, 255, 255, .1);--glass-bg: rgba(255, 255, 255, .03);--glass-border: rgba(255, 255, 255, .08);--glass-blur: blur(16px);--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .5);--shadow-glow: 0 0 15px rgba(124, 58, 237, .4)}*{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:var(--bg-color);color:var(--text-primary);font-family:var(--font-main);overflow:hidden;height:100vh;width:100vw}#root{height:100%}button{cursor:pointer;border:none;background:none;font-family:inherit;transition:all .2s ease}input,textarea,select{font-family:inherit;color:#fff;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:8px;padding:.6rem 1rem;transition:all .2s ease}.form-group input,.form-group select,.form-group textarea{width:100%;background:#ffffff0d;color:#fff;border:1px solid var(--glass-border)}input:focus,textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #8b5cf633}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .4s ease-out forwards}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:20px}::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}.card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:20px;padding:1.5rem;transition:all .4s cubic-bezier(.175,.885,.32,1.1)}.card:hover{border-color:#ffffff26;transform:translateY(-4px);box-shadow:0 15px 35px -10px #0006}:root{--bg-color: #0b0c10;--panel-color: rgba(15, 15, 25, .8);--text-primary: #f8fafc;--text-secondary: #94a3b8;--border-color: rgba(255, 255, 255, .1);--accent-primary: #8b5cf6;--accent-secondary: #a78bfa;--accent-gradient: linear-gradient(135deg, #8b5cf6 0%, #d946ef 100%);--glass-bg: rgba(255, 255, 255, .03);--glass-border: rgba(255, 255, 255, .08);--glass-blur: blur(12px);--shadow-glow: 0 0 20px rgba(139, 92, 246, .2);color-scheme:dark}input,select,textarea,button{color-scheme:dark}*{box-sizing:border-box}.app-container{display:flex;height:100vh;width:100vw;background:var(--bg-color);background-image:radial-gradient(at 0% 0%,hsla(253,16%,7%,1) 0,transparent 50%),radial-gradient(at 50% 0%,hsla(225,39%,30%,.1) 0,transparent 50%),radial-gradient(at 100% 0%,hsla(339,49%,30%,.1) 0,transparent 50%)}.sidebar{width:280px;background:var(--panel-color);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:1.5rem .8rem;z-index:100}.sidebar-brand{display:flex;align-items:center;gap:.8rem;padding:.5rem 1rem 2rem}.brand-icon{width:40px;height:40px;background:#8b5cf61a;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 15px #8b5cf633}.sidebar-brand h2{font-size:1.25rem;font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.4rem}.sidebar-item{display:flex;align-items:center;gap:.8rem;padding:.75rem 1rem;border-radius:12px;color:var(--text-secondary);transition:all .2s ease;width:100%;position:relative;font-weight:500;font-size:.95rem}.sidebar-item:hover{background:#ffffff0a;color:var(--text-primary);transform:translate(4px)}.sidebar-item.active{background:#8b5cf61a;color:var(--text-primary);font-weight:600}.active-indicator{position:absolute;right:1rem;width:4px;height:4px;background:var(--accent-primary);border-radius:50%;box-shadow:0 0 8px var(--accent-primary)}.sidebar-group{margin-top:.5rem}.group-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;color:var(--text-secondary);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-radius:12px;transition:all .2s ease}.group-header:hover{background:#ffffff05;color:var(--text-primary)}.group-title{display:flex;align-items:center;gap:.6rem}.group-items{display:flex;flex-direction:column;gap:.2rem;margin-left:.5rem;padding-left:.5rem;border-left:1px solid rgba(255,255,255,.05);margin-top:.2rem;margin-bottom:.5rem}.sidebar-divider{height:1px;background:#ffffff0d;margin:1rem}.sidebar-footer{padding:1rem;text-align:center;font-size:.75rem;color:var(--text-secondary);opacity:.5}.main-content{flex:1;height:100vh;overflow-y:auto;padding:2rem}.view-container{max-width:1200px;margin:0 auto}header.view-header{margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center}.view-header h1{font-size:2rem;font-weight:700}.header-actions{display:flex;gap:1rem}.card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem}.btn-primary{background:var(--accent-gradient);color:#fff;padding:.6rem 1.2rem;border-radius:10px;font-weight:600;display:flex;align-items:center;gap:.5rem;box-shadow:var(--shadow-glow)}.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.1)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}.stat-value{font-size:2.2rem;font-weight:800;margin-top:.5rem;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.text-success{color:#10b981!important;-webkit-text-fill-color:#10b981!important;background:none!important;background-clip:initial!important}.text-danger{color:#ef4444!important;-webkit-text-fill-color:#ef4444!important;background:none!important;background-clip:initial!important}.text-warning{color:#f59e0b!important;-webkit-text-fill-color:#f59e0b!important;background:none!important;background-clip:initial!important}.text-pending{color:#f97316!important;-webkit-text-fill-color:#f97316!important;background:none!important;background-clip:initial!important}.card h3{color:var(--text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}.charts-container{margin-top:2rem;display:grid;grid-template-columns:1fr;gap:1.5rem}.chart-card{padding:1.5rem}.chart-header{margin-bottom:1.5rem}.chart-header h3{font-size:1.1rem;color:var(--text-primary);text-transform:none}.search-box{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:1rem;color:var(--text-secondary)}.search-box input{padding-left:2.8rem;width:300px}.table-card{padding:0;overflow-x:auto}.data-table{width:100%;border-collapse:collapse;text-align:left;min-width:900px}.card.table-card{overflow-x:auto}.data-table th:last-child,.data-table td:last-child{position:sticky;right:0;background:var(--panel-color);box-shadow:-3px 0 8px #0003;z-index:1}.data-table th{padding:1.2rem 1.5rem;background:#ffffff05;color:var(--text-secondary);font-size:.85rem;font-weight:600;text-transform:uppercase;border-bottom:1px solid var(--border-color)}.data-table td{padding:1.2rem 1.5rem;border-bottom:1px solid var(--border-color);font-size:.95rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover{background:#ffffff03}.font-bold{font-weight:600}.text-right{text-align:right}.text-center{text-align:center}.text-secondary{color:var(--text-secondary)}.py-8{padding-top:2rem;padding-bottom:2rem}.badge{background:var(--glass-bg);border:1px solid var(--glass-border);padding:.25rem .75rem;border-radius:20px;font-size:.8rem;color:var(--accent-secondary)}.action-buttons{display:flex;gap:.5rem;justify-content:flex-end}.icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:var(--text-secondary);transition:all .2s ease}.icon-btn:hover{background:var(--glass-bg);color:var(--text-primary)}.icon-btn.danger:hover{background:#ef44441a;color:#ef4444}.status-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .6rem;border-radius:6px;font-size:.75rem;font-weight:700;letter-spacing:.02em}.status-badge.pendiente{background:#f59e0b1a;color:#f59e0b}.status-badge.aceptado,.status-badge.pagado{background:#10b9811a;color:#10b981}.status-badge.cancelado{background:#ef44441a;color:#ef4444}.text-success{color:#10b981}.text-warning{color:#f59e0b}.text-danger{color:#ef4444}.modal-overlay{position:fixed;inset:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex!important;justify-content:center!important;align-items:center!important;z-index:999999!important;margin:0!important;padding:0!important}.modal-content{background:#171923;border:1px solid rgba(255,255,255,.1);border-radius:24px;width:90%;max-width:800px;max-height:90vh;margin:auto!important;display:flex;flex-direction:column;box-shadow:0 0 80px #000000e6;position:relative;z-index:1000000;animation:modalPop .3s cubic-bezier(.34,1.56,.64,1);overflow:hidden}@keyframes modalPop{0%{transform:scale(.9) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.modal-header{padding:1.2rem 2rem;border-bottom:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center}.modal-header h2{font-size:1.3rem;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.modal-body{padding:1rem 1.5rem;flex:1;overflow-y:auto}.entity-form{display:grid;grid-template-columns:1fr 1fr;gap:.8rem 1.5rem}.entity-form .form-group:first-child,.entity-form .form-group:nth-child(4),.entity-form .form-group:nth-child(6),.entity-form .form-actions{grid-column:span 2}.entity-form .form-row{display:contents}.form-group{margin-bottom:.8rem}.form-group label{display:block;margin-bottom:.3rem;color:var(--text-secondary);font-size:.85rem}.form-group input,.form-group select,.form-group textarea,.input-field{width:100%;background:#1a1c23!important;color:#f8fafc!important;border:1px solid var(--glass-border);border-radius:8px;padding:.6rem;color-scheme:dark}select option{background-color:#1a1c23!important;color:#f8fafc!important}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}.btn-secondary{background:var(--glass-bg);color:var(--text-primary);padding:.6rem 1.2rem;border-radius:10px;border:1px solid var(--glass-border)}.btn-secondary:hover{background:var(--glass-border)}@media print{@page{margin:1cm;size:landscape}body,html,#root,.app-container,.main-content{background:#fff!important;color:#000!important;display:block!important;height:auto!important;width:100%!important;overflow:visible!important;margin:0!important;padding:0!important}*{-webkit-backdrop-filter:none!important;backdrop-filter:none!important;filter:none!important;box-shadow:none!important;animation:none!important;transition:none!important}.sidebar,.view-header,.action-buttons,.no-print,.search-box,.stat-card,.filter-card,.report-filters,.icon-btn,.sidebar-nav,.header-actions,.brand-icon,.close-btn,button,.modal-overlay,footer,label,.form-group,.search-icon{display:none!important}.view-container,.card,.table-card{display:block!important;background:transparent!important;border:none!important;margin:0!important;padding:0!important;width:100%!important}.report-header-print,.only-print{display:block!important;text-align:center!important;margin-bottom:25px!important;border-bottom:3px solid black!important;padding-bottom:10px!important;color:#000!important}table.data-table{display:table!important;width:100%!important;border:2px solid black!important;border-collapse:collapse!important;margin-top:10px!important;color:#000!important;visibility:visible!important;opacity:1!important}table.data-table thead{display:table-header-group!important;background:#eee!important}table.data-table tbody{display:table-row-group!important}table.data-table tr{display:table-row!important;page-break-inside:avoid!important;visibility:visible!important}table.data-table th,table.data-table td{display:table-cell!important;border:1px solid #000000!important;padding:4px 5px!important;text-align:left!important;font-size:7.5pt!important;background:#fff!important;color:#000!important;visibility:visible!important;white-space:nowrap!important;overflow:hidden!important}table.data-table th{background:#f0f0f0!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:-.02em!important}table.data-table th:nth-child(2),table.data-table td:nth-child(2){width:30%!important}.font-bold,td strong,td span{font-weight:700!important;color:#000!important}.text-secondary{color:#444!important}}.only-print{display:none}.login-overlay{position:fixed;inset:0;background:var(--bg-color);background-image:radial-gradient(at 10% 20%,hsla(253,16%,7%,1) 0,transparent 50%),radial-gradient(at 90% 80%,hsla(225,39%,30%,.1) 0,transparent 50%);display:flex;align-items:center;justify-content:center;z-index:999999}.login-card{background:var(--panel-color);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);padding:3rem 2.5rem;border-radius:28px;width:100%;max-width:420px;box-shadow:0 0 50px #0006}.login-header{margin-bottom:1.5rem;text-align:center}.login-header h1{font-size:1.8rem;font-weight:800;margin:1rem 0 .4rem;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.login-header p{color:var(--text-secondary);font-size:.95rem}.login-form{margin-top:1rem}.input-with-icon{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1.2rem;color:var(--text-secondary)}.input-with-icon input{padding-left:3.5rem!important;height:54px;font-size:1.1rem;width:100%}.btn-login{width:100%;background:var(--accent-gradient);color:#fff;padding:1.1rem;border-radius:14px;font-weight:700;font-size:1.05rem;display:flex;align-items:center;justify-content:center;gap:.8rem;margin-top:2rem;box-shadow:var(--shadow-glow)}.btn-login:hover{transform:translateY(-3px);filter:brightness(1.1)}.login-footer{margin-top:2.5rem;opacity:.5;font-size:.85rem;text-align:center}.error-text{color:#ef4444;font-size:.85rem;margin-top:.5rem;font-weight:500;text-align:left}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.shake{animation:shake .2s ease-in-out}.scroll-top-btn{position:fixed;bottom:2rem;right:2rem;width:50px;height:50px;border-radius:50%;background:var(--accent-gradient);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 15px #0000004d,var(--shadow-glow);z-index:1000;transition:all .3s cubic-bezier(.175,.885,.32,1.275);animation:fadeIn .3s ease-out}.scroll-top-btn:hover{transform:translateY(-5px);box-shadow:0 6px 20px #8b5cf666}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.selected-row{background:#8b5cf61f!important}.action-menu{position:fixed;background:#0f111af2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:16px;z-index:10000;box-shadow:0 15px 35px #00000080,0 0 0 1px #ffffff0d,0 0 20px #8b5cf61a;padding:.6rem;min-width:200px;display:flex;flex-direction:column;gap:2px;animation:menuAppear .25s cubic-bezier(.16,1,.3,1);pointer-events:auto}@keyframes menuAppear{0%{opacity:0;transform:scale(.9) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.menu-item{display:flex;align-items:center;gap:.85rem;padding:.75rem 1rem;width:100%;border-radius:12px;font-size:.9rem;font-weight:500;color:#cbd5e1;background:transparent;border:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-align:left}.menu-item:hover{background:#8b5cf61a;color:#fff;padding-left:1.25rem}.menu-item svg{color:var(--text-secondary);transition:color .2s}.menu-item:hover svg{color:var(--accent-secondary);transform:scale(1.1)}.menu-item.text-danger:hover{background:#ef44441a;color:#fca5a5}.menu-item.text-danger:hover svg{color:#ef4444}.menu-item.text-success:hover{background:#22c55e1a;color:#86efac}.menu-item.text-success:hover svg{color:#10b981}.action-drawer-overlay{position:fixed;inset:0;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:11000;animation:fadeIn .3s ease;display:flex;justify-content:flex-end}.action-drawer{width:320px;height:100%;background:#141721;border-left:1px solid rgba(139,92,246,.3);box-shadow:-15px 0 45px #000000b3;display:flex;flex-direction:column;animation:drawerSlideIn .4s cubic-bezier(.16,1,.3,1);overflow-y:auto}@keyframes drawerSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;background:#8b5cf60d}.drawer-header h3{margin:0;font-size:1.1rem;color:#fff}.drawer-content{padding:1rem;display:flex;flex-direction:column;gap:.5rem}.drawer-section{padding:.5rem 0}.drawer-section-title{font-size:.75rem;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.05em;margin-bottom:.75rem;padding-left:.5rem}.drawer-item{display:flex;align-items:center;gap:1rem;padding:.9rem 1rem;width:100%;border-radius:12px;background:#ffffff05;border:1px solid transparent;color:#cbd5e1;cursor:pointer;transition:all .2s;text-align:left}.drawer-item:hover{background:#8b5cf61a;border-color:#8b5cf64d;color:#fff;transform:translate(-4px)}.drawer-item svg{color:var(--accent-secondary)}.drawer-item.danger:hover{background:#ef44441a;border-color:#ef44444d;color:#f87171}.drawer-item.danger svg{color:#ef4444}.close-drawer-btn{background:#ffffff0d;border:none;color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.data-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:auto}.data-table th,.data-table td{white-space:nowrap;padding:1rem .75rem}@media(max-width:1200px){.data-table td:nth-child(5),.data-table th:nth-child(5){display:none}.data-table td:nth-child(6),.data-table th:nth-child(6){display:none}}.menu-divider{height:1px;background:#ffffff0f;margin:.4rem .6rem}.name-link-btn{background:none;border:none;padding:0;margin:0;color:#fff;font-weight:700;font-size:inherit;font-family:inherit;cursor:pointer;text-align:left;transition:all .2s ease;text-decoration:none;position:relative}.name-link-btn:hover{color:var(--accent-secondary);text-decoration:underline;text-underline-offset:4px}
