*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0a0a0a;--bg-secondary: #1a1a1a;--bg-card: #1f1f1f;--bg-hover: #2a2a2a;--text-primary: #ffffff;--text-secondary: #b0b0b0;--accent-gold: #ffd700;--income-color: #4ECDC4;--expense-color: #FF6B6B;--border-color: #333;--shadow: 0 4px 20px rgba(0, 0, 0, .5);--radius: 12px}body{font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,var(--bg-primary) 0%,#1a1a2e 100%);color:var(--text-primary);line-height:1.6;min-height:100vh;touch-action:manipulation;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}.app{min-height:100vh;display:flex;flex-direction:column}.header{background:linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 100%);padding:2rem 0;box-shadow:0 4px 20px #0000004d;border-bottom:2px solid var(--accent-gold)}h1{text-align:center;font-size:2.5rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--accent-gold) 0%,#ffed4e 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 10px rgba(255,215,0,.3)}.subtitle{text-align:center;color:var(--text-secondary);font-size:1.1rem;margin:0}.container{max-width:1400px;margin:0 auto;padding:2rem;flex:1}.card{background:var(--bg-card);padding:1.5rem;border-radius:var(--radius);margin-bottom:1.5rem;box-shadow:var(--shadow);border:1px solid var(--border-color);transition:all .3s ease}.card:hover{transform:translateY(-2px);box-shadow:0 8px 30px #0009}.card h3{margin-bottom:1rem;color:var(--accent-gold);font-size:1.3rem}.dashboard{margin-bottom:2rem}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-card{background:linear-gradient(135deg,var(--bg-card) 0%,#252525 100%);padding:1.5rem;border-radius:var(--radius);display:flex;align-items:center;gap:1.5rem;box-shadow:var(--shadow);border:1px solid var(--border-color);transition:all .3s ease}.summary-card:hover{transform:translateY(-5px);box-shadow:0 10px 35px #000000b3}.card-icon{font-size:3rem;opacity:.9}.card-content{flex:1}.card-content h3{color:var(--text-secondary);font-size:.9rem;font-weight:500;margin:0 0 .5rem;text-transform:uppercase;letter-spacing:1px}.card-content .amount{font-size:2rem;font-weight:700;margin:0;line-height:1.2}.income-card .amount{color:var(--income-color)}.expense-card .amount{color:var(--expense-color)}.balance-card .amount.positive{color:var(--accent-gold)}.balance-card .amount.negative{color:var(--expense-color)}.transactions-count{display:block;font-size:.85rem;color:var(--text-secondary);margin-top:.3rem}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}.chart-card{min-height:350px}.chart-card.full-width{grid-column:1 / -1}.action-section{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.transaction-form{position:relative}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.success-message{background:var(--income-color);color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.transaction-type-toggle{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem}.toggle-btn{padding:.75rem;border:2px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:1rem;font-weight:600}.toggle-btn:hover{background:var(--bg-hover);transform:translateY(-2px)}.toggle-btn.active.income{background:var(--income-color);border-color:var(--income-color);color:#fff}.toggle-btn.active.expense{background:var(--expense-color);border-color:var(--expense-color);color:#fff}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--text-secondary);font-size:.9rem;font-weight:500}input,select{padding:.75rem;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;transition:all .3s ease}@media screen and (max-width: 768px){input,select,textarea{font-size:16px!important}}input:focus,select:focus{outline:none;border-color:var(--accent-gold);box-shadow:0 0 0 3px #ffd7001a;scroll-margin-top:100px}input.error{border-color:var(--expense-color)}.error-message{color:var(--expense-color);font-size:.85rem;margin-top:.25rem}.preview-amount{color:var(--income-color);font-size:.9rem;font-weight:600;margin-top:.25rem}.submit-btn{width:100%;padding:1rem;border-radius:8px;border:none;background:linear-gradient(135deg,var(--accent-gold) 0%,#ffed4e 100%);color:#000;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ffd7004d;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ffd70066}.submit-btn:active{transform:translateY(0)}.export-card h3{margin-bottom:1rem}.export-buttons{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.export-btn{padding:.75rem 1rem;border-radius:8px;border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;color:#fff}.filter-toggle-btn{text-align:left;display:flex;align-items:center;gap:.5rem}.export-filters{background:var(--bg-secondary);padding:1.5rem;border-radius:10px;margin:1rem 0;border:1px solid var(--border-color)}.export-filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.filter-count{background:rgba(78,205,196,.1);border:1px solid #4ECDC4;padding:1rem;border-radius:8px;text-align:center;color:#4ecdc4;font-size:1.05rem;margin-top:1rem}.export-info-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.json-btn{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.csv-btn{background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%)}.danger-btn{background:linear-gradient(135deg,#ff6b6b 0%,#c92a2a 100%)}.export-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0000004d}.export-info{color:var(--text-secondary);font-size:.9rem;margin:.5rem 0}.filters-card{background:linear-gradient(135deg,#1f1f1f 0%,#2a2a2a 100%)}.filters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.clear-filters-btn{padding:.5rem 1rem;border-radius:6px;border:none;background:var(--expense-color);color:#fff;font-size:.9rem;cursor:pointer;transition:all .3s ease}.clear-filters-btn:hover{transform:scale(1.05)}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.filter-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem;font-weight:500}.transaction-list{overflow:hidden}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.sort-controls{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.sort-controls label{color:var(--text-secondary);font-size:.9rem}.sort-btn{padding:.5rem .75rem;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .3s ease}.sort-btn:hover{background:var(--bg-hover)}.sort-btn.active{background:var(--accent-gold);color:#000;border-color:var(--accent-gold)}.table-container{overflow-x:auto;margin-bottom:1rem}table{width:100%;border-collapse:collapse;font-size:.95rem}thead{background:var(--bg-secondary)}th{padding:1rem;text-align:left;font-weight:600;color:var(--accent-gold);border-bottom:2px solid var(--border-color);text-transform:uppercase;font-size:.85rem;letter-spacing:.5px}td{padding:1rem;border-bottom:1px solid var(--border-color)}.transaction-row{transition:all .3s ease}.transaction-row:hover{background:var(--bg-hover)}.transaction-row.ingreso{border-left:3px solid var(--income-color)}.transaction-row.gasto{border-left:3px solid var(--expense-color)}.date-text{color:var(--text-secondary);font-size:.85rem}.badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600}.badge.ingreso{background:rgba(78,205,196,.2);color:var(--income-color);border:1px solid var(--income-color)}.badge.gasto{background:rgba(255,107,107,.2);color:var(--expense-color);border:1px solid var(--expense-color)}.amount-text{font-weight:700;font-size:1.1rem}.amount-text.ingreso{color:var(--income-color)}.amount-text.gasto{color:var(--expense-color)}.category-badge{display:inline-block;padding:.15rem .5rem;background:var(--bg-secondary);border-radius:4px;font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.category-pill{display:inline-block;padding:.25rem .75rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-radius:20px;font-size:.85rem;font-weight:600}.account-badge{display:inline-block;padding:.25rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;font-size:.85rem;color:var(--text-secondary)}.barber-badge{display:inline-block;padding:.25rem .75rem;background:linear-gradient(135deg,#FFD93D 0%,#F9A825 100%);color:#000;border-radius:6px;font-size:.85rem;font-weight:600}.no-barber{color:var(--text-secondary);font-style:italic}.barber-field{grid-column:span 2}.barber-select{border:2px solid #FFD93D!important;background:linear-gradient(135deg,rgba(255,217,61,.1) 0%,rgba(249,168,37,.1) 100%)}.field-hint{display:block;color:var(--text-secondary);font-size:.8rem;margin-top:.25rem;font-style:italic}.action-buttons{display:flex;gap:.5rem}.btn-edit,.btn-delete,.btn-save,.btn-cancel{padding:.5rem .75rem;border-radius:6px;border:none;cursor:pointer;font-size:1rem;transition:all .3s ease;background:var(--bg-secondary)}.btn-edit:hover{background:#667eea;transform:scale(1.1)}.btn-delete:hover{background:var(--expense-color);transform:scale(1.1)}.btn-save:hover{background:var(--income-color);transform:scale(1.1)}.btn-cancel:hover{background:#999;transform:scale(1.1)}.edit-input{padding:.5rem;border-radius:4px;border:1px solid var(--accent-gold);background:var(--bg-secondary);color:var(--text-primary);width:100%}.list-footer{padding-top:1rem;border-top:1px solid var(--border-color);text-align:center;color:var(--text-secondary);font-size:.9rem}.empty-state{text-align:center;padding:3rem 1rem}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{color:var(--text-primary);margin-bottom:.5rem}.empty-state p{color:var(--text-secondary)}.footer{background:var(--bg-secondary);padding:2rem;text-align:center;color:var(--text-secondary);border-top:1px solid var(--border-color);margin-top:auto}@media (max-width: 1024px){.charts-grid,.action-section{grid-template-columns:1fr}}@media (max-width: 768px){.container{padding:1rem}h1{font-size:2rem}.subtitle{font-size:.95rem}.summary-cards,.form-grid,.filters-grid{grid-template-columns:1fr}.table-container{overflow-x:scroll}table{font-size:.85rem}th,td{padding:.75rem .5rem}.list-header{flex-direction:column;align-items:flex-start}.sort-controls{width:100%;justify-content:flex-start}}@media (max-width: 480px){.card{padding:1rem}.card-content .amount{font-size:1.5rem}.action-buttons,.export-buttons{flex-direction:column}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--accent-gold);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#ffed4e}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.card{animation:fadeIn .5s ease}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.login-background{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0}.login-shape{position:absolute;border-radius:50%;filter:blur(80px);opacity:.3;animation:float 20s infinite ease-in-out}.shape-1{width:400px;height:400px;background:linear-gradient(135deg,#ffd700,#ffed4e);top:-100px;left:-100px;animation-delay:0s}.shape-2{width:500px;height:500px;background:linear-gradient(135deg,#4ECDC4,#44A08D);bottom:-150px;right:-150px;animation-delay:7s}.shape-3{width:300px;height:300px;background:linear-gradient(135deg,#FF6B6B,#c92a2a);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:14s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(50px,-50px) scale(1.1)}66%{transform:translate(-50px,50px) scale(.9)}}.login-card{background:rgba(31,31,31,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,215,0,.2);border-radius:20px;padding:3rem;max-width:450px;width:100%;box-shadow:0 20px 60px #000000b3;position:relative;z-index:1;animation:slideUp .6s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.login-logo{font-size:4rem;margin-bottom:1rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.login-title{font-size:2rem;background:linear-gradient(135deg,var(--accent-gold) 0%,#ffed4e 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.5rem}.login-subtitle{color:var(--text-secondary);font-size:1rem}.login-form{margin-bottom:1.5rem}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;font-size:1.2rem;z-index:1}.input-wrapper input{padding-left:3rem;width:100%}.toggle-password{position:absolute;right:1rem;background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.5rem;color:var(--text-secondary);transition:all .3s ease}.toggle-password:hover{color:var(--accent-gold);transform:scale(1.1)}.error-alert{background:rgba(255,107,107,.2);border:1px solid var(--expense-color);color:var(--expense-color);padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;animation:shake .5s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.login-button{width:100%;padding:1rem;border-radius:10px;border:none;background:linear-gradient(135deg,var(--accent-gold) 0%,#ffed4e 100%);color:#000;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ffd7004d;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ffd70080}.login-button:disabled{opacity:.7;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid #000;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-divider{text-align:center;margin:2rem 0 1.5rem;position:relative}.login-divider:before,.login-divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--border-color)}.login-divider:before{left:0}.login-divider:after{right:0}.login-divider span{background:var(--bg-card);padding:0 1rem;color:var(--text-secondary);font-size:.9rem}.demo-accounts{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.demo-button{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .3s ease;text-align:left}.demo-button:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent-gold);transform:translate(5px)}.demo-button:disabled{opacity:.5;cursor:not-allowed}.demo-button.admin{border-left:3px solid #4ECDC4}.demo-button.user{border-left:3px solid #FFD93D}.demo-icon{font-size:2rem}.demo-info{flex:1}.demo-title{font-weight:600;margin-bottom:.25rem}.demo-credentials{font-size:.85rem;color:var(--text-secondary)}.login-footer{text-align:center;color:var(--text-secondary);font-size:.9rem}.login-footer p{margin:.5rem 0}.version{font-size:.8rem;opacity:.7}.header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.user-menu{display:flex;align-items:center;gap:1rem;background:rgba(31,31,31,.8);padding:.75rem 1.25rem;border-radius:50px;border:1px solid var(--border-color)}.user-info{display:flex;align-items:center;gap:.75rem}.user-avatar{width:45px;height:45px;background:linear-gradient(135deg,var(--accent-gold) 0%,#ffed4e 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.user-details{text-align:left}.user-name{font-weight:600;font-size:.95rem;color:var(--text-primary)}.user-role{font-size:.8rem;color:var(--text-secondary)}.logout-button{padding:.5rem 1rem;border-radius:20px;border:1px solid var(--expense-color);background:rgba(255,107,107,.1);color:var(--expense-color);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.logout-button:hover{background:var(--expense-color);color:#fff;transform:scale(1.05)}@media (max-width: 768px){.login-card{padding:2rem 1.5rem}.login-logo{font-size:3rem}.login-title{font-size:1.5rem}.shape-1,.shape-2,.shape-3{width:200px;height:200px}.user-menu{width:100%;justify-content:space-between}.header-content{text-align:center}.header-content>div:first-child{width:100%}}
