:root{--font-family: "Inter", system-ui, Avenir, Helvetica, Arial, sans-serif;--primary: #3b82f6;--primary-hover: #2563eb;--bg-base: #0f1115;--bg-surface: #1a1d24;--bg-surface-hover: #222630;--bg-elevated: #282c35;--text-main: #f0f0f0;--text-muted: #9ca3af;--danger: #ef4444;--success: #22c55e;--warning: #f59e0b;--border: #333a45;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-glow: 0 0 15px rgba(59, 130, 246, .3)}body{margin:0;padding:0;font-family:var(--font-family);background-color:var(--bg-base);color:var(--text-main);line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}a{color:var(--primary);text-decoration:inherit;transition:color .2s ease}a:hover{color:var(--primary-hover)}h1,h2,h3,h4,h5,h6{margin-top:0;font-weight:600;line-height:1.2}h1{font-size:2rem;margin-bottom:1.5rem}p{color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:var(--radius-sm);padding:.5rem 1rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease-in-out;border:none;outline:none;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary);color:#000;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-secondary{background-color:var(--bg-elevated);color:var(--text-main);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-surface-hover);border-color:#4a5463}.btn-danger{background-color:#ef44441a;color:var(--danger)}.btn-danger:hover:not(:disabled){background-color:var(--danger);color:#fff}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:var(--text-muted)}.form-input{width:100%;padding:.75rem 1rem;background-color:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-main);font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #3b82f633}.card{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem;box-shadow:var(--shadow-md)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.table-container{width:100%;overflow-x:auto}table{width:100%;border-collapse:separate;border-spacing:0;text-align:left}th{background-color:var(--bg-elevated);color:var(--text-muted);font-weight:500;font-size:.875rem;padding:.75rem 1rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}th:first-child{border-top-left-radius:var(--radius-sm)}th:last-child{border-top-right-radius:var(--radius-sm)}td{padding:1rem;border-bottom:1px solid var(--border);color:var(--text-main)}tr:last-child td{border-bottom:none}tr:hover td{background-color:#ffffff05}.badge{display:inline-flex;align-items:center;padding:.125rem .625rem;font-size:.75rem;font-weight:600;border-radius:9999px}.badge-low-stock{background-color:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2)}.badge-ok-stock{background-color:#22c55e1a;color:var(--success);border:1px solid rgba(34,197,94,.2)}@media print{body,html,#root,.sidebar,.header,.layout-container,.main-content,nav,aside{visibility:hidden!important;height:0!important;margin:0!important;padding:0!important}.print-area,.print-area *{visibility:visible!important}.print-area{position:absolute!important;left:0!important;top:0!important;width:100%!important;margin:0!important;padding:0!important;background-color:#fff!important;color:#000!important;box-shadow:none!important;border:none!important}.print-area div,.print-area span,.print-area p,.print-area th,.print-area td,.print-area h1,.print-area h2,.print-area h3{color:#000!important;background-color:transparent!important;border-color:#eee!important}.hide-on-print{display:none!important}}.layout-container{display:flex;min-height:100vh;background-color:var(--bg-base)}.sidebar{width:280px;background-color:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1.5rem;position:sticky;top:0;height:100vh}.sidebar-brand{display:flex;flex-direction:column;align-items:center;margin-bottom:2.5rem;text-align:center}.brand-logo-img{width:60px;height:60px;border-radius:50%;object-fit:cover;margin-bottom:.5rem;box-shadow:0 0 15px #3b82f666;border:2px solid var(--primary)}.sidebar-brand h2{color:var(--text-main);margin:0;font-size:1.25rem;letter-spacing:-.02em}.brand-subtitle{color:var(--primary);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.5rem}.nav-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-radius:var(--radius-sm);color:var(--text-muted);font-weight:500;transition:all .2s ease}.nav-item:hover{background-color:var(--bg-surface-hover);color:var(--text-main)}.nav-item.active{background-color:#3b82f626;color:var(--primary);border:1px solid rgba(59,130,246,.3)}.nav-icon{opacity:.8}.nav-item.active .nav-icon{opacity:1}.main-content{flex:1;display:flex;flex-direction:column;overflow-x:hidden}.top-header{height:80px;border-bottom:1px solid var(--border);background-color:var(--bg-surface);display:flex;justify-content:space-between;align-items:center;padding:0 2rem;position:sticky;top:0;z-index:10}.header-greeting h3{margin:0 0 .25rem;font-size:1.125rem}.header-greeting p{margin:0;font-size:.875rem}.header-user-info{display:flex;align-items:center;gap:.75rem}.header-role-badge{background-color:#3b82f626;color:var(--primary);padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:700;letter-spacing:.05em;border:1px solid rgba(59,130,246,.3)}.content-area{padding:2rem;flex:1}@media print{.sidebar,.top-header{display:none!important}.layout-container{display:block!important}.main-content{overflow:visible!important;margin:0!important;padding:0!important}.content-area{padding:0!important}body,html{background-color:#fff!important;color:#000!important;height:auto!important;overflow:visible!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}.productos-page{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:var(--shadow-sm)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.stat-icon.bg-info{background-color:#3b82f61a;color:#3b82f6}.stat-icon.bg-warning{background-color:#f59e0b1a}.stat-info h4{margin:0 0 .25rem;font-size:.875rem;color:var(--text-muted)}.stat-info h2{margin:0;font-size:1.5rem;color:var(--text-main)}.search-bar{position:relative;margin-bottom:1.5rem}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-input{padding-left:3rem;background-color:var(--bg-elevated)}.action-buttons{display:flex;justify-content:flex-end;gap:.5rem}.btn-icon{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background-color:var(--bg-surface-hover);color:var(--text-main)}.btn-icon.text-danger:hover{color:var(--danger);background-color:#ef44441a}.modal-overlay{position:fixed;inset:0;background-color:#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}.modal-content{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;max-width:600px;box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0000004d}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:1.25rem}.btn-close{background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;line-height:1;padding:.25rem .5rem;border-radius:4px}.btn-close:hover{background-color:var(--bg-elevated);color:var(--text-main)}.modal-body{padding:1.5rem}.form-row{display:flex;gap:1rem}@media print{.print-area{position:static!important;width:100%;max-width:none!important;background-color:#fff!important;color:#000!important;box-shadow:none!important;border:none!important;display:block!important}.hide-on-print{display:none!important}.print-only{display:block!important}.print-area h2,.print-area h3,.print-area p,.print-area strong,.print-area div{color:#000!important;border-color:#ddd!important;background-color:transparent!important}}.turnos-page{animation:fadeIn .3s ease}.calendar-header{display:flex;justify-content:space-between;align-items:center;background-color:var(--bg-surface);padding:1rem 1.5rem;border-radius:var(--radius-md) var(--radius-md) 0 0;border:1px solid var(--border);border-bottom:none}.date-navigation{display:flex;align-items:center;gap:1rem}.date-display{font-size:1.25rem;font-weight:600;min-width:250px;text-align:center}.calendar-grid{display:grid;background-color:var(--border);gap:1px;border:1px solid var(--border);border-radius:0 0 var(--radius-md) var(--radius-md);overflow:hidden;position:relative}.grid-header-row{display:contents}.grid-cell-header{background-color:var(--bg-elevated);padding:1rem;text-align:center;font-weight:600;color:var(--text-muted)}.grid-time-column{background-color:var(--bg-elevated);padding:.75rem;text-align:right;font-weight:500;color:var(--text-muted);font-size:.875rem;border-bottom:1px solid rgba(255,255,255,.05)}.grid-cell{background-color:var(--bg-surface);padding:.5rem;min-height:80px;position:relative;cursor:pointer;transition:background-color .2s;border-bottom:1px solid rgba(255,255,255,.05)}.grid-cell:hover{background-color:var(--bg-surface-hover)}.grid-cell.past-time{background-image:repeating-linear-gradient(45deg,#0003,#0003 10px,#0000001a 10px 20px);cursor:not-allowed}.turno-card{position:absolute;inset:4px;border-radius:var(--radius-sm);padding:.5rem;font-size:.75rem;display:flex;flex-direction:column;justify-content:space-between;z-index:5;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .1s;overflow:hidden}.turno-card:hover{transform:scale(1.02);z-index:10;box-shadow:var(--shadow-md)}.turno-card.reservado{background-color:#3b82f626;border:1px solid rgba(59,130,246,.4);border-left:4px solid var(--primary)}.turno-card.pagado{background-color:#22c55e26;border:1px solid rgba(34,197,94,.3);border-left:4px solid var(--success)}.turno-info-cliente{font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.turno-info-estado{text-transform:uppercase;font-size:.65rem;letter-spacing:.05em;opacity:.8}.date-picker-input{background-color:var(--bg-surface);color:var(--text-main);border:1px solid var(--border);padding:.5rem;border-radius:var(--radius-sm);font-family:inherit}.date-picker-input::-webkit-calendar-picker-indicator{filter:invert(1)}.legend-container{display:flex;gap:1.5rem;margin-top:1rem;padding:1rem;background-color:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-muted)}.legend-box{width:16px;height:16px;border-radius:4px}.legend-box.reservado{background-color:#3b82f626;border-left:4px solid var(--primary)}.legend-box.pagado{background-color:#22c55e26;border-left:4px solid var(--success)}.cartel-story{width:320px;height:568px;min-width:320px;min-height:568px;flex-shrink:0;background:linear-gradient(145deg,#0f1115,#172554);border-radius:16px;padding:2rem;display:flex;flex-direction:column;align-items:center;color:#fff;text-align:center;position:relative;overflow:hidden;box-shadow:0 10px 25px #00000080;box-sizing:border-box}.cartel-story:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at center,#3b82f626,#0000 70%)}.cartel-header{font-size:1.5rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;z-index:1;margin-bottom:.25rem;display:flex;flex-direction:column;align-items:center}.cartel-logo{width:70px;height:70px;border-radius:50%;object-fit:cover;margin-bottom:.5rem;border:2px solid white;box-shadow:0 4px 10px #00000080}.cartel-cancha{font-size:1.1rem;color:var(--primary);font-weight:600;margin-top:.25rem}.cartel-date{font-size:.95rem;color:#cbd5e1;text-transform:capitalize;margin-bottom:2rem;z-index:1}.cartel-title{background-color:var(--primary);color:#fff;padding:.5rem 1.5rem;border-radius:20px;font-weight:700;font-size:1.25rem;margin-bottom:1.5rem;z-index:1;box-shadow:0 4px 6px #0000004d}.cartel-slots{display:flex;flex-direction:column;gap:.75rem;width:100%;z-index:1;flex:1;overflow-y:hidden}.cartel-slot{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);padding:.75rem;border-radius:8px;font-size:1.25rem;font-weight:600}.cartel-footer{margin-top:auto;font-size:.9rem;color:#94a3b8;z-index:1}.btn-icon{background:transparent;border:none;cursor:pointer;border-radius:4px;padding:4px;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-icon:hover{background:#ffffff1a}.large-touch{padding:.5rem;min-height:38px;border-radius:8px;font-size:.875rem;font-weight:600}@media(max-width:900px){.calendar-grid{overflow-x:auto}.mobile-min-width{min-width:250px}}.ventas-page{animation:fadeIn .3s ease;display:flex;gap:2rem;height:calc(100vh - 160px)}.pos-left{flex:2;display:flex;flex-direction:column;gap:1.5rem}.pos-right{flex:1;min-width:350px;display:flex;flex-direction:column}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;overflow-y:auto;padding-right:.5rem}.product-card{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;justify-content:space-between;min-height:120px}.product-card:hover{background-color:var(--bg-surface-hover);transform:translateY(-2px);border-color:var(--primary);box-shadow:0 4px 12px #3b82f61a}.product-card.out-of-stock{opacity:.5;cursor:not-allowed;pointer-events:none}.product-card-title{font-weight:600;margin-bottom:.5rem;line-height:1.2}.product-card-price{color:var(--primary);font-weight:700;font-size:1.125rem}.cart-card{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;flex-direction:column;height:100%}.cart-header{padding:1.5rem;border-bottom:1px solid var(--border)}.cart-header h2{margin:0;font-size:1.25rem}.cart-items{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.cart-item{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px dashed var(--border)}.cart-item-info{flex:1}.cart-item-title{font-weight:500;margin-bottom:.25rem}.cart-item-controls{display:flex;align-items:center;gap:.5rem;background-color:var(--bg-base);border-radius:var(--radius-sm);padding:.25rem}.btn-qty{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-main);border-radius:4px;cursor:pointer}.btn-qty:hover{background-color:var(--bg-surface-hover)}.cart-item-price{font-weight:700;min-width:80px;text-align:right}.cart-footer{padding:1.5rem;background-color:var(--bg-elevated);border-top:1px solid var(--border);border-radius:0 0 var(--radius-md) var(--radius-md)}.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;font-size:1.5rem;font-weight:700}.cart-total-amount{color:var(--primary);font-size:2rem}.payment-methods{display:flex;gap:.5rem;margin-bottom:1.5rem}.payment-btn{flex:1;padding:.75rem;border:1px solid var(--border);background-color:var(--bg-base);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;font-weight:500;transition:all .2s}.payment-btn.active{background-color:#3b82f61a;color:var(--primary);border-color:var(--primary)}@media print{.pos-left,.pos-right{display:none!important}.modal-overlay{position:static!important;background:transparent!important;display:block!important}.print-area{position:static;width:100%;max-width:none!important;box-shadow:none;background-color:#fff!important;color:#000!important;border:none!important}.hide-on-print{display:none!important}#print-cierre-caja,#print-cierre-caja h2,#print-cierre-caja h3{color:#000!important}#print-cierre-caja table{border-collapse:collapse}#print-cierre-caja th,#print-cierre-caja td{border-bottom:1px solid #ddd;padding:.5rem;color:#000!important}#print-cierre-caja strong{color:#000!important}}.dashboard-page{animation:fadeIn .3s ease}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.dash-stat-card{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem;display:flex;align-items:center;justify-content:space-between;transition:transform .2s,box-shadow .2s}.dash-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary)}.dash-stat-info h3{margin:0;font-size:.875rem;color:var(--text-muted);font-weight:500}.dash-stat-info .value{margin:.5rem 0 0;font-size:2rem;font-weight:700;color:var(--text-main)}.dash-stat-icon{width:60px;height:60px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.dash-stat-icon.primary{background-color:#3b82f61a;color:var(--primary)}.dash-stat-icon.success{background-color:#22c55e1a;color:var(--success)}.dash-stat-icon.warning{background-color:#f59e0b1a;color:var(--warning)}.dashboard-grids{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem}.activity-card{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem}.activity-card h3{margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.activity-empty{text-align:center;padding:2rem;color:var(--text-muted);font-style:italic}@media(max-width:900px){.dashboard-grids{grid-template-columns:1fr}}.usuarios-page{animation:fadeIn .3s ease}.permission-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:1rem}.permission-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.permission-item:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:0 4px 12px #3b82f61a}.permission-item.active{background:#3b82f614;border-color:var(--primary)}.permission-item.active:after{content:"";position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 25px 25px 0;border-color:transparent var(--primary) transparent transparent}.permission-icon-wrapper{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ffffff08;border-radius:10px;transition:all .2s ease}.permission-item.active .permission-icon-wrapper{background:var(--primary);color:#fff}.permission-label{flex:1;font-size:.95rem;font-weight:500}.role-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .8rem;border-radius:99px;font-size:.75rem;font-weight:700;text-transform:uppercase}.role-admin{background:#3b82f626;color:#3b82f6;border:1px solid rgba(59,130,246,.3)}.role-empleado{background:#ffffff0d;color:var(--text-muted);border:1px solid var(--border)}.user-avatar{width:42px;height:42px;border-radius:12px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;text-shadow:0 2px 4px rgba(0,0,0,.2)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-base);background-image:radial-gradient(ellipse at 20% 50%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(59,130,246,.05) 0%,transparent 50%)}.login-container{width:100%;max-width:420px;padding:2rem}.login-card{background-color:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem;box-shadow:0 20px 40px #0006}.login-brand{display:flex;flex-direction:column;align-items:center;margin-bottom:2rem;text-align:center}.login-brand-logo{width:80px;height:80px;border-radius:50%;object-fit:cover;margin-bottom:1rem;box-shadow:0 0 20px #3b82f666;border:2px solid var(--primary);background-color:#fff}.login-brand h1{font-size:1.5rem;margin:0 0 .25rem;color:var(--text-main)}.login-brand p{margin:0;font-size:.875rem;color:var(--text-muted)}.login-error{background-color:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);padding:.75rem 1rem;margin-bottom:1.5rem;font-size:.875rem;text-align:center;animation:shakeError .3s ease}@keyframes shakeError{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.login-form .form-group{margin-bottom:1.25rem}.login-form .form-label{color:var(--text-main);font-weight:600;margin-bottom:.5rem}.login-form .form-input{padding:.875rem 1rem;font-size:1rem;background-color:var(--bg-base)}.login-submit{width:100%;padding:.875rem;font-size:1.05rem;margin-top:.5rem;font-weight:600;letter-spacing:.02em}.login-footer{text-align:center;margin-top:1.5rem;font-size:.8rem;color:var(--text-muted)}
