.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;width:100%;max-width:100vw;background:var(--color-white);border-top:1px solid var(--color-border);padding:6px 0 max(6px,env(safe-area-inset-bottom));z-index:1000;box-shadow:0 -2px 10px var(--color-shadow);overflow-x:hidden}@media (max-width: 768px){.mobile-nav{display:flex;justify-content:space-around;align-items:center}}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;color:var(--color-text-light);padding:6px 8px;border-radius:10px;flex:1;max-width:70px;min-width:0}.mobile-nav-item.active{color:var(--color-primary);background:#22c55e1a}.nav-icon{font-size:20px;line-height:1}.nav-label{font-size:10px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;text-align:center}.desktop-nav{display:none;position:fixed;bottom:32px;right:32px;z-index:1000}@media (min-width: 769px){.desktop-nav{display:block}}.fab{width:64px;height:64px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #22c55e4d;position:relative;z-index:1002}.fab:hover{background:var(--color-primary-dark);transform:scale(1.05)}.fab.open{background:var(--color-danger)}.fab-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;z-index:999;animation:fadeIn .2s ease}.fab-menu{position:absolute;bottom:80px;right:0;display:flex;flex-direction:column;gap:12px;z-index:1001}.fab-menu-item{display:flex;align-items:center;gap:12px;background:var(--color-white);color:var(--color-text);padding:14px 20px;border-radius:12px;box-shadow:0 2px 12px var(--color-shadow);border:1px solid var(--color-border);min-width:160px;animation:slideIn .3s ease backwards}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.fab-menu-item:hover{background:var(--color-bg);border-color:var(--color-primary);transform:translate(-4px)}.fab-menu-item.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.fab-icon{font-size:20px}.fab-label{font-weight:500;font-size:15px}.month-selector{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;transition:all .3s ease}.month-selector.current-month{background:var(--color-primary);box-shadow:0 2px 8px #22c55e4d}.month-selector.current-month .month-nav-btn{color:#fff}.month-selector.current-month .month-nav-btn:hover{background:#fff3}.month-selector.current-month .month-text{color:#fff}.month-nav-btn{background:transparent;border:none;font-size:24px;font-weight:700;color:var(--color-primary);cursor:pointer;padding:4px 12px;border-radius:4px;transition:background-color .2s ease;line-height:1}.month-nav-btn:hover{background:#22c55e1a}.month-nav-btn:active{background:#22c55e33}.month-display{position:relative;display:flex;align-items:center;min-width:200px}.month-input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer;z-index:2}.month-text{font-weight:600;font-size:16px;color:var(--color-text);text-transform:capitalize;white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:8px;pointer-events:none;width:100%}.current-badge{display:none}@media (max-width: 768px){.month-selector{padding:6px 8px;gap:8px}.month-nav-btn{font-size:20px;padding:2px 8px}.month-display{min-width:160px}.month-text{font-size:14px}.current-badge{font-size:10px;padding:2px 6px}}@media (max-width: 480px){.month-selector{flex:1;justify-content:space-between}.month-display{min-width:0;flex:1;justify-content:center}.month-text{font-size:13px}}.dashboard{max-width:1000px;margin:0 auto;padding:20px}@media (max-width: 768px){.dashboard{padding:16px 16px 90px}}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px;flex-wrap:wrap}@media (max-width: 768px){.dashboard-header{flex-direction:column;align-items:stretch}.header-title-group{justify-content:center}}.balance-label{font-size:14px;opacity:.9;font-weight:500}.balance-subtitle{font-size:13px;opacity:.8;margin-top:8px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin:24px 0}.stat-card{display:flex;align-items:center;gap:16px;padding:20px}.stat-icon{font-size:32px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:14px;flex-shrink:0}.income-icon{background:#22c55e1a}.expense-icon{background:#ef44441a}.credit-icon{background:#3b82f61a}.stat-content{flex:1;min-width:0}.stat-label{font-size:13px;color:var(--color-text-light);font-weight:500;margin-bottom:4px}.stat-value{font-size:20px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.income-value{color:var(--color-primary)}.expense-value{color:var(--color-danger)}.credit-value{color:#3b82f6}.recent-section,.credit-card-summary{margin-top:32px}.section-subtitle{font-size:18px;font-weight:600;margin-bottom:16px;color:var(--color-text)}.transactions-list,.installments-list{display:flex;flex-direction:column;gap:12px}.transaction-item,.installment-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;transition:transform .2s ease;min-height:60px}.transaction-item:hover,.installment-item:hover{transform:translate(4px)}.transaction-info,.installment-info{flex:1;min-width:0}.transaction-description,.installment-description{font-weight:500;font-size:15px;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transaction-date,.installment-progress{font-size:13px;color:var(--color-text-light)}.transaction-amount,.installment-amount{font-weight:700;font-size:16px;flex-shrink:0;margin-left:16px;display:flex;align-items:center}.transaction-amount.income{color:var(--color-primary)}.transaction-amount.expense{color:var(--color-danger)}.installment-amount{color:#3b82f6}.empty-state{text-align:center;padding:48px 24px;color:var(--color-text-light)}.empty-state p:first-child{font-size:16px;font-weight:500;margin-bottom:8px;color:var(--color-text)}.empty-subtitle{font-size:14px}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.stat-value{font-size:16px}.balance-amount{font-size:32px}.transaction-item,.installment-item{padding:10px 14px;min-height:54px}.transaction-description,.installment-description{font-size:14px}.transaction-amount,.installment-amount{font-size:14px;margin-left:10px}.transaction-date,.installment-progress{font-size:12px}}.kebab-menu{position:relative;display:inline-block}.kebab-button{background:none;border:none;font-size:24px;color:var(--color-text-light);cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s ease;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.kebab-button:hover{background:var(--color-bg);color:var(--color-text)}.kebab-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--color-white);border:1px solid var(--color-border);border-radius:10px;box-shadow:0 4px 12px var(--color-shadow);min-width:140px;z-index:1000;overflow:hidden;animation:slideDown .2s ease}@media (max-width: 480px){.kebab-dropdown{box-shadow:0 4px 16px #00000026;min-width:130px}.kebab-button{width:36px;height:36px}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.kebab-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 14px;background:none;border:none;text-align:left;font-size:14px;font-weight:500;color:var(--color-text);cursor:pointer;transition:background .2s ease;border-bottom:1px solid var(--color-border)}.kebab-item:last-child{border-bottom:none}.kebab-item:hover{background:var(--color-bg)}.edit-item:hover{background:#3b82f61a;color:#3b82f6}.delete-item:hover{background:#ef44441a;color:var(--color-danger)}.kebab-icon{font-size:16px;display:flex;align-items:center;justify-content:center;width:20px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--color-white);border-radius:16px;padding:24px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:var(--color-text)}.modal-close{background:none;border:none;font-size:28px;line-height:1;color:var(--color-text-light);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.modal-close:hover{background:var(--color-bg);color:var(--color-text)}.modal-actions{display:flex;gap:12px;margin-top:24px}.modal-actions .btn{flex:1}.btn-secondary{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-border)}@media (max-width: 480px){.modal-content{padding:20px}.modal-header h3{font-size:16px}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.expenses{max-width:800px;margin:0 auto;padding:20px}@media (max-width: 768px){.expenses{padding:16px 16px 90px}}.screen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px;flex-wrap:wrap}@media (max-width: 768px){.screen-header{flex-direction:column;align-items:stretch}}.badge{display:inline-block;padding:3px 8px;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;margin-left:8px}.badge-recurring{background:#22c55e26;color:var(--color-primary)}.badge-installment{background:#3b82f626;color:#3b82f6}.form-card{margin-bottom:24px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.form-title{font-size:18px;font-weight:600;margin-bottom:20px;color:var(--color-text)}.full-width{width:100%;margin-top:8px}.total-card{margin-bottom:32px;text-align:center;padding:24px}.total-label{font-size:14px;color:var(--color-text-light);font-weight:500;margin-bottom:8px}.total-amount{font-size:32px;font-weight:700}.expense-color{color:var(--color-danger)}.income-color{color:var(--color-primary)}.expenses-list{margin-top:32px}.list-items{display:flex;flex-direction:column;gap:12px}.expense-item{display:flex;flex-direction:column;gap:12px;padding:16px;transition:transform .2s ease}.expense-item:hover{transform:translate(4px)}.expense-main{display:grid;grid-template-columns:1fr auto auto;align-items:flex-start;gap:12px}.expense-info{min-width:0;overflow:hidden}.expense-description{font-weight:500;font-size:15px;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.expense-meta{display:flex;gap:12px;font-size:13px;color:var(--color-text-light);flex-wrap:wrap}.expense-category{background:#22c55e1a;color:var(--color-primary);padding:2px 10px;border-radius:8px;font-weight:500}.expense-amount{font-weight:700;font-size:18px;color:var(--color-danger);flex-shrink:0}@media (max-width: 480px){.screen-header{flex-direction:column;align-items:stretch}.screen-header .btn{width:100%}.total-amount{font-size:28px}.expense-main{grid-template-columns:1fr auto auto;gap:8px}.expense-amount{font-size:16px;text-align:right}.expense-description{font-size:14px}}.income{max-width:800px;margin:0 auto;padding:20px}@media (max-width: 768px){.income{padding:16px 16px 90px}}.income-list{margin-top:32px}.income-item{display:flex;flex-direction:column;gap:12px;padding:16px;transition:transform .2s ease}.income-item:hover{transform:translate(4px)}.income-main{display:grid;grid-template-columns:1fr auto auto;align-items:flex-start;gap:12px}.income-info{min-width:0;overflow:hidden}.income-description{font-weight:500;font-size:15px;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.income-date{font-size:13px;color:var(--color-text-light)}.income-amount{font-weight:700;font-size:18px;color:var(--color-primary);flex-shrink:0}@media (max-width: 480px){.income-main{grid-template-columns:1fr auto auto;gap:8px}.income-amount{font-size:16px;text-align:right}.income-description{font-size:14px}}.credit-card{max-width:800px;margin:0 auto;padding:20px}@media (max-width: 768px){.credit-card{padding:16px 16px 90px}}.credit-total{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none}.credit-color{color:#3b82f6}.installment-preview{background:#22c55e1a;padding:12px 16px;border-radius:10px;margin-bottom:16px;color:var(--color-primary);font-size:15px;border:1px solid rgba(34,197,94,.2)}.purchases-list{margin-top:32px}.purchase-item{padding:20px;display:flex;flex-direction:column;gap:16px;transition:transform .2s ease}.purchase-item:hover{transform:translate(4px)}.purchase-header{display:grid;grid-template-columns:1fr auto;align-items:flex-start;gap:12px}.purchase-info{min-width:0;overflow:hidden}.purchase-description{font-weight:600;font-size:16px;margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text)}.purchase-meta{display:flex;gap:12px;font-size:13px;color:var(--color-text-light);flex-wrap:wrap}.purchase-category{background:#22c55e1a;color:var(--color-primary);padding:2px 10px;border-radius:8px;font-weight:500}.purchase-details{background:var(--color-bg);padding:16px;border-radius:12px;display:flex;flex-direction:column;gap:10px}.detail-row{display:flex;justify-content:space-between;align-items:center;font-size:14px}.detail-row span{color:var(--color-text-light)}.detail-row strong{color:var(--color-text);font-weight:600}.remaining-amount{color:#3b82f6!important;font-size:16px}.progress-bar{width:100%;height:8px;background:var(--color-border);border-radius:10px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);transition:width .3s ease;border-radius:10px}@media (max-width: 480px){.purchase-item{padding:16px}.purchase-header{grid-template-columns:1fr auto;gap:8px}.purchase-description{font-size:14px}.detail-row{font-size:12px}.purchase-details{padding:12px}}.charts{max-width:1000px;margin:0 auto;padding:20px}@media (max-width: 768px){.charts{padding:16px 16px 90px}}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.summary-card{display:flex;align-items:center;gap:16px;padding:20px}.summary-icon{font-size:32px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:14px;flex-shrink:0}.income-summary .summary-icon{background:#22c55e1a}.expense-summary .summary-icon{background:#ef44441a}.balance-summary .summary-icon{background:#3b82f61a}.summary-content{flex:1;min-width:0}.summary-label{font-size:13px;color:var(--color-text-light);font-weight:500;margin-bottom:4px}.summary-value{font-size:20px;font-weight:700;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chart-card{margin-bottom:32px;padding:24px}.chart-title{font-size:18px;font-weight:600;margin-bottom:24px;color:var(--color-text)}.custom-tooltip{background:var(--color-white);padding:12px 16px;border-radius:10px;box-shadow:0 4px 12px var(--color-shadow);border:1px solid var(--color-border)}.tooltip-label{font-weight:600;margin-bottom:4px;color:var(--color-text)}.tooltip-value{color:var(--color-primary);font-weight:700;font-size:16px}.tooltip-percentage{color:var(--color-text-light);font-size:14px;margin-top:2px}.category-breakdown{margin-top:32px}.category-list{display:flex;flex-direction:column;gap:12px}.category-item{display:flex;align-items:center;gap:16px;padding:16px;transition:transform .2s ease}.category-item:hover{transform:translate(4px)}.category-color{width:12px;height:40px;border-radius:6px;flex-shrink:0}.category-info{flex:1;min-width:0}.category-name{font-weight:600;font-size:15px;margin-bottom:4px;color:var(--color-text)}.category-percentage{font-size:13px;color:var(--color-text-light)}.category-amount{font-weight:700;font-size:18px;color:var(--color-text);flex-shrink:0}@media (max-width: 480px){.summary-cards{grid-template-columns:1fr}.summary-value{font-size:18px}.chart-card{padding:16px}.category-amount{font-size:16px}}.settings{max-width:800px;margin:0 auto;padding:20px}@media (max-width: 768px){.settings{padding:16px 16px 90px}}.settings-section{margin-bottom:32px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:16px}@media (max-width: 480px){.section-header{flex-direction:column;align-items:stretch}.section-header .btn{width:100%}}.salary-info{padding:20px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--color-border)}.info-row:last-child{border-bottom:none}.info-label{font-weight:500;color:var(--color-text-light);font-size:14px}.info-value{font-weight:600;color:var(--color-text);font-size:15px}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-active{background:#22c55e1a;color:var(--color-primary)}.badge-inactive{background:#0000000d;color:var(--color-text-light)}.checkbox-group{margin:16px 0}.checkbox-group label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px}.checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.input-hint{display:block;margin-top:4px;font-size:12px;color:var(--color-text-light)}.recurring-list{margin-top:16px}.recurring-item{display:flex;flex-direction:column;gap:12px;padding:16px;transition:transform .2s ease}.recurring-item:hover{transform:translate(4px)}.recurring-main{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.recurring-info{flex:1;min-width:0}.recurring-description{font-weight:500;font-size:15px;margin-bottom:6px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.recurring-details{font-size:13px;color:var(--color-text-light);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.recurring-category{font-weight:500}.recurring-separator{color:var(--color-border)}.recurring-date{font-style:italic}.recurring-amount{font-weight:700;font-size:18px;color:var(--color-error);flex-shrink:0}.recurring-actions{display:flex;gap:8px;padding-top:8px;border-top:1px solid var(--color-border)}.btn-toggle{padding:6px 12px;font-size:13px;background:transparent;border:1px solid var(--color-border);color:var(--color-text);border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-toggle:hover{background:#0000000d;border-color:var(--color-text-light)}.btn-toggle:active{transform:scale(.98)}@media (max-width: 480px){.recurring-main{flex-direction:column;gap:12px}.recurring-amount{font-size:20px}.recurring-actions{flex-direction:column}.btn-toggle{width:100%}}.info-card{padding:20px;background:linear-gradient(135deg,#22c55e0d,#22c55e05);border-left:4px solid var(--color-primary)}.info-title{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--color-text)}.info-list{list-style:none;padding:0;margin:0}.info-list li{padding:8px 0;font-size:14px;line-height:1.6;color:var(--color-text);display:flex;gap:8px}.info-list li:before{content:"•";color:var(--color-primary);font-weight:700;flex-shrink:0}.info-list strong{color:var(--color-primary)}.form-title{font-size:18px;font-weight:600;margin-bottom:16px;color:var(--color-text)}.backup-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;padding:20px}.backup-action-item{display:flex;flex-direction:column;gap:12px}.action-title{font-size:16px;font-weight:600;color:var(--color-text);margin:0}.action-description{font-size:14px;line-height:1.5;color:var(--color-text-light);margin:0;flex:1}.backup-action-item .btn{margin-top:auto}@media (max-width: 768px){.backup-actions{grid-template-columns:1fr;gap:20px;padding:16px}}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding-top:20px}@media (max-width: 768px){.main-content{padding-top:10px}}.header-title-group{display:flex;align-items:center;gap:12px}@media (max-width: 768px){.header-title-group{justify-content:center}}*{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #fafafa;--color-white: #ffffff;--color-text: #1f2937;--color-text-light: #6b7280;--color-primary: #22c55e;--color-primary-dark: #16a34a;--color-border: #e5e7eb;--color-danger: #ef4444;--color-shadow: rgba(0, 0, 0, .05);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}html{overflow-x:hidden;width:100%}body{background-color:var(--color-bg);color:var(--color-text);line-height:1.6;overflow-x:hidden;width:100%;max-width:100vw}#root{min-height:100vh;width:100%;max-width:100vw;overflow-x:hidden}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all .2s ease}input,select,textarea{font-family:inherit;outline:none;border:1.5px solid var(--color-border);transition:border-color .2s ease}input:focus,select:focus,textarea:focus{border-color:var(--color-primary)}.container{max-width:1200px;margin:0 auto;padding:20px}@media (max-width: 768px){.container{padding:16px 16px 80px}}.card{background:var(--color-white);border-radius:16px;padding:24px;box-shadow:0 1px 3px var(--color-shadow);border:1px solid var(--color-border)}.btn{padding:12px 24px;border-radius:12px;font-weight:500;font-size:15px;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #22c55e33}.btn-primary:active{transform:translateY(0)}.btn-danger{background:var(--color-danger);color:#fff;padding:8px 16px;font-size:14px}.btn-danger:hover{background:#dc2626}.input-group{margin-bottom:16px}.input-group label{display:block;margin-bottom:6px;font-weight:500;color:var(--color-text);font-size:14px}.input-group input,.input-group select{width:100%;max-width:100%;padding:12px 16px;border-radius:10px;font-size:15px;background:var(--color-white);box-sizing:border-box}.input-group input[type=date],.input-group input[type=month]{max-width:100%;overflow:hidden}@media (max-width: 480px){.input-group input,.input-group select{padding:10px 12px;font-size:14px}}.section-title{font-size:24px;font-weight:600;margin-bottom:20px;color:var(--color-text)}.balance-card{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;border:none;box-shadow:0 4px 20px #22c55e26}.balance-amount{font-size:42px;font-weight:700;margin:12px 0}@media (max-width: 768px){.balance-amount{font-size:36px}}
