/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-primary-400:#818cf8;--color-primary-500:#6366f1;--color-primary-600:#4f46e5;--color-primary-700:#4338ca;--color-success-400:#34d399;--color-success-500:#10b981;--color-success-600:#059669;--color-danger-400:#f87171;--color-danger-500:#ef4444;--color-danger-600:#dc2626;--color-warning-400:#fbbf24;--color-warning-500:#f59e0b;--color-surface-light:#fff;--color-surface-light-secondary:#f8fafc;--color-surface-light-tertiary:#f1f5f9;--color-border-light:#e2e8f0;--color-text-light-primary:#0f172a;--color-text-light-secondary:#475569;--color-text-light-tertiary:#94a3b8;--color-surface-dark:#0f172a;--color-surface-dark-secondary:#1e293b;--color-surface-dark-tertiary:#334155;--color-border-dark:#334155;--color-text-dark-primary:#f1f5f9;--color-text-dark-secondary:#94a3b8;--color-text-dark-tertiary:#64748b;--font-family-sans:"Inter", system-ui, -apple-system, sans-serif}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}*{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-family-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;max-width:100vw!important;overflow-x:hidden!important}html,body,#root{max-width:100vw!important;overflow-x:hidden!important}body{min-height:100vh;transition:background-color .3s,color .3s}body.light{background-color:var(--color-surface-light-secondary);color:var(--color-text-light-primary)}body.dark{background-color:var(--color-surface-dark);color:var(--color-text-dark-primary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}.light ::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.dark ::-webkit-scrollbar-thumb{background:#475569;border-radius:3px}.app-layout{min-height:100vh;display:flex}.main-content{flex:1;min-height:100vh;margin-left:260px;transition:margin-left .3s}@media (width<=768px){.main-content{margin-left:0;padding-bottom:72px}}.page-container{max-width:1400px;margin:0 auto;padding:24px 32px}@media (width<=768px){.page-container{padding:16px}}.sidebar{z-index:40;border-right:1px solid;flex-direction:column;width:260px;transition:background-color .3s,border-color .3s,transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.light .sidebar{background-color:var(--color-surface-light);border-color:var(--color-border-light)}.dark .sidebar{background-color:var(--color-surface-dark-secondary);border-color:var(--color-border-dark)}@media (width<=768px){.sidebar{display:none;transform:translate(-100%)}}.sidebar-logo{border-bottom:1px solid;align-items:center;gap:12px;padding:24px 20px;display:flex}.light .sidebar-logo{border-color:var(--color-border-light)}.dark .sidebar-logo{border-color:var(--color-border-dark)}.sidebar-logo-icon{background:linear-gradient(135deg, var(--color-primary-500), var(--color-primary-700));color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;font-weight:800;display:flex}.sidebar-logo-text{background:linear-gradient(135deg, var(--color-primary-500), var(--color-primary-700));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex}.sidebar-link{cursor:pointer;border-radius:10px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.light .sidebar-link{color:var(--color-text-light-secondary)}.dark .sidebar-link{color:var(--color-text-dark-secondary)}.light .sidebar-link:hover{background-color:var(--color-surface-light-tertiary);color:var(--color-primary-600)}.dark .sidebar-link:hover{background-color:var(--color-surface-dark-tertiary);color:var(--color-primary-400)}.sidebar-link.active{background:linear-gradient(135deg, var(--color-primary-500), var(--color-primary-600));box-shadow:0 4px 12px #6366f14d;color:#fff!important}.sidebar-footer{border-top:1px solid;padding:16px 12px}.light .sidebar-footer{border-color:var(--color-border-light)}.dark .sidebar-footer{border-color:var(--color-border-dark)}.bottom-nav{z-index:50;border-top:1px solid;justify-content:space-around;padding:8px 16px;transition:background-color .3s;display:none;position:fixed;bottom:0;left:0;right:0}.light .bottom-nav{background-color:var(--color-surface-light);border-color:var(--color-border-light)}.dark .bottom-nav{background-color:var(--color-surface-dark-secondary);border-color:var(--color-border-dark)}@media (width<=768px){.bottom-nav{display:flex}}.bottom-nav-link{cursor:pointer;border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:6px 12px;font-size:11px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.light .bottom-nav-link{color:var(--color-text-light-tertiary)}.dark .bottom-nav-link{color:var(--color-text-dark-tertiary)}.bottom-nav-link.active{color:var(--color-primary-500)!important}.header{z-index:30;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid;justify-content:space-between;align-items:center;padding:16px 32px;transition:background-color .3s,border-color .3s;display:flex;position:sticky;top:0}.light .header{border-color:var(--color-border-light);background-color:#ffffffd9}.dark .header{border-color:var(--color-border-dark);background-color:#0f172ad9}@media (width<=768px){.header{padding:12px 16px}}.header-left h1{letter-spacing:-.025em;font-size:24px;font-weight:700}.header-left p{margin-top:2px;font-size:13px}.light .header-left p{color:var(--color-text-light-secondary)}.dark .header-left p{color:var(--color-text-dark-secondary)}.header-actions{align-items:center;gap:12px;display:flex}.role-selector{cursor:pointer;appearance:none;border:1px solid;border-radius:10px;outline:none;align-items:center;gap:8px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.light .role-selector{background-color:var(--color-surface-light-tertiary);border-color:var(--color-border-light);color:var(--color-text-light-primary)}.dark .role-selector{background-color:var(--color-surface-dark-tertiary);border-color:var(--color-border-dark);color:var(--color-text-dark-primary)}.role-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.role-badge.admin{color:var(--color-primary-500);background:#6366f126}.role-badge.viewer{color:var(--color-success-500);background:#10b98126}.theme-toggle{cursor:pointer;border:1px solid;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex}.light .theme-toggle{background-color:var(--color-surface-light-tertiary);border-color:var(--color-border-light);color:var(--color-text-light-secondary)}.dark .theme-toggle{background-color:var(--color-surface-dark-tertiary);border-color:var(--color-border-dark);color:var(--color-warning-400)}.theme-toggle:hover{transform:scale(1.05)}.card{border:1px solid;border-radius:16px;padding:24px;transition:all .3s}.light .card{background-color:var(--color-surface-light);border-color:var(--color-border-light)}.dark .card{background-color:var(--color-surface-dark-secondary);border-color:var(--color-border-dark)}.card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000014}.dark .card:hover{box-shadow:0 8px 25px #0000004d}.summary-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px;display:grid}@media (width<=1024px){.summary-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.summary-grid{grid-template-columns:1fr}}.summary-card{border:1px solid;border-radius:16px;padding:24px;transition:all .3s;position:relative;overflow:hidden}.light .summary-card{background-color:var(--color-surface-light);border-color:var(--color-border-light)}.dark .summary-card{background-color:var(--color-surface-dark-secondary);border-color:var(--color-border-dark)}.summary-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px #00000014}.dark .summary-card:hover{box-shadow:0 12px 30px #0000004d}.summary-card:before{content:"";border-radius:16px 16px 0 0;height:4px;position:absolute;top:0;left:0;right:0}.summary-card.balance:before{background:linear-gradient(90deg, var(--color-primary-400), var(--color-primary-600))}.summary-card.income:before{background:linear-gradient(90deg, var(--color-success-400), var(--color-success-600))}.summary-card.expense:before{background:linear-gradient(90deg, var(--color-danger-400), var(--color-danger-600))}.summary-card.savings:before{background:linear-gradient(90deg, var(--color-warning-400), var(--color-primary-500))}.summary-card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.summary-card-label{font-size:13px;font-weight:500}.light .summary-card-label{color:var(--color-text-light-secondary)}.dark .summary-card-label{color:var(--color-text-dark-secondary)}.summary-card-icon{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.summary-card-icon.balance{color:var(--color-primary-500);background:#6366f11f}.summary-card-icon.income{color:var(--color-success-500);background:#10b9811f}.summary-card-icon.expense{color:var(--color-danger-500);background:#ef44441f}.summary-card-icon.savings{color:var(--color-warning-500);background:#f59e0b1f}.summary-card-value{letter-spacing:-.03em;font-size:28px;font-weight:800;line-height:1}.summary-card-change{border-radius:6px;align-items:center;gap:4px;margin-top:8px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-flex}.summary-card-change.positive{color:var(--color-success-600);background:#10b9811a}.summary-card-change.negative{color:var(--color-danger-500);background:#ef44441a}.charts-grid{grid-template-columns:2fr 1fr;gap:20px;margin-bottom:24px;display:grid}@media (width<=1024px){.charts-grid{grid-template-columns:1fr}}.chart-card{border:1px solid;border-radius:16px;padding:24px;transition:background-color .3s,border-color .3s}.light .chart-card{background-color:var(--color-surface-light);border-color:var(--color-border-light)}.dark .chart-card{background-color:var(--color-surface-dark-secondary);border-color:var(--color-border-dark)}.chart-card-title{margin-bottom:20px;font-size:16px;font-weight:600}.table-container{border:1px solid;border-radius:16px;transition:background-color .3s,border-color .3s;overflow-x:auto}.light .table-container{background-color:var(--color-surface-light);border-color:var(--color-border-light)}.dark .table-container{background-color:var(--color-surface-dark-secondary);border-color:var(--color-border-dark)}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid;padding:14px 20px;font-size:12px;font-weight:600}.light .data-table th{color:var(--color-text-light-tertiary);border-color:var(--color-border-light);background-color:var(--color-surface-light-tertiary)}.dark .data-table th{color:var(--color-text-dark-tertiary);border-color:var(--color-border-dark);background-color:var(--color-surface-dark-tertiary)}.data-table td{border-bottom:1px solid;padding:14px 20px;transition:background-color .15s}.light .data-table td{border-color:var(--color-border-light)}.dark .data-table td{border-color:var(--color-border-dark)}.light .data-table tr:hover td{background-color:var(--color-surface-light-tertiary)}.dark .data-table tr:hover td{background-color:#33415566}.data-table tr:last-child td{border-bottom:none}.amount-cell{font-variant-numeric:tabular-nums;font-weight:600}.amount-cell.income{color:var(--color-success-500)}.amount-cell.expense{color:var(--color-danger-500)}.type-badge{border-radius:6px;align-items:center;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.type-badge.income{color:var(--color-success-500);background:#10b9811f}.type-badge.expense{color:var(--color-danger-500);background:#ef44441f}.category-badge{border-radius:6px;align-items:center;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.light .category-badge{background:var(--color-surface-light-tertiary);color:var(--color-text-light-secondary)}.dark .category-badge{background:var(--color-surface-dark-tertiary);color:var(--color-text-dark-secondary)}.filters-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.search-input{min-width:200px;font-size:14px;font-family:var(--font-family-sans);border:1px solid;border-radius:10px;outline:none;flex:1;padding:10px 16px 10px 40px;transition:all .2s}.light .search-input{background-color:var(--color-surface-light);border-color:var(--color-border-light);color:var(--color-text-light-primary)}.dark .search-input{background-color:var(--color-surface-dark-secondary);border-color:var(--color-border-dark);color:var(--color-text-dark-primary)}.search-input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #6366f126}.search-input::placeholder{color:var(--color-text-light-tertiary)}.dark .search-input::placeholder{color:var(--color-text-dark-tertiary)}.filter-select{cursor:pointer;font-size:14px;font-family:var(--font-family-sans);appearance:none;background-position:right 10px center;background-repeat:no-repeat;background-size:16px;border:1px solid;border-radius:10px;outline:none;padding:10px 32px 10px 12px;transition:all .2s}.light .filter-select{background-color:var(--color-surface-light);border-color:var(--color-border-light);color:var(--color-text-light-primary);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.dark .filter-select{background-color:var(--color-surface-dark-secondary);border-color:var(--color-border-dark);color:var(--color-text-dark-primary);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.filter-select:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #6366f126}.date-input{font-size:14px;font-family:var(--font-family-sans);border:1px solid;border-radius:10px;outline:none;padding:10px 12px;transition:all .2s}.light .date-input{background-color:var(--color-surface-light);border-color:var(--color-border-light);color:var(--color-text-light-primary)}.dark .date-input{background-color:var(--color-surface-dark-secondary);border-color:var(--color-border-dark);color:var(--color-text-dark-primary)}.date-input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #6366f126}.btn{cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font-family-sans);border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn:hover{filter:brightness(1.1);transform:translateY(-2px)}.btn:active{transform:scale(.96)}.btn-primary{background:linear-gradient(135deg, var(--color-primary-500), var(--color-primary-600));color:#fff;box-shadow:0 4px 12px #6366f14d}.btn-primary:hover{box-shadow:0 6px 16px #6366f166}.btn-danger{background:linear-gradient(135deg, var(--color-danger-500), var(--color-danger-600));color:#fff;box-shadow:0 4px 12px #ef44444d}.btn-ghost{background:0 0;border:1px solid;padding:8px 14px;font-size:13px}.light .btn-ghost{border-color:var(--color-border-light);color:var(--color-text-light-secondary)}.dark .btn-ghost{border-color:var(--color-border-dark);color:var(--color-text-dark-secondary)}.btn-ghost:hover{border-color:var(--color-primary-500);color:var(--color-primary-500)}.btn-icon{cursor:pointer;background:0 0;border:1px solid;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;padding:0;transition:all .2s;display:inline-flex}.light .btn-icon{border-color:var(--color-border-light);color:var(--color-text-light-secondary)}.dark .btn-icon{border-color:var(--color-border-dark);color:var(--color-text-dark-secondary)}.btn-icon:hover{border-color:var(--color-primary-500);color:var(--color-primary-500);background:#6366f114}.btn-icon.danger:hover{border-color:var(--color-danger-500);color:var(--color-danger-500);background:#ef444414}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{border:1px solid;border-radius:20px;width:90%;max-width:500px;padding:32px;animation:.3s slideUp}.light .modal{background-color:var(--color-surface-light);border-color:var(--color-border-light)}.dark .modal{background-color:var(--color-surface-dark-secondary);border-color:var(--color-border-dark)}.modal-title{margin-bottom:24px;font-size:20px;font-weight:700}.form-group{margin-bottom:16px}.form-label{margin-bottom:6px;font-size:13px;font-weight:600;display:block}.light .form-label{color:var(--color-text-light-secondary)}.dark .form-label{color:var(--color-text-dark-secondary)}.form-input{width:100%;font-size:14px;font-family:var(--font-family-sans);border:1px solid;border-radius:10px;outline:none;padding:10px 14px;transition:all .2s}.light .form-input{background-color:var(--color-surface-light-tertiary);border-color:var(--color-border-light);color:var(--color-text-light-primary)}.dark .form-input{background-color:var(--color-surface-dark-tertiary);border-color:var(--color-border-dark);color:var(--color-text-dark-primary)}.form-input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #6366f126}.form-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.empty-state{text-align:center;padding:60px 20px}.empty-state-icon{border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;display:flex}.light .empty-state-icon{background:var(--color-surface-light-tertiary);color:var(--color-text-light-tertiary)}.dark .empty-state-icon{background:var(--color-surface-dark-tertiary);color:var(--color-text-dark-tertiary)}.empty-state-title{margin-bottom:8px;font-size:18px;font-weight:600}.empty-state-text{font-size:14px}.light .empty-state-text{color:var(--color-text-light-tertiary)}.dark .empty-state-text{color:var(--color-text-dark-tertiary)}.insights-grid{grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px;display:grid}@media (width<=1024px){.insights-grid{grid-template-columns:1fr}}.insight-card{border:1px solid;border-radius:16px;padding:24px;transition:all .3s}.light .insight-card{background-color:var(--color-surface-light);border-color:var(--color-border-light)}.dark .insight-card{background-color:var(--color-surface-dark-secondary);border-color:var(--color-border-dark)}.insight-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000014}.dark .insight-card:hover{box-shadow:0 8px 25px #0000004d}.progress-bar-outer{border-radius:4px;width:100%;height:8px;overflow:hidden}.light .progress-bar-outer{background-color:var(--color-surface-light-tertiary)}.dark .progress-bar-outer{background-color:var(--color-surface-dark-tertiary)}.progress-bar-inner{border-radius:4px;height:100%;transition:width .8s}.search-wrapper{flex:1;min-width:200px;position:relative}.search-wrapper svg{pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.light .search-wrapper svg{color:var(--color-text-light-tertiary)}.recent-transactions{margin-top:0}.recent-transactions-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.recent-transactions-header h3{font-size:16px;font-weight:600}.recent-transactions-header a{color:var(--color-primary-500);font-size:13px;font-weight:500;text-decoration:none}.recent-transactions-header a:hover{text-decoration:underline}.transaction-item{border-bottom:1px solid;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.light .transaction-item{border-color:var(--color-border-light)}.dark .transaction-item{border-color:var(--color-border-dark)}.transaction-item:last-child{border-bottom:none}.transaction-info{align-items:center;gap:12px;display:flex}.transaction-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.transaction-icon.income{color:var(--color-success-500);background:#10b9811f}.transaction-icon.expense{color:var(--color-danger-500);background:#ef44441f}.transaction-name{font-size:14px;font-weight:500}.transaction-category{font-size:12px}.light .transaction-category{color:var(--color-text-light-tertiary)}.dark .transaction-category{color:var(--color-text-dark-tertiary)}.transaction-amount{font-variant-numeric:tabular-nums;font-size:14px;font-weight:600}.transaction-amount.income{color:var(--color-success-500)}.transaction-amount.expense{color:var(--color-danger-500)}.transaction-date{text-align:right;font-size:12px}.light .transaction-date{color:var(--color-text-light-tertiary)}.dark .transaction-date{color:var(--color-text-dark-tertiary)}.sort-btn{cursor:pointer;text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600;font-family:var(--font-family-sans);background:0 0;border:none;align-items:center;gap:4px;padding:0;display:inline-flex}.light .sort-btn{color:var(--color-text-light-tertiary)}.dark .sort-btn{color:var(--color-text-dark-tertiary)}.sort-btn:hover,.sort-btn.active{color:var(--color-primary-500)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.animate-in{opacity:0;animation:.5s forwards fadeSlideUp}.animate-in:first-child{animation-delay:50ms}.animate-in:nth-child(2){animation-delay:.1s}.animate-in:nth-child(3){animation-delay:.15s}.animate-in:nth-child(4){animation-delay:.2s}.observation-card{border:1px solid;border-radius:16px;align-items:flex-start;gap:16px;margin-top:20px;padding:20px 24px;transition:all .3s;display:flex}.light .observation-card{background:linear-gradient(135deg,#6366f10a,#6366f114);border-color:#6366f133}.dark .observation-card{background:linear-gradient(135deg,#6366f114,#6366f11f);border-color:#6366f140}.observation-icon{width:40px;height:40px;color:var(--color-primary-500);background:#6366f126;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.observation-text{font-size:14px;line-height:1.6}.light .observation-text{color:var(--color-text-light-secondary)}.dark .observation-text{color:var(--color-text-dark-secondary)}.page-title{letter-spacing:-.025em;margin-bottom:24px;font-size:24px;font-weight:700}.transaction-right{text-align:right}.search-wrapper{align-items:center;position:relative;display:flex!important}.search-wrapper svg{color:var(--color-text-light-tertiary);pointer-events:none;position:absolute;left:14px}.dark .search-wrapper svg{color:var(--color-text-dark-tertiary)}.admin-actions{gap:6px;display:flex}.date-cell{white-space:nowrap}@media (width<=768px){.header{flex-direction:column!important;align-items:flex-start!important;gap:12px!important;height:auto!important;padding:16px!important}.header-left{width:100%!important}.header-actions{border-top:1px solid #ffffff0d;justify-content:space-between!important;gap:10px!important;width:100%!important;padding-top:8px!important}.role-selector{flex:1;max-width:120px!important;padding:6px 10px!important;font-size:13px!important}.header-left h1{font-size:20px!important}.greeting-text{font-size:12px}.header-avatar{width:34px;height:34px}.role-badge.hidden-mobile,.hidden-mobile{display:none!important}.visible-mobile{display:flex!important}.table-container{-webkit-overflow-scrolling:touch;width:100%;max-width:100%;margin:0;padding:0;overflow-x:auto}}@media (width<=640px){.app-layout{width:100%!important;max-width:100vw!important;overflow-x:hidden!important}.data-table th,.data-table td{padding:12px 10px!important;font-size:13px!important}.category-badge{white-space:nowrap!important;padding:2px 6px!important;font-size:11px!important}.data-table th:nth-child(3),.data-table td:nth-child(3),.data-table th:nth-child(5),.data-table td:nth-child(5){display:none!important}.admin-actions{display:flex;flex-direction:column!important;gap:4px!important}.date-cell{max-width:60px;white-space:normal!important}.filters-bar{flex-direction:column!important;gap:12px!important;margin-bottom:24px!important;display:flex!important}.search-wrapper,.filter-select,.date-input,.btn-ghost{width:100%!important}.search-input{flex:1!important;width:100%!important}.btn-ghost{justify-content:center!important}}.text-truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
