body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid #667eea;outline-offset:2px}:root{--primary:#667eea;--primary-dark:#4c63d2;--secondary:#764ba2;--success:#22c55e;--danger:#ef4444;--warning:#f59e0b;--muted:#b8bfcc;--bg:#0f172a;--card:#111827;--text:#111827}body,html{background:linear-gradient(180deg,#f8fafc,#eef2ff);color:#111827;color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;min-height:100%}a,button{transition:all .2s ease-in-out}@media (prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto!important;transition:none!important}}.header{-webkit-backdrop-filter:none;backdrop-filter:none;background:#0000;position:-webkit-sticky;position:sticky;top:0;transition:background-color .3s ease,box-shadow .3s ease;will-change:background-color,box-shadow;z-index:1000}.header-container{flex-wrap:nowrap;height:88px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 20px;transition:height .25s ease}.header-container,.logo{align-items:center;display:flex}.logo{flex:1 1 auto;justify-content:flex-start;min-width:0;text-decoration:none}.header.at-top .header-title{color:#111827;text-shadow:none}.header.scrolled{-webkit-backdrop-filter:saturate(160%) blur(10px);backdrop-filter:saturate(160%) blur(10px);background:linear-gradient(180deg,#111827e0,#111827d1);box-shadow:0 8px 24px #0003}.header.scrolled .header-container{height:60px}.header.scrolled .header-title{color:#fff;text-shadow:0 2px 4px #0000004d}.header-title{font-size:1.5rem;font-weight:700;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav{flex:0 0 auto;margin-left:auto}.nav,.nav-authenticated{align-items:center;display:flex}.nav-authenticated{gap:24px}.nav-link{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;color:#fff;font-weight:500;padding:8px 16px;text-decoration:none;transition:all .3s ease}.nav-link:hover{background:#ffffff26;text-shadow:0 2px 4px #0003;transform:translateY(-1px)}.header.at-top .nav-link{-webkit-backdrop-filter:none;backdrop-filter:none;color:#111827}.header.at-top .nav-link:hover{background:#0000000f}.header.scrolled .nav-link{color:#fff}.user-dropdown{position:relative}.user-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #fff3;border-radius:25px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:10px;min-width:120px;padding:8px 16px;transition:all .3s ease}.user-button:hover{background:#fff3;border-color:#fff6;box-shadow:0 4px 12px #0003;transform:translateY(-1px)}.header.at-top .user-button{-webkit-backdrop-filter:none;backdrop-filter:none;background:#0000000a;border-color:#00000014;color:#111827}.header.at-top .user-button:hover{background:#00000014;border-color:#0000001f}.header.at-top .user-name{color:#111827}.user-avatar{align-items:center;background:linear-gradient(180deg,#474747 23%,#3a3a3a 95%);border-radius:50%;box-shadow:0 2px 8px #0003;color:#fff;display:flex;font-size:14px;font-weight:700;height:32px;justify-content:center;width:32px}.user-status-dot{background:#22c55e;border:2px solid #fffc;border-radius:999px;height:8px;margin-left:2px;width:8px}.user-name{color:#fff;flex:1 1;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-weight:750;line-height:1.6;text-align:left}.dropdown-arrow{opacity:.8;transition:transform .3s ease}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{animation:fadeInDown .25s ease;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;min-width:200px;overflow:hidden;padding:6px 0;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}.dropdown-menu:before{background:#fff;box-shadow:-2px -2px 4px #0000000a;content:"";height:12px;position:absolute;right:16px;top:-6px;transform:rotate(45deg);width:12px}.dropdown-header{color:#6b7280;font-size:12px;font-weight:700;letter-spacing:.06em;padding:10px 16px 6px;text-transform:uppercase}.dropdown-separator{background:#f0f2f5;border-radius:1px;height:1px;margin:6px 8px}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{align-items:center;background:none;border:none;color:#333;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 16px;text-align:left;text-decoration:none;transition:background-color .2s ease;width:100%}.dropdown-item:hover{background-color:#f8f9fa}.dropdown-item:first-child:hover{background:linear-gradient(180deg,#474747 23%,#3a3a3a 95%);color:#fff}.logout-item:hover{background-color:#fee;color:#dc3545}.dropdown-icon{font-size:16px;text-align:center;width:20px}.nav-guest{align-items:center;display:flex;gap:12px}.btn{border:2px solid #0000}.btn-outline{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-color:#ffffff4d;color:#fff}.btn-outline:hover{background:#ffffff1a;border-color:#ffffff80}.btn-primary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-color:#ffffff4d}.btn-primary:hover{background:#ffffff4d;box-shadow:0 4px 12px #0003}.header .btn-primary{background:#fff;border-color:#000;color:#111827}.header .btn-primary:hover{background:#ff9898;border-color:#d97706;box-shadow:0 6px 14px #00000040;transform:translateY(-1px)}.header .btn-outline{background:#fff;border-color:#fff;color:#1f2937}.header .btn-outline:hover{background:#f3f4f6;border-color:#f3f4f6;box-shadow:0 6px 14px #0003;transform:translateY(-1px)}.header .btn:focus-visible{outline:2px solid #fff;outline-offset:2px}@media (max-width:768px){.header-container{height:72px;padding:0 16px}.header.scrolled .header-container{height:56px}.header .header-container.container-fluid{padding-left:8px!important;padding-right:8px!important}.header .logo{justify-content:flex-start!important;min-width:0}.header .nav{flex:0 0 auto;margin-left:auto!important}.logo{justify-content:flex-start;min-width:0}.header-title{font-size:1.25rem}.nav-authenticated{gap:12px}.nav-link{font-size:13px;padding:6px 12px}.user-button{min-width:0;padding:6px 12px}.user-name{display:none}.dropdown-menu{min-width:160px;right:-10px}}@media (max-width:480px){.nav-link{display:none}.header-title{font-size:1.1rem}.user-button{min-width:0}.dropdown-menu{left:50%;right:auto;transform:translateX(-50%)}}body{background-color:#f8f9fa;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}.container{margin:0 auto;max-width:1200px;padding:0 20px}.app-layout{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;padding:20px 0}.btn{display:inline-block;font-size:1rem;font-weight:500;line-height:1;padding:.75rem 1.5rem;text-align:center;transition:all .3s ease}.loading-container{min-height:200px;padding:2rem}.loading-container-fullscreen{align-items:center;background-color:#f8f9fae6;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:9999}.loading-spinner{align-items:center;display:flex;flex-direction:column;gap:1rem}.spinner{border:4px solid #e3e3e3;border-top-color:#007bff;height:40px;width:40px}.loading-message{color:#666;font-size:1rem;margin:0}.btn:disabled .loading-text:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;content:"";display:inline-block;height:12px;margin-left:8px;width:12px}.btn-primary{background-color:#007bff}.btn-primary:hover{background-color:#0056b3;transform:translateY(-2px)}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#545b62}.btn-outline{background-color:initial;border:2px solid #007bff;color:#007bff}.btn-outline:hover{background-color:#007bff;color:#fff}.btn-full{width:100%}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.home-container{margin:0 auto;max-width:1200px;padding:2rem}.hero-features{margin:0 auto 1.5rem;max-width:800px;text-align:left}.hero-features ul{list-style:none;padding:0}.hero-features li{margin:.4rem 0;opacity:.95}.hero{background:linear-gradient(180deg,#474747 23%,#3a3a3a 95%);border-radius:16px;box-shadow:0 10px 30px #6366f140;color:#fff;margin-bottom:4rem;padding:4rem 0;text-align:center}.hero h1{font-size:3rem;margin-bottom:1rem}.hero p{font-size:1.25rem;margin-bottom:2rem;opacity:.9}.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.features{text-align:center}.features h2{color:#333;font-size:2.5rem;margin-bottom:3rem}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:3rem}.feature-card{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2rem;transition:transform .3s ease}.feature-card:hover{transform:translateY(-5px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#333;font-size:1.5rem;margin-bottom:1rem}.feature-card p{color:#666;line-height:1.6}.auth-container{align-items:center;display:flex;justify-content:center;min-height:80vh;padding:2rem}.auth-card{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;max-width:450px;padding:2.5rem;width:100%}.auth-header{margin-bottom:2rem;text-align:center}.auth-header h2{color:#333;font-size:2rem;margin-bottom:.5rem}.auth-header p{color:#666}.auth-form,.form-group{margin-bottom:1.5rem}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:.5rem}.form-input{border:2px solid #e1e5e9;border-radius:6px;font-size:1rem;padding:.75rem;transition:border-color .3s ease;width:100%}.form-input:focus{border-color:#007bff;outline:none}.form-input.error{border-color:#dc3545}.password-input-container{position:relative}.password-toggle{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem;position:absolute;right:.75rem;top:50%;transform:translateY(-50%)}.error-message{color:#dc3545;display:block;font-size:.875rem;margin-top:.5rem}.auth-footer{border-top:1px solid #e1e5e9;padding-top:1rem;text-align:center}.auth-link{color:#007bff;font-weight:500;text-decoration:none}.auth-link:hover{text-decoration:underline}.alert{border-radius:6px;font-weight:500;margin-bottom:1.5rem;padding:1rem}.alert-error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.alert-success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.dashboard-container{margin:0 auto;max-width:1200px;padding:2rem}.dashboard-header{margin-bottom:3rem;text-align:center}.dashboard-header h1{color:#333;font-size:2.5rem;margin-bottom:.5rem}.dashboard-header p{color:#666;font-size:1.25rem}.dashboard-content{grid-gap:2rem;display:grid;gap:2rem}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:3rem}.stat-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;display:flex;gap:1.5rem;padding:2rem;transition:transform .3s ease}.stat-card:hover{transform:translateY(-3px)}.stat-icon{font-size:3rem}.stat-info h3{color:#666;font-size:1rem;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.stat-info p{color:#333;font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.stat-meta{color:#999;font-size:.875rem}.role-badge{border-radius:20px;display:inline-block;font-size:.875rem;font-weight:500;padding:.25rem .75rem}.role-admin{background-color:#28a745;color:#fff}.role-user{background-color:#007bff;color:#fff}.dashboard-actions{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.action-card{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2rem}.action-card h3{color:#333;font-size:1.5rem;margin-bottom:1.5rem}.action-buttons{flex-direction:column;gap:1rem}.recent-activity{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2rem}.recent-activity h3{color:#333;font-size:1.5rem;margin-bottom:1.5rem}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{background-color:#f8f9fa;border-radius:8px;gap:1rem;padding:1rem}.activity-icon,.activity-item{align-items:center;display:flex}.activity-icon{background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000001a;font-size:1.5rem;height:40px;justify-content:center;width:40px}.activity-content p{color:#333;font-weight:500;margin-bottom:.25rem}.activity-time{color:#666;font-size:.875rem}.footer{background:linear-gradient(180deg,#474747 23%,#3a3a3a 95%);border-top:1px solid #ffffff0f;color:#e9ecef;margin-top:auto;padding:32px 0 18px}.footer-container{margin:0 auto;max-width:1100px;padding:0 20px}.footer-grid{grid-gap:20px;align-items:center;display:grid;gap:20px;grid-template-columns:1.2fr 1fr 1.2fr}.footer-brand .brand-title{color:#fff;font-size:18px;font-weight:700}.footer-brand .brand-tag{color:#9aa4b2;font-size:13px;margin-top:4px}.footer-links{display:flex;gap:16px;justify-content:center}.footer-links a{border-radius:8px;color:#cfd6df;font-size:14px;padding:6px 10px;text-decoration:none;transition:color .2s ease,background-color .2s ease}.footer-links a:hover{background:#ffffff0f;color:#fff}.footer-meta{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.footer-social{display:flex;gap:10px}.footer-social a{align-items:center;background:#ffffff0f;border-radius:10px;color:#fff;display:inline-flex;height:34px;justify-content:center;text-decoration:none;transition:transform .15s ease,background-color .2s ease;width:34px}.footer-social a:hover{background:#ffffff1f;transform:translateY(-2px)}.footer-copy{color:#98a2b3;font-size:12px}@media (max-width:768px){.footer-grid{grid-template-columns:1fr}.footer-meta{align-items:flex-end;text-align:right}}.loading-container{align-items:center;display:flex;justify-content:center;min-height:50vh}.loading{color:#007bff;font-size:1.25rem;text-align:center}@media (max-width:768px){
    /*    !*flex-direction: column;*!*/.nav-authenticated,.nav-guest{flex-wrap:wrap;justify-content:center}.hero h1{font-size:2rem}.hero p{font-size:1rem}.hero-buttons{align-items:center;flex-direction:column}.features h2{font-size:2rem}.features-grid{grid-template-columns:1fr}.auth-card{margin:1rem;padding:2rem}.dashboard-container{padding:1rem}.dashboard-header h1{font-size:2rem}.stats-grid{grid-template-columns:1fr}.stat-card{flex-direction:column;text-align:center}.dashboard-actions{grid-template-columns:1fr}.action-buttons{gap:.75rem}.user-menu{flex-wrap:wrap;justify-content:center}}@media (max-width:480px){.container,.dashboard-container,.home-container{padding:1rem}.auth-card{padding:1.5rem}.btn{font-size:.9rem;padding:.6rem 1.2rem}.hero{padding:2rem 1rem}.action-card,.recent-activity,.stat-card{padding:1.5rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-card,.dashboard-container,.home-container{animation:fadeIn .5s ease-out}*{transition:color .3s ease,background-color .3s ease}a:focus,button:focus,input:focus{outline:2px solid #007bff;outline-offset:2px}.btn:hover:not(:disabled){box-shadow:0 4px 12px #0000004d}.form-input:hover{border-color:#b3d7ff}.auth-form .form-group:has(.form-input.error) label{color:#dc3545}.type-buttons{display:flex;gap:10px;margin-top:5px}.type-btn{align-items:center;background:#fff;border:2px solid #ddd;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:12px 16px;transition:all .3s ease}.type-btn:hover:not(:disabled){border-color:#999;transform:translateY(-1px)}.type-btn:disabled{cursor:not-allowed;opacity:.6}.type-btn.active{box-shadow:0 2px 8px #0000001a;font-weight:600}.type-btn.expense-active{background:#fff5f5;border-color:#dc3545;color:#dc3545}.type-btn.income-active{background:#f8fff9;border-color:#28a745;color:#28a745}.type-icon{font-size:16px}@media (max-width:768px){.type-buttons{flex-direction:column}.type-btn{margin-bottom:8px}}.transaction-table-container{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;margin:20px 0;overflow:hidden}.table-wrapper{overflow-x:auto}.transaction-table{border-collapse:collapse;font-size:14px;min-width:800px;width:100%}.transaction-table thead{background:linear-gradient(180deg,#474747 23%,#3a3a3a 95%);color:#fff}.transaction-table th{border:none;font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px 12px;text-align:left;text-transform:uppercase}.transaction-table tbody tr{border-bottom:1px solid #f0f0f0;position:relative;transition:all .2s ease}.transaction-table tbody tr:hover{background-color:#f8f9fa;box-shadow:inset 0 0 0 9999px #0000,0 2px 8px #0000000d}.transaction-table tbody tr:last-child{border-bottom:none}.transaction-table th{padding:13px 12px}.transaction-table td{border:none;padding:8px 12px;vertical-align:middle}.type-badge{align-items:center;border-radius:20px;display:flex;font-size:12px;font-weight:600;gap:6px;padding:4px 8px;width:-webkit-fit-content;width:fit-content}.type-badge.income{background:#28a7451a;border:1px solid #28a74533;color:#28a745}.type-badge.expense{background:#dc35451a;border:1px solid #dc354533;color:#dc3545}.type-icon{font-size:14px}.type-text{font-size:11px;text-transform:uppercase}.category-cell{color:#495057;font-weight:500}.description-cell{max-width:200px}.description-text{color:#6c757d;font-style:italic}.no-description{color:#adb5bd;font-style:italic}.date-cell{color:#495057;font-weight:500;white-space:nowrap}.amount-cell{font-size:14px;font-weight:700}.amount.income{color:#28a745}.amount.expense{color:#dc3545}.actions-cell{text-align:center;width:120px}.action-buttons{display:flex;gap:8px;justify-content:center}.btn{border-radius:6px;font-size:12px;padding:6px 10px}.btn-sm{font-size:11px;padding:4px 8px}.btn-delete{background:#dc35451a;border:1px solid #dc354533;color:#dc3545}.btn-delete:hover{transform:translateY(-1px)}.btn-danger{background:#dc3545;border:1px solid #dc3545;color:#fff}.btn-danger:hover{background:#c82333;border-color:#bd2130;box-shadow:0 2px 8px #dc35454d;transform:translateY(-1px)}.btn-outline{background:#0000;border:1px solid #dee2e6;color:#6c757d}.btn-outline:hover{background:#f8f9fa;color:#495057;transform:translateY(-1px)}.cancel-btn,.confirm-btn{border-radius:50%;font-weight:700;height:28px;min-width:28px}.confirm-btn{background:#28a745;border:none;color:#fff}.confirm-btn:hover{background:#218838;box-shadow:0 2px 8px #28a7454d}.cancel-btn{background:#f8f9fa;border:1px solid #dee2e6;color:#6c757d}.cancel-btn:hover{background:#e9ecef;color:#495057}.loading-message{align-items:center;color:#6c757d;display:flex;font-size:16px;gap:12px;justify-content:center;padding:60px 20px;text-align:center}.spinner{animation:spin 1s linear infinite;border:2px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:20px;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.empty-state{color:#6c757d;padding:60px 20px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px}.empty-state h3{color:#495057;font-size:20px;margin:0 0 8px}.empty-state p{font-size:14px;margin:0;opacity:.8}@media (max-width:768px){.transaction-table-container{border-radius:8px;margin:10px 0}.transaction-table{font-size:12px;min-width:600px}.type-text{display:none}.description-cell{max-width:120px}.description-text{font-size:11px}.action-buttons{gap:4px}.btn-sm{font-size:10px;padding:3px 6px}}@media (max-width:480px){.transaction-table{min-width:500px}.type-badge{padding:3px 6px}.type-icon{font-size:12px}.description-cell{max-width:100px}.actions-cell{width:80px}}.action-buttons .btn{opacity:.7;transition:opacity .2s ease,transform .2s ease}.btn[title]:hover:after{background:#333;border-radius:4px;color:#fff;content:attr(title);font-size:11px;margin-bottom:4px;padding:4px 8px;white-space:nowrap}.btn[title]:hover:after,.btn[title]:hover:before{bottom:100%;left:50%;position:absolute;transform:translateX(-50%);z-index:1000}.btn[title]:hover:before{border:4px solid #0000;border-top-color:#333;content:""}.btn[title]{position:relative}.filters-section{background:#fff;border-bottom:1px solid #e9ecef;border-radius:12px 12px 0 0;box-shadow:0 2px 4px #0000000a;padding:20px}.filters-container{align-items:center;display:flex;flex-wrap:wrap;gap:20px}.filter-group{align-items:center;display:flex;gap:8px}.filter-label{color:#495057;font-size:14px;font-weight:600;white-space:nowrap}.filter-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:linear-gradient(180deg,#fff,#f9fafb);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='20' height='20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m5 7.5 5 5 5-5' stroke='%23667eea' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:2px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 3px #00000014,inset 0 1px 0 #fffc;color:#111827;cursor:pointer;font-size:14px;font-weight:500;min-width:150px;padding:10px 36px 10px 14px;transition:all .2s ease-in-out}.filter-select:hover{background:linear-gradient(180deg,#fff,#eef2ff);border-color:#a5b4fc;box-shadow:0 4px 12px #667eea26,inset 0 1px 0 #ffffffe6;transform:translateY(-1px)}.filter-select:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea26,0 4px 12px #667eea33;outline:none}.filter-select:disabled{background:linear-gradient(180deg,#f8f9fa,#e9ecef);border-color:#dee2e6;box-shadow:none;color:#adb5bd;cursor:not-allowed;opacity:.7}.btn-reset{align-items:center;background:linear-gradient(180deg,#474747 23%,#3a3a3a 95%);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:8px 16px;transition:all .2s ease}.btn-reset:hover{color:#fff;transform:translateY(-1px)}.active-filters{align-items:center;border-top:1px solid #e9ecef;display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;padding-top:16px}.active-filters-label{color:#6c757d;font-size:13px;font-weight:600}.filter-tag{background:linear-gradient(180deg,#474747 23%,#3a3a3a 95%);border-radius:20px;font-weight:500;gap:6px;padding:4px 8px}.filter-tag,.remove-filter{align-items:center;color:#fff;display:flex;font-size:12px}.remove-filter{background:#fff3;border:none;border-radius:50%;cursor:pointer;font-weight:700;height:18px;justify-content:center;transition:background .2s ease;width:18px}.remove-filter:hover{background:#ffffff4d;transform:scale(1.1)}@media (max-width:768px){.filters-container{align-items:stretch;flex-direction:column;gap:16px}.filter-group{align-items:flex-start;flex-direction:column;gap:6px}.filter-select{min-width:auto;width:100%}.btn-reset{align-self:center;width:-webkit-fit-content;width:fit-content}.active-filters{align-items:flex-start;flex-direction:column}}.transaction-table-container .table-wrapper{border-radius:0 0 12px 12px}.transaction-table-container:has(.filters-section){box-shadow:0 4px 20px #00000014}.filters-section+.empty-state,.filters-section+.table-wrapper{background:#fff;border-radius:0 0 12px 12px}.filters-section+.empty-state{border-top:none}.page-container{margin:0 auto;max-width:1200px;padding:20px}.page-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.page-header h1{color:#495057;font-size:2rem;margin:0}.error-message{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;padding:40px;text-align:center}.error-message h3{color:#dc3545;margin-bottom:10px}.error-message p{color:#6c757d;margin-bottom:20px}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:modalSlideIn .3s ease;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;max-width:500px;overflow-x:hidden;overflow-y:auto;padding:30px;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px 20px 0}.modal-header h2{color:#495057;font-size:1.25rem;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#adb5bd;cursor:pointer;display:flex;font-size:24px;height:35px;justify-content:center;padding:5px;transition:all .2s ease;width:35px}.close-btn:hover{background:#f8f9fa;color:#6c757d}@media (max-width:768px){.page-container{padding:15px}.page-header{align-items:stretch;flex-direction:column;gap:15px}.page-header h1{font-size:1.5rem;text-align:center}.modal-overlay{padding:10px}.modal-header{padding:15px 15px 0}.modal-header h2{font-size:1.1rem}}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:10px 20px;text-decoration:none;transition:all .2s ease}.btn-primary{background:linear-gradient(180deg,#474747 23%,#3a3a3a 95%);color:#fff}.btn-primary:hover{box-shadow:0 4px 12px #ea66664d;transform:translateY(-1px)}.filters-section.loading{opacity:.7;pointer-events:none}.filters-section.loading:after{animation:spin 1s linear infinite;border:2px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;content:"";height:20px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:20px}.btn-table{padding:5px 10px}.category-with-badge{align-items:center;display:flex;gap:8px}.type-indicator{align-items:center;border-radius:50%;display:inline-flex;flex-shrink:0;font-size:16px;height:24px;justify-content:center;width:24px}.type-indicator.income{background:#28a7451a;border:1px solid #28a74533}.type-indicator.expense{background:#dc35451a;border:1px solid #dc354533}@keyframes fadeInTooltip{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.transaction-row.deleting:after{background:#dc3545e6;border-radius:20px;color:#fff;content:"⚠️ Suppression en cours...";font-size:12px;font-weight:600;left:50%;opacity:.8;padding:8px 16px;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:50}@media (max-width:768px){.transaction-row:hover:not(.deleting):before{display:none}.category-with-badge{align-items:flex-start;flex-direction:column;gap:4px}.type-indicator{font-size:14px;height:20px;width:20px}.actions-cell{width:60px}.btn-sm{font-size:10px;padding:3px 6px}.transaction-row.deleting:after{font-size:10px;padding:6px 12px}}@media (max-width:480px){.category-with-badge{gap:2px}.type-indicator{font-size:12px;height:18px;width:18px}.description-cell{max-width:80px}.description-text{font-size:11px}.actions-cell{width:50px}}.transaction-row.income:hover:not(.deleting){background:linear-gradient(90deg,#28a7450d,#0000)}.transaction-row.expense:hover:not(.deleting){background:linear-gradient(90deg,#dc35450d,#0000)}.transaction-row{position:relative}.transaction-row:after,.transaction-row:before{pointer-events:none}.btn-edit{display:none}.btn-delete:hover{background:#dc354533;transform:scale(1.1)}.confirm-delete{animation:slideInDelete .3s ease;display:flex;gap:6px;justify-content:center}.transaction-row.deleting,.transaction-row.deleting:hover{background:inherit;box-shadow:none;cursor:default}.transaction-row .actions-cell{position:relative;z-index:1}.transaction-row .actions-cell .btn{cursor:pointer}.transaction-row .actions-cell .btn:focus-visible{outline:2px solid #495057}.transactions-summary{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:16px}.summary-card{background:#fff;border:1px solid #e9ecef;border-radius:10px;box-shadow:0 1px 2px #0000000a;padding:14px 16px}.summary-card .summary-title{color:#6c757d;font-size:12px;letter-spacing:.02em;margin-bottom:6px;text-transform:uppercase}.summary-card .summary-amount{font-size:20px;font-weight:700}.summary-card.income .summary-amount{color:#198754}.summary-card.expense .summary-amount{color:#dc3545}.summary-card.net.positive .summary-amount{color:#0d6efd}.summary-card.net.negative .summary-amount{color:#dc3545}@media (max-width:768px){.transactions-summary{grid-template-columns:1fr}}.transaction-table tbody tr{will-change:background-color,box-shadow}.btn-delete-transaction:hover{background:#dc354533;transform:translateY(-1px)}.form-divider{background:linear-gradient(90deg,#0000,#e9ecef 50%,#0000);border:none;height:1px;margin:5px 0}.btn-delete-transaction{background:#dc35451a;border:2px solid #dc354533;color:#dc3545;transition:all .3s ease}.btn-delete-transaction:hover:not(:disabled){background:#dc354526;border-color:#dc354566;transform:translateY(-1px)}.delete-confirm-section{background:#dc35450d;border:1px solid #dc35451a;border-radius:8px;padding:20px;text-align:center}.delete-warning{color:#721c24;font-size:14px;font-weight:500;line-height:1.5;margin:0 0 20px}.delete-confirm-buttons{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.btn-confirm-delete{background:#dc3545;border:2px solid #dc3545;color:#fff;min-width:180px}.btn-confirm-delete:hover:not(:disabled){background:#c82333;border-color:#bd2130;box-shadow:0 4px 12px #dc35454d;transform:translateY(-1px)}.btn-cancel-delete{background:#fff;border:2px solid #dee2e6;color:#6c757d;min-width:120px}.btn-cancel-delete:hover:not(:disabled){background:#f8f9fa;border-color:#adb5bd;color:#495057}.form-textarea{min-height:80px;resize:vertical}.text-muted{color:#8c9193!important;display:block;font-size:12px;margin-top:4px}@media (max-width:768px){.delete-confirm-buttons{align-items:stretch;flex-direction:column}.btn-cancel-delete,.btn-confirm-delete{min-width:auto;width:100%}.delete-warning{font-size:13px}}.delete-confirm-section{animation:slideInDelete .3s ease-out}@keyframes slideInDelete{0%{max-height:0;opacity:0;transform:translateY(-10px)}to{max-height:200px;opacity:1;transform:translateY(0)}}.btn-confirm-delete:disabled{background:#dc3545;cursor:not-allowed;opacity:.7}.btn-confirm-delete:disabled:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;content:"";display:inline-block;height:16px;margin-left:8px;vertical-align:middle;width:16px}.transaction-table{min-width:700px}@media (max-width:768px){.transaction-table{min-width:550px}.transaction-row:hover:not(.deleting):after{display:none}.transaction-table td,.transaction-table th{padding:14px 10px}.description-cell{max-width:140px}}@media (max-width:480px){.transaction-table{min-width:450px}.form-delete-section{margin-top:20px}.delete-confirm-section{padding:15px}.delete-warning{font-size:12px;margin-bottom:15px}}.btn-cancel-delete:focus,.btn-confirm-delete:focus,.btn-delete-transaction:focus{outline:2px solid #667eea;outline-offset:2px}@media (prefers-color-scheme:dark){.delete-confirm-section{background:#dc35451a;border-color:#dc354533}}.btn-delete-transaction:hover{animation:pulseDelete 1.5s infinite}@keyframes pulseDelete{0%,to{box-shadow:0 0 0 0 #dc354566}50%{box-shadow:0 0 0 8px #dc35451a}}.transaction-form{max-height:70vh;overflow-y:auto;padding-right:5px}.transaction-form::-webkit-scrollbar{width:6px}.transaction-form::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.transaction-form::-webkit-scrollbar-thumb{background:#667eea;border-radius:3px}.transaction-form::-webkit-scrollbar-thumb:hover{background:#5a67d8}.btn-cancel-delete,.btn-confirm-delete,.btn-delete-transaction,.delete-confirm-section,.form-delete-section{transition:all .3s cubic-bezier(.4,0,.2,1)}@supports (-webkit-appearance:none){.btn-confirm-delete:disabled:after{margin-left:6px}}.description-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-content{display:flex;flex-direction:column;max-height:90vh}.modal-content .transaction-form{flex:1 1;min-height:0}.modal-overlay.closing{animation:modalFadeOut .3s ease forwards}@keyframes modalFadeOut{0%{opacity:1}to{opacity:0}}.modal-overlay.closing .modal-content{animation:modalSlideOut .3s ease forwards}@keyframes modalSlideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-30px) scale(.9)}}.chart-modal{max-width:800px}.chart-summary{margin-bottom:12px}.chart-total{color:#495057;font-size:14px}.chart-bars{display:flex;flex-direction:column;gap:10px;margin-top:8px}.chart-row{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:180px 1fr 140px}.chart-label{align-items:center;color:#343a40;display:flex;font-size:14px;gap:8px}.chart-label .dot{border-radius:50%;display:inline-block;height:10px;width:10px}.bar-track{background:#f1f3f5;border-radius:999px;height:14px;overflow:hidden}.bar-fill{border-radius:999px;height:100%}.bar-value{font-feature-settings:"tnum";color:#495057;font-size:13px;font-variant-numeric:tabular-nums;text-align:right}.chart-legend{border-top:1px solid #e9ecef;display:flex;flex-wrap:wrap;gap:8px 14px;margin-top:16px;padding-top:12px}.chart-legend .legend-item{align-items:center;color:#6c757d;display:inline-flex;font-size:12px;gap:6px}.chart-legend .dot{border-radius:999px;height:10px;width:10px}@media (max-width:600px){.chart-row{gap:6px;grid-template-columns:1fr}.bar-value{text-align:left}}.theme-toggle{align-items:center;background:#f1f3f5;border:1px solid #0000000d;border-radius:999px;display:inline-flex;gap:6px;padding:4px}.toggle-option{background:#0000;border:none;border-radius:999px;color:#495057;cursor:pointer;font-weight:600;padding:8px 14px;transition:all .2s ease}.toggle-option:hover{background:#fff9}.toggle-option.active{background:#fff;box-shadow:0 2px 8px #00000014;color:#1f2937}.quick-actions-row{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.btn-accent{background:linear-gradient(180deg,#474747 23%,#3a3a3a 95%);border:none;color:#fff}.btn-accent:hover{box-shadow:0 6px 16px #764ba259;transform:translateY(-1px)}.save-btn{background:#667eea;border-color:#667eea;color:#fff}.save-btn:hover{background:#5a67d8}.action-card .btn{border-radius:10px;padding:10px 16px}.hero .btn-cta{background:#fff;border:2px solid #fff;border-radius:10px;box-shadow:0 10px 20px #00000026;color:#111827;font-size:1.125rem;padding:14px 28px}.hero .btn-cta:hover{background:#f3f4f6;border-color:#f3f4f6;box-shadow:0 14px 24px #0003;transform:translateY(-2px)}.hero .btn-cta:focus-visible{outline:3px solid #111827;outline-offset:3px}@media (max-width:480px){.hero .btn-cta{width:100%}}.category-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.category-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 2px #0000000a;color:#111827;cursor:pointer;display:inline-flex;font-weight:500;justify-content:center;padding:10px 12px}.category-btn:hover{background:#f9fafb}.category-btn.active{background:#eef2ff;border-color:#667eea;box-shadow:inset 0 0 0 2px #667eea26;color:#3730a3}.category-btn:disabled{cursor:not-allowed;opacity:.6}.transaction-form button[type=submit]:focus-visible{outline:none}.transaction-form .btn:focus,.transaction-form .btn:focus-visible{box-shadow:none}.modal-content .row,.modal-content [class*=row]{--bs-gutter-x:0;margin-left:0;margin-right:0}.modal-content{overflow-x:hidden!important}.default-badge{background:linear-gradient(180deg,#22c55e,#16a34a);border:1px solid #15803d99;border-radius:9999px;box-shadow:0 4px 12px #22c55e59,inset 0 1px 0 #fff3;font-weight:600;gap:6px;letter-spacing:.2px;padding:4px 10px;text-transform:none}.default-badge,.default-badge .check-icon{align-items:center;color:#fff;display:inline-flex;font-size:12px}.default-badge .check-icon{background:#ffffff38;border-radius:50%;box-shadow:inset 0 1px 2px #0000001f;height:16px;justify-content:center;line-height:1;width:16px}.danger-panel{background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#7f1d1d;padding:12px 14px}.info-message{background:#fef9c3;border:1px solid #fde68a;border-radius:8px;color:#713f12;padding:10px 12px}.account-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:linear-gradient(180deg,#fff,#f9fafb);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='20' height='20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m5 7.5 5 5 5-5' stroke='%23667eea' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:2px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 3px #00000014,inset 0 1px 0 #fffc;color:#111827;cursor:pointer;font-size:14px;font-weight:600;line-height:1.2;padding:10px 36px 10px 14px;transition:all .2s ease-in-out}.account-select:hover{background:linear-gradient(180deg,#fff,#eef2ff);border-color:#a5b4fc;box-shadow:0 4px 12px #667eea26,inset 0 1px 0 #ffffffe6;transform:translateY(-1px)}.account-select:focus-visible{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea26,0 4px 12px #667eea33;outline:none}.account-select:disabled{background:linear-gradient(180deg,#f8f9fa,#e9ecef);box-shadow:none;color:#adb5bd;cursor:not-allowed;opacity:.7}.btn-cat-profile{width:200px}.category-drag-table tbody tr.category-row{background:#fff;position:relative;transition:all .2s ease-in-out;-webkit-user-select:none;user-select:none}.category-drag-table tbody tr.category-row:hover{background:linear-gradient(180deg,#f9fafb,#f3f4f6);box-shadow:0 2px 8px #00000014}.category-drag-table tbody tr.category-row.dragging{background:linear-gradient(180deg,#eef2ff,#e0e7ff);box-shadow:0 8px 24px #667eea4d;cursor:grabbing!important;opacity:.5;transform:scale(1.02)}.category-drag-table tbody tr.category-row.drag-over{background:linear-gradient(180deg,#fef3c7,#fde68a);border-top:2px solid #f59e0b;box-shadow:0 4px 16px #f59e0b4d}.category-drag-table tbody tr.category-row .drag-handle{opacity:.5;transition:opacity .2s ease}.category-drag-table tbody tr.category-row:hover .drag-handle{color:#667eea;opacity:1}.responsive-flex{display:flex;flex-wrap:wrap;gap:8px}.responsive-stack{display:flex;flex-direction:column;gap:8px}@media (max-width:768px){.dashboard-header{padding-bottom:16px}.dashboard-header h1{font-size:1.75rem}.dashboard-header p{font-size:.95rem}.page-header{align-items:flex-start;flex-direction:column;gap:12px}.page-header h1{font-size:1.75rem}.header-actions{flex-wrap:wrap;width:100%}.header-actions .btn{flex:1 1 auto;min-width:140px}.account-chooser{align-items:flex-start!important;flex-direction:column!important;gap:8px!important}.account-chooser .account-select{width:100%}.stat-card{gap:1rem;padding:1.5rem}.stat-icon{font-size:2.5rem}.stat-info h3{font-size:.9rem}.stat-info p{font-size:1.3rem}.stat-card .btn{font-size:.9rem;padding:8px 14px}.type-buttons{flex-wrap:wrap;gap:8px}.btn-cat-profile{flex:1 1 auto;min-width:140px;width:auto}.account-select{font-size:13px;min-width:0;width:100%}.transaction-table{font-size:13px}.transaction-table td,.transaction-table th{padding:10px 8px}.drag-handle{font-size:14px!important}.modal-content{margin:10px;max-width:calc(100% - 20px);padding:20px}.modal-header h2{font-size:1.3rem}.form-group,.transaction-form .form-group{margin-bottom:1rem}.form-label,.transaction-form .form-label{font-size:.9rem;margin-bottom:6px}.form-control,.form-input,.transaction-form .form-control,.transaction-form .form-input{font-size:14px;padding:10px 12px}.modal-actions{flex-direction:column;gap:8px}.modal-actions .btn{width:100%}.danger-panel,.error-message,.info-message{font-size:.9rem;padding:10px 12px}}@media (max-width:480px){.header-container{padding:0 12px}.logo{justify-content:flex-start}.header-title{font-size:1.1rem;text-align:left}.nav-authenticated{gap:8px}.user-button{min-width:0;padding:6px 10px}.user-avatar{font-size:13px;height:28px;width:28px}.dashboard-container{padding:.75rem}.dashboard-header{margin-bottom:1rem;padding-bottom:12px}.dashboard-header h1{font-size:1.5rem}.dashboard-header p{font-size:.875rem}.page-container{padding:.75rem}.page-header{margin-bottom:1rem;padding-bottom:12px}.page-header h1{font-size:1.5rem}.header-actions{flex-direction:column}.header-actions .btn{min-width:0;width:100%}.account-chooser{margin-bottom:1rem!important}.account-chooser>div:first-child{font-size:.875rem}.stat-card{gap:.75rem;padding:1.25rem}.stat-icon{font-size:2rem}.stat-info h3{font-size:.85rem}.stat-info p{font-size:1.2rem}.stat-meta{font-size:.8rem}.btn,.stat-card .btn{font-size:.875rem;min-height:44px;padding:10px 16px}.stat-card>div[style*="display: flex"]{flex-direction:column!important;gap:8px!important}.stat-card .btn{width:100%}.type-buttons{flex-direction:column;width:100%}.btn-cat-profile,.type-btn{min-width:0;width:100%}.account-select{font-size:13px;padding:10px 32px 10px 12px;width:100%}.transaction-table{font-size:12px;min-width:100%}.transaction-table td,.transaction-table th{padding:8px 6px}.transaction-table th{font-size:11px}.modal-overlay{padding:10px}.modal-content{margin:0;max-height:calc(100vh - 20px);max-width:100%;padding:16px}.modal-header{margin-bottom:16px;padding-bottom:12px}.modal-header h2{font-size:1.15rem}.close-btn{font-size:1.25rem;height:32px;width:32px}.form-group,.transaction-form .form-group{margin-bottom:.875rem}.form-label,.transaction-form .form-label{font-size:.85rem;margin-bottom:4px}.form-control,.form-input,.transaction-form .form-control,.transaction-form .form-input{font-size:13px;min-height:44px;padding:10px}textarea.form-control,textarea.form-input{min-height:80px}.password-toggle{min-width:44px;padding:8px}.category-grid{gap:8px}.category-btn{font-size:.875rem;min-height:44px;padding:10px 14px}.modal-actions{flex-direction:column;gap:10px;margin-top:16px}.modal-actions .btn{min-height:44px;width:100%}.delete-confirm-buttons{flex-direction:column!important}.delete-confirm-buttons .btn{width:100%!important}.danger-panel,.error-message,.info-message{font-size:.85rem;padding:8px 10px}.empty-state{font-size:.9rem;padding:1.5rem 1rem}.drag-handle{font-size:16px!important;padding:4px}.filter-select{font-size:13px;min-width:0;width:100%}.default-badge{font-size:11px;padding:3px 8px}}
/*# sourceMappingURL=main.54f539f0.css.map*/