.navbar{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:stretch;background:#fff;padding:6px 0;padding-bottom:max(6px,env(safe-area-inset-bottom));box-shadow:0 -4px 20px #0000001a;z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:var(--color-text-light);padding:4px 2px;border-radius:var(--radius-sm);transition:all .2s ease;flex:1;min-width:0}.nav-item:active{transform:scale(.95)}.nav-icon{width:22px;height:22px;stroke-width:2;transition:transform .2s ease;flex-shrink:0}.nav-label{font-size:.65rem;font-weight:600;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.nav-item.active{color:var(--color-primary)}.nav-item.active .nav-icon{transform:scale(1.1)}.nav-item.income.active{color:var(--color-income)}.nav-item.expense.active{color:var(--color-expense)}.nav-item.logout{background:none;border:none;color:var(--color-text-light);min-height:auto;padding:4px 2px}.nav-item.logout:hover{color:var(--color-expense)}.nav-app-title{display:none}@media (min-width: 768px){.navbar{position:fixed;top:0;left:0;bottom:0;right:auto;width:var(--sidebar-width);flex-direction:column;justify-content:flex-start;padding:var(--spacing-md) var(--spacing-sm);box-shadow:4px 0 20px #00000014;gap:var(--spacing-xs)}.nav-app-title{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);margin-bottom:var(--spacing-md);border-bottom:2px solid var(--color-bg);padding-bottom:var(--spacing-md)}.nav-app-logo{width:40px;height:40px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.nav-app-name{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary-dark)}.nav-item{flex-direction:row;justify-content:flex-start;padding:var(--spacing-sm);gap:var(--spacing-sm);border-radius:var(--radius-md);flex:0}.nav-item:hover{background:var(--color-bg)}.nav-item.active{background:#2d5a271a}.nav-icon{width:24px;height:24px}.nav-label{font-size:var(--font-size-sm);margin-top:0}.nav-item.logout{margin-top:auto;padding:var(--spacing-sm);border-top:1px solid var(--color-border);padding-top:var(--spacing-md)}}.btn{font-family:inherit;font-weight:700;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);text-decoration:none}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-size-sm{font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-sm);min-height:44px}.btn-size-md{font-size:var(--font-size-md);padding:var(--spacing-sm) var(--spacing-md);min-height:56px}.btn-size-lg{font-size:clamp(1.1rem,4vw,1.5rem);padding:min(4vw,24px) min(5vw,32px);min-height:64px}.btn-primary:hover:not(:disabled){background:var(--color-primary-light);box-shadow:0 4px 12px #2d5a274d}.btn-income{background:linear-gradient(135deg,var(--color-income) 0%,#16A34A 100%);color:var(--color-text-inverse)}.btn-income:hover:not(:disabled){box-shadow:0 4px 12px #22c55e66}.btn-expense{background:linear-gradient(135deg,var(--color-expense) 0%,#DC2626 100%);color:var(--color-text-inverse)}.btn-expense:hover:not(:disabled){box-shadow:0 4px 12px #ef444466}.btn-outline:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:#2d5a270d}.btn-full{width:100%}.btn-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:btn-spin .8s linear infinite}@keyframes btn-spin{to{transform:rotate(360deg)}}.summary-card{background:#fff;border-radius:var(--radius-lg);padding:min(4vw,24px);box-shadow:0 4px 20px #00000014}.summary-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary-dark);text-align:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px dashed var(--color-border)}.summary-row{display:grid;grid-template-columns:1fr 1fr;gap:min(3vw,16px);margin-bottom:var(--spacing-md)}.summary-item{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-sm);border-radius:var(--radius-md)}.summary-item.income{background:var(--color-income-bg)}.summary-item.expense{background:var(--color-expense-bg)}.summary-label{display:flex;align-items:center;gap:6px;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-light);margin-bottom:var(--spacing-xs)}.summary-value{font-size:var(--font-size-lg);font-weight:700}.summary-item.income .summary-value{color:var(--color-income)}.summary-item.expense .summary-value{color:var(--color-expense)}.summary-net{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);border-radius:var(--radius-md);text-align:center}.summary-net.positive{background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.summary-net.negative{background:linear-gradient(135deg,#fee2e2,#fecaca)}.summary-net-label{display:flex;align-items:center;gap:8px;font-size:var(--font-size-md);font-weight:600;color:var(--color-text-light);margin-bottom:var(--spacing-xs)}.summary-net-value{font-size:clamp(1.75rem,8vw,2.5rem);font-weight:700}.summary-net.positive .summary-net-value{color:var(--color-income)}.summary-net.negative .summary-net-value{color:var(--color-expense)}.transaction-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.transaction-item{display:flex;align-items:flex-start;gap:min(3vw,16px);padding:min(3vw,16px);background:#fff;border-radius:var(--radius-md);box-shadow:0 2px 4px #0000000d;animation:slideIn .3s ease}.transaction-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius-md);flex-shrink:0}.transaction-item.income .transaction-icon{background:var(--color-income-bg);color:var(--color-income)}.transaction-item.expense .transaction-icon{background:var(--color-expense-bg);color:var(--color-expense)}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.transaction-info{flex:1;min-width:0}.transaction-type{display:flex;align-items:center;gap:var(--spacing-xs);font-weight:600;font-size:var(--font-size-md)}.transaction-category{font-weight:400;color:var(--color-text-light);font-size:var(--font-size-sm)}.transaction-date{font-size:var(--font-size-sm);color:var(--color-text-light);margin-top:2px}.transaction-note{font-size:var(--font-size-sm);color:var(--color-text-light);margin-top:var(--spacing-xs);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transaction-right{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-xs)}.transaction-amount{font-size:var(--font-size-md);font-weight:700;white-space:nowrap}.transaction-amount.income{color:var(--color-income)}.transaction-amount.expense{color:var(--color-expense)}.transaction-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;min-height:28px;padding:0;font-size:14px;background:var(--color-expense-bg);color:var(--color-expense);border-radius:var(--radius-sm);opacity:.7}.transaction-delete:hover{opacity:1;background:var(--color-expense);color:#fff}.transaction-empty{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-xl);color:var(--color-text-light);text-align:center}.transaction-empty svg{margin-bottom:var(--spacing-sm);opacity:.5}.store-selector{position:relative;display:inline-block;min-width:200px}.store-selector.single{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-bg-card);border-radius:var(--radius-md);color:var(--color-text);font-weight:500;font-size:.85rem;box-shadow:0 2px 4px var(--color-shadow)}.store-selector.single svg{width:16px;height:16px;flex-shrink:0}.store-selector-trigger{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-height:auto;width:100%}.store-selector-trigger svg:first-child{width:16px;height:16px;flex-shrink:0}.store-selector-trigger:hover{border-color:var(--color-primary);background:var(--color-bg)}.store-selector-trigger.open{border-color:var(--color-primary);border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent}.store-name{text-align:left;white-space:nowrap}.chevron{transition:transform .2s ease;color:var(--color-text-light);width:14px;height:14px;flex-shrink:0}.chevron.rotate{transform:rotate(180deg)}.store-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--color-bg-card);border:2px solid var(--color-primary);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);box-shadow:0 4px 12px var(--color-shadow);z-index:1000;max-height:300px;overflow-y:auto}.store-option{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;background:none;border:none;border-bottom:1px solid var(--color-border);text-align:left;cursor:pointer;transition:background .15s ease;min-height:auto}.store-option:last-child{border-bottom:none}.store-option:hover{background:var(--color-bg)}.store-option.active{background:var(--color-income-bg)}.store-option-name{flex:1;font-weight:500;font-size:.85rem;color:var(--color-text);white-space:nowrap}.store-badge{font-size:.55rem;padding:.1rem .3rem;background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);font-weight:600;text-transform:uppercase;flex-shrink:0}.store-role{font-size:.55rem;padding:.1rem .3rem;border-radius:var(--radius-sm);font-weight:500;flex-shrink:0}.store-role.owner{background:var(--color-income-bg);color:var(--color-income)}.store-role.admin{background:#fef3c7;color:#d97706}.store-role.member{background:#e5e7eb;color:var(--color-text-light)}@media (min-width: 768px){.store-selector{min-width:240px}.store-selector.single{padding:.5rem 1rem;font-size:.95rem}.store-selector.single svg{width:18px;height:18px}.store-selector-trigger{padding:.5rem 1rem;font-size:.95rem}.store-selector-trigger svg:first-child{width:18px;height:18px}.chevron{width:16px;height:16px}.store-option{padding:.5rem 1rem}.store-option-name{font-size:.95rem}.store-badge,.store-role{font-size:.65rem;padding:.15rem .4rem}}.home{padding-bottom:100px}.home-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:var(--spacing-md);color:var(--color-text-light)}@media (min-width: 768px){.home-loading{margin-left:var(--sidebar-width)}}.home-header{text-align:center;padding:var(--spacing-lg) 0 var(--spacing-md)}.home-logo{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;border-radius:var(--radius-lg);margin-bottom:var(--spacing-sm);box-shadow:0 4px 12px #2d5a274d}.home-title{font-size:var(--font-size-xxl);font-weight:700;color:var(--color-primary-dark);margin-bottom:4px}.home-greeting{display:inline-flex;align-items:center;gap:6px;font-size:var(--font-size-md);color:var(--color-primary);font-weight:600;margin-bottom:var(--spacing-sm)}.home-store-selector{display:block;margin-bottom:var(--spacing-xs)}.home-date{font-size:var(--font-size-sm);color:var(--color-text-light);margin-top:var(--spacing-xs)}.home-content,.home-main{display:flex;flex-direction:column}.home-actions{display:grid;grid-template-columns:1fr 1fr;gap:min(3vw,16px);margin-top:var(--spacing-md)}.home-actions a{text-decoration:none}.home-transactions{margin-top:var(--spacing-lg)}@media (min-width: 768px){.home{padding-bottom:var(--spacing-lg)}.home-logo,.home-title{display:none}.home-header{text-align:left;padding:var(--spacing-md) 0;display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-md)}.home-greeting{margin-bottom:0;font-size:var(--font-size-lg)}.home-date{margin-top:0;margin-left:auto;font-size:var(--font-size-md)}.home-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);align-items:start;max-width:1000px;margin:0 auto}.home-main{position:sticky;top:var(--spacing-md)}.home-transactions{margin-top:0;max-height:calc(100vh - 180px);overflow-y:auto;padding-right:var(--spacing-sm)}.home-transactions::-webkit-scrollbar{width:6px}.home-transactions::-webkit-scrollbar-track{background:var(--color-bg);border-radius:3px}.home-transactions::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.home-transactions::-webkit-scrollbar-thumb:hover{background:var(--color-text-light)}}@media (min-width: 1200px){.home-content{max-width:1100px}}@media (min-width: 1600px){.home-content{max-width:none;gap:var(--spacing-xl)}}.input-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-label{font-size:var(--font-size-md);font-weight:600;color:var(--color-text)}.input{font-family:inherit;font-size:var(--font-size-lg);padding:var(--spacing-sm);border:3px solid var(--color-border);border-radius:var(--radius-md);width:100%;min-height:60px;transition:all .2s ease;background:#fff}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #2d5a271a}.input::placeholder{color:var(--color-text-light);font-size:var(--font-size-md)}.input-error{border-color:var(--color-expense)}.input-error:focus{border-color:var(--color-expense);box-shadow:0 0 0 4px #ef44441a}.input-error-text{font-size:var(--font-size-sm);color:var(--color-expense);font-weight:600}.select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:48px}.textarea{min-height:100px;resize:vertical}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.form-page{padding-bottom:100px}.form-header{text-align:center;padding:var(--spacing-lg) var(--spacing-md);margin:0 calc(var(--spacing-sm) * -1);border-radius:0 0 var(--radius-lg) var(--radius-lg);margin-bottom:var(--spacing-md)}.form-header.income{background:linear-gradient(135deg,var(--color-income) 0%,#16A34A 100%);color:#fff}.form-header.expense{background:linear-gradient(135deg,var(--color-expense) 0%,#DC2626 100%);color:#fff}.form-header-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:#fff3;border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.form-title{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-xs)}.form-subtitle{font-size:var(--font-size-md);opacity:.9}.form-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:0 4px 20px #00000014;display:flex;flex-direction:column;gap:var(--spacing-md)}.form-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.form-success{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;animation:fadeIn .3s ease}.form-success .success-icon{color:var(--color-income);margin-bottom:var(--spacing-md);animation:bounceIn .5s ease}@keyframes bounceIn{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.form-success h2{font-size:var(--font-size-xl);color:var(--color-income);margin-bottom:var(--spacing-xs)}.form-success p{color:var(--color-text-light)}.form-no-store{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:var(--spacing-md)}.form-no-store .no-store-icon{color:var(--color-text-light);margin-bottom:var(--spacing-md)}.form-no-store h2{font-size:var(--font-size-xl);color:var(--color-text);margin-bottom:var(--spacing-xs)}.form-no-store p{color:var(--color-text-light);margin-bottom:var(--spacing-lg)}@media (min-width: 768px){.form-page{padding-bottom:var(--spacing-lg);max-width:700px;display:flex;flex-direction:column}.form-header{margin:0;border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);text-align:left}.form-header-icon{margin-bottom:0;width:48px;height:48px;flex-shrink:0}.form-header-info{display:flex;flex-direction:column}.form-title{font-size:var(--font-size-xl);margin-bottom:2px}.form-subtitle{font-size:var(--font-size-sm)}.form-card{flex:1;padding:var(--spacing-lg);display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md) var(--spacing-lg);align-content:start}.form-card>.message{grid-column:1 / -1}.form-card>.input-group:has(.textarea){grid-column:1 / -1}.form-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-sm)}.form-actions button{min-width:140px}.form-success,.form-no-store{min-height:auto;flex:1;justify-content:center}}.summary-page{padding-bottom:100px}.summary-header{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-lg) 0 var(--spacing-sm)}.summary-header-icon{color:var(--color-primary);margin-bottom:var(--spacing-xs)}.summary-page-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary-dark)}.month-selector{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding:var(--spacing-sm);background:#fff;border-radius:var(--radius-lg);box-shadow:0 2px 8px #0000000d}.month-display{display:flex;flex-direction:column;align-items:center;min-width:150px}.month-name{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary-dark)}.month-year{font-size:var(--font-size-sm);color:var(--color-text-light)}.summary-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;gap:var(--spacing-md);color:var(--color-text-light)}@media (min-width: 768px){.summary-loading{margin-left:var(--sidebar-width)}}.spinner-icon{animation:spin 1s linear infinite;color:var(--color-primary)}.summary-transactions{margin-top:var(--spacing-lg)}.section-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary-dark);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-xs)}.section-title:before{content:"";width:4px;height:24px;background:var(--color-primary);border-radius:2px}@media (min-width: 768px){.summary-page{padding-bottom:var(--spacing-lg)}.summary-header{flex-direction:row;justify-content:flex-start;text-align:left;gap:var(--spacing-sm);padding:var(--spacing-md) 0}.summary-content{display:grid;grid-template-columns:350px 1fr;gap:var(--spacing-lg);align-items:start}.summary-transactions{margin-top:0}}.history-page{padding-bottom:100px}.history-header{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-lg) 0 var(--spacing-sm)}.history-header-icon{color:var(--color-primary);margin-bottom:var(--spacing-xs)}.history-page-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary-dark)}.history-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;gap:var(--spacing-md);color:var(--color-text-light)}@media (min-width: 768px){.history-loading{margin-left:var(--sidebar-width)}}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;gap:var(--spacing-md);color:var(--color-text-light)}.empty-icon{opacity:.3}.timeline{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.timeline-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:0 2px 8px #0000000d;cursor:pointer;transition:all .2s ease;position:relative;border-left:4px solid var(--color-border)}.timeline-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.timeline-card.positive{border-left-color:var(--color-income)}.timeline-card.negative{border-left-color:var(--color-expense)}.timeline-date{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-md);font-weight:700;color:var(--color-primary-dark);margin-bottom:var(--spacing-sm);padding-right:28px}.timeline-summary{display:flex;flex-direction:column;gap:6px}.timeline-row{display:flex;justify-content:space-between;align-items:center}.timeline-label{display:flex;align-items:center;gap:4px;font-size:var(--font-size-sm);color:var(--color-text-light)}.timeline-label.income{color:var(--color-income)}.timeline-label.expense{color:var(--color-expense)}.timeline-value{font-size:var(--font-size-md);font-weight:600}.timeline-value.income{color:var(--color-income)}.timeline-value.expense{color:var(--color-expense)}.timeline-value.positive{color:var(--color-income)}.timeline-value.negative{color:var(--color-expense)}.timeline-divider{height:1px;background:var(--color-border);margin:6px 0}.timeline-row.net .timeline-label{font-weight:600;color:var(--color-text)}.timeline-indicator{position:absolute;top:var(--spacing-md);right:var(--spacing-md)}.indicator-positive{color:var(--color-income)}.indicator-negative{color:var(--color-expense)}.timeline-details{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px dashed var(--color-border);animation:fadeIn .2s ease}.details-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-light);margin-bottom:var(--spacing-sm)}.details-list{list-style:none;display:flex;flex-direction:column;gap:8px}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--color-bg);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.detail-info{display:flex;align-items:center;gap:8px}.detail-item.income .detail-info{color:var(--color-income)}.detail-item.expense .detail-info{color:var(--color-expense)}.detail-note{color:var(--color-text)}.detail-actions{display:flex;align-items:center;gap:8px}.detail-amount{font-weight:600}.detail-amount.income{color:var(--color-income)}.detail-amount.expense{color:var(--color-expense)}.detail-delete{width:24px;height:24px;min-height:24px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-light);font-size:12px;cursor:pointer;transition:all .2s}.detail-delete:hover{background:var(--color-expense-bg);border-color:var(--color-expense);color:var(--color-expense)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (min-width: 768px){.history-page{padding-bottom:var(--spacing-lg)}.history-header{flex-direction:row;justify-content:flex-start;text-align:left;gap:var(--spacing-sm);padding:var(--spacing-md) 0}.history-header-icon{margin-bottom:0}.timeline{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-md)}}@media (min-width: 1400px){.timeline{grid-template-columns:repeat(4,1fr)}}@media (min-width: 1600px){.timeline{grid-template-columns:repeat(5,1fr);gap:var(--spacing-lg)}}@media (min-width: 1920px){.timeline{grid-template-columns:repeat(6,1fr)}}.dashboard-page{padding-bottom:100px}.dashboard-header{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-lg) 0 var(--spacing-sm)}.dashboard-header-icon{color:var(--color-primary);margin-bottom:var(--spacing-xs)}.dashboard-page-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary-dark)}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;gap:var(--spacing-md);color:var(--color-text-light)}@media (min-width: 768px){.dashboard-loading{margin-left:var(--sidebar-width)}}.dashboard-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-md);display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:0 2px 8px #0000000d}.stat-card.income{border-top:4px solid var(--color-income)}.stat-card.expense{border-top:4px solid var(--color-expense)}.stat-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-sm)}.stat-card.income .stat-icon{background:var(--color-income-bg);color:var(--color-income)}.stat-card.expense .stat-icon{background:var(--color-expense-bg);color:var(--color-expense)}.stat-info{display:flex;flex-direction:column;gap:4px}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-light)}.stat-value{font-size:var(--font-size-lg);font-weight:700}.stat-card.income .stat-value{color:var(--color-income)}.stat-card.expense .stat-value{color:var(--color-expense)}.net-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center;box-shadow:0 4px 12px #00000014}.net-card.positive{background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.net-card.negative{background:linear-gradient(135deg,#fee2e2,#fecaca)}.net-header{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);font-size:var(--font-size-md);font-weight:600;margin-bottom:var(--spacing-sm)}.net-card.positive .net-header{color:var(--color-income)}.net-card.negative .net-header{color:var(--color-expense)}.net-value{font-size:var(--font-size-xxl);font-weight:700;margin-bottom:var(--spacing-xs)}.net-card.positive .net-value{color:var(--color-primary-dark)}.net-card.negative .net-value{color:#991b1b}.net-status{font-size:var(--font-size-md);display:flex;align-items:center;justify-content:center;gap:6px}.net-card.positive .net-status{color:var(--color-income)}.net-card.negative .net-status{color:var(--color-expense)}.dashboard-section{margin-top:var(--spacing-sm)}.dashboard-section .section-title{font-size:var(--font-size-md);font-weight:700;color:var(--color-primary-dark);margin-bottom:var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-xs)}.highlight-cards{display:flex;flex-direction:column;gap:var(--spacing-sm)}.highlight-card{background:#fff;border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:0 2px 8px #0000000d}.highlight-card.income{border-left:4px solid var(--color-income)}.highlight-card.expense{border-left:4px solid var(--color-expense)}.highlight-label{display:flex;align-items:center;gap:6px;font-size:var(--font-size-sm);color:var(--color-text-light);margin-bottom:4px}.highlight-card.income .highlight-label{color:var(--color-income)}.highlight-card.expense .highlight-label{color:var(--color-expense)}.highlight-date{font-size:var(--font-size-md);font-weight:600;color:var(--color-text)}.highlight-value{font-size:var(--font-size-lg);font-weight:700;margin-top:4px}.highlight-card.income .highlight-value{color:var(--color-income)}.highlight-card.expense .highlight-value{color:var(--color-expense)}.comparison-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:0 2px 8px #0000000d}.comparison-row{display:flex;flex-direction:column;gap:4px;padding:var(--spacing-xs) 0}.comparison-label{font-size:var(--font-size-sm);color:var(--color-text-light);font-weight:600}.comparison-values{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-md)}.comparison-prev,.comparison-arrow{color:var(--color-text-light)}.comparison-current{font-weight:700;color:var(--color-text)}.comparison-current.positive,.comparison-prev.positive{color:var(--color-income)}.comparison-current.negative,.comparison-prev.negative{color:var(--color-expense)}.comparison-change{display:inline-flex;align-items:center;gap:2px;font-size:var(--font-size-sm);font-weight:600;padding:2px 8px;border-radius:var(--radius-full);width:fit-content}.comparison-change.up{background:var(--color-income-bg);color:var(--color-income)}.comparison-change.down{background:var(--color-expense-bg);color:var(--color-expense)}.comparison-divider{height:1px;background:var(--color-border);margin:var(--spacing-xs) 0}.comparison-row.net{padding-top:var(--spacing-sm)}.comparison-row.net .comparison-label{font-size:var(--font-size-md);color:var(--color-text)}.chart-section{grid-column:1 / -1}.chart-container{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:0 2px 8px #0000000d;overflow:visible}.chart-tooltip{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);box-shadow:0 4px 12px #0000001a;font-size:var(--font-size-sm)}.chart-tooltip-label{font-weight:600;margin-bottom:4px;color:var(--color-text)}.pie-chart-container{display:flex;flex-direction:column;gap:var(--spacing-md);overflow:visible}.pie-chart-container .recharts-responsive-container,.pie-chart-container .recharts-wrapper,.pie-chart-container svg{overflow:visible!important}.pie-legend{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:center}.pie-legend-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);background:var(--color-bg);padding:6px 12px;border-radius:var(--radius-md)}.pie-legend-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.pie-legend-label{color:var(--color-text);font-weight:500}.pie-legend-percent{color:var(--color-primary);font-weight:700;font-size:var(--font-size-sm)}.pie-legend-value{color:var(--color-text-light);font-weight:600}.recharts-legend-wrapper{padding-top:var(--spacing-md)!important}.recharts-default-legend{display:flex;justify-content:center;gap:var(--spacing-md)}.recharts-legend-item{display:flex!important;align-items:center;gap:6px}.bar-chart{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:0 2px 8px #0000000d;display:flex;flex-direction:column;gap:10px}.bar-row{display:flex;align-items:center;gap:var(--spacing-sm)}.bar-date{font-size:var(--font-size-sm);color:var(--color-text-light);min-width:24px;text-align:right}.bar-track{flex:1;height:20px;background:var(--color-bg);border-radius:var(--radius-sm);overflow:hidden}.bar-fill{height:100%;border-radius:var(--radius-sm);transition:width .5s ease;min-width:4px}.bar-fill.income{background:linear-gradient(90deg,var(--color-income) 0%,#4ADE80 100%)}.bar-value{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text);min-width:70px;text-align:right}@media (min-width: 768px){.dashboard-page{padding-bottom:var(--spacing-lg)}.dashboard-header{flex-direction:row;justify-content:flex-start;text-align:left;gap:var(--spacing-sm);padding:var(--spacing-md) 0}.dashboard-header-icon{margin-bottom:0}.dashboard-content{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.stats-grid{grid-column:1 / -1;gap:var(--spacing-md)}.stat-card{flex-direction:row;text-align:left;gap:var(--spacing-md);padding:var(--spacing-lg)}.stat-icon{margin-bottom:0}.net-card{grid-column:1 / -1;padding:var(--spacing-xl)}.net-value{font-size:2.5rem}.highlight-cards{flex-direction:row}.highlight-card{flex:1;padding:var(--spacing-lg)}.comparison-row{flex-direction:row;align-items:center;justify-content:space-between}.comparison-card,.bar-chart{padding:var(--spacing-lg)}.bar-track{height:28px}.chart-container{padding:var(--spacing-lg)}.chart-section{grid-column:span 1}.pie-chart-container{flex-direction:column;align-items:center}.pie-legend-item{padding:8px 16px}}@media (min-width: 1200px){.pie-chart-container{flex-direction:row;align-items:center;gap:var(--spacing-lg)}.pie-chart-container>.recharts-responsive-container{flex:0 0 250px;min-width:250px}.pie-legend{flex-direction:column;justify-content:center;flex:1}}@media (min-width: 1200px){.dashboard-content{grid-template-columns:repeat(3,1fr)}.stats-grid{grid-column:span 2}.net-card{grid-column:span 1;display:flex;flex-direction:column;justify-content:center}.dashboard-section .section-title{font-size:var(--font-size-lg)}.chart-section{grid-column:span 2}.chart-section:has(.pie-chart-container){grid-column:span 1}.dashboard-section{grid-column:span 1}}@media (min-width: 1600px){.dashboard-content{grid-template-columns:repeat(4,1fr);gap:var(--spacing-xl)}.stats-grid{grid-column:span 2;grid-template-columns:1fr 1fr}.net-card{grid-column:span 2;flex-direction:row;align-items:center;justify-content:space-around;padding:var(--spacing-xl)}.net-card .net-header{margin-bottom:0}.net-card .net-value{font-size:3rem;margin-bottom:0}.net-card .net-status{font-size:var(--font-size-lg)}.stat-card{padding:var(--spacing-xl)}.stat-icon{width:72px;height:72px}.stat-value{font-size:var(--font-size-xl)}.highlight-card{padding:var(--spacing-xl)}.highlight-value{font-size:var(--font-size-xl)}.chart-section{grid-column:span 2}.chart-container{padding:var(--spacing-xl)}.chart-section:has(.pie-chart-container){grid-column:span 2}.pie-chart-container>.recharts-responsive-container{max-width:350px}.pie-legend-item{padding:10px 16px;font-size:var(--font-size-md)}.dashboard-section:not(.chart-section){grid-column:span 1}}@media (min-width: 1920px){.dashboard-content{grid-template-columns:repeat(4,1fr)}.stats-grid,.net-card,.chart-section{grid-column:span 2}.bar-track{height:32px}.bar-value{font-size:var(--font-size-md);min-width:90px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%)}.login-card{width:100%;max-width:400px;background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:0 10px 40px #0003;animation:fadeInUp .5s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:var(--spacing-lg)}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);box-shadow:0 4px 12px #2d5a274d}.login-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary-dark);margin-bottom:var(--spacing-xs)}.login-subtitle{font-size:var(--font-size-md);color:var(--color-text-light)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.login-form .message{margin-bottom:0}.spinner-icon{animation:spin 1s linear infinite}:root{--color-primary: #2D5A27;--color-primary-light: #4A7C43;--color-primary-dark: #1E3D1A;--color-income: #22C55E;--color-income-bg: #DCFCE7;--color-expense: #EF4444;--color-expense-bg: #FEE2E2;--color-bg: #F5F5DC;--color-bg-card: #FFFFFF;--color-bg-dark: #E8E4D4;--color-text: #1F2937;--color-text-light: #6B7280;--color-text-inverse: #FFFFFF;--color-border: #D1D5DB;--color-shadow: rgba(0, 0, 0, .1);--font-size-sm: 1rem;--font-size-md: 1.25rem;--font-size-lg: 1.5rem;--font-size-xl: 2rem;--font-size-xxl: 2.5rem;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--radius-sm: .5rem;--radius-md: 1rem;--radius-lg: 1.5rem;--radius-full: 9999px;--sidebar-width: 220px}*{margin:0;padding:0;box-sizing:border-box}html{font-size:18px}body{font-family:Sarabun,sans-serif;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-dark) 100%);color:var(--color-text);min-height:100vh;line-height:1.6;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}@media (min-width: 768px){#root{flex-direction:row}}button,.btn{font-family:inherit;font-size:var(--font-size-md);font-weight:600;padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;min-height:56px;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}button:active{transform:scale(.98)}button:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-light)}.btn-income{background:var(--color-income);color:var(--color-text-inverse)}.btn-income:hover:not(:disabled){background:#16a34a}.btn-expense{background:var(--color-expense);color:var(--color-text-inverse)}.btn-expense:hover:not(:disabled){background:#dc2626}.btn-outline{background:transparent;border:2px solid var(--color-border);color:var(--color-text)}.btn-outline:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}input,select,textarea{font-family:inherit;font-size:var(--font-size-md);padding:var(--spacing-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);width:100%;min-height:56px;transition:border-color .2s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary)}input::placeholder{color:var(--color-text-light)}label{display:block;font-size:var(--font-size-md);font-weight:600;margin-bottom:var(--spacing-xs);color:var(--color-text)}.card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:min(4vw,24px);box-shadow:0 4px 6px var(--color-shadow)}.container{width:100%;max-width:100%;margin:0 auto;padding:0 min(4vw,16px);overflow-x:hidden}@media (min-width: 768px){.container{flex:1;max-width:1200px;padding:var(--spacing-md) var(--spacing-lg);margin-left:var(--sidebar-width)}}@media (min-width: 1600px){.container{max-width:1500px}}@media (min-width: 1920px){.container{max-width:none;padding:var(--spacing-md) var(--spacing-xl)}}.page-header{text-align:center;padding:var(--spacing-md) 0}.page-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-primary-dark)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.pulse{animation:pulse 2s infinite}.text-center{text-align:center}.text-income{color:var(--color-income)}.text-expense{color:var(--color-expense)}.text-light{color:var(--color-text-light)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.flex{display:flex}.flex-col{flex-direction:column}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.items-center{align-items:center}.justify-between{justify-content:space-between}.w-full{width:100%}.spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.message{padding:var(--spacing-sm);border-radius:var(--radius-md);font-weight:600;text-align:center}.message-success{background:var(--color-income-bg);color:var(--color-income)}.message-error{background:var(--color-expense-bg);color:var(--color-expense)}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);color:var(--color-text-light)}@media (min-width: 768px){.loading-screen{margin-left:var(--sidebar-width)}}.loading-screen .spinner-icon{animation:spin 1s linear infinite;color:var(--color-primary)}
