:root{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #e8e8e8;--bg-card: #ffffff;--bg-input: #ffffff;--bg-hover: #f0f0f0;--bg-modal-overlay: rgba(0, 0, 0, .5);--text-primary: #212121;--text-secondary: #666666;--text-muted: #999999;--text-inverse: #ffffff;--border-color: #e0e0e0;--border-light: #f0f0f0;--shadow-sm: 0 1px 3px rgba(0,0,0,.12);--shadow-md: 0 4px 6px rgba(0,0,0,.1);--shadow-lg: 0 10px 25px rgba(0,0,0,.15);--color-success: #4CAF50;--color-danger: #f44336;--color-warning: #ff9800;--color-info: #2196F3;--color-primary: #1976d2;--color-primary-light: #42a5f5;--revenue-color: #4CAF50;--expense-color: #f44336;--revenue-bg: #e8f5e9;--expense-bg: #ffebee;--table-header-bg: #f5f5f5;--table-row-hover: #f5f5f5;--table-stripe: #fafafa}[data-theme=dark]{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-tertiary: #0f3460;--bg-card: #1e1e3a;--bg-input: #2a2a4a;--bg-hover: #2a2a4a;--bg-modal-overlay: rgba(0, 0, 0, .7);--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-muted: #808080;--text-inverse: #1a1a2e;--border-color: #3a3a5a;--border-light: #2a2a4a;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 6px rgba(0,0,0,.3);--shadow-lg: 0 10px 25px rgba(0,0,0,.4);--color-success: #66bb6a;--color-danger: #ef5350;--color-warning: #ffa726;--color-info: #42a5f5;--color-primary: #42a5f5;--color-primary-light: #64b5f6;--revenue-color: #66bb6a;--expense-color: #ef5350;--revenue-bg: #1b3a1b;--expense-bg: #3a1b1b;--table-header-bg: #1e1e3a;--table-row-hover: #2a2a4a;--table-stripe: #1e1e3a}@media print{.layout-header,.layout-footer,.breadcrumbs,.print-button,.modal-overlay,.stats-items,.table-toolbar,.filters-panel,.column-selector,.pagination-controls,.action-buttons,.search-bar,.toolbar-btn,nav,footer,.no-print{display:none!important}.layout-content,.main-content,.app-content,.content-area,.accounting-table-container{margin:0!important;padding:0!important;width:100%!important;max-width:100%!important}.layout{display:block!important}body{background:#fff!important;color:#000!important;font-size:10pt!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}table{width:100%!important;border-collapse:collapse!important;font-size:9pt!important}th,td{border:1px solid #ccc!important;padding:4px 6px!important;background:#fff!important;color:#000!important}th{background:#f0f0f0!important;font-weight:700!important}tr{page-break-inside:avoid}.print-header{display:block!important;text-align:center;margin-bottom:1rem;border-bottom:2px solid #333;padding-bottom:.5rem}.print-header h1{font-size:14pt;margin:0}.print-header .print-date{font-size:9pt;color:#666}.revenue{color:#2e7d32!important}.expense{color:#c62828!important}.positive{color:#2e7d32!important}.negative{color:#c62828!important}.col-actions,.action-cell,.sticky-col,.deleted-entry{display:none!important}.table-total-row{border-top:2px solid #333!important;font-weight:700!important;font-size:10pt!important;padding:8px!important;display:flex!important;justify-content:space-between!important}.table-wrapper,.table-wrapper-with-total{overflow:visible!important;max-height:none!important}@page{margin:1.5cm;@bottom-center{content:"Page " counter(page) " / " counter(pages)}}}.print-header{display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:root{--primary-color: #2c3e50;--secondary-color: #34495e;--accent-color: #3498db;--header-bg: var(--primary-color);--btn-primary-bg: var(--accent-color);--btn-primary-hover: color-mix(in srgb, var(--accent-color) 85%, black);--link-color: var(--accent-color);--success-color: #27ae60;--warning-color: #f39c12;--danger-color: #e74c3c;--info-color: #3498db;--gray-100: #f8f9fa;--gray-200: #e9ecef;--gray-300: #dee2e6;--gray-400: #ced4da;--gray-500: #adb5bd;--gray-600: #6c757d;--gray-700: #495057;--gray-800: #343a40;--gray-900: #212529;--tva-color: #8e44ad;--tva-bg: #f5eef8}html,body,#root{height:100%;height:100dvh;margin:0;padding:0;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);background:var(--primary-color)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.btn-themed{background-color:var(--accent-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:background-color .2s}.btn-themed:hover{background-color:var(--btn-primary-hover)}.link-themed{color:var(--link-color);text-decoration:none}.link-themed:hover{text-decoration:underline}.header-themed{background-color:var(--header-bg);color:#fff}.tva-column{background-color:var(--tva-bg)}.tva-header{background-color:var(--tva-color);color:#fff}.tva-value{color:var(--tva-color);font-weight:500}@media(max-width:768px){.hide-on-mobile{display:none!important}}@media(min-width:769px){.hide-on-desktop{display:none!important}}.global-search{position:relative;width:100%;max-width:400px}.search-input-container{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;font-size:14px;pointer-events:none;opacity:.6}.search-input{width:100%;padding:8px 36px;border:2px solid #e5e7eb;border-radius:24px;font-size:14px;background:#f9fafb;transition:all .2s ease}.search-input:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.search-input::placeholder{color:#9ca3af}.search-loading{position:absolute;right:36px;color:#6b7280;font-size:12px;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.search-clear{position:absolute;right:8px;width:24px;height:24px;border:none;background:#e5e7eb;border-radius:50%;cursor:pointer;font-size:16px;color:#6b7280;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.search-clear:hover{background:#d1d5db;color:#374151}.search-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;border:1px solid #e5e7eb;max-height:400px;overflow-y:auto;z-index:1000}.search-no-results,.search-hint{padding:16px;text-align:center;color:#6b7280;font-size:14px}.search-section{padding:8px 0}.search-section:not(:last-child){border-bottom:1px solid #f3f4f6}.search-section-header{padding:4px 16px;font-size:11px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.search-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .15s ease}.search-item:hover,.search-item.selected{background:#f3f4f6}.search-item-icon{font-size:18px;width:24px;text-align:center}.search-item-content{flex:1;min-width:0}.search-item-title{font-size:14px;font-weight:500;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-item-subtitle{font-size:12px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-item-badge{font-size:11px;padding:2px 8px;background:#dbeafe;color:#1d4ed8;border-radius:10px;font-weight:500}.search-item-status{font-size:11px;padding:2px 8px;border-radius:10px;font-weight:500}.search-item-status.active{background:#d1fae5;color:#065f46}.search-item-status.inactive{background:#fee2e2;color:#991b1b}@media(max-width:768px){.global-search{max-width:none}.search-dropdown{position:fixed;top:60px;left:8px;right:8px;max-height:calc(100vh - 80px)}}.breadcrumbs{padding:.5rem 1rem .5rem 6.5rem;font-size:.8rem;color:#666}.breadcrumbs ol{display:flex;flex-wrap:wrap;align-items:center;list-style:none;margin:0;padding:0;gap:.25rem}.breadcrumbs li{display:flex;align-items:center;gap:.25rem}.breadcrumbs .breadcrumb-link{color:#1976d2;text-decoration:none;background:none;border:none;padding:0;font:inherit;cursor:pointer}.breadcrumbs .breadcrumb-link:hover{text-decoration:underline}.breadcrumbs .breadcrumb-category{color:#888}.breadcrumbs .active span{color:#333;font-weight:500}.breadcrumb-separator{color:#ccc;margin:0 .15rem}[data-theme=dark] .breadcrumbs{color:#999}[data-theme=dark] .breadcrumbs .breadcrumb-link{color:#64b5f6}[data-theme=dark] .breadcrumbs .breadcrumb-category{color:#777}[data-theme=dark] .breadcrumbs .active span{color:#e0e0e0}[data-theme=dark] .breadcrumb-separator{color:#555}@media(max-width:768px){.breadcrumbs{padding:.35rem .75rem .35rem 5rem;font-size:.75rem}}@keyframes skeleton-pulse{0%{opacity:.6}50%{opacity:.3}to{opacity:.6}}.skeleton-line{background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:4px;margin-bottom:.5rem}.skeleton-circle{background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:50%}.skeleton-card{padding:1rem;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:1rem}.skeleton-table{width:100%}.skeleton-table-header{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem;padding:.75rem 1rem;background:#f5f5f5;border-radius:4px 4px 0 0}.skeleton-table-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem;padding:.75rem 1rem;border-bottom:1px solid #f0f0f0}.skeleton-stats{display:flex;gap:1rem;margin-bottom:1rem}.skeleton-stat-card{flex:1;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:8px}[data-theme=dark] .skeleton-line,[data-theme=dark] .skeleton-circle{background:linear-gradient(90deg,#2a2a4a 25%,#3a3a5a,#2a2a4a 75%);background-size:200% 100%}[data-theme=dark] .skeleton-card{border-color:#3a3a5a}[data-theme=dark] .skeleton-table-header{background:#1e1e3a}[data-theme=dark] .skeleton-table-row{border-bottom-color:#2a2a4a}[data-theme=dark] .skeleton-stat-card{border-color:#3a3a5a}.layout{height:100%;display:flex;flex-direction:column;background-color:var(--bg-secondary);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.layout-header{background:linear-gradient(135deg,#2c3e50,#3498db);color:#fff;display:flex;flex-direction:column;box-shadow:0 2px 10px #0000001a;z-index:100;overflow:visible;flex-shrink:0;position:relative}.header-top{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;min-height:70px;gap:1rem}.header-brand{display:flex;align-items:center;gap:.75rem;min-width:180px;position:relative;z-index:200;flex-shrink:0}.brand-logo{height:106px;width:auto;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.4));transition:transform .3s ease;position:absolute;top:-36px;left:0;z-index:1000;pointer-events:auto}.brand-logo:hover{transform:scale(1.08)}.brand-title{font-size:1.5rem;font-weight:700;margin:0;line-height:1.2}.brand-subtitle{font-size:.85rem;opacity:.9;margin-top:-2px}.header-title{font-size:1.1rem;font-weight:600;margin:0;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.3);white-space:nowrap}.nav-desktop{display:flex;gap:.3rem;justify-content:center;padding:0;background:transparent;flex:1}.nav-desktop.nav-inline{flex-wrap:nowrap;max-width:none}.nav-item{display:flex;align-items:center;gap:.35rem;padding:.5rem .75rem;background:#ffffff1a;border:none;border-radius:6px;color:#fff;cursor:pointer;transition:all .2s ease;font-size:.8rem;white-space:nowrap}.nav-item:hover{background:#fff3}.nav-item.active{background:#ffffff59;box-shadow:0 2px 6px #0003;font-weight:600}.nav-icon{font-size:.95rem;filter:drop-shadow(0 0 3px rgba(255,255,255,.9))}.nav-label{font-weight:500;font-size:.8rem}.header-search{flex:1;max-width:350px;margin:0 1rem}@media(max-width:1024px){.header-search{display:none}}.header-actions{display:flex;align-items:center;gap:1rem}.user-info{display:flex;flex-direction:column;align-items:flex-end;font-size:.9rem;text-shadow:0 1px 3px rgba(0,0,0,.3)}.user-name{font-weight:700;font-size:.95rem;color:#fff}.association-name{font-size:.75rem;opacity:.85;background:#ffffff26;padding:1px 8px;border-radius:10px;margin-bottom:2px}.user-role{font-size:.8rem;color:#e8f4f8;font-weight:500}.logout-btn{padding:.5rem 1rem;background:#e74c3ccc;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;transition:background .3s ease}.logout-btn:hover{background:#e74c3c}.mobile-menu-toggle{display:none;background:#ffffff1a;border:none;border-radius:8px;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;margin-left:.5rem;min-width:44px;min-height:44px;transition:background .2s}.mobile-menu-toggle:hover{background:#fff3}.mobile-menu-toggle:active{background:#ffffff4d}.nav-mobile{background:#34495e;display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;box-shadow:0 4px 15px #0003;z-index:99;max-height:calc(100vh - 60px);overflow-y:auto}.nav-item-mobile{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;min-height:40px;background:transparent;border:none;color:#fff;cursor:pointer;transition:background .3s ease;text-align:left;border-bottom:1px solid rgba(255,255,255,.1);font-size:1rem}.nav-item-mobile .nav-icon{font-size:1rem;min-width:20px}.nav-item-mobile .nav-label{font-size:.9rem}.nav-item-mobile:hover{background:#ffffff1a}.nav-item-mobile.active{background:#3498db4d;border-left:4px solid #3498db}.nav-item-mobile:active{background:#3498db80}.layout-content{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0}.content-wrapper{padding:.5rem}.layout-footer{display:none}.footer-content{display:flex;justify-content:space-between;align-items:center;width:100%}.footer-user{opacity:.8}@media(max-width:1024px){.header-top{padding:.5rem .75rem}.nav-desktop{gap:.25rem}.nav-item{padding:.4rem .5rem;font-size:.75rem}.nav-desktop .nav-label{display:none}.nav-desktop .nav-icon{font-size:1.3rem}.nav-mobile .nav-label{display:inline}.brand-logo{height:120px;top:-15px}.header-title{font-size:.95rem}.content-wrapper{padding:.75rem}}@media(max-width:768px){.header-brand{min-width:auto}.brand-logo{height:100px;top:-10px}.header-title{font-size:.85rem}.brand-subtitle,.nav-desktop{display:none}.mobile-menu-toggle{display:block}.user-info{display:none}.logout-btn{padding:.4rem .8rem;font-size:.8rem}.content-wrapper{padding:.5rem}.layout-footer{display:none}}@media(max-width:480px){.header-top{padding:.4rem .5rem}.brand-logo{height:80px;top:-31px}.header-title{font-size:.75rem}.content-wrapper{padding:.75rem .5rem}.nav-item-mobile{padding:.5rem .75rem;min-height:36px;gap:.5rem}.nav-item-mobile .nav-icon{font-size:.9rem}.nav-item-mobile .nav-label{font-size:.8rem}.mobile-menu-toggle{font-size:1.3rem;padding:.3rem}}@media(min-width:1200px){.header-top{padding:.6rem 1.5rem}.brand-logo{height:110px;top:-40px}.header-title{font-size:1.2rem}.content-wrapper{padding:.5rem 1rem;max-width:100%;margin:0 auto}.nav-desktop{gap:.5rem}.nav-item{padding:.55rem .9rem;font-size:.85rem}}@media(prefers-reduced-motion:no-preference){.nav-mobile{animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}}.user-menu-container{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;transition:all .2s ease;color:#fff}.user-menu-trigger:hover{background:#fff3;border-color:#ffffff4d}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem;color:#fff;text-transform:uppercase;flex-shrink:0}.user-info-compact{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}.user-name-compact{font-weight:600;font-size:.85rem;color:#fff}.user-role-compact{font-size:.7rem;color:#ffffffbf}.dropdown-arrow{transition:transform .2s ease;opacity:.8}.dropdown-arrow.open{transform:rotate(180deg)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-lg);z-index:1000;overflow:hidden;animation:dropdownSlide .2s ease}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.dropdown-user-info{display:flex;flex-direction:column;gap:.25rem}.dropdown-user-name{font-weight:600;font-size:.95rem;color:var(--text-primary)}.dropdown-user-email{font-size:.8rem;color:var(--text-secondary)}.dropdown-association{font-size:.75rem;color:#3b82f6;background:#eff6ff;padding:.25rem .5rem;border-radius:4px;margin-top:.25rem;display:inline-block}.dropdown-divider{height:1px;background:var(--border-color);margin:0}.dropdown-section{padding:.5rem}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;background:none;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;color:var(--text-primary);transition:all .15s ease;text-align:left}.dropdown-item:hover{background:var(--bg-hover)}.dropdown-item svg{flex-shrink:0;color:var(--text-secondary)}.dropdown-item:hover svg{color:var(--text-primary)}.dropdown-item span{flex:1}.dropdown-item-danger{color:#dc2626}.dropdown-item-danger:hover{background:#fef2f2}.dropdown-item-danger svg{color:#dc2626}.badge-active{font-size:.65rem;background:#10b981;color:#fff;padding:.2rem .5rem;border-radius:10px;font-weight:600;text-transform:uppercase}.hamburger{display:block;width:22px;height:2px;background:#fff;position:relative;transition:background .2s ease}.hamburger:before,.hamburger:after{content:"";position:absolute;left:0;width:100%;height:2px;background:#fff;transition:all .3s ease}.hamburger:before{top:-7px}.hamburger:after{bottom:-7px}.hamburger.open{background:transparent}.hamburger.open:before{top:0;transform:rotate(45deg)}.hamburger.open:after{bottom:0;transform:rotate(-45deg)}@media(max-width:768px){.user-info-compact{display:none}.user-menu-trigger{padding:.4rem}.user-avatar{width:32px;height:32px;font-size:.75rem}.dropdown-arrow{display:none}.user-dropdown{position:fixed;top:auto;right:.5rem;left:.5rem;width:auto;max-width:300px;margin-left:auto}}@media(max-width:400px){.user-dropdown{right:.25rem;left:.25rem;max-width:none}.dropdown-header{padding:.75rem}.dropdown-user-name{font-size:.9rem}.dropdown-user-email{font-size:.75rem;word-break:break-all}.dropdown-association{font-size:.7rem}.dropdown-item{padding:.6rem;font-size:.85rem}.dropdown-item svg{width:16px;height:16px}}.footer-separator{margin:0 .5rem;opacity:.5}@media(max-width:900px)and (orientation:landscape){.layout{width:100vw;max-width:100vw;overflow-x:hidden}.header-top{min-height:28px;padding:.1rem .4rem}.brand-logo{height:32px;top:0}.nav-desktop{display:none}.mobile-menu-toggle{display:block;font-size:1rem;padding:.1rem;min-width:28px;min-height:28px}.layout-footer{display:none!important}.user-info{display:none}.logout-btn{padding:.15rem .3rem;font-size:.6rem}.layout-content{flex:1;overflow-y:auto}.content-wrapper{padding:.15rem}.nav-mobile{max-height:calc(100vh - 40px)}.nav-item-mobile{padding:.35rem .6rem;min-height:30px;gap:.4rem}.nav-item-mobile .nav-icon{font-size:.8rem;min-width:16px}.nav-item-mobile .nav-label{font-size:.75rem}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-card{background:#fff;border-radius:15px;padding:2rem;box-shadow:0 20px 40px #0000001a;max-width:900px;width:100%;max-height:90vh;overflow-y:auto}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:80px;height:80px;margin-bottom:1rem;border-radius:50%;object-fit:cover}.login-header h1{color:#333;margin:.5rem 0;font-size:1.8rem;font-weight:600}.login-header p{color:#666;margin:0;font-size:1rem}.login-form{margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group input{width:100%;padding:.75rem 1rem;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;transition:border-color .3s ease;box-sizing:border-box}.form-group input:focus{border-color:#667eea}.form-group input:focus:not(:focus-visible){outline:none}.form-group input:focus-visible{outline:3px solid var(--color-primary, #667eea);outline-offset:2px}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:6px;margin-bottom:1rem;border:1px solid #fcc;text-align:center}.login-btn{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:1.5rem}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.quick-login-section{border-top:1px solid #e1e5e9;padding-top:1.5rem}.quick-login-section h3{color:#333;margin-bottom:1.5rem;text-align:center;font-size:1.2rem}.quick-login-group{margin-bottom:1.5rem}.quick-login-group h4{color:#555;margin-bottom:.75rem;font-size:1rem;display:flex;align-items:center;gap:.5rem}.quick-login-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.5rem}.quick-login-btn{padding:.5rem .75rem;border:none;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s ease;font-family:monospace}.quick-login-btn:hover:not(:disabled){transform:translateY(-1px)}.quick-login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.quick-login-btn.admin{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff}.quick-login-btn.admin:hover:not(:disabled){box-shadow:0 5px 15px #ff6b6b4d}.quick-login-btn.budgeter{background:linear-gradient(135deg,#4ecdc4,#44a08d);color:#fff}.quick-login-btn.budgeter:hover:not(:disabled){box-shadow:0 5px 15px #4ecdc44d}.quick-login-btn.spender{background:linear-gradient(135deg,#45b7d1,#2980b9);color:#fff}.quick-login-btn.spender:hover:not(:disabled){box-shadow:0 5px 15px #45b7d14d}.login-loading{display:flex;align-items:center;justify-content:center;height:200px;font-size:1.2rem;color:#fff}@media(max-width:768px){.login-card{margin:1rem;padding:1.5rem}.quick-login-buttons{grid-template-columns:1fr}.login-header h1{font-size:1.5rem}}.login-box{background:#fff;border-radius:15px;padding:2rem;box-shadow:0 20px 40px #0003;max-width:400px;width:100%}.login-box h1{text-align:center;color:#667eea;margin-bottom:.5rem}.login-box h2{text-align:center;color:#333;margin-bottom:1.5rem;font-weight:500}.login-box button[type=submit]{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.login-box button[type=submit]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.login-box button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.auto-login-section{margin-top:1.5rem;text-align:center}.auto-login-section hr{border:none;border-top:1px solid #e1e5e9;margin-bottom:1rem}.auto-login-section p{color:#666;font-size:.9rem;margin-bottom:1rem}.auto-login-btn{width:100%;background:#f3f4f6;color:#374151;border:2px solid #e5e7eb;padding:.75rem;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s ease;margin-bottom:1rem}.auto-login-btn:hover:not(:disabled){background:#e5e7eb}.direct-login-buttons{display:flex;gap:.5rem}.direct-login-btn{flex:1;padding:.5rem;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease}.direct-login-btn.admin{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.direct-login-btn.budgeter{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.direct-login-btn.spender{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.direct-login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.verification-info{text-align:center;margin-bottom:1.5rem;padding:1rem;background:#eff6ff;border-radius:12px}.verification-icon{font-size:3rem;margin-bottom:.5rem}.verification-info p{color:#1e40af;margin:.25rem 0}.verification-hint{font-size:.85rem;color:#6b7280!important}.verification-input{text-align:center;font-size:1.8rem!important;letter-spacing:.5rem;font-weight:600}.verification-actions{display:flex;gap:.75rem;margin-top:1rem}.resend-btn{flex:1;background:#f3f4f6;color:#374151;border:2px solid #e5e7eb;padding:.6rem;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .2s ease}.resend-btn:hover:not(:disabled){background:#e5e7eb}.resend-btn:disabled{opacity:.5;cursor:not-allowed}.cancel-btn{flex:1;background:transparent;color:#6b7280;border:2px solid #e5e7eb;padding:.6rem;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .2s ease}.cancel-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: hsl(6, 78%, 57%);--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-container-width: fit-content;--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-padding: 14px;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-toast-shadow: 0px 4px 12px rgba(0, 0, 0, .1);--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y: 0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 auto;align-items:center;word-break:break-word}@media only screen and (max-width:480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width: 100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.App{height:100%}.skip-link{position:absolute;top:-100%;left:0;background:#1a1a2e;color:#fff;padding:.75rem 1.5rem;z-index:10000;font-size:1rem;text-decoration:none;border-radius:0 0 8px}.skip-link:focus{top:0}.App-logo{height:40vmin;pointer-events:none}@media(prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin infinite 20s linear}}.App-header{background-color:#282c34;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:calc(10px + 2vmin);color:#fff}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
