@import"https://fonts.googleapis.com/css2?family=Merriweather:wght@400;600&family=Nunito:wght@400;600;700&display=swap";.account-form-group select,.account-form-row .account-form-group select{appearance:none;background-color:var(--white);background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-4) center;padding-right:var(--space-8);cursor:pointer;color:var(--ink);font-weight:500}.settings-container{max-width:800px;margin:0 auto;padding:var(--space-6) var(--space-4)}.settings-section{margin-bottom:var(--space-8)}.section-title{font-family:var(--font-serif);font-size:var(--text-2xl);font-weight:600;color:var(--forest);margin-bottom:var(--space-3)}.section-description{font-size:var(--text-base);color:var(--ink);line-height:1.6;margin-bottom:var(--space-6)}.settings-card{background:var(--white);border:1px solid var(--medium-gray);border-radius:var(--card-radius);padding:var(--space-6);margin-bottom:var(--space-4);box-shadow:var(--shadow-sm)}.settings-card-danger{border-left:4px solid var(--error)}.settings-card-warning{border-left:4px solid var(--soft-gold);background-color:var(--bg-warning-light)}.settings-card-header{margin-bottom:var(--space-4)}.settings-card-title{font-family:var(--font-serif);font-size:var(--text-xl);font-weight:600;color:var(--ink);margin-bottom:var(--space-2)}.settings-card-description{font-size:var(--text-sm);color:var(--medium-gray);line-height:1.5}.settings-card .card-actions{display:flex;flex-direction:column;gap:var(--space-3);padding:0}.btn-primary{background-color:var(--forest);color:var(--cream);border:none;border-radius:var(--input-radius);padding:var(--space-3) var(--space-6);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all .15s ease;min-height:44px}.btn-primary:hover:not(:disabled){background-color:var(--dark-forest);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background-color:transparent;color:var(--forest);border:2px solid var(--forest);border-radius:var(--input-radius);padding:var(--space-3) var(--space-6);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all .15s ease;min-height:44px}.btn-secondary:hover{background-color:var(--forest);color:var(--cream)}.btn-destructive{background-color:transparent;color:var(--error);border:2px solid var(--error);border-radius:var(--input-radius);padding:var(--space-3) var(--space-6);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all .15s ease;min-height:44px}.btn-destructive:hover:not(:disabled){background-color:var(--error);color:var(--white)}.btn-destructive:disabled{opacity:.5;cursor:not-allowed}.btn-destructive:focus-visible{outline:3px solid var(--error);outline-offset:2px;box-shadow:0 0 0 4px #dc26261a}.btn-secondary:focus-visible{outline:3px solid var(--forest);outline-offset:2px;box-shadow:0 0 0 4px var(--focus-ring-forest)}.success-message{color:var(--leaf);font-size:var(--text-sm);font-weight:600;margin:0}.delete-confirm{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4);background-color:var(--bg-error-light);border-radius:var(--input-radius);border:1px solid var(--error)}.warning-text{color:var(--error);font-size:var(--text-sm);font-weight:600;margin:0}.confirm-input-group{display:flex;flex-direction:column;gap:var(--space-2)}.confirm-input-group label{font-size:var(--text-sm);color:var(--ink);font-weight:600}.confirm-input{border:2px solid var(--medium-gray);border-radius:var(--input-radius);padding:var(--space-3);font-size:var(--text-base);font-family:var(--font-sans);transition:border-color .15s ease;min-height:44px}.confirm-input:focus{outline:none;border-color:var(--forest);box-shadow:0 0 0 3px var(--focus-ring-forest)}.button-group{display:flex;gap:var(--space-3);justify-content:flex-end}.button-group button{flex:0 0 auto}.legal-links{display:flex;flex-direction:column;gap:var(--space-2)}.legal-link{color:var(--forest);text-decoration:none;font-size:var(--text-base);padding:var(--space-2) 0;border-bottom:1px solid transparent;transition:border-color .15s ease;display:inline-block;width:fit-content}.legal-link:hover{border-bottom-color:var(--forest)}.confirm-actions{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4);background-color:var(--light-gray);border-radius:var(--input-radius);border:1px solid var(--medium-gray)}.info-text{font-size:var(--text-sm);color:var(--dark-gray);margin:0;line-height:1.5}.loading-state{padding:var(--space-6);text-align:center}.loading-text{font-size:var(--text-base);color:var(--medium-gray);font-style:italic;margin:0}.profile-info{display:flex;flex-direction:column;gap:var(--space-4)}.info-row{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-3) 0;border-bottom:1px solid var(--light-gray);gap:var(--space-4)}.info-row:last-child{border-bottom:none}.info-label{font-size:var(--text-base);font-weight:600;color:var(--dark-gray);flex-shrink:0;min-width:140px}.info-value{font-size:var(--text-base);color:var(--ink);text-align:right;word-break:break-word}.preference-display{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);padding:0}.preference-value{font-size:var(--text-base);color:var(--ink);font-weight:500;padding:0}.preference-edit{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4);background-color:var(--light-gray);border-radius:var(--input-radius);border:1px solid var(--medium-gray)}.edit-label{font-size:var(--text-sm);font-weight:600;color:var(--ink)}.currency-select,.month-input,.timezone-select,.month-select,.year-select{border:2px solid var(--medium-gray);border-radius:var(--input-radius);padding:var(--space-3);font-size:var(--text-base);font-family:var(--font-sans);background-color:var(--white);color:var(--ink);transition:border-color .15s ease;min-height:44px;width:100%}.currency-select:focus,.month-input:focus,.timezone-select:focus,.month-select:focus,.year-select:focus{outline:none;border-color:var(--forest);box-shadow:0 0 0 3px var(--focus-ring-forest)}.currency-select:hover,.timezone-select:hover,.month-select:hover,.year-select:hover{border-color:var(--forest)}.month-year-picker{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-4)}.picker-field{display:flex;flex-direction:column;gap:var(--space-2)}.picker-label{font-size:var(--text-sm);font-weight:600;color:var(--dark-gray)}.save-success-banner{background-color:var(--leaf);color:var(--white);padding:var(--space-4);border-radius:var(--input-radius);font-size:var(--text-base);font-weight:600;margin-bottom:var(--space-4);text-align:center;box-shadow:var(--shadow-sm)}.session-card{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4)}.session-info{flex:1}.session-details{margin-top:var(--space-3);color:var(--medium-gray);font-size:var(--text-sm)}.session-details p{margin:var(--space-2) 0}.current-session-badge{color:var(--leaf);font-size:.8em;margin-right:var(--space-2)}.settings-card-warning{border-left:4px solid var(--soft-gold);background-color:var(--cream)}.confirm-actions{width:100%}.warning-text{color:var(--ink);margin-bottom:var(--space-4);font-size:var(--text-sm)}@media (max-width: 768px){.settings-container{padding:var(--space-4) var(--space-3)}.settings-card{padding:var(--space-4)}.button-group{flex-direction:column}.button-group button{width:100%}.preference-display{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.preference-display button{width:100%}.info-row{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.info-label{min-width:auto}.info-value{text-align:left}.month-year-picker{grid-template-columns:1fr}.session-card{flex-direction:column;align-items:flex-start}.session-card .card-actions,.session-card .card-actions button{width:100%}}:root{--forest: #234E3F;--leaf: #6CA86C;--cream: #FDFBF7;--soft-gold: #D8B56A;--ink: #22302A;--white: #FFFFFF;--light-gray: #F9FAFB;--medium-gray: #6B7280;--dark-gray: #374151;--error: #DC2626;--success: #059669;--warning: #D97706;--dark-bg: #0D1117;--dark-surface: #161B22;--dark-surface-hover: #21262D;--dark-border: #30363D;--dark-text: #F0F6FC;--dark-text-secondary: #8B949E;--dark-forest: #4A9660;--dark-leaf: #7DC8A4;--dark-cream: #21262D;--bg-warning-light: #fffbf0;--bg-error-light: #fff5f5;--focus-ring-forest: rgba(35, 78, 63, .1);--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 20px;--text-xl: 24px;--text-2xl: 32px;--text-3xl: 44px;--font-serif: "Merriweather", serif;--font-sans: "Nunito", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "SF Mono", "Monaco", "Inconsolata", "Roboto Mono", monospace;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-6: 24px;--space-8: 32px;--space-12: 48px;--card-radius: 18px;--input-radius: 11px;--button-radius: 12px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-full: 9999px;--container-width: 1200px;--sidebar-width: 240px;--sidebar-collapsed-width: 64px;--header-height: 88px;--content-padding: var(--space-8);--shadow-sm: 0 1px 3px rgba(34, 48, 42, .1);--shadow-md: 0 4px 12px rgba(34, 48, 42, .1);--shadow-lg: 0 8px 24px rgba(34, 48, 42, .12);--transition-fast: .15s ease-out;--transition-base: .2s ease-out;--transition-slow: .3s ease-out;--transition-bounce: .3s cubic-bezier(.68, -.55, .265, 1.55);--z-sidebar: 100;--z-header: 200;--z-dropdown: 1000;--z-modal: 2000;--z-toast: 3000;--z-tooltip: 4000}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.6;color:var(--ink);background-color:var(--cream);transition:background-color var(--transition-base),color var(--transition-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:focus{outline:2px solid var(--forest);outline-offset:2px}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid var(--forest);outline-offset:2px}::selection{background-color:var(--leaf);color:var(--white)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--light-gray)}::-webkit-scrollbar-thumb{background:var(--medium-gray);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--dark-gray)}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:400;line-height:1.2;margin-bottom:var(--space-4);color:var(--forest)}p{margin-bottom:var(--space-4)}.heading-1{font-family:var(--font-serif);font-size:var(--text-3xl);font-weight:400;color:var(--ink);line-height:1.2}.heading-2{font-family:var(--font-serif);font-size:var(--text-xl);font-weight:600;color:var(--ink);line-height:1.3}.heading-3{font-family:var(--font-serif);font-size:var(--text-lg);font-weight:600;color:var(--ink);line-height:1.3}.heading-4{font-family:var(--font-serif);font-size:var(--text-base);font-weight:600;color:var(--ink);line-height:1.4}.heading-5{font-family:var(--font-serif);font-size:var(--text-sm);font-weight:600;color:var(--ink);line-height:1.4}.heading-6{font-family:var(--font-serif);font-size:var(--text-xs);font-weight:600;color:var(--ink);line-height:1.4}.text-large{font-size:var(--text-lg);color:var(--medium-gray)}.text-medium,.text-base{font-size:var(--text-base);color:var(--ink)}.text-small{font-size:var(--text-sm);color:var(--medium-gray)}a{color:var(--forest);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--leaf)}ul,ol{padding-left:var(--space-6);margin-bottom:var(--space-4)}li{margin-bottom:var(--space-2)}img{max-width:100%;height:auto}.skip-link{position:absolute;top:-40px;left:6px;background:var(--forest);color:var(--white);padding:8px;border-radius:var(--radius-sm);text-decoration:none;z-index:var(--z-tooltip);transition:top var(--transition-fast)}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.container{width:100%;max-width:var(--container-width);margin:0 auto;padding:0 var(--content-padding)}.container-fluid{width:100%;padding:0 var(--content-padding)}.container-narrow{max-width:800px}.container-wide{max-width:1400px}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.flex-1{flex:1}.flex-auto{flex:1 1 auto}.flex-none{flex:none}.flex-shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-evenly{justify-content:space-evenly}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}.self-auto{align-self:auto}.self-start{align-self:flex-start}.self-end{align-self:flex-end}.self-center{align-self:center}.self-stretch{align-self:stretch}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.col-span-1{grid-column:span 1 / span 1}.col-span-2{grid-column:span 2 / span 2}.col-span-3{grid-column:span 3 / span 3}.col-span-4{grid-column:span 4 / span 4}.col-span-5{grid-column:span 5 / span 5}.col-span-6{grid-column:span 6 / span 6}.col-span-full{grid-column:1 / -1}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.gap-12{gap:var(--space-12)}.m-0{margin:0}.m-auto{margin:auto}.mx-auto{margin-left:auto;margin-right:auto}.my-auto{margin-top:auto;margin-bottom:auto}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mt-12{margin-top:var(--space-12)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.mb-12{margin-bottom:var(--space-12)}.ml-1{margin-left:var(--space-1)}.ml-2{margin-left:var(--space-2)}.ml-3{margin-left:var(--space-3)}.ml-4{margin-left:var(--space-4)}.ml-6{margin-left:var(--space-6)}.ml-8{margin-left:var(--space-8)}.ml-12{margin-left:var(--space-12)}.mr-1{margin-right:var(--space-1)}.mr-2{margin-right:var(--space-2)}.mr-3{margin-right:var(--space-3)}.mr-4{margin-right:var(--space-4)}.mr-6{margin-right:var(--space-6)}.mr-8{margin-right:var(--space-8)}.mr-12{margin-right:var(--space-12)}.p-0{padding:0}.pt-1{padding-top:var(--space-1)}.pt-2{padding-top:var(--space-2)}.pt-3{padding-top:var(--space-3)}.pt-4{padding-top:var(--space-4)}.pt-6{padding-top:var(--space-6)}.pt-8{padding-top:var(--space-8)}.pt-12{padding-top:var(--space-12)}.pb-1{padding-bottom:var(--space-1)}.pb-2{padding-bottom:var(--space-2)}.pb-3{padding-bottom:var(--space-3)}.pb-4{padding-bottom:var(--space-4)}.pb-6{padding-bottom:var(--space-6)}.pb-8{padding-bottom:var(--space-8)}.pb-12{padding-bottom:var(--space-12)}.pl-1{padding-left:var(--space-1)}.pl-2{padding-left:var(--space-2)}.pl-3{padding-left:var(--space-3)}.pl-4{padding-left:var(--space-4)}.pl-6{padding-left:var(--space-6)}.pl-8{padding-left:var(--space-8)}.pl-12{padding-left:var(--space-12)}.pr-1{padding-right:var(--space-1)}.pr-2{padding-right:var(--space-2)}.pr-3{padding-right:var(--space-3)}.pr-4{padding-right:var(--space-4)}.pr-6{padding-right:var(--space-6)}.pr-8{padding-right:var(--space-8)}.pr-12{padding-right:var(--space-12)}.px-1{padding-left:var(--space-1);padding-right:var(--space-1)}.px-2{padding-left:var(--space-2);padding-right:var(--space-2)}.px-3{padding-left:var(--space-3);padding-right:var(--space-3)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.px-8{padding-left:var(--space-8);padding-right:var(--space-8)}.py-1{padding-top:var(--space-1);padding-bottom:var(--space-1)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-3{padding-top:var(--space-3);padding-bottom:var(--space-3)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.py-6{padding-top:var(--space-6);padding-bottom:var(--space-6)}.py-8{padding-top:var(--space-8);padding-bottom:var(--space-8)}.w-auto{width:auto}.w-1\/2{width:50%}.w-1\/3{width:33.333333%}.w-2\/3{width:66.666667%}.w-1\/4{width:25%}.w-3\/4{width:75%}.w-fit{width:fit-content}.h-full{height:100%}.h-auto{height:auto}.h-screen{height:100vh}.h-fit{height:fit-content}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.static{position:static}.block{display:block}.inline{display:inline}.inline-block{display:inline-block}.hidden{display:none}.text-left{text-align:left}.text-center{text-align:center}.text-justify{text-align:justify}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-scroll{overflow:scroll}.overflow-visible{overflow:visible}.page-layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:var(--content-padding)}@media (max-width: 768px){.container{padding:0 var(--space-4)}.md\:hidden{display:none}.md\:flex{display:flex}.md\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}.header-content{display:flex;align-items:center;justify-content:space-between;height:64px}.header-content .logo{display:flex;align-items:center}.header-content .logo svg{height:75px;width:auto}.user-profile{display:flex;align-items:center;gap:var(--space-3);color:var(--dark-gray);font-size:var(--text-sm)}.avatar{width:32px;height:32px;background:var(--leaf);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:600}.nav{background:var(--white);border-bottom:1px solid #E5E7EB}.nav-content{display:flex;gap:var(--space-8)}.nav-item{padding:var(--space-4) 0;border-bottom:3px solid transparent;color:var(--medium-gray);text-decoration:none;font-weight:600;transition:all .2s ease}.nav-item:hover{color:var(--forest)}.nav-item.active{color:var(--forest);border-bottom-color:var(--forest)}@media (max-width: 480px){.container{padding:0 var(--space-3)}.sm\:hidden{display:none}.sm\:flex{display:flex}.sm\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.sm\:text-center{text-align:center}}.text-muted{color:var(--medium-gray)}.app-shell{display:grid;grid-template-areas:"sidebar header" "sidebar main";grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:var(--header-height) 1fr;height:100vh;width:100vw;overflow:hidden;background-color:var(--cream)}.app-shell.sidebar-collapsed{grid-template-columns:var(--sidebar-collapsed-width) 1fr}.app-shell .sidebar,.app-shell .app-sidebar{grid-area:sidebar;background-color:var(--white);border-right:1px solid var(--light-gray);overflow-y:auto;display:flex;flex-direction:column;z-index:var(--z-sidebar);position:relative}.app-shell .header,.app-shell .app-header{grid-area:header;background-color:var(--white);border-bottom:1px solid var(--light-gray);display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-4) var(--space-4) var(--space-4) 48px;z-index:var(--z-header);overflow:visible;box-shadow:var(--shadow-sm)}.app-shell .main,.app-shell .main-content,.app-shell .app-content{grid-area:main;overflow-y:auto;overflow-x:hidden;background-color:var(--cream);padding:var(--space-8) var(--space-8) var(--space-8) 48px;min-width:0}.header .page-header{display:flex;align-items:flex-start;gap:var(--space-4)}.header .page-header>div{display:flex;flex-direction:column;gap:var(--space-1)}.header .page-title{font-family:Merriweather,serif;font-size:var(--text-xl);font-weight:600;color:var(--forest);margin:0;line-height:1;padding-top:6px}.header .page-subtitle{font-size:var(--text-sm);color:var(--medium-gray);margin:0;line-height:1.4}.header .header-actions{display:flex;align-items:flex-start;gap:var(--space-4)}.sidebar .sidebar-header{padding:var(--space-4);border-bottom:1px solid var(--light-gray);display:flex;align-items:flex-start;gap:var(--space-4);flex-shrink:0}.sidebar-header .logo{display:block;width:48px;height:48px;flex-shrink:0}.sidebar-header .logo-text{font-family:Merriweather,serif;font-size:28px;font-weight:600;color:var(--forest);line-height:1;flex-shrink:0;padding-top:10px}.sidebar .user-menu{padding:var(--space-4) var(--space-4);border-bottom:1px solid var(--light-gray);position:relative;flex-shrink:0;overflow:visible}.user-menu-trigger{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);background:var(--cream);border:1px solid var(--light-gray);border-radius:var(--button-radius);cursor:pointer;transition:all .2s ease;text-align:left}.user-menu-trigger:hover{background:var(--light-gray);border-color:var(--medium-gray)}.user-menu-trigger:disabled{cursor:not-allowed;opacity:.6}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--forest);color:var(--white);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:600;font-size:14px}.user-initials{display:block}.user-email{flex:1;min-width:0;font-size:14px;color:var(--dark-gray);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-trigger:hover .user-email{color:var(--ink)}.user-menu-trigger .dropdown-icon{flex-shrink:0;color:var(--medium-gray);transition:transform .2s ease}.user-menu-trigger[aria-expanded=true] .dropdown-icon{transform:rotate(180deg)}.user-menu-dropdown{position:absolute;top:100%;left:var(--space-4);right:var(--space-4);margin-top:var(--space-2);background:var(--white);border:1px solid var(--light-gray);border-radius:var(--button-radius);box-shadow:var(--shadow-md);z-index:var(--z-dropdown);overflow:hidden}.user-menu-dropdown .menu-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);width:100%;background:none;border:none;text-decoration:none;color:var(--dark-gray);font-size:15px;cursor:pointer;transition:background-color .15s ease;text-align:left}.user-menu-dropdown .menu-item:hover{background:var(--cream)}.user-menu-dropdown .menu-item:active{background:var(--light-gray)}.user-menu-dropdown .menu-item-logout{color:var(--danger);border-top:1px solid var(--light-gray)}.user-menu-dropdown .menu-item-logout:hover{background:#dc26260d}.user-menu-dropdown .menu-item:disabled{opacity:.5;cursor:not-allowed}.sidebar-collapsed .user-menu{padding:var(--space-4) var(--space-2);overflow:visible}.sidebar-collapsed .user-menu-trigger{padding:var(--space-2);justify-content:center}.sidebar-collapsed .user-email,.sidebar-collapsed .user-menu-trigger .dropdown-icon{display:none}.sidebar-collapsed .user-menu-dropdown{width:200px;left:auto;right:auto;margin-top:0}@media (max-width: 768px){.user-menu-dropdown{left:var(--space-4);right:var(--space-4)}}.sidebar-toggle{display:none;position:absolute;top:96px;right:var(--space-3);transform:translateY(-50%);width:32px;height:32px;padding:0;background:var(--white);border:1px solid var(--light-gray);border-radius:var(--button-radius);cursor:pointer;color:var(--dark-gray);opacity:0;transition:opacity .15s ease,background-color .15s ease,border-color .15s ease,color .15s ease;z-index:10;box-shadow:0 1px 3px #0000001a;will-change:opacity;display:flex;align-items:center;justify-content:center}.sidebar:hover .sidebar-toggle,.app-sidebar:hover .sidebar-toggle{opacity:1}.sidebar-toggle:hover{background:var(--forest);border-color:var(--forest);color:var(--white);box-shadow:0 2px 4px #234e3f33}.sidebar-toggle:active{background:var(--ink);border-color:var(--ink)}.sidebar-toggle:focus-visible{opacity:1;outline:2px solid var(--forest);outline-offset:2px}.sidebar-toggle svg{display:block;width:16px;height:16px;stroke-width:2.5}@media (min-width: 769px){.sidebar-toggle{display:flex}}.sidebar-collapsed .sidebar,.sidebar-collapsed .app-sidebar{width:var(--sidebar-collapsed-width);min-width:var(--sidebar-collapsed-width);max-width:var(--sidebar-collapsed-width);overflow-y:auto;overflow-x:visible;z-index:var(--z-dropdown)}.sidebar-collapsed .sidebar-header{justify-content:center;padding:var(--space-6) 0;display:flex;align-items:center}.sidebar-collapsed .logo-text{display:none}.sidebar-collapsed .sidebar-toggle{right:50%;transform:translate(50%,-50%)}.sidebar-collapsed .nav-item{justify-content:center;padding:var(--space-3) 0;overflow:hidden;width:100%;display:flex;align-items:center}.sidebar-collapsed .nav-item span,.sidebar-collapsed .nav-badge{display:none}.sidebar-collapsed .nav-item svg{margin-right:0}.sidebar .nav-menu{flex:1;padding:var(--space-6) 0;overflow-y:auto}.sidebar .nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-6);color:var(--dark-gray);text-decoration:none;border-radius:0;transition:all .2s ease;font-size:17px;font-weight:400;cursor:pointer}.sidebar .nav-item:hover{background-color:var(--light-gray);color:var(--forest)}.sidebar .nav-item.active{background-color:var(--forest);color:var(--white);font-weight:600}.sidebar .nav-icon{width:24px;height:24px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar .nav-icon svg{width:100%;height:100%;stroke:currentColor}.main .content-container,.main-content .content-container{max-width:var(--container-width);margin:0 auto;width:100%}.main .page-section,.main-content .page-section{background-color:var(--white);border-radius:var(--card-radius);padding:var(--space-8);margin-bottom:var(--space-6);box-shadow:var(--shadow-sm);border:1px solid var(--light-gray)}.page-section .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.page-section .section-title{font-family:Merriweather,serif;font-size:var(--text-xl);font-weight:600;color:var(--forest);margin:0}.page-section .section-actions{display:flex;gap:var(--space-3)}@media (max-width: 768px){.app-shell,.app-shell.sidebar-collapsed{grid-template-areas:"sidebar header" "sidebar main";grid-template-columns:var(--sidebar-collapsed-width) 1fr!important;grid-template-rows:auto 1fr;gap:0}.app-shell .sidebar,.app-shell .app-sidebar{width:var(--sidebar-collapsed-width);min-width:var(--sidebar-collapsed-width);max-width:var(--sidebar-collapsed-width);border-right:none}.sidebar-header,.app-sidebar .sidebar-header{justify-content:center;padding:var(--space-6) 0}.logo-text{display:none}.nav-item{justify-content:center;padding:var(--space-3) 0}.nav-item span,.nav-badge{display:none}.nav-item svg{margin-right:0}.user-menu{padding:var(--space-4) var(--space-2)}.user-menu-trigger{padding:var(--space-2);justify-content:center}.user-email,.user-menu-trigger .dropdown-icon{display:none}.app-shell .main,.app-shell .main-content{padding:var(--space-3) var(--space-3) var(--space-3) 0}.page-section{padding:var(--space-6)}.app-shell .header,.app-shell .app-header{padding:var(--space-3) var(--space-3) var(--space-3) 0;flex-direction:column;align-items:stretch;gap:var(--space-3)}.header .page-header{width:100%}.header .page-title{font-size:var(--text-lg);padding-top:0}.header .header-actions{width:100%;flex-direction:column;gap:var(--space-2);align-items:stretch}.header .header-actions button{width:100%;min-width:0}}@media (min-width: 769px) and (max-width: 1024px){.logo-text{display:none}.sidebar-header,.app-sidebar .sidebar-header{justify-content:center}}@media (min-width: 1920px){.main .content-container,.main-content .content-container{max-width:1400px}}.sidebar,.app-sidebar{transition:width .3s ease}.app-shell{transition:grid-template-columns .3s ease}.mobile-menu-toggle{display:none;align-items:center;justify-content:center;width:48px;height:48px;padding:0;margin-right:var(--space-4);background:none;border:none;color:var(--forest);cursor:pointer;flex-shrink:0}.mobile-menu-toggle:hover{background:var(--light-gray);border-radius:var(--button-radius)}.mobile-menu-toggle:active{background:var(--medium-gray)}.mobile-menu-close{display:none;position:absolute;top:var(--space-4);right:var(--space-4);align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:none;border:none;color:var(--dark-gray);cursor:pointer;z-index:10}.mobile-menu-close:hover{background:var(--light-gray);border-radius:var(--button-radius);color:var(--forest)}.mobile-menu-close:active{background:var(--medium-gray)}.mobile-menu-backdrop{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;z-index:var(--z-sidebar);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.nav-item-disabled{cursor:not-allowed;opacity:.6;background:none;border:none;width:100%;text-align:left;font-family:inherit;font-size:inherit;padding:var(--space-3) var(--space-6)}.nav-item-disabled:hover{background:var(--light-gray);color:var(--dark-gray)}@media (max-width: 768px){.mobile-menu-toggle,.mobile-menu-close,.mobile-menu-backdrop{display:none!important}}.nav-item:focus-visible{outline:2px solid var(--forest);outline-offset:-2px}.header-actions button:focus-visible{outline:2px solid var(--forest);outline-offset:2px}.mobile-menu-toggle:focus-visible,.mobile-menu-close:focus-visible{outline:2px solid var(--forest);outline-offset:2px}@media print{.app-shell{display:block;height:auto;overflow:visible}.sidebar,.app-sidebar{display:none}.header,.app-header{position:static;border-bottom:2px solid var(--ink)}.main,.main-content{overflow:visible;padding:0}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border:none;border-radius:var(--button-radius);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;line-height:1;text-decoration:none;cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--forest);color:var(--white)}.btn-primary:hover:not(:disabled){background-color:var(--leaf);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--light-gray);color:var(--forest);border:1px solid var(--medium-gray)}.btn-secondary:hover:not(:disabled){background-color:var(--medium-gray);color:var(--white)}.btn-outline{background-color:transparent;color:var(--forest);border:2px solid var(--forest)}.btn-outline:hover:not(:disabled){background-color:var(--forest);color:var(--white)}.btn-danger{background-color:var(--error);color:var(--white)}.btn-danger:hover:not(:disabled){background-color:#b91c1c}.btn-success{background-color:var(--success);color:var(--white)}.btn-success:hover:not(:disabled){background-color:#047857}.btn-warning{background-color:var(--warning);color:var(--white)}.btn-warning:hover:not(:disabled){background-color:#b45309}.btn-accent{background-color:var(--soft-gold);color:var(--ink)}.btn-accent:hover:not(:disabled){background-color:#c69c6d;color:var(--white)}.btn-ghost{background-color:transparent;color:var(--forest);border:none}.btn-ghost:hover:not(:disabled){background-color:#234e3f1a}.btn-error{background-color:var(--error);color:var(--white)}.btn-error:hover:not(:disabled){background-color:#b91c1c}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-lg)}.btn-xs{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);min-height:24px}.btn-spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:currentColor}.btn-icon-left{margin-right:var(--space-2)}.btn-icon-right{margin-left:var(--space-2)}.w-full{width:100%}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:600;color:var(--forest)}.form-input{width:100%;padding:var(--space-3);border:1px solid var(--medium-gray);border-radius:var(--input-radius);font-family:var(--font-sans);font-size:var(--text-base);background-color:var(--white);color:var(--ink);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--forest);box-shadow:0 0 0 3px #234e3f1a}.form-input::placeholder{color:var(--medium-gray)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236B7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right var(--space-3) center;background-repeat:no-repeat;background-size:16px 16px;padding-right:var(--space-12)}.form-textarea{resize:vertical;min-height:100px}.form-error{display:block;margin-top:var(--space-2);font-size:var(--text-sm);color:var(--error)}.form-helper{display:flex;justify-content:flex-end;margin-top:var(--space-1)}.character-count{font-size:var(--text-xs);color:var(--medium-gray);font-weight:500}.form-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--light-gray)}.custom-select{position:relative;display:inline-block;width:100%}.custom-select-button{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border:2px solid var(--light-gray);border-radius:var(--input-radius);background:var(--white);font-size:var(--text-base);font-family:inherit;color:var(--ink);cursor:pointer;transition:all var(--transition-fast);text-align:left}.custom-select-button:hover{border-color:var(--medium-gray)}.custom-select-button:focus{outline:none;border-color:var(--forest);box-shadow:0 0 0 3px #234e3f1a}.custom-select-open .custom-select-button{border-color:var(--forest);box-shadow:0 0 0 3px #234e3f1a;border-radius:var(--input-radius) var(--input-radius) 0 0}.custom-select-error .custom-select-button{border-color:var(--error)}.custom-select-error .custom-select-button:focus{border-color:var(--error);box-shadow:0 0 0 3px #dc26261a}.custom-select-disabled .custom-select-button{background:var(--light-gray);color:var(--medium-gray);cursor:not-allowed;border-color:var(--light-gray)}.custom-select-arrow{margin-left:var(--space-2);color:var(--medium-gray);transition:transform var(--transition-fast);flex-shrink:0}.custom-select-dropdown{position:absolute;top:100%;left:0;right:0;z-index:2100;background:var(--white);border:1px solid var(--forest);border-top:none;border-radius:0 0 var(--input-radius) var(--input-radius);box-shadow:var(--shadow-lg);max-height:240px;overflow-y:auto}.select-group-label{padding:var(--space-2) var(--space-4);font-size:var(--text-xs);font-weight:600;color:var(--medium-gray);background:var(--light-gray);text-transform:uppercase;letter-spacing:.5px}.select-option{padding:var(--space-3) var(--space-4);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-base);color:var(--ink)}.select-option:hover{background:#234e3f0d}.select-option-focused{background:#234e3f1a}.select-option-selected{background:#234e3f26;font-weight:600}.select-option-selected:after{content:"✓";float:right;color:var(--forest);font-weight:700}.select-option-disabled:hover{background:none}.select-custom-actions{border-top:1px solid var(--light-gray);background:#f9fafb80}.select-custom-action{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-base);color:var(--forest);font-weight:600}.select-custom-action:hover{background:#234e3f0d}.select-custom-action.select-option-focused{background:#234e3f1a}.select-custom-action-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:var(--text-sm);font-weight:700;color:var(--forest)}.input-with-addon{display:flex;align-items:center}.input-addon{background:var(--light-gray);border:2px solid var(--light-gray);border-right:none;padding:var(--space-3) var(--space-4);border-radius:var(--input-radius) 0 0 var(--input-radius);color:var(--medium-gray);font-weight:600;font-size:var(--text-base)}.input-with-addon .form-input{border-radius:0 var(--input-radius) var(--input-radius) 0;border-left:none}.custom-datepicker{position:relative;display:inline-block;width:100%}.datepicker-input-wrapper{position:relative;display:flex;align-items:center}.datepicker-input{width:100%;padding:var(--space-3) var(--space-4);padding-right:40px;border:2px solid var(--light-gray);border-radius:var(--input-radius);background:var(--white);font-size:var(--text-base);font-family:inherit;color:var(--ink);cursor:pointer;transition:all var(--transition-fast)}.datepicker-input:hover{border-color:var(--medium-gray)}.datepicker-input:focus{outline:none;border-color:var(--forest);box-shadow:0 0 0 3px #234e3f1a}.datepicker-input::placeholder{color:var(--medium-gray)}.custom-datepicker-open .datepicker-input{border-color:var(--forest);box-shadow:0 0 0 3px #234e3f1a;border-radius:var(--input-radius) var(--input-radius) 0 0}.custom-datepicker-error .datepicker-input{border-color:var(--error)}.custom-datepicker-error .datepicker-input:focus{border-color:var(--error);box-shadow:0 0 0 3px #dc26261a}.custom-datepicker-disabled .datepicker-input{background:var(--light-gray);color:var(--medium-gray);cursor:not-allowed;border-color:var(--light-gray)}.datepicker-icon{position:absolute;right:var(--space-3);color:var(--medium-gray);pointer-events:none;display:flex;align-items:center}.datepicker-calendar{position:absolute;top:100%;left:0;right:0;z-index:2100;background:var(--white);border:1px solid var(--forest);border-top:none;border-radius:0 0 var(--input-radius) var(--input-radius);box-shadow:var(--shadow-lg);padding:var(--space-4);min-width:280px;width:max-content}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.calendar-nav-button{background:none;border:none;padding:var(--space-2);border-radius:var(--input-radius);color:var(--medium-gray);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.calendar-nav-button:hover{background:var(--light-gray);color:var(--ink)}.calendar-month-year{font-weight:600;font-size:var(--text-base);color:var(--ink)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-1);margin-bottom:var(--space-3)}.weekday-label{text-align:center;font-size:var(--text-xs);font-weight:600;color:var(--medium-gray);padding:var(--space-2);text-transform:uppercase;letter-spacing:.5px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-1)}.calendar-day-cell{display:flex;align-items:center;justify-content:center;width:36px;height:36px}.calendar-day{width:36px;height:36px;border:none;background:none;border-radius:var(--input-radius);cursor:pointer;font-size:var(--text-sm);color:var(--ink);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}@media (max-width: 767px){.calendar-day-cell,.calendar-day{width:44px;height:44px}}.calendar-day:hover{background:var(--light-gray)}.calendar-day-today{background:#234e3f1a;color:var(--forest);font-weight:600}.calendar-day-today:hover{background:#234e3f33}.calendar-day-selected{background:var(--forest);color:var(--white);font-weight:600}.calendar-day-selected:hover{background:var(--leaf)}.calendar-day-disabled{color:var(--medium-gray);cursor:not-allowed;opacity:.5}.calendar-day-disabled:hover{background:none}.calendar-day:focus{outline:none}.calendar-day:focus-visible{outline:2px solid var(--forest);outline-offset:2px;z-index:1}.calendar-day-focused{box-shadow:0 0 0 2px var(--leaf);position:relative}.transaction-form{display:grid;gap:var(--space-4);grid-template-columns:1fr 1fr;max-width:none}.transaction-form .form-group.full-width,.transaction-form .form-actions{grid-column:1 / -1}.form-textarea{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--light-gray);border-radius:var(--input-radius);font-family:var(--font-sans);font-size:var(--text-base);line-height:1.5;color:var(--ink);resize:vertical;min-height:100px;transition:all var(--transition-fast)}.form-textarea:hover{border-color:var(--medium-gray)}.form-textarea:focus{outline:none;border-color:var(--forest);box-shadow:0 0 0 3px #234e3f1a}.form-textarea::placeholder{color:var(--medium-gray)}.form-input-error.form-textarea{border-color:var(--error)}@media (max-width: 768px){.transaction-form{grid-template-columns:1fr;gap:var(--space-3)}}.card{background-color:var(--white);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);overflow:visible;transition:box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--shadow-md)}.card-accent-gold{border-left:4px solid var(--soft-gold)}.card-accent-forest{border-left:4px solid var(--forest)}.card-accent-leaf{border-left:4px solid var(--leaf)}.card-header{padding:var(--space-6);border-bottom:1px solid var(--light-gray)}.card-title{margin:0;font-size:var(--text-lg);font-weight:600;color:var(--forest)}.card-content{padding:var(--space-6)}.card-footer{padding:var(--space-6);border-top:1px solid var(--light-gray);background-color:var(--light-gray)}.table{width:100%;border-collapse:collapse;margin-bottom:var(--space-6)}.table th,.table td{padding:var(--space-3);text-align:left;border-bottom:1px solid var(--light-gray)}.table th{background-color:var(--light-gray);font-weight:600;color:var(--forest);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em}.table tbody tr:hover{background-color:var(--light-gray)}.table-striped tbody tr:nth-child(2n){background-color:#f9fafb80}.table-container{background:var(--white);border-radius:var(--card-radius);overflow-x:auto;box-shadow:var(--shadow-md);border:1px solid var(--light-gray)}.data-table{width:100%;border-collapse:collapse}.table-header-cell{position:sticky;top:0;z-index:5;background:var(--light-gray);padding:var(--space-4);text-align:left;font-weight:600;font-size:var(--text-sm);color:var(--dark-gray);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--medium-gray)}.table-header-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-fast)}.table-header-sortable:hover{background-color:var(--medium-gray);color:var(--white)}.table-header-content{display:flex;align-items:center;justify-content:space-between}.table-sort-indicator{margin-left:var(--space-2);opacity:.6;font-size:var(--text-xs)}.table-cell{padding:var(--space-4);border-bottom:1px solid var(--light-gray);vertical-align:middle}.table-cell-center{text-align:center}.table-cell-right{text-align:right}.table-row:hover{background:#234e3f05}.table-row-selected{background:#234e3f0d;border-left:4px solid var(--forest)}.table-row-clickable{cursor:pointer}.table-checkbox{width:16px;height:16px;border-radius:var(--radius-sm);border:2px solid var(--medium-gray);background:var(--white);cursor:pointer}.table-checkbox:checked{background:var(--forest);border-color:var(--forest)}.table-loading-row .loading-skeleton{height:16px;background:linear-gradient(90deg,var(--light-gray) 25%,#e0e0e0 50%,var(--light-gray) 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-radius:var(--radius-sm)}.loading-checkbox{width:16px;height:16px}.loading-text{height:16px}.table-empty-state{padding:var(--space-12);text-align:center;color:var(--medium-gray);background:var(--light-gray)}.pagination{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) 0;flex-wrap:wrap;gap:var(--space-4)}.pagination-info{color:var(--medium-gray);font-size:var(--text-sm)}.pagination-controls{display:flex;align-items:center;gap:var(--space-2)}.pagination-pages{display:flex;align-items:center;gap:var(--space-1)}.pagination-button{padding:var(--space-2) var(--space-3);border:1px solid var(--light-gray);background:var(--white);color:var(--dark-gray);border-radius:var(--input-radius);cursor:pointer;font-size:var(--text-sm);transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--space-2);min-width:32px;justify-content:center}.pagination-button:hover:not(.pagination-button-disabled){background:var(--light-gray)}.pagination-button-active{background:var(--forest);color:var(--white);border-color:var(--forest)}.pagination-button-disabled{opacity:.5;cursor:not-allowed}.pagination-ellipsis{padding:var(--space-2) var(--space-3);color:var(--medium-gray);font-size:var(--text-sm)}.pagination-size-selector{display:flex;align-items:center;gap:var(--space-2)}.pagination-size-label{font-size:var(--text-sm);color:var(--medium-gray)}.pagination-size-select{padding:var(--space-2) var(--space-3);border:1px solid var(--light-gray);border-radius:var(--input-radius);background:var(--white);font-size:var(--text-sm)}.breadcrumb-nav{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-6);padding:var(--space-3) var(--space-4);background:var(--light-gray);border-radius:var(--input-radius)}.breadcrumb-list{display:flex;align-items:center;list-style:none;margin:0;padding:0;gap:var(--space-2)}.breadcrumb-list-item{display:flex;align-items:center;gap:var(--space-2)}.breadcrumb-item{font-size:var(--text-sm);transition:color var(--transition-fast);text-decoration:none;background:none;border:none;padding:0;cursor:pointer}.breadcrumb-link{color:var(--medium-gray)}.breadcrumb-link:hover{color:var(--forest)}.breadcrumb-current{color:var(--forest);font-weight:600;cursor:default}.breadcrumb-separator{color:var(--medium-gray);font-size:var(--text-sm)}.breadcrumb-separator-icon{transform:rotate(90deg)}.breadcrumb-ellipsis{color:var(--medium-gray);cursor:default}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-2xl);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.badge-default{background:var(--light-gray);color:var(--dark-gray)}.badge-success{background:#0596691a;color:var(--success)}.badge-warning{background:#d977061a;color:var(--warning)}.badge-error{background:#dc26261a;color:var(--error)}.badge-info{background:#3b82f61a;color:#3b82f6}.badge-forest{background:#234e3f1a;color:var(--forest)}.badge-leaf{background:#6ca86c1a;color:var(--leaf)}.badge-sm{padding:var(--space-1) var(--space-2);font-size:10px}.badge-lg{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}.badge-dot .badge-dot-indicator{width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}.tabs{width:100%}.tabs-horizontal{display:flex;flex-direction:column}.tabs-vertical{display:flex;flex-direction:row;align-items:stretch}.tab-list{display:flex;border-bottom:1px solid var(--light-gray);margin-bottom:var(--space-6)}.tab-list-horizontal{flex-direction:row}.tab-list-vertical{flex-direction:column;border-bottom:none;border-right:1px solid var(--light-gray);margin-bottom:0;margin-right:var(--space-6);min-width:200px}.tab{background:none;border:none;padding:var(--space-3) var(--space-6);font-size:var(--text-sm);font-weight:500;color:var(--medium-gray);cursor:pointer;transition:all var(--transition-fast);border-bottom:2px solid transparent;position:relative}.tabs-vertical .tab{border-bottom:none;border-right:2px solid transparent;text-align:left;justify-content:flex-start}.tab:hover:not(.tab-disabled){color:var(--forest);background:var(--light-gray)}.tab-active{color:var(--forest);font-weight:600;border-bottom-color:var(--forest)}.tabs-vertical .tab-active{border-right-color:var(--forest);border-bottom-color:transparent}.tab-disabled{opacity:.5;cursor:not-allowed}.tab-content{display:flex;align-items:center;gap:var(--space-2)}.tab-badge{background:var(--medium-gray);color:var(--white);padding:var(--space-1) var(--space-2);border-radius:var(--radius-lg);font-size:10px;font-weight:700;min-width:18px;text-align:center}.tab-active .tab-badge{background:var(--forest)}.tab-panels{flex:1}.tab-panel{outline:none}.tab-panel-hidden{display:none}.tab-panel-active{display:block}.tabs-pills .tab-list{border-bottom:none;margin-bottom:var(--space-4);gap:var(--space-2)}.tabs-pills .tab{border-radius:var(--button-radius);border-bottom:none}.tabs-pills .tab-active{background:var(--forest);color:var(--white);border-bottom-color:transparent}.tabs-underline .tab{background:transparent;border-bottom:2px solid transparent}.tabs-underline .tab-active{background:transparent;border-bottom-color:var(--forest)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-12);color:var(--medium-gray)}.empty-state-sm{padding:var(--space-6)}.empty-state-lg{padding:var(--space-16)}.empty-state-icon{margin-bottom:var(--space-6);color:var(--medium-gray);opacity:.6}.empty-state-content{max-width:400px}.empty-state-title{font-family:var(--font-serif);font-size:var(--text-lg);font-weight:600;color:var(--dark-gray);margin-bottom:var(--space-4)}.empty-state-sm .empty-state-title{font-size:var(--text-base);margin-bottom:var(--space-3)}.empty-state-lg .empty-state-title{font-size:var(--text-xl);margin-bottom:var(--space-6)}.empty-state-description{margin-bottom:var(--space-6);line-height:1.6}.empty-state-description p{margin-bottom:var(--space-2)}.empty-state-actions{display:flex;flex-direction:column;gap:var(--space-3);align-items:center}@media (min-width: 640px){.empty-state-actions{flex-direction:row}}.empty-state-onboarding{max-width:800px;margin:0 auto}.empty-state-onboarding .empty-state-content{max-width:700px}.empty-state-welcome{font-size:var(--text-lg);color:var(--medium-gray);margin-bottom:var(--space-8);line-height:1.6}.onboarding-checklist{background:var(--white);border-radius:var(--card-radius);padding:var(--space-8);box-shadow:var(--shadow-md);margin:var(--space-8) 0;max-width:600px;margin-left:auto;margin-right:auto}.onboarding-steps{list-style:none;padding:0;margin:0}.onboarding-step{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-4);width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--light-gray);cursor:pointer;transition:background-color var(--transition-base)}.onboarding-step:hover{background-color:var(--cream)}.onboarding-step:last-child{border-bottom:none}.onboarding-step-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;margin-top:2px}.onboarding-step-icon.complete{color:var(--success)}.onboarding-step-icon.not-started{color:var(--medium-gray)}.onboarding-step-content{flex:1}.onboarding-step-title{font-size:var(--text-base);font-weight:600;color:var(--ink);margin-bottom:var(--space-1)}.onboarding-step-description{font-size:var(--text-sm);color:var(--medium-gray);line-height:1.5}.onboarding-progress-summary{text-align:center;margin-top:var(--space-6);font-size:var(--text-sm);color:var(--medium-gray)}.onboarding-progress-bar{height:8px;background:var(--light-gray);border-radius:var(--radius-sm);margin-top:var(--space-3);overflow:hidden}.onboarding-progress-fill{height:100%;background:linear-gradient(90deg,var(--forest),var(--leaf));transition:width var(--transition-slow);border-radius:var(--radius-sm)}.onboarding-cta-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);margin-top:var(--space-6)}.onboarding-cta-description{text-align:center;color:var(--medium-gray);font-size:var(--text-base);line-height:1.6;max-width:500px}@media (max-width: 767px){.onboarding-checklist{padding:var(--space-6)}.onboarding-step{padding:var(--space-3)}.onboarding-step-title{font-size:var(--text-sm)}.empty-state-onboarding .empty-state-title{font-size:var(--text-2xl)}.empty-state-welcome{font-size:var(--text-base)}.onboarding-cta-description{font-size:var(--text-sm)}}.rotate-90{transform:rotate(90deg)}.rotate-180{transform:rotate(180deg)}.rotate-270{transform:rotate(270deg)}.transaction-description{min-width:200px}.description-main{font-weight:600;margin-bottom:var(--space-1);color:var(--ink)}.description-merchant{font-size:var(--text-sm);color:var(--medium-gray)}.category-name{font-weight:500;display:flex;align-items:center;gap:var(--space-2);color:var(--ink)}.category-group{font-size:var(--text-xs);color:var(--medium-gray);text-transform:uppercase;font-weight:600}.category-icon{color:var(--forest)}.amount-display{font-weight:700;text-align:right;min-width:100px;font-family:var(--font-sans);font-variant-numeric:tabular-nums}.action-reconciled{background:#0596691a;color:var(--success)}.action-reconciled:hover{background:var(--success);color:var(--white)}.action-pending{background:#d977061a;color:var(--warning)}.action-pending:hover{background:var(--warning);color:var(--white)}.transaction-pagination{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--light-gray)}.load-more-container{margin-top:var(--space-6);text-align:center;padding:var(--space-4)}.transaction-list-loading,.transaction-list-error{padding:var(--space-8)}.animate-spin{animation:spin 1s linear infinite}.sidebar{width:var(--sidebar-width);background-color:var(--white);border-right:1px solid var(--light-gray);display:flex;flex-direction:column;box-shadow:var(--shadow-sm);border-radius:var(--card-radius);overflow:hidden;height:100vh}.logo-icon{width:32px;height:32px;background-color:var(--white);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--forest);font-weight:700;font-size:var(--text-sm)}.logo-text{font-family:var(--font-serif);font-size:var(--text-lg);font-weight:600}.nav-menu{flex:1;padding:var(--space-6) 0;list-style:none;margin:0}.nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-6);color:var(--dark-gray);text-decoration:none;transition:all var(--transition-fast);font-weight:400}.nav-link:hover{background-color:var(--light-gray);color:var(--forest)}.nav-link.active{background-color:var(--forest);color:var(--white);font-weight:600}.nav-link-disabled{opacity:.5;cursor:not-allowed;position:relative}.nav-link-disabled:hover{background-color:transparent;color:var(--dark-gray)}.nav-badge{font-size:var(--text-xs);background:var(--soft-gold);color:var(--ink);padding:var(--space-1) var(--space-2);border-radius:var(--radius-lg);font-weight:600;margin-left:auto}.nav{display:flex;align-items:center;gap:var(--space-6)}.nav-link{color:var(--ink);text-decoration:none;font-weight:500;transition:color var(--transition-fast);position:relative}.nav-link:hover,.nav-link.active{color:var(--forest)}.nav-link.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background-color:var(--forest)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge-success{background-color:#0596691a;color:var(--success)}.badge-warning{background-color:#d977061a;color:var(--warning)}.badge-error{background-color:#dc26261a;color:var(--error)}.badge-neutral{background-color:var(--light-gray);color:var(--medium-gray)}.alert{padding:var(--space-4);border-radius:var(--input-radius);margin-bottom:var(--space-4);border-left:4px solid}.alert-success{background-color:#0596691a;border-color:var(--success);color:var(--success)}.alert-warning{background-color:#d977061a;border-color:var(--warning);color:var(--warning)}.alert-error{background-color:#dc26261a;border-color:var(--error);color:var(--error)}.alert-info{background-color:#234e3f1a;border-color:var(--forest);color:var(--forest)}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-overlay{position:fixed;inset:0;background-color:#22302abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;padding:var(--space-4)}.modal-overlay.active{opacity:1;visibility:visible;animation:modalFadeIn .3s ease}.modal{background-color:var(--white);border-radius:var(--card-radius);box-shadow:0 20px 60px #0000004d;width:100%;max-height:calc(100vh - var(--space-8));overflow-y:auto;display:flex;flex-direction:column;transform:translateY(40px);opacity:0;transition:transform .3s cubic-bezier(.16,1,.3,1),opacity .3s ease}.modal-overlay.active .modal{transform:translateY(0);opacity:1;animation:modalSlideUp .4s cubic-bezier(.16,1,.3,1)}.modal-sm{max-width:400px}.modal-md{max-width:600px}.modal-lg{max-width:800px}.modal-xl{max-width:1200px}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--light-gray);flex-shrink:0}.modal-title{font-family:var(--font-serif);font-size:var(--text-xl);font-weight:600;color:var(--forest);margin:0;line-height:1.4;padding-right:var(--space-4);word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;max-width:100%}.modal-close{background:none;border:2px solid transparent;color:var(--medium-gray);cursor:pointer;padding:var(--space-2);width:40px;height:40px;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--button-radius);transition:all var(--transition-fast);flex-shrink:0}.modal-close:hover{background-color:var(--light-gray);color:var(--ink);border-color:var(--light-gray)}.modal-close:focus-visible{outline:none;border-color:var(--forest);background-color:#234e3f1a;color:var(--forest)}.modal-close svg{width:20px;height:20px}.modal-body{padding:var(--space-6);overflow-y:auto;flex:1}.confirmation-content{display:flex;flex-direction:column;gap:var(--space-8);padding:var(--space-2) 0}.modal-title-centered{text-align:center;padding-right:0!important}.modal-header-centered{justify-content:center}.confirmation-message{font-size:var(--text-base);color:var(--ink);line-height:1.7;text-align:center;text-transform:none!important;max-width:90%;margin:0 auto}.confirmation-actions{display:flex;gap:var(--space-4);justify-content:center;align-items:center;padding-top:var(--space-4)}.confirmation-actions .btn{min-width:120px;min-height:48px;padding:var(--space-3) var(--space-6);font-size:var(--text-base);font-weight:600}.confirmation-modal-content{display:flex;flex-direction:column;gap:var(--space-6)}@media (max-width: 767px){.modal-overlay{padding:0;align-items:flex-end}.modal{max-width:100vw;max-height:95vh;min-height:50vh;border-radius:var(--card-radius) var(--card-radius) 0 0;margin:0}.modal-sm,.modal-md,.modal-lg,.modal-xl{max-width:100vw}.modal-header{padding:var(--space-5)}.modal-title{font-size:var(--text-lg)}.modal-close{width:44px;height:44px;min-width:44px;min-height:44px}.confirmation-modal-content{padding:var(--space-5)}.confirmation-actions{flex-direction:column-reverse;gap:var(--space-4)}.confirmation-actions .btn{width:100%;min-width:unset}}@media (min-width: 768px) and (max-width: 1023px){.modal-lg,.modal-xl{max-width:90vw}}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;left:0;min-width:200px;background-color:var(--white);border:1px solid var(--light-gray);border-radius:var(--input-radius);box-shadow:var(--shadow-md);z-index:var(--z-dropdown);opacity:0;visibility:hidden;transform:translateY(-8px);transition:all var(--transition-fast)}.dropdown.active .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{display:block;width:100%;padding:var(--space-3);color:var(--ink);text-decoration:none;transition:background-color var(--transition-fast)}.dropdown-item:hover{background-color:var(--light-gray);color:var(--forest)}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--light-gray);border-radius:50%;border-top-color:var(--forest);animation:spin 1s ease-in-out infinite}.loading-skeleton{background:linear-gradient(90deg,var(--light-gray) 25%,rgba(249,250,251,.5) 50%,var(--light-gray) 75%);background-size:200% 100%;animation:loading 1.5s infinite}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.budget-section{margin-bottom:var(--space-8)}.budget-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-6);margin-bottom:var(--space-8)}.summary-card{background:var(--white);border-radius:var(--card-radius);padding:var(--space-6);box-shadow:var(--shadow-md);border-left:4px solid}.summary-card.income{border-left-color:var(--success)}.summary-card.expenses,.summary-card.spent{border-left-color:var(--error)}.summary-card.remaining,.summary-card.surplus{border-left-color:var(--leaf)}.summary-card.allocated{border-left-color:var(--soft-gold)}.summary-card.deficit{border-left-color:var(--error)}.summary-label{font-size:var(--text-sm);color:var(--medium-gray);text-transform:uppercase;font-weight:600;margin-bottom:var(--space-2)}.summary-amount{font-size:var(--text-2xl);font-weight:700;font-family:var(--font-sans);font-variant-numeric:tabular-nums;margin-bottom:var(--space-2)}.summary-amount.income{color:var(--success)}.summary-amount.expenses,.summary-amount.spent{color:var(--error)}.summary-amount.remaining,.summary-amount.surplus{color:var(--leaf)}.summary-amount.allocated{color:var(--soft-gold)}.summary-amount.deficit{color:var(--error)}.summary-trend{font-size:var(--text-sm);display:flex;align-items:center;gap:var(--space-1)}.summary-trend.deficit{color:var(--error)}.trend-positive{color:var(--success)}.trend-negative{color:var(--error)}.page-header{margin-bottom:var(--space-8)}.page-title{font-family:Merriweather,serif;font-size:var(--text-3xl);font-weight:400;color:var(--ink);margin-bottom:var(--space-2)}.page-subtitle{color:var(--medium-gray);font-size:var(--text-lg)}.controls-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-8);gap:var(--space-4)}.month-controls{display:flex;align-items:center;gap:var(--space-4)}.month-nav{display:flex;align-items:center;background:var(--white);border-radius:var(--card-radius);box-shadow:0 1px 3px #22302a1a;overflow:hidden}.month-nav button{background:none;border:none;padding:var(--space-3) var(--space-4);color:var(--medium-gray);cursor:pointer;transition:all .2s ease;min-height:44px;font-size:var(--text-lg)}.month-nav button:hover{background:var(--light-gray);color:var(--forest)}.current-month{font-weight:700;color:var(--forest);padding:0 var(--space-6);font-size:var(--text-lg)}.method-select{background:var(--white);border:2px solid #E5E7EB;border-radius:var(--input-radius);padding:var(--space-3) var(--space-12) var(--space-3) var(--space-4);font-size:var(--text-base);color:var(--ink);cursor:pointer;min-height:44px;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23374151' d='M6 8L2 4h8l-4 4z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center}.budget-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-6);margin-bottom:var(--space-8)}.summary-card{background:var(--white);padding:var(--space-6);border-radius:var(--card-radius);box-shadow:0 1px 3px #22302a1a;border:1px solid #E5E7EB}.summary-card .label{font-size:var(--text-base);color:var(--medium-gray);margin-bottom:var(--space-2);font-weight:600}.summary-card .value{font-size:var(--text-2xl);font-weight:700;color:var(--ink)}.logo-icon{width:32px;height:32px;background:var(--forest);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:var(--text-base)}.logo-text{font-family:Merriweather,serif;font-size:var(--text-lg);font-weight:700;color:var(--forest)}.nav-menu{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}.nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--button-radius);text-decoration:none;color:var(--medium-gray);font-weight:500;transition:all .2s ease}.nav-link:hover{background-color:var(--light-gray);color:var(--ink)}.nav-link.active{background-color:var(--forest);color:var(--white)}.nav-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:var(--text-base)}.page-title{font-family:Merriweather,serif;font-size:var(--text-2xl);font-weight:600;color:var(--ink);margin:0}.header-content{display:flex;align-items:center;justify-content:space-between;width:100%;height:100%;padding:0 var(--space-6)}.header-left{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2)}.header-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.page-subtitle{font-size:var(--text-sm);color:var(--medium-gray);margin:0;font-weight:400}.export-dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;right:0;background:var(--white);border:1px solid var(--light-gray);border-radius:var(--input-radius);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);min-width:150px;margin-top:var(--space-2)}.dropdown-item{display:block;width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;text-align:left;color:var(--ink);font-size:var(--text-sm);cursor:pointer;transition:background-color var(--transition-fast)}.dropdown-item:hover{background-color:var(--light-gray)}.dropdown-item:first-child{border-top-left-radius:var(--input-radius);border-top-right-radius:var(--input-radius)}.dropdown-item:last-child{border-bottom-left-radius:var(--input-radius);border-bottom-right-radius:var(--input-radius)}@media (max-width: 768px){.header-content{padding:0 var(--space-4)}.header-actions{flex-direction:column;gap:var(--space-2)}.page-title{font-size:var(--text-xl)}}.category-actions{position:relative}.category-actions-toggle{min-width:32px;min-height:32px;padding:var(--space-1);border-radius:var(--button-radius);font-size:var(--text-sm);opacity:.4;transition:opacity .2s ease,background-color .2s ease,color .2s ease;border:none}.category-item:hover .category-actions-toggle,.category-group-header:hover .category-actions-toggle,.category-actions-toggle:focus-visible{opacity:1}.category-actions-toggle:hover{background-color:#224e3f0d;color:var(--forest)}.category-actions-toggle:focus-visible{outline:2px solid var(--forest);outline-offset:2px}.actions-dropdown{position:absolute;right:0;top:calc(100% + var(--space-1));background:var(--white);border:1px solid var(--light-gray);border-radius:var(--card-radius);box-shadow:var(--shadow-lg);min-width:180px;z-index:100;animation:slideDown .2s ease-out;overflow:visible}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.action-item{width:100%;padding:var(--space-3) var(--space-4);text-align:left;border:none;background:transparent;cursor:pointer;transition:background-color .15s ease,color .15s ease;font-size:var(--text-sm);color:var(--ink);font-weight:500;display:block}.action-item:hover{background-color:var(--cream);color:var(--forest)}.action-item:focus{outline:none;background-color:var(--light-gray);color:var(--forest)}.action-item.action-danger{color:var(--ink)}.action-item.action-danger:hover{background-color:#fee;color:#dc2626}.action-item.action-danger:focus{background-color:#fee;color:#dc2626}.action-item:disabled{opacity:.6;cursor:not-allowed}.action-item:disabled:hover{background-color:transparent;color:var(--ink)}.category-group-actions{position:relative;display:flex;align-items:center}@media (max-width: 767px){.category-actions-toggle{min-width:48px;min-height:48px;font-size:var(--text-xl)}.actions-dropdown{min-width:200px}.action-item{padding:var(--space-4) var(--space-4);font-size:var(--text-base)}}.form-server-error{background:#dc262614;border-left:4px solid var(--error);border-radius:var(--input-radius);padding:var(--space-4);margin:0 0 var(--space-4) 0;width:100%;box-sizing:border-box;grid-column:1 / -1}.form-server-error-content{display:flex;align-items:flex-start;gap:var(--space-3)}.form-server-error-icon{font-size:var(--text-2xl);line-height:1;flex-shrink:0}.form-server-error-message{flex:1}.form-server-error-message strong{display:block;font-size:var(--text-base);font-weight:600;font-family:var(--font-serif);color:var(--ink);margin-bottom:var(--space-2)}.form-server-error-message p{font-size:var(--text-sm);line-height:1.5;color:var(--dark-gray);margin-bottom:var(--space-3)}.error-retry-button{padding:var(--space-2) var(--space-4);background:var(--forest);color:var(--white);border:none;border-radius:var(--button-radius);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background-color var(--transition-fast)}.error-retry-button:hover{background:var(--leaf)}.error-retry-button:focus{outline:2px solid var(--forest);outline-offset:2px}.help-tooltip-wrapper{position:relative;display:inline-flex;align-items:center;margin-left:var(--space-2)}.help-icon-button{background:none;border:none;padding:var(--space-1);cursor:help;color:var(--medium-gray);transition:color var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full)}.help-icon-button:hover,.help-icon-button:focus-visible{color:var(--leaf);outline:none}.help-icon-button:focus-visible{box-shadow:0 0 0 2px var(--leaf)}.help-tooltip{position:absolute;z-index:var(--z-tooltip);background-color:var(--forest);color:var(--cream);padding:var(--space-3) var(--space-4);border-radius:var(--input-radius);font-size:var(--text-sm);line-height:1.5;max-width:280px;box-shadow:var(--shadow-lg);animation:tooltipFadeIn .2s ease;white-space:normal;word-wrap:break-word}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.help-tooltip-top{bottom:calc(100% + var(--space-2));left:50%;transform:translate(-50%)}.help-tooltip-bottom{top:calc(100% + var(--space-2));left:50%;transform:translate(-50%)}.help-tooltip-left{right:calc(100% + var(--space-2));top:50%;transform:translateY(-50%)}.help-tooltip-right{left:calc(100% + var(--space-2));top:50%;transform:translateY(-50%)}.custom-select{position:relative;width:100%}.custom-select-button{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--cream);border:1px solid var(--light-gray);border-radius:var(--radius-md);font-family:var(--font-ui);font-size:16px;font-weight:400;color:var(--ink);cursor:pointer;transition:all .2s ease;text-align:left}.custom-select-button:hover:not(:disabled){border-color:var(--forest);background:#fff}.custom-select-button:focus:not(:disabled){outline:none;border-color:var(--leaf);box-shadow:0 0 0 3px #6ca86c1a}.custom-select-button:disabled{background:var(--light-gray);color:var(--medium-gray);cursor:not-allowed;opacity:.6}.custom-select-value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-select-placeholder{color:var(--medium-gray)}.custom-select-arrow{display:flex;align-items:center;margin-left:8px;transition:transform .2s ease;color:var(--medium-gray)}.custom-select-open .custom-select-arrow{transform:rotate(180deg)}.custom-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--light-gray);border-radius:var(--radius-md);box-shadow:0 4px 12px #234e3f26;max-height:400px;overflow-y:auto;z-index:1000;animation:dropdown-fade-in .15s ease;overflow-x:hidden}@keyframes dropdown-fade-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.select-option{padding:12px 16px;font-family:var(--font-ui);font-size:15px;color:var(--ink);cursor:pointer;transition:background-color .15s ease;border-bottom:1px solid var(--lightest-gray)}.select-option:last-child{border-bottom:none}.select-option:hover{background-color:#6ca86c14}.select-option-focused{background-color:#6ca86c1f}.select-option-selected{background-color:#6ca86c26;font-weight:500;color:var(--forest)}.select-option-disabled{color:var(--medium-gray);cursor:not-allowed;opacity:.5}.select-option-disabled:hover{background-color:transparent}.select-group{border-bottom:1px solid var(--light-gray)}.select-group:last-child{border-bottom:none}.select-group-label{padding:8px 16px 4px;font-family:var(--font-heading);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--medium-gray);background-color:var(--lightest-gray)}.select-custom-actions{border-top:2px solid var(--light-gray);padding:4px 0;background-color:var(--lightest-gray);display:block!important;visibility:visible!important}.select-custom-action{display:flex;align-items:center;gap:8px;padding:10px 16px;font-family:var(--font-ui);font-size:15px;font-weight:500;color:var(--leaf);cursor:pointer;transition:background-color .15s ease}.select-custom-action:hover,.select-custom-action.select-option-focused{background-color:#6ca86c1f}.select-custom-action-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;font-size:18px;font-weight:600;color:var(--leaf)}.select-custom-action-label{flex:1}.custom-select-error .custom-select-button{border-color:#ef4444}.custom-select-error .custom-select-button:focus{box-shadow:0 0 0 3px #ef44441a}.custom-select-disabled{opacity:.6;pointer-events:none}.custom-select-dropdown::-webkit-scrollbar{width:8px}.custom-select-dropdown::-webkit-scrollbar-track{background:var(--lightest-gray);border-radius:0 var(--radius-md) var(--radius-md) 0}.custom-select-dropdown::-webkit-scrollbar-thumb{background:var(--medium-gray);border-radius:4px}.custom-select-dropdown::-webkit-scrollbar-thumb:hover{background:var(--forest)}@media (max-width: 768px){.custom-select-button,.select-option{padding:14px;font-size:16px}.custom-select-dropdown{max-height:250px}}.budget-wizard{background:var(--white);border-radius:var(--card-radius);box-shadow:var(--shadow-lg);max-width:900px;margin:0 auto;padding:var(--space-8)}.wizard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-8);padding-bottom:var(--space-4);border-bottom:1px solid var(--light-gray)}.wizard-progress{display:flex;align-items:center;gap:var(--space-2)}.wizard-step-indicator{font-size:var(--text-sm);font-weight:600;color:var(--forest)}.wizard-content{min-height:400px;margin-bottom:var(--space-8)}.wizard-step{animation:fadeIn .3s ease-in}.wizard-title{font-family:var(--font-serif);font-size:var(--text-3xl);font-weight:600;color:var(--ink);margin-bottom:var(--space-4)}.wizard-subtitle{font-size:var(--text-base);color:var(--medium-gray);margin-bottom:var(--space-8);line-height:1.6}.method-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-6)}.method-card{background:var(--white);border:2px solid var(--light-gray);border-radius:var(--card-radius);padding:var(--space-6);cursor:pointer;transition:all var(--transition-normal);text-align:left}.method-card:hover{border-color:var(--forest);box-shadow:var(--shadow-md);transform:translateY(-2px)}.method-card:focus{outline:3px solid var(--forest);outline-offset:2px}.method-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.method-card-title{font-size:var(--text-xl);font-weight:600;color:var(--forest)}.method-card-complexity{font-size:var(--text-xs);padding:var(--space-1) var(--space-3);background:var(--light-gray);border-radius:var(--button-radius);color:var(--medium-gray);font-weight:600}.method-card-description{font-size:var(--text-sm);color:var(--medium-gray);line-height:1.6}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-6)}.form-field{display:flex;flex-direction:column;gap:var(--space-2)}.form-field .form-input{min-height:48px;padding:var(--space-4)}@media (max-width: 768px){.form-field .form-input{min-height:44px;font-size:var(--text-lg)}}.to-be-assigned-card{background:var(--cream);border:2px solid var(--forest);border-radius:var(--card-radius);padding:var(--space-8);text-align:center;margin-top:var(--space-6)}.to-be-assigned-card h3{font-size:var(--text-xl);font-weight:600;color:var(--forest);margin-bottom:var(--space-4)}.to-be-assigned-card .amount{font-size:var(--text-4xl);font-weight:700;color:var(--ink);margin-bottom:var(--space-3);font-family:var(--font-sans)}.to-be-assigned-card .hint{font-size:var(--text-sm);color:var(--medium-gray);line-height:1.5}.percentage-buckets{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-6);margin-top:var(--space-6)}.percentage-bucket{background:var(--light-gray);border-radius:var(--card-radius);padding:var(--space-6);border:2px solid transparent;transition:border-color var(--transition-normal)}.percentage-bucket:focus-within{border-color:var(--forest)}.percentage-bucket .form-label{font-size:var(--text-lg);font-weight:600;color:var(--forest);margin-bottom:var(--space-3);display:block}.percentage-bucket .form-input{margin-bottom:var(--space-3)}.percentage-bucket .bucket-amount{font-size:var(--text-2xl);font-weight:700;color:var(--ink);font-family:var(--font-sans);display:block;text-align:center;padding:var(--space-3);background:var(--white);border-radius:var(--input-radius)}.allocation-placeholder{background:var(--light-gray);border:2px dashed var(--medium-gray);border-radius:var(--card-radius);padding:var(--space-12);text-align:center;color:var(--medium-gray);font-size:var(--text-base);margin-top:var(--space-6)}.review-summary{background:var(--cream);border-radius:var(--card-radius);padding:var(--space-8);margin-bottom:var(--space-8);margin-top:var(--space-6)}.review-item{display:flex;justify-content:space-between;padding:var(--space-4) 0;border-bottom:1px solid var(--light-gray)}.review-item:last-child{border-bottom:none}.review-label{font-size:var(--text-base);font-weight:600;color:var(--medium-gray)}.review-value{font-size:var(--text-base);font-weight:600;color:var(--ink);font-family:var(--font-sans)}.error-message{background:#fee2e2;border:1px solid #EF4444;color:#991b1b;padding:var(--space-4);border-radius:var(--input-radius);margin-bottom:var(--space-6);font-size:var(--text-sm);line-height:1.5}.wizard-footer{display:flex;justify-content:space-between;padding-top:var(--space-6);border-top:1px solid var(--light-gray)}.btn-create{width:100%;padding:var(--space-4) var(--space-6);font-size:var(--text-base);font-weight:600}@media (max-width: 768px){.budget-wizard{padding:var(--space-6)}.wizard-title{font-size:var(--text-2xl)}.method-cards,.form-grid,.percentage-buckets{grid-template-columns:1fr}.wizard-footer{flex-direction:column-reverse;gap:var(--space-3)}.wizard-footer .btn{width:100%}.to-be-assigned-card .amount{font-size:var(--text-3xl)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.wizard-step-category-setup .category-groups{display:grid;gap:var(--space-5);margin-bottom:var(--space-6)}.wizard-step-category-setup .category-group{background:var(--cream);border-radius:var(--radius-md);padding:var(--space-4)}.wizard-step-category-setup .category-group-title{font-family:var(--font-serif);font-size:var(--text-lg);font-weight:600;color:var(--forest);margin-bottom:var(--space-3)}.wizard-step-category-setup .category-checkboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-2)}.wizard-step-category-setup .category-checkbox-label{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast)}.wizard-step-category-setup .category-checkbox-label:hover{background-color:var(--white)}.wizard-step-category-setup .category-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--forest)}.wizard-step-category-setup .category-checkbox-text{font-size:var(--text-sm);color:var(--ink);-webkit-user-select:none;user-select:none}.wizard-step-category-setup .category-checkbox:disabled+.category-checkbox-text{opacity:.5;cursor:not-allowed}@media (prefers-reduced-motion: reduce){.wizard-step{animation:none}.method-card:hover{transform:none}}:root{--bulk-toolbar-height: 68px;--bulk-toolbar-gap: 4px;--bulk-toolbar-total: calc(var(--bulk-toolbar-height) + var(--bulk-toolbar-gap));--quickstat-item-min-width: 150px;--quickstat-divider-height: 40px;--skeleton-stat-width: 120px;--skeleton-stat-height: 40px;--filter-min-width: 200px;--datepicker-icon-right: 40px;--interval-input-width: 60px}.loading-spinner{border:3px solid var(--light-gray);border-top-color:var(--forest);border-radius:50%;width:24px;height:24px;animation:spin .8s linear infinite}.action-button:focus{outline:2px solid var(--forest);outline-offset:2px}.quickstats-section{margin-bottom:var(--space-6)}.quickstats-header{margin-bottom:var(--space-3)}.quickstats-title{font-size:var(--text-sm);color:var(--medium-gray);font-weight:600;margin:0;text-transform:uppercase;letter-spacing:.5px}.quickstats-compact{display:flex;flex-direction:column;align-items:stretch;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--white);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);border-left:3px solid var(--forest)}.quickstat-compact-item{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:var(--space-1);padding:var(--space-2) 0;min-width:auto;flex:1 1 auto}.quickstat-compact-label{font-size:var(--text-xs);color:var(--medium-gray);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.quickstat-compact-value{font-size:var(--text-lg);font-weight:700;font-family:Merriweather,serif}.quickstat-compact-value.income,.quickstat-compact-value.positive{color:var(--success)}.quickstat-compact-value.expense,.quickstat-compact-value.negative{color:var(--error)}.quickstat-compact-divider{display:none;width:1px;height:var(--quickstat-divider-height);background:var(--light-gray)}.quickstats-compact.loading{justify-content:space-around}.skeleton-stat{width:var(--skeleton-stat-width);height:var(--skeleton-stat-height);background:linear-gradient(90deg,var(--cream) 25%,var(--light-gray) 50%,var(--cream) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.filters-section{background:var(--white);border-radius:var(--card-radius);overflow:visible;box-shadow:var(--shadow-md);margin-bottom:var(--space-6);padding:var(--space-6)}.filters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.filters-title{font-family:var(--font-serif);font-size:var(--text-lg);color:var(--forest);font-weight:600;margin:0}.filters-row{display:flex;flex-direction:column;align-items:stretch;gap:var(--space-3)}.filters-row-secondary{margin-top:var(--space-3)}.filter-group{display:flex;flex-direction:column;gap:var(--space-2);min-width:100%;flex-shrink:0}.filter-control{padding:var(--space-3) var(--space-4);border:2px solid var(--light-gray);border-radius:var(--input-radius);font-size:var(--text-base);background-color:var(--white);color:var(--ink);font-family:var(--font-sans);transition:all var(--transition-fast)}.filter-control::placeholder{color:var(--medium-gray)}.filter-control:hover{border-color:var(--medium-gray)}.filter-control:focus{outline:2px solid var(--forest);outline-offset:2px;border-color:var(--forest);box-shadow:0 0 0 3px #234e3f1a}.filters-section .filter-group .custom-select-placeholder,.filters-section .filter-group .custom-select-value{color:var(--medium-gray)}.filter-group .custom-datepicker{min-width:var(--filter-min-width);flex-shrink:0}.filter-group .custom-datepicker .datepicker-input{padding:var(--space-3) var(--space-4);padding-right:var(--datepicker-icon-right);border:2px solid var(--light-gray);font-size:var(--text-base);color:var(--ink)}.filter-group .custom-datepicker .datepicker-input::placeholder{color:var(--medium-gray)}.filter-group .custom-datepicker .datepicker-icon{right:var(--space-3)}.filter-group .custom-datepicker .datepicker-input:hover{border-color:var(--medium-gray)}.filter-group .custom-datepicker-open .datepicker-input{border:2px solid var(--forest);border-radius:var(--input-radius) var(--input-radius) 0 0}.filter-group .custom-datepicker .datepicker-calendar{border:2px solid var(--forest);border-top:none}.active-filters-container{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);background:var(--cream);border-radius:var(--card-radius);margin-bottom:var(--space-6);flex-wrap:wrap}.active-filters-label{font-weight:600;font-size:var(--text-sm);color:var(--forest)}.filter-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--white);border:1px solid var(--light-gray);border-radius:var(--input-radius);font-size:var(--text-sm);transition:all var(--transition-fast)}.filter-chip:hover{box-shadow:var(--shadow-sm)}.filter-chip-label{color:var(--medium-gray)}.filter-chip-value{color:var(--ink);font-weight:500}.filter-chip-remove{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border:none;background:var(--medium-gray);color:var(--white);border-radius:50%;cursor:pointer;font-size:var(--text-xs);padding:0;transition:all var(--transition-fast)}.filter-chip-remove:hover{background:var(--forest);transform:scale(1.1)}.filter-chip-remove:focus{outline:2px solid var(--forest);outline-offset:2px}.clear-filters-button{margin-left:auto;font-size:var(--text-sm)}.transactions-section{background:var(--white);border-radius:var(--card-radius);box-shadow:var(--shadow-md);overflow:visible;max-width:100%}.transaction-list{width:100%;max-width:100%;overflow:visible}.transactions-section .table-container{overflow:visible;max-width:100%}.transactions-section .data-table{border-collapse:separate;border-spacing:0;min-width:100%;width:100%}.transactions-section .table-header-cell{position:static;background:var(--light-gray);border-bottom:2px solid var(--medium-gray)}.transactions-section .data-table thead tr{position:sticky;top:calc(var(--content-padding) * -1);z-index:5;background:var(--light-gray)}.transaction-list:has(.bulk-operations-toolbar) .data-table thead tr{top:calc(var(--bulk-toolbar-total) - var(--content-padding))}.transactions-header{padding:var(--space-6);border-bottom:1px solid var(--light-gray);background:var(--light-gray);display:flex;justify-content:space-between;align-items:center}.transactions-title{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--forest);font-weight:600;margin:0}.transaction-count{color:var(--medium-gray);font-size:var(--text-sm)}.transactions-table{width:100%;padding:0}.transaction-row{display:grid;grid-template-columns:1fr 3fr 2fr 1.5fr 1fr 1.5fr;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--light-gray);transition:all var(--transition-fast);cursor:pointer;align-items:center;font-size:var(--text-xs)}.transaction-row:hover{background:var(--light-gray);transform:translate(2px)}.transaction-row.selected{background:#234e3f0d;border-left:4px solid var(--forest)}.transaction-cell{display:flex;align-items:center;font-size:var(--text-sm)}.transaction-description{display:flex;flex-direction:column;gap:var(--space-1)}.description-main{font-weight:600;color:var(--ink);font-size:var(--text-sm)}.description-merchant{font-size:var(--text-xs);color:var(--medium-gray)}.category-display{display:flex;flex-direction:column;gap:var(--space-1)}.category-name{font-weight:600;color:var(--ink);font-size:var(--text-sm);display:flex;align-items:center;gap:var(--space-2)}.category-group{font-size:var(--text-xs);color:var(--medium-gray)}.category-icon{color:var(--forest);opacity:.7}.amount-display{font-weight:700;font-family:var(--font-sans);font-variant-numeric:tabular-nums;font-size:var(--text-base)}.amount-expense{color:var(--error)}.amount-income{color:var(--success)}.amount-transfer{color:var(--warning)}.action-buttons{display:flex;gap:var(--space-2);justify-content:flex-end}.action-button{padding:var(--space-2);border:none;border-radius:var(--input-radius);cursor:pointer;transition:all var(--transition-fast);background:transparent;color:var(--medium-gray);display:flex;align-items:center;justify-content:center}.action-button:hover:not(:disabled){background:var(--light-gray);transform:scale(1.1)}.action-edit:hover{background:#6ca86c1a;color:var(--leaf)}.action-delete:hover{background:#dc26261a;color:var(--error)}.action-reconciled{color:var(--success)}.action-pending{color:var(--warning)}.action-button:disabled{opacity:.4;cursor:not-allowed}.transaction-list-loading{display:flex;justify-content:center;align-items:center;padding:var(--space-12);min-height:400px}.transaction-list-error{padding:var(--space-12)}.transaction-pagination{padding:var(--space-6);border-top:1px solid var(--light-gray)}.load-more-container{display:flex;justify-content:center;padding:var(--space-6);border-top:1px solid var(--light-gray)}.transaction-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);min-height:400px}.transaction-card{background:var(--white);border-radius:var(--card-radius);padding:var(--space-4);margin-bottom:var(--space-3);box-shadow:var(--shadow-sm);border:1px solid var(--light-gray)}.transaction-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-3)}.card-meta{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--light-gray);font-size:var(--text-sm);color:var(--medium-gray)}.duplicate-warning{background:linear-gradient(135deg,#d8b56a26,#d8b56a0d);border:2px solid var(--soft-gold);border-radius:var(--card-radius);padding:var(--space-6);margin:var(--space-6) 0;box-shadow:var(--shadow-md)}.duplicate-warning .warning-header{display:flex;gap:var(--space-4);align-items:flex-start;margin-bottom:var(--space-4)}.duplicate-warning .warning-icon{font-size:var(--text-2xl);flex-shrink:0;line-height:1}.duplicate-warning .warning-content{flex:1}.duplicate-warning .warning-content h4{font-family:var(--font-serif);font-size:var(--text-lg);color:var(--ink);margin:0 0 var(--space-2) 0;font-weight:600}.duplicate-warning .warning-content p{font-size:var(--text-base);color:var(--dark-gray);margin:0;line-height:1.5}.duplicate-details{margin:var(--space-4) 0;border-top:1px solid rgba(216,181,106,.3);padding-top:var(--space-4)}.duplicate-details summary{cursor:pointer;font-weight:600;color:var(--forest);font-size:var(--text-base);padding:var(--space-2);border-radius:var(--card-radius-sm);transition:background-color var(--transition-base);-webkit-user-select:none;user-select:none}.duplicate-details summary:hover{background-color:#d8b56a1a}.duplicate-details summary:focus{outline:2px solid var(--forest);outline-offset:2px}.duplicate-list{list-style:none;padding:0;margin:var(--space-4) 0 0 0}.duplicate-item{padding:var(--space-3);margin-bottom:var(--space-2);background:var(--cream);border-left:3px solid var(--soft-gold);border-radius:var(--card-radius-sm)}.duplicate-row-label{font-size:var(--text-xs);color:var(--medium-gray);text-transform:uppercase;font-weight:600;letter-spacing:.5px;margin-bottom:var(--space-1)}.duplicate-info{font-size:var(--text-base);color:var(--ink);margin-bottom:var(--space-1)}.duplicate-match{display:block;font-size:var(--text-sm);color:var(--medium-gray);font-style:italic}.duplicate-more{padding:var(--space-3);text-align:center;color:var(--medium-gray);font-style:italic}.duplicate-checkbox{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-3);background:var(--cream);border-radius:var(--card-radius-sm);cursor:pointer;transition:background-color var(--transition-base)}.duplicate-checkbox:hover{background-color:#d8b56a1a}.duplicate-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--forest)}.duplicate-checkbox span{font-size:var(--text-base);color:var(--ink);-webkit-user-select:none;user-select:none}.duplicate-checkbox input[type=checkbox]:focus{outline:2px solid var(--forest);outline-offset:2px}.recurring-toggle{margin:var(--space-4) 0;padding:var(--space-3) 0;border-top:1px solid var(--light-gray);border-bottom:1px solid var(--light-gray)}.recurring-toggle .toggle-label{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-weight:500;color:var(--dark-gray);-webkit-user-select:none;user-select:none}.recurring-toggle input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--forest)}.recurring-toggle input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.recurring-toggle input[type=checkbox]:focus{outline:2px solid var(--forest);outline-offset:2px}.recurring-section{margin-top:0}.recurring-section .section-title{display:none}.form-section.compact{margin-bottom:var(--space-4)}.form-section.compact .form-row,.form-section.compact .form-group{margin-bottom:var(--space-3)}.form-helper.compact{font-size:var(--text-xs);margin-top:var(--space-1);line-height:1.4;color:var(--medium-gray)}.occurrence-preview.compact{margin-top:var(--space-3)}.occurrence-preview-label{font-weight:600;font-size:var(--text-sm);color:var(--dark-gray);margin-bottom:var(--space-2)}.occurrence-grid{display:grid;grid-template-columns:1fr;gap:var(--space-2)}.occurrence-item{padding:var(--space-2) var(--space-3);background:var(--cream);border-radius:var(--input-radius);font-size:var(--text-sm);color:var(--dark-gray);text-align:center;border-left:2px solid var(--forest)}.occurrence-empty{font-size:var(--text-sm);color:var(--medium-gray);font-style:italic;padding:var(--space-3);text-align:center;background:var(--light-gray);border-radius:var(--input-radius)}.recurrence-summary.compact{background:transparent;padding:var(--space-2) 0;border-radius:0;font-size:var(--text-sm);color:var(--medium-gray);border-left:none;margin-top:var(--space-2);margin-bottom:var(--space-3)}.recurrence-summary.compact strong{color:var(--dark-gray);font-weight:600}.recurrence-row{display:grid;grid-template-columns:1fr;gap:var(--space-3);align-items:start}.interval-group{min-width:100px}.recurrence-row .interval-group .interval-input{width:var(--interval-input-width)}.schedule-row{display:grid;grid-template-columns:1fr;gap:var(--space-3);align-items:start}.tab-navigation{display:flex;gap:var(--space-2);background:var(--white);border-bottom:2px solid var(--light-gray);padding:0 var(--space-4);margin:0 calc(var(--space-4) * -1) var(--space-4) calc(var(--space-4) * -1)}.tab{flex:1;padding:var(--space-3) var(--space-2);background:transparent;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;color:var(--medium-gray);font-weight:600;font-size:var(--text-sm);text-align:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:relative;display:flex;align-items:center;gap:var(--space-2)}.tab:hover{color:var(--forest);background:#6ca86c0d}.tab.active{color:var(--forest);border-bottom-color:var(--leaf)}.tab-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--light-gray);color:var(--medium-gray);padding:.125rem .5rem;border-radius:10px;font-size:.7rem;font-weight:700;min-width:1.25rem;line-height:1;margin-left:var(--space-1)}.tab.active .tab-badge{background:var(--leaf);color:var(--white)}.bulk-operations-toolbar{position:sticky;top:calc(var(--content-padding) * -1);z-index:11;display:flex;flex-direction:column;align-items:stretch;gap:var(--space-3);padding:var(--space-4);background:var(--cream);border:2px solid var(--leaf);border-radius:var(--card-radius);margin-bottom:0;box-shadow:0 -1px 3px #0000001a,0 1px 2px -1px #0000001a}.bulk-operations-info{display:flex;align-items:center;justify-content:center;gap:var(--space-3);color:var(--forest);font-size:var(--text-base)}.bulk-operations-info svg{color:var(--leaf);flex-shrink:0}.bulk-selection-count{color:var(--ink);font-size:var(--text-sm)}.bulk-selection-count strong{font-weight:700;color:var(--forest);font-size:var(--text-base)}.bulk-operations-actions{display:flex;align-items:center;justify-content:center;gap:var(--space-2);flex-wrap:wrap}.bulk-category-picker{display:flex;flex-direction:column;gap:var(--space-2)}.bulk-category-select{width:100%;min-width:var(--filter-min-width)}@media (min-width: 769px){.quickstats-compact{flex-direction:row;align-items:center;gap:var(--space-6);padding:var(--space-4) var(--space-6)}.quickstat-compact-item{flex-direction:column;justify-content:flex-start;align-items:flex-start;min-width:var(--quickstat-item-min-width);padding:0}.quickstat-compact-divider{display:block}.quickstat-compact-value{font-size:var(--text-xl)}.filters-row{flex-direction:row;align-items:flex-end;flex-wrap:wrap}.filter-group{min-width:var(--filter-min-width)}.transaction-row{gap:var(--space-3);padding:var(--space-4) var(--space-6);font-size:var(--text-sm)}.occurrence-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.recurrence-row{grid-template-columns:1fr .8fr}.schedule-row{grid-template-columns:1fr 1fr}.transaction-form .form-actions,.recurring-transaction-form .form-actions{position:static;margin:0;box-shadow:none}.tab-navigation{gap:var(--space-4);padding:0 var(--space-6);margin:0 calc(var(--space-6) * -1) var(--space-6) calc(var(--space-6) * -1)}.tab{flex:initial;padding:var(--space-4) var(--space-3);font-size:var(--text-base);text-align:left;justify-content:flex-start}.tab-badge{font-size:var(--text-xs);margin-left:0}.bulk-operations-toolbar{flex-direction:row;justify-content:space-between;padding:var(--space-4) var(--space-6);gap:var(--space-4)}.bulk-operations-info{justify-content:flex-start}.bulk-operations-actions{justify-content:flex-end}.bulk-category-picker{flex-direction:row;align-items:center}.bulk-category-select{width:auto}}@media (min-width: 1025px){.transaction-row{gap:var(--space-4);font-size:var(--text-sm)}.recurrence-row{grid-template-columns:1fr .8fr 1fr}.schedule-row{grid-template-columns:1fr 1fr 1fr}}.welcome-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6, 2rem);background:linear-gradient(135deg,#fdfbf7,#f8f6f3)}.welcome-container{max-width:900px;width:100%}.welcome-header{text-align:center;margin-bottom:var(--space-8, 3rem)}.welcome-logo{display:flex;justify-content:center;margin-bottom:var(--space-4, 1.5rem)}.logo-large{filter:drop-shadow(0 2px 8px rgba(35,78,63,.1))}.welcome-content{background:#fff;border-radius:var(--radius-xl);padding:var(--space-6, 2rem);box-shadow:0 4px 24px #00000014}.value-proposition{margin-bottom:var(--space-6, 2rem)}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-4, 1.5rem);margin-top:var(--space-4, 1.5rem)}.feature-card{padding:var(--space-4, 1.5rem);border:1px solid var(--light-gray, #E5E5E5);border-radius:var(--radius-lg);background:var(--cream, #FDFBF7);transition:transform .2s ease,box-shadow .2s ease}.feature-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6ca86c26}.feature-icon{margin-bottom:var(--space-3, 1rem)}.quick-start-guide{margin-top:var(--space-6, 2rem);padding-top:var(--space-6, 2rem);border-top:1px solid var(--light-gray, #E5E5E5)}.steps-list{margin-top:var(--space-4, 1.5rem)}.step-item{display:flex;align-items:flex-start;gap:var(--space-3, 1rem);margin-bottom:var(--space-4, 1.5rem)}.step-number{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--leaf, #6CA86C);color:#fff;border-radius:50%;font-weight:600;font-size:var(--text-sm, .875rem)}.step-content{flex:1}.welcome-actions{margin-top:var(--space-6, 2rem);display:flex;flex-direction:column;align-items:center}.welcome-footer{margin-top:var(--space-6, 2rem)}.method-assessment-quiz{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6, 2rem);background:linear-gradient(135deg,#fdfbf7,#f8f6f3)}.quiz-container{max-width:700px;width:100%;background:#fff;border-radius:var(--radius-xl);padding:var(--space-6, 2rem);box-shadow:0 4px 24px #00000014}.quiz-progress{margin-bottom:var(--space-6, 2rem)}.quiz-progress-bar{width:100%;height:4px;background:var(--light-gray, #E5E5E5);border-radius:var(--radius-sm);overflow:hidden}.quiz-progress-fill{height:100%;transition:width .3s ease}.quiz-question{margin-bottom:var(--space-5, 1.75rem)}.quiz-options{display:flex;flex-direction:column;gap:var(--space-3, 1rem)}.quiz-option{width:100%;text-align:left;padding:var(--space-4, 1.5rem);border:2px solid var(--light-gray, #E5E5E5);border-radius:var(--radius-lg);background:#fff;cursor:pointer;transition:all .2s ease}.quiz-option:hover{border-color:var(--leaf, #6CA86C);background:var(--cream, #FDFBF7);transform:translate(4px)}.quiz-option:focus{outline:2px solid var(--leaf, #6CA86C);outline-offset:2px}.quiz-option-label{font-weight:600;margin-bottom:var(--space-1, .5rem);color:var(--forest, #234E3F)}.quiz-option-description{font-size:var(--text-sm, .875rem);color:var(--medium-gray, #6B7280)}.quiz-navigation{margin-top:var(--space-6, 2rem);display:flex;justify-content:space-between;align-items:center}.quiz-comparison-view{min-height:100vh;padding:var(--space-6, 2rem)}.success-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6, 2rem);background:linear-gradient(135deg,#fdfbf7,#f8f6f3)}.success-container{max-width:800px;width:100%}.success-icon{text-align:center;margin-bottom:var(--space-5, 1.75rem)}.success-summary{background:var(--cream, #FDFBF7);padding:var(--space-5, 1.75rem);border-radius:var(--radius-lg);margin-bottom:var(--space-5, 1.75rem)}.summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4, 1.5rem)}.summary-item{text-align:center}.next-steps{margin-bottom:var(--space-5, 1.75rem)}.step-card{display:flex;gap:var(--space-3, 1rem);padding:var(--space-3, 1rem);background:#fff;border-radius:var(--radius-md);border:1px solid var(--light-gray, #E5E5E5);margin-bottom:var(--space-3, 1rem)}.success-actions{text-align:center;margin-top:var(--space-6, 2rem)}.success-encouragement{margin-top:var(--space-6, 2rem);padding:var(--space-4, 1.5rem);background:var(--cream, #FDFBF7);border-radius:var(--radius-md);border-left:4px solid var(--leaf, #6CA86C);text-align:center}@media (max-width: 768px){.feature-grid{grid-template-columns:1fr}.summary-grid{grid-template-columns:1fr;gap:var(--space-3, 1rem)}.welcome-screen,.method-assessment-quiz,.success-screen,.welcome-content,.quiz-container{padding:var(--space-4, 1.5rem)}}.btn-link{background:none;border:none;cursor:pointer;text-decoration:underline;color:var(--medium-gray, #6B7280);font-size:var(--text-sm, .875rem);padding:0}.btn-link:hover{color:var(--forest, #234E3F)}.btn-link:focus{outline:2px solid var(--leaf, #6CA86C);outline-offset:2px}.auth-page{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;background:linear-gradient(135deg,var(--cream) 0%,#f0f4f0 100%);padding:var(--space-8) var(--space-6);overflow-y:auto}.auth-container{width:100%;max-width:480px;margin:auto 0}.auth-header{text-align:center;margin-bottom:var(--space-8)}.auth-logo{margin-bottom:var(--space-4)}.auth-title{font-family:var(--font-serif);font-size:var(--text-3xl);color:var(--forest);margin-bottom:var(--space-2)}.auth-tagline{color:var(--medium-gray);font-size:var(--text-base);margin-bottom:0}.auth-card{margin-bottom:var(--space-6)}.auth-features{margin-bottom:var(--space-8);padding:var(--space-6);background:var(--white);border-radius:var(--card-radius);border:1px solid var(--light-gray)}.auth-features h3{text-align:center;margin-bottom:var(--space-6);margin-top:0;color:var(--forest);font-family:var(--font-serif);font-size:var(--text-xl)}.auth-features-grid{display:grid;gap:var(--space-4)}.auth-feature-item{display:flex;align-items:flex-start;gap:var(--space-3);color:var(--dark-gray);font-size:var(--text-sm);line-height:1.6}.auth-feature-icon{flex-shrink:0;font-size:var(--text-xl);line-height:1;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.auth-privacy{padding-bottom:var(--space-8)}@media (max-width: 480px){.auth-page{padding:var(--space-4) var(--space-3)}.auth-container{max-width:100%}.auth-title{font-size:var(--text-2xl)}.auth-features{padding:var(--space-4)}.auth-features h3{font-size:var(--text-lg)}.auth-features-grid{gap:var(--space-3)}.auth-privacy{padding-bottom:var(--space-6)}}.reports-dashboard{display:flex;flex-direction:column;gap:var(--space-8);padding:var(--space-4)}.reports-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--space-4)}.loading-spinner{width:48px;height:48px;border:4px solid var(--cream);border-top-color:var(--forest);border-radius:50%;animation:spin .8s linear infinite}.reports-grid{display:grid;grid-template-columns:1fr;gap:var(--space-8)}@media (min-width: 1024px){.reports-grid{grid-template-columns:repeat(1,1fr)}}.report-card{background:var(--white);border-radius:var(--card-radius);box-shadow:var(--shadow-md);padding:var(--space-6);transition:transform var(--transition-base),box-shadow var(--transition-base)}.report-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.report-title{font-family:var(--font-serif);font-size:var(--text-xl);font-weight:600;color:var(--forest);margin:0 0 var(--space-2) 0}.report-subtitle{font-size:var(--text-sm);color:var(--medium-gray);margin:0 0 var(--space-6) 0}.reports-filters{display:flex;flex-direction:column;gap:var(--space-4)}@media (min-width: 768px){.reports-filters{flex-direction:row;gap:var(--space-6)}}.date-range-selector{background:var(--white);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);flex:1}.date-range-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);color:var(--ink);font-weight:600}.date-icon{color:var(--forest)}.date-range-controls{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center}.predefined-ranges{display:flex;flex-wrap:wrap;gap:var(--space-2);flex:1}.range-button{padding:var(--space-2) var(--space-4);border:2px solid var(--medium-gray);border-radius:var(--button-radius);background:var(--white);color:var(--ink);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.range-button:hover{border-color:var(--forest);background:var(--light-gray)}.range-button.active{border-color:var(--forest);background:var(--forest);color:var(--white)}.custom-range-inputs{display:flex;flex-wrap:wrap;gap:var(--space-4);align-items:flex-end;width:100%}.date-input-group{display:flex;flex-direction:column;gap:var(--space-1);flex:1;min-width:150px}.date-input-group label{font-size:var(--text-sm);font-weight:600;color:var(--ink)}.date-separator{font-size:var(--text-sm);color:var(--medium-gray);margin-bottom:var(--space-2)}.custom-actions{display:flex;gap:var(--space-2)}.selected-range-display{padding:var(--space-3);background:var(--light-gray);border-radius:var(--input-radius);font-size:var(--text-sm);color:var(--ink)}.text-secondary{color:var(--medium-gray)}.account-filter{background:var(--white);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);flex:1;position:relative}.account-filter-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);color:var(--ink);font-weight:600}.account-icon{color:var(--forest)}.account-filter-controls{position:relative}.account-filter-button{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--medium-gray);border-radius:var(--button-radius);background:var(--white);color:var(--ink);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all var(--transition-fast);display:flex;justify-content:space-between;align-items:center}.account-filter-button:hover:not(:disabled){border-color:var(--forest);background:var(--light-gray)}.account-filter-button.active{border-color:var(--forest);background:var(--forest);color:var(--white)}.account-filter-button:disabled{opacity:.5;cursor:not-allowed}.filter-button-text{flex:1;text-align:left}.chevron-icon{transition:transform var(--transition-fast)}.chevron-icon.open{transform:rotate(180deg)}.account-dropdown{position:absolute;top:calc(100% + var(--space-2));left:0;right:0;background:var(--white);border:2px solid var(--forest);border-radius:var(--input-radius);box-shadow:var(--shadow-lg);z-index:1000;max-height:400px;overflow:hidden;display:flex;flex-direction:column}.account-dropdown-header{padding:var(--space-3);border-bottom:1px solid var(--light-gray);background:var(--cream)}.select-all-button{width:100%;padding:var(--space-2);border:none;background:transparent;color:var(--forest);font-size:var(--text-sm);font-weight:600;cursor:pointer;text-align:left;transition:background var(--transition-fast);border-radius:var(--input-radius)}.select-all-button:hover{background:var(--light-gray)}.account-list{overflow-y:auto;max-height:300px}.account-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--light-gray)}.account-option:hover{background:var(--cream)}.account-option:last-child{border-bottom:none}.account-checkbox{cursor:pointer;width:18px;height:18px;accent-color:var(--forest)}.account-name{flex:1;font-size:var(--text-sm);font-weight:600;color:var(--ink);display:flex;flex-direction:column;gap:var(--space-1)}.account-type{text-transform:capitalize;font-weight:400}.account-balance{font-size:var(--text-sm);font-weight:600;color:var(--leaf)}.account-balance.negative{color:var(--error)}.account-empty-state{padding:var(--space-6);text-align:center}.selected-accounts-badges{display:flex;flex-wrap:wrap;gap:var(--space-2);padding-top:var(--space-2)}.account-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--forest);color:var(--white);border-radius:var(--button-radius);font-size:var(--text-sm);font-weight:600}.remove-account-button{background:transparent;border:none;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;color:var(--white);transition:opacity var(--transition-fast)}.remove-account-button:hover{opacity:.7}.chart-container{display:flex;flex-direction:column;gap:var(--space-6)}.chart-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-4)}.summary-stat{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4);background:var(--light-gray);border-radius:var(--input-radius)}.stat-label{font-size:var(--text-sm);color:var(--medium-gray);font-weight:600}.stat-value{font-size:var(--text-xl);font-weight:700;color:var(--forest)}.stat-value.income,.stat-value.positive{color:var(--leaf)}.stat-value.expense,.stat-value.negative{color:var(--error)}.stat-value.warning{color:var(--warning)}.stat-value.success{color:var(--success)}.chart-tooltip{background:var(--white);border:2px solid var(--forest);border-radius:var(--input-radius);padding:var(--space-3);box-shadow:var(--shadow-md)}.tooltip-label{font-weight:700;color:var(--forest);margin:0 0 var(--space-2) 0;font-size:var(--text-sm)}.tooltip-value{font-size:var(--text-sm);color:var(--ink);margin:var(--space-1) 0}.tooltip-value strong{font-weight:700;color:var(--forest)}.tooltip-value.income strong{color:var(--leaf)}.tooltip-value.expense strong{color:var(--error)}.tooltip-value.net strong{color:var(--forest)}.tooltip-value.over-budget strong{color:var(--error)}.tooltip-value.under-budget strong{color:var(--leaf)}.tooltip-percentage{font-size:var(--text-xs);color:var(--medium-gray);margin-top:var(--space-1)}.category-breakdown,.budget-breakdown,.cash-flow-summary{margin-top:var(--space-6)}.breakdown-title{font-family:var(--font-serif);font-size:var(--text-lg);font-weight:600;color:var(--forest);margin:0 0 var(--space-4) 0}.breakdown-list{display:flex;flex-direction:column;gap:var(--space-3)}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);background:var(--light-gray);border-radius:var(--input-radius);transition:background var(--transition-fast)}.breakdown-item:hover{background:var(--cream)}.breakdown-item.over-budget{background:#dc26260d;border-left:3px solid var(--error)}.breakdown-item.on-track{background:#6ca86c0d;border-left:3px solid var(--leaf)}.item-info{display:flex;align-items:center;gap:var(--space-3);flex:1}.item-color{width:16px;height:16px;border-radius:var(--radius-sm);flex-shrink:0}.item-name{font-size:var(--text-sm);font-weight:600;color:var(--ink)}.item-values{display:flex;align-items:center;gap:var(--space-4)}.item-amount{font-size:var(--text-sm);font-weight:600;color:var(--forest)}.item-percentage{font-size:var(--text-sm);color:var(--medium-gray);min-width:50px;text-align:right}.item-percentage.over-budget{color:var(--error);font-weight:700}.item-percentage.on-track{color:var(--leaf)}.progress-bar{flex:1;height:8px;background:#e5e7eb;border-radius:var(--radius-sm);overflow:hidden;margin-left:var(--space-2)}.progress-fill{height:100%;transition:width var(--transition-base);border-radius:var(--radius-sm)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.summary-item{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);background:var(--light-gray);border-radius:var(--input-radius)}.item-label{font-size:var(--text-sm);color:var(--medium-gray);font-weight:600}.item-value{font-size:var(--text-lg);font-weight:700;color:var(--forest)}.item-value.income{color:var(--leaf)}.item-value.expense{color:var(--error)}.item-value.positive{color:var(--leaf)}.item-value.negative{color:var(--error)}.clickable-chart-item{cursor:pointer;transition:all var(--transition-fast);outline:none}.clickable-chart-item:hover{background:var(--cream);transform:translate(4px);box-shadow:var(--shadow-sm)}.clickable-chart-item:focus-visible{outline:2px solid var(--forest);outline-offset:2px}.clickable-chart-item:active{transform:translate(2px)}.chart-interaction-hint{margin-top:var(--space-4);padding:var(--space-3);background:#6ca86c1a;border-left:3px solid var(--leaf);border-radius:var(--input-radius);font-size:var(--text-sm);color:var(--ink);font-style:italic}.chart-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;padding:var(--space-8);text-align:center;gap:var(--space-4)}.empty-icon{color:var(--medium-gray);opacity:.5}.empty-text{font-size:var(--text-lg);font-weight:600;color:var(--ink);margin:0}.empty-subtext{font-size:var(--text-sm);color:var(--medium-gray);margin:0;max-width:400px}@media (max-width: 768px){.reports-dashboard{padding:var(--space-2)}.report-card{padding:var(--space-4)}.date-range-controls{flex-direction:column;align-items:stretch}.predefined-ranges{flex-direction:column}.range-button{width:100%}.custom-range-inputs{flex-direction:column}.date-input-group{width:100%}.chart-summary{grid-template-columns:1fr}}.account-balances-table{width:100%}.balances-section{margin-bottom:var(--space-8)}.balances-section:last-child{margin-bottom:var(--space-6)}.balances-section-title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:700;color:var(--forest);margin:0 0 var(--space-4) 0;padding-bottom:var(--space-3);border-bottom:3px solid var(--forest)}.balances-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:var(--space-4)}.balances-table thead th{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:700;color:var(--forest);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-4) var(--space-4);background:var(--cream);text-align:left;border-bottom:2px solid var(--forest)}.balances-table thead th:first-child{border-top-left-radius:var(--radius-md)}.balances-table thead th:last-child{border-top-right-radius:var(--radius-md)}.balances-table tbody tr{transition:background-color .2s ease}.balances-table tbody tr:hover{background:var(--cream)}.balances-table tbody tr:last-child td{border-bottom:1px solid var(--light-gray)}.balances-table td{padding:var(--space-4) var(--space-4);font-family:var(--font-ui);font-size:var(--text-base);color:var(--ink);border-bottom:1px solid #f3f4f6}.account-name{font-weight:600;color:var(--forest);font-size:var(--text-base);margin-bottom:var(--space-1)}.account-institution{font-size:var(--text-sm);color:var(--medium-gray);font-weight:400}.balance-cell{font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-weight:600;font-size:var(--text-base);color:var(--forest)}.balance-cell.liability{color:#d84545}.balances-table tfoot{font-weight:700}.balances-table tfoot .total-row{border-top:3px solid var(--forest);background:linear-gradient(to bottom,var(--cream) 0%,var(--white) 100%)}.balances-table tfoot td{padding:var(--space-5) var(--space-4);color:var(--forest);font-family:var(--font-heading);font-size:var(--text-lg);font-weight:700}.text-right{text-align:right}.net-worth-summary{display:flex;justify-content:space-between;align-items:center;padding:var(--space-8);margin-top:var(--space-8);background:linear-gradient(135deg,var(--forest) 0%,#1a3a2e 100%);border-radius:var(--radius-lg);color:var(--white);box-shadow:0 8px 24px #234e3f4d;position:relative;overflow:hidden}.net-worth-summary:before{content:"";position:absolute;top:-50%;right:-10%;width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%}.net-worth-label{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:700;letter-spacing:-.02em;position:relative;z-index:1}.net-worth-value{font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:var(--text-4xl);font-weight:700;letter-spacing:-.03em;position:relative;z-index:1}.net-worth-value.negative{color:#fca5a5}.net-worth-value.positive{color:#86efac}.account-balances-loading,.account-balances-error,.account-balances-empty{padding:var(--space-12);text-align:center}.account-balances-loading .loading-spinner{margin:0 auto var(--space-4);width:48px;height:48px;border:4px solid var(--light-gray);border-top-color:var(--forest);border-radius:50%;animation:spin 1s linear infinite}.account-balances-loading p{color:var(--medium-gray);font-size:var(--text-base)}.account-balances-error{background:#fef2f2;border-radius:var(--radius-lg);padding:var(--space-8)}.account-balances-error .error-message{color:#dc2626;font-weight:600;font-size:var(--text-lg);margin-bottom:var(--space-3)}.account-balances-error .error-details{color:#991b1b;font-size:var(--text-sm);font-family:SF Mono,Monaco,monospace}.account-balances-empty{background:var(--cream);border-radius:var(--radius-lg);border:2px dashed var(--light-gray);padding:var(--space-12)}.account-balances-empty p{color:var(--medium-gray);font-size:var(--text-base);line-height:1.6}@media (max-width: 768px){.balances-table{font-size:var(--text-sm)}.balances-table thead th{padding:var(--space-3) var(--space-2);font-size:var(--text-xs)}.balances-table td{padding:var(--space-3) var(--space-2)}.account-institution{display:none}.net-worth-summary{flex-direction:column;gap:var(--space-4);text-align:center;padding:var(--space-6)}.net-worth-label{font-size:var(--text-xl)}.net-worth-value{font-size:var(--text-3xl)}.balances-section-title{font-size:var(--text-base)}.balances-table tfoot td{font-size:var(--text-base);padding:var(--space-4) var(--space-2)}}@media print{.reports-dashboard{padding:0}.report-card{box-shadow:none;border:1px solid #E5E7EB;page-break-inside:avoid;margin-bottom:20px}.date-range-selector{page-break-after:avoid}.btn,.export-dropdown{display:none}}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-3);max-width:420px;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--white);border-radius:var(--input-radius);box-shadow:var(--shadow-lg);pointer-events:auto;animation:toastSlideIn var(--transition-base) var(--transition-bounce) forwards;min-width:300px;max-width:100%;border-left:4px solid}.toast-success{border-left-color:var(--success);background:linear-gradient(to right,rgba(5,150,105,.05) 0%,var(--white) 8px)}.toast-error{border-left-color:var(--error);background:linear-gradient(to right,rgba(220,38,38,.05) 0%,var(--white) 8px)}.toast-warning{border-left-color:var(--warning);background:linear-gradient(to right,rgba(217,119,6,.05) 0%,var(--white) 8px)}.toast-info{border-left-color:var(--leaf);background:linear-gradient(to right,rgba(108,168,108,.05) 0%,var(--white) 8px)}.toast-content{display:flex;align-items:flex-start;gap:var(--space-3);flex:1}.toast-icon{font-size:var(--text-lg);line-height:1;flex-shrink:0}.toast-message{flex:1;font-size:var(--text-sm);line-height:1.5;color:var(--ink);font-family:var(--font-sans)}.toast-actions{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}.toast-action{padding:var(--space-1) var(--space-3);background:var(--forest);color:var(--white);border:none;border-radius:var(--button-radius);font-size:var(--text-sm);font-family:var(--font-sans);font-weight:600;cursor:pointer;transition:background-color var(--transition-fast)}.toast-action:hover{background:#1a3a2e}.toast-action:active{transform:scale(.98)}.toast-close{padding:0;width:24px;height:24px;background:transparent;border:none;color:var(--medium-gray);font-size:var(--text-xl);line-height:1;cursor:pointer;transition:color var(--transition-fast);flex-shrink:0}.toast-close:hover{color:var(--ink)}@media (max-width: 640px){.toast-container{bottom:var(--space-4);right:var(--space-4);left:var(--space-4);max-width:none}.toast{min-width:0}}.error-message{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);border-radius:var(--input-radius);border-left:4px solid;margin:var(--space-4) 0}.error-message-critical{background:#dc26261a;border-left-color:var(--error)}.error-message-error{background:#dc262614;border-left-color:var(--error)}.error-message-warning{background:#d9770614;border-left-color:var(--warning)}.error-message-info{background:#6ca86c14;border-left-color:var(--leaf)}.error-message-content{display:flex;align-items:flex-start;gap:var(--space-3)}.error-message-icon{font-size:var(--text-xl);line-height:1;flex-shrink:0}.error-message-text{flex:1}.error-message-title{font-size:var(--text-base);font-weight:600;font-family:var(--font-serif);color:var(--ink);margin-bottom:var(--space-1)}.error-message-body{font-size:var(--text-sm);line-height:1.5;color:var(--dark-gray);font-family:var(--font-sans)}.error-message-actions{display:flex;gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-6);background:var(--cream)}.error-boundary-content{max-width:600px;text-align:center;background:var(--white);padding:var(--space-8);border-radius:var(--card-radius);box-shadow:var(--shadow-md)}.error-boundary .error-icon{font-size:64px;margin-bottom:var(--space-4)}.error-boundary h3{font-size:var(--text-2xl);font-family:var(--font-serif);color:var(--ink);margin-bottom:var(--space-3)}.error-boundary p{font-size:var(--text-base);line-height:1.6;color:var(--dark-gray);margin-bottom:var(--space-6)}.error-boundary .error-details{margin:var(--space-6) 0;text-align:left}.error-boundary .error-details summary{font-size:var(--text-sm);font-weight:600;color:var(--medium-gray);cursor:pointer;padding:var(--space-2);border-radius:var(--button-radius);transition:background-color var(--transition-fast)}.error-boundary .error-details summary:hover{background:var(--light-gray)}.error-boundary .error-stack{margin-top:var(--space-3);padding:var(--space-4);background:var(--light-gray);border-radius:var(--input-radius);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--dark-gray);overflow-x:auto;white-space:pre-wrap;word-wrap:break-word}.error-boundary .error-actions{display:flex;gap:var(--space-3);justify-content:center;flex-wrap:wrap}.toast-action:focus-visible,.toast-close:focus-visible{outline:2px solid var(--forest);outline-offset:2px}@media (prefers-contrast: high){.toast,.error-message{border-width:2px;border-style:solid}.toast-success,.error-message-info{border-color:var(--success)}.toast-error,.error-message-error,.error-message-critical{border-color:var(--error)}.toast-warning,.error-message-warning{border-color:var(--warning)}}@media (prefers-reduced-motion: reduce){.toast{animation:none}.toast-action,.toast-close{transition:none}}.budget-overview{padding:var(--space-6);max-width:var(--container-width);margin:0 auto;background:var(--cream)}.budget-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6);padding-bottom:var(--space-4);gap:var(--space-6);flex-wrap:wrap;border-bottom:1px solid var(--light-gray)}.budget-title-section{flex:1}.budget-title{font-family:var(--font-serif);font-size:var(--text-3xl);font-weight:600;color:var(--ink);margin:0 0 var(--space-1) 0;line-height:1.2}.budget-subtitle{font-family:var(--font-sans);font-size:var(--text-sm);font-weight:500;color:var(--medium-gray);margin:0;text-transform:uppercase;letter-spacing:.5px}.budget-header-actions{display:flex;align-items:center;gap:var(--space-3)}.budget-selector{padding:var(--space-2) var(--space-4);border:1px solid var(--light-gray);border-radius:var(--button-radius);background:var(--white);font-size:var(--text-sm);color:var(--ink);cursor:pointer;transition:all var(--transition-fast)}.budget-selector:hover{border-color:var(--forest)}.budget-selector:focus{outline:2px solid var(--forest);outline-offset:2px}.budget-refresh-indicator{margin-left:var(--space-3);font-size:var(--text-sm);color:var(--medium-gray);font-weight:400;animation:pulse 1.5s ease-in-out infinite}.budget-actions{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.budget-selector{margin-right:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--input-radius);border:1px solid var(--light-gray);background-color:var(--white)}.budget-warnings{background:var(--white);padding:var(--space-4);border-radius:var(--card-radius);border-left:4px solid var(--soft-gold);margin-bottom:var(--space-6)}.budget-warning-text{color:var(--medium-gray)}.budget-content{display:flex;flex-direction:column;gap:var(--space-6)}.budget-row-editable,.budget-item-editable{background:transparent;border:none;cursor:pointer;padding:0;margin:0;width:100%;display:block;text-align:right;transition:text-decoration var(--transition-fast)}.budget-row-editable:hover,.budget-item-editable:hover{text-decoration:underline;text-decoration-color:var(--leaf)}.budget-row-editable:focus-visible,.budget-item-editable:focus-visible{outline:2px solid var(--forest);outline-offset:2px}.budget-value-interactive{display:inline}.budget-label,.edit-indicator{display:none}@media (max-width: 768px){.budget-header{flex-direction:column;align-items:flex-start}.budget-actions{width:100%;justify-content:stretch}.budget-actions>*{flex:1}.category-group-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.category-group-totals{width:100%;justify-content:space-between}.budget-amounts{grid-template-columns:1fr;min-width:auto;gap:var(--space-2)}.category-budget{flex-direction:column;align-items:stretch;gap:var(--space-4)}.category-progress{min-width:auto}.category-actions-bar{flex-wrap:wrap}.category-actions-bar .action-button{flex:1 1 45%}}@media (max-width: 480px){.budget-overview{padding:var(--space-4)}.category-item{flex-direction:column;align-items:stretch;gap:var(--space-3)}.category-info{flex-direction:column;align-items:flex-start}.budget-summary{flex-direction:column;gap:var(--space-2)}}@media (prefers-reduced-motion: reduce){.budget-refresh-indicator,.progress-overflow{animation:none}.toggle-icon,.progress-fill{transition:none}}.financial-summary-hero{margin-bottom:var(--space-6);background:var(--white);border-radius:var(--card-radius);padding:var(--space-6);border:1px solid var(--light-gray);box-shadow:var(--shadow-sm)}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);margin-bottom:var(--space-4)}.summary-card{text-align:center;padding:var(--space-5);background:var(--cream);border-radius:var(--card-radius);border:1px solid var(--light-gray);transition:all var(--transition-fast)}.summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.summary-card-highlight{background:linear-gradient(135deg,var(--leaf) 0%,var(--forest) 100%);border-color:var(--leaf);color:var(--white)}.summary-card-highlight .summary-label,.summary-card-highlight .summary-value,.summary-card-highlight .summary-subtext{color:var(--white)}.summary-label{font-size:var(--text-sm);font-weight:600;color:var(--medium-gray);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.5px}.summary-value{font-family:var(--font-sans);font-size:var(--text-3xl);font-weight:700;color:var(--forest);margin-bottom:var(--space-1);line-height:1.1}.summary-subtext{font-size:var(--text-xs);color:var(--medium-gray);font-weight:500}.budget-status{text-align:center;padding:var(--space-3) var(--space-4);border-radius:var(--button-radius);font-weight:600;font-size:var(--text-sm);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;transition:all var(--transition-fast)}.budget-status-success{background:#6ca86c1a;color:var(--forest);border:1px solid var(--leaf)}.budget-status-warning{background:#d8b56a1a;color:#8b6914;border:1px solid var(--soft-gold)}@media (max-width: 768px){.summary-cards{grid-template-columns:repeat(2,1fr)}.summary-value{font-size:var(--text-2xl)}}@media (max-width: 480px){.summary-cards{grid-template-columns:1fr}.financial-summary-hero{padding:var(--space-4)}}.budget-row-editing{display:flex;flex-direction:column;gap:var(--space-2);padding:0;background:#6ca86c0d;border-radius:var(--button-radius)}.budget-edit-controls{display:flex;flex-direction:column;gap:var(--space-3)}.budget-input-wrapper{position:relative;flex:1}.budget-input{width:100%;padding:var(--space-3);font-size:var(--text-base);font-family:var(--font-sans);font-variant-numeric:tabular-nums;border:2px solid var(--light-gray);border-radius:var(--input-radius);background:var(--white);color:var(--ink);transition:all var(--transition-fast);min-height:48px}.budget-input:focus{outline:none;border-color:var(--forest);box-shadow:0 0 0 3px #234e3f1a}.budget-input:disabled{background:var(--light-gray);cursor:not-allowed;opacity:.6}.budget-input-error{border-color:var(--error)}.budget-input-error:focus{box-shadow:0 0 0 3px #dc26261a}.budget-error-message{margin-top:var(--space-1);font-size:var(--text-sm);color:var(--error);font-weight:500;display:flex;align-items:center;gap:var(--space-1)}.budget-error-message:before{content:"⚠️";font-size:var(--text-base)}.budget-edit-actions{display:flex;gap:var(--space-2);align-items:center}.button-small{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);min-height:48px;font-weight:600;border-radius:var(--button-radius);transition:all var(--transition-fast);cursor:pointer;border:1px solid transparent;font-family:var(--font-sans)}.button-primary:hover:not(:disabled){background:#234e3fe6;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.button-primary:disabled{background:var(--medium-gray);border-color:var(--medium-gray);cursor:not-allowed;opacity:.6}.button-ghost{background:transparent;color:var(--medium-gray);border-color:var(--light-gray)}.button-ghost:hover:not(:disabled){background:var(--light-gray);color:var(--ink);border-color:var(--medium-gray)}.button-ghost:disabled{cursor:not-allowed;opacity:.6}@media (max-width: 768px){.budget-edit-controls{flex-direction:column}.budget-edit-actions{width:100%}.budget-edit-actions button{flex:1}}@media (max-width: 480px){.budget-input{font-size:var(--text-base);padding:var(--space-3)}.button-small{padding:var(--space-3) var(--space-4);font-size:var(--text-base)}}@media (prefers-reduced-motion: reduce){.budget-input,.button-primary,.button-ghost{transition:none}.button-primary:hover:not(:disabled){transform:none}}.budget-empty-state{max-width:600px;margin:var(--space-8) auto;text-align:center;padding:var(--space-8);background:var(--white);border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000000f}.empty-state-icon{font-size:48px;margin-bottom:var(--space-4)}.empty-state-heading{font-family:var(--font-heading);font-size:28px;font-weight:700;color:var(--forest);margin-bottom:var(--space-4)}.empty-state-message{font-family:var(--font-body);font-size:16px;color:var(--ink);line-height:1.6;margin-bottom:var(--space-6)}.empty-state-cta{margin-bottom:var(--space-4)}.empty-state-secondary{font-size:14px;color:#6b7280;margin-top:var(--space-4)}:root{--metric-primary-value: 48px;--metric-primary-label: 14px;--metric-secondary-value: 30px;--metric-secondary-label: 13px;--metric-tertiary-value: 16px;--metric-tertiary-label: 12px;--heading-primary: 26px;--heading-secondary: 18px}.compact-health-summary-wrapper{margin-bottom:var(--space-6)}.compact-summary{background:var(--white);border:1px solid rgba(107,114,128,.2);border-left:4px solid var(--success);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-6);transition:all var(--transition-base);box-shadow:0 2px 8px #0000000a}.compact-summary.has-issues{border-left-color:var(--error);background:linear-gradient(90deg,rgba(220,38,38,.02) 0%,var(--white) 100%);box-shadow:0 2px 8px #dc262614}.compact-summary-content{display:flex;align-items:center;justify-content:flex-start;gap:var(--space-4);flex-wrap:wrap}.compact-metric{display:flex;flex-direction:column;gap:var(--space-1);min-width:auto}.compact-status{flex-direction:row;align-items:center;gap:var(--space-2);font-weight:600;font-size:var(--text-base);color:var(--ink);min-width:auto;margin-right:var(--space-4)}.compact-status .metric-text{font-size:15px;font-weight:600;color:var(--ink)}.status-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;flex-shrink:0}.status-icon-healthy{color:var(--success);background:#0596691a}.status-icon-warning{color:var(--warning);background:#d977061a}.status-icon-critical{color:var(--error);background:#dc26261a}.metric-label{color:var(--medium-gray);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.05em}.compact-metric-primary{margin-left:var(--space-8);margin-right:var(--space-8);padding-left:var(--space-6);padding-right:var(--space-6);border-left:1px solid rgba(107,114,128,.15);border-right:1px solid rgba(107,114,128,.15)}.compact-metric-primary .metric-label{font-size:12px;color:var(--forest);font-weight:600}.compact-metric-primary .metric-value{color:var(--ink);font-weight:800;font-size:52px;font-family:var(--font-mono);font-variant-numeric:tabular-nums;line-height:1;margin-top:var(--space-1)}.compact-metric-secondary{margin-right:var(--space-4)}.compact-metric-secondary .metric-value{color:var(--ink);font-weight:600;font-size:18px;font-family:var(--font-mono);font-variant-numeric:tabular-nums;line-height:1.2}.compact-metric-tertiary{margin-left:var(--space-2)}.compact-metric-tertiary .metric-label{font-size:10px;color:var(--medium-gray)}.compact-metric-tertiary .metric-value{color:var(--medium-gray);font-weight:600;font-size:16px;font-family:var(--font-mono);font-variant-numeric:tabular-nums;line-height:1.2}.compact-toggle{background:transparent;color:var(--forest);border:1.5px solid rgba(35,78,63,.4);padding:10px 20px;border-radius:var(--radius-md);font-size:15px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;letter-spacing:.01em;margin-left:auto;min-height:40px;display:flex;align-items:center;gap:var(--space-2)}.compact-toggle:hover{background:#234e3f14;border-color:var(--forest);box-shadow:0 2px 4px #234e3f26;transform:translateY(0)}.compact-toggle:active{background:#234e3f1f;transform:translateY(0);box-shadow:none}.compact-toggle:focus-visible{outline:2px solid var(--forest);outline-offset:2px}.compact-summary.has-issues .compact-toggle{color:var(--error);border-color:#dc262680;background:#dc262608}.compact-summary.has-issues .compact-toggle:hover{background:#dc262614;border-color:var(--error);box-shadow:0 2px 4px #dc262626}.expanded-dashboard{margin-top:var(--space-6);animation:expand-in .3s cubic-bezier(.4,0,.2,1)}@keyframes expand-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 767px){.compact-summary-content{flex-direction:column;align-items:stretch;gap:var(--space-3)}.compact-metric{justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--light-gray)}.compact-metric:last-of-type{border-bottom:none}.compact-toggle{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-base)}}@media (min-width: 768px) and (max-width: 1024px){.compact-summary-content{gap:var(--space-3)}.compact-metric{flex:1;min-width:120px}}.budget-progress-bar-enhanced{display:flex;flex-direction:column;gap:var(--space-2);position:relative;min-width:280px}.progress-bar-wrapper{display:flex;align-items:center;gap:var(--space-3)}.progress-bar-track{flex:1;min-width:100px;max-width:120px;height:8px;background:var(--light-gray);border-radius:var(--radius-full);overflow:hidden;position:relative;opacity:.6}.progress-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .4s cubic-bezier(.4,0,.2,1),background-color .3s ease;position:relative;z-index:1;display:inline-block;float:left}.progress-bar-budgeted-portion{border-radius:var(--radius-full) 0 0 var(--radius-full)}.progress-bar-overage-portion{border-radius:0 var(--radius-full) var(--radius-full) 0;background:#f87171!important}.progress-bar-fill[data-status=healthy]{background:linear-gradient(90deg,var(--leaf) 0%,var(--success) 100%)}.progress-bar-fill[data-status=warning]{background:linear-gradient(90deg,var(--soft-gold) 0%,var(--warning) 100%)}.progress-bar-fill[data-status=caution]{background:linear-gradient(90deg,#f59e0b,#ea580c)}.progress-bar-fill[data-status=overspent]{background:#f87171!important}.progress-bar-overflow{position:absolute;right:-16px;top:0;height:12px;width:16px;background:repeating-linear-gradient(45deg,#f87171,#f87171 3px,#f8717199 3px 6px);border-radius:0 var(--radius-full) var(--radius-full) 0;animation:overflow-pulse 1.5s ease-in-out infinite;z-index:2}@keyframes overflow-pulse{0%,to{opacity:1}50%{opacity:.7}}.progress-bar-empty{background:var(--light-gray)!important;opacity:1}.progress-bar-unbudgeted{background:#f87171!important;opacity:1}.progress-bar-track[data-no-budget=true]{background:var(--light-gray);border:none;opacity:1}.progress-percent{min-width:48px;text-align:right}.progress-labels{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--medium-gray);flex-wrap:wrap}.progress-label-spent{font-weight:600;color:var(--ink)}.progress-label-divider{color:var(--medium-gray)}.progress-label-budgeted{font-weight:600;color:var(--forest)}.progress-label-remaining{margin-left:auto;font-weight:600;color:var(--success)}.progress-label-remaining[data-overspent=true]{color:var(--error)}.progress-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--ink);color:var(--cream);padding:var(--space-3);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-tooltip);min-width:220px;opacity:1;pointer-events:auto;transition:opacity var(--transition-fast)}.progress-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--ink)}.progress-tooltip h4{font-family:var(--font-serif);font-size:var(--text-sm);font-weight:600;margin:0 0 var(--space-2) 0;color:var(--cream)}.progress-tooltip dl{display:grid;grid-template-columns:auto 1fr;gap:var(--space-1) var(--space-3);margin:0;font-size:var(--text-xs)}.progress-tooltip dt{color:#fdfbf7b3;font-weight:400}.progress-tooltip dd{margin:0;font-weight:600;text-align:right;color:var(--cream);font-variant-numeric:tabular-nums}.budget-progress-bar-enhanced:focus-visible{outline:2px solid var(--forest);outline-offset:2px;border-radius:var(--radius-sm)}.budget-health-dashboard{display:grid;grid-template-columns:2fr repeat(3,1fr);grid-template-rows:auto auto;gap:var(--space-4);margin-bottom:var(--space-8);padding:var(--space-6);background:linear-gradient(135deg,#6ca86c08,#234e3f08);border-radius:var(--card-radius)}.health-card-primary{grid-row:1 / 3;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-8);background:var(--white);border:2px solid transparent;transition:border-color var(--transition-base);border-radius:var(--card-radius)}.health-card-primary[data-status=healthy]{border-color:var(--success)}.health-card-primary[data-status=warning]{border-color:var(--warning)}.health-card-primary[data-status=critical]{border-color:var(--error)}.health-status-icon{width:96px;height:96px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:48px;margin-bottom:var(--space-4);background:var(--light-gray);transition:all var(--transition-base)}.health-status-icon[data-status=healthy]{background:#0596691a;color:var(--success)}.health-status-icon[data-status=warning]{background:#d977061a;color:var(--warning)}.health-status-icon[data-status=critical]{background:#dc26261a;color:var(--error);animation:health-pulse 2s ease-in-out infinite}@keyframes health-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.health-title{font-family:var(--font-serif);font-size:var(--heading-primary);font-weight:600;color:var(--ink);margin:0 0 var(--space-3) 0;text-transform:none}.health-metrics{display:flex;gap:var(--space-6);margin-top:var(--space-4)}.health-metric{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.metric-value{font-size:var(--metric-primary-value);font-weight:700;color:var(--forest);font-family:system-ui,-apple-system,sans-serif;font-variant-numeric:tabular-nums}.metric-label{font-size:var(--metric-primary-label);color:var(--medium-gray);text-transform:none;letter-spacing:0;font-weight:600;font-family:var(--font-sans)}.metric-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-4);text-align:center;background:var(--white);border-left:4px solid var(--light-gray);transition:all var(--transition-fast);border-radius:var(--card-radius);cursor:pointer}.metric-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.metric-card-error{border-left-color:var(--error)}.metric-card-warning{border-left-color:var(--warning)}.metric-card-info{border-left-color:var(--forest)}.metric-icon{width:56px;height:56px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-3);transition:all var(--transition-base)}.metric-icon-error{background:#dc26261a;color:var(--error)}.metric-icon-warning{background:#d977061a;color:var(--warning)}.metric-icon-info{background:#234e3f1a;color:var(--forest)}.metric-count{font-size:var(--metric-secondary-value);font-weight:700;color:var(--ink);font-family:system-ui,-apple-system,sans-serif;margin-bottom:var(--space-1);font-variant-numeric:tabular-nums}.metric-subtext{font-size:var(--text-xs);color:var(--medium-gray);margin-top:var(--space-1)}.pace-indicator-card{grid-column:1 / -1;padding:var(--space-5);background:var(--white);border-radius:var(--card-radius)}.pace-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4)}.pace-header-icon{color:var(--forest);flex-shrink:0}.pace-title{font-family:var(--font-serif);font-size:var(--heading-secondary);font-weight:600;color:var(--forest);margin:0;text-transform:none}.pace-visualization{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-4)}.pace-bar-group{display:flex;flex-direction:column;gap:var(--space-2)}.pace-bar-label{display:flex;justify-content:space-between;align-items:baseline}.pace-bar-label-text{font-size:var(--metric-secondary-label);font-weight:600;color:var(--medium-gray);text-transform:none;letter-spacing:0;font-family:var(--font-sans)}.pace-bar-label-value{font-size:var(--metric-primary-label);font-weight:700;color:var(--ink);font-family:system-ui,-apple-system,sans-serif;font-variant-numeric:tabular-nums}.pace-bar-track{height:10px;background:#6b72801a;border-radius:var(--radius-full);overflow:hidden;position:relative}.pace-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .6s cubic-bezier(.4,0,.2,1)}.pace-bar-fill-time{background:linear-gradient(90deg,#6b728099,#6b7280cc)}.pace-bar-fill-spending{background:linear-gradient(90deg,var(--leaf) 0%,var(--success) 100%)}.pace-bar-fill-spending-fast{background:linear-gradient(90deg,var(--warning) 0%,var(--error) 100%)}.pace-bar-fill-under-budget,.pace-bar-fill-on-track{background:linear-gradient(90deg,var(--leaf) 0%,var(--success) 100%)}.pace-status-container{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.pace-status-badge{padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-weight:600;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em}.pace-status-on-track{background:#0596691a;color:var(--success)}.pace-status-spending-fast{background:#d977061a;color:var(--warning)}.pace-status-under-budget{background:#6ca86c1a;color:var(--leaf)}.pace-description{color:var(--medium-gray);font-size:14px;font-weight:500}.budget-warning-card{margin-bottom:var(--space-6);border-left:4px solid;background:var(--white);animation:warning-card-enter .3s ease-out;border-radius:var(--card-radius)}@keyframes warning-card-enter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.budget-warning-overspent{border-left-color:var(--error);background:linear-gradient(90deg,rgba(220,38,38,.03) 0%,var(--white) 100%)}.budget-warning-approaching{border-left-color:var(--warning);background:linear-gradient(90deg,rgba(217,119,6,.03) 0%,var(--white) 100%)}.budget-warning-pace{border-left-color:var(--forest);background:linear-gradient(90deg,rgba(35,78,63,.03) 0%,var(--white) 100%)}.warning-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--light-gray)}.warning-card-title{display:flex;align-items:center;gap:var(--space-3)}.warning-icon{font-size:24px}.warning-card-title h3{font-family:var(--font-serif);font-size:var(--text-sm);font-weight:600;color:var(--ink);margin:0;text-transform:uppercase;letter-spacing:.05em}.warning-card-dismiss{background:none;border:none;font-size:24px;color:var(--medium-gray);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.warning-card-dismiss:hover{background:var(--light-gray);color:var(--ink)}.warning-card-dismiss:focus-visible{outline:2px solid var(--forest);outline-offset:2px}.warning-card-body{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4)}.warning-card-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3);background:var(--cream);border-radius:var(--radius-md);gap:var(--space-4)}.warning-item-details{flex:1}.warning-item-title{font-family:var(--font-serif);font-size:var(--text-base);font-weight:600;color:var(--forest);margin:0 0 var(--space-1) 0}.warning-item-description{font-size:var(--text-sm);font-weight:600;color:var(--ink);margin:0 0 var(--space-1) 0}.warning-item-subtext{color:var(--medium-gray);margin:0}.warning-item-actions{display:flex;gap:var(--space-2);align-items:center;flex-shrink:0}.warning-card-summary{padding:var(--space-3);background:var(--light-gray);border-radius:var(--radius-md);text-align:center;font-size:var(--text-sm);color:var(--ink)}.warning-card-summary strong{color:var(--error);font-weight:700}.trend-indicator{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;font-family:var(--font-mono);font-variant-numeric:tabular-nums;transition:all var(--transition-fast);cursor:help}.trend-increased{background:#dc26261a;color:var(--error);border:1px solid rgba(220,38,38,.2)}.trend-decreased{background:#0596691a;color:var(--success);border:1px solid rgba(5,150,105,.2)}.trend-stable{background:#6b72801a;color:var(--medium-gray);border:1px solid rgba(107,114,128,.2)}.trend-na{background:var(--light-gray);color:var(--medium-gray);border:1px solid var(--light-gray);cursor:default}.trend-icon{font-size:12px;line-height:1}.trend-text{line-height:1}.trend-indicator:not(.trend-na):hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.trend-increased:hover{background:#dc262626}.trend-decreased:hover{background:#05966926}.trend-stable:hover{background:#6b728026}.trend-indicator:focus-visible{outline:2px solid var(--forest);outline-offset:2px}@media (max-width: 767px){.budget-progress-bar-enhanced{min-width:200px}.progress-labels{flex-direction:column;align-items:flex-start;gap:var(--space-1)}.progress-label-remaining{margin-left:0}.progress-tooltip{left:0;right:0;transform:none;min-width:auto}.budget-health-dashboard{grid-template-columns:1fr;grid-template-rows:auto;gap:var(--space-3);padding:var(--space-4)}.health-card-primary{grid-row:auto;padding:var(--space-6)}.health-status-icon{width:72px;height:72px;font-size:36px}.health-metrics{flex-direction:column;gap:var(--space-4)}.metric-card{padding:var(--space-3)}.pace-dots{gap:2px}.pace-dot{width:6px;height:6px}.warning-card-item{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.warning-item-actions{width:100%;flex-direction:column}.warning-item-actions button{width:100%}}@media (min-width: 768px) and (max-width: 1024px){.budget-health-dashboard{grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto}.health-card-primary{grid-column:1 / -1;grid-row:1}.pace-indicator-card{grid-column:1 / -1}}@media (prefers-reduced-motion: reduce){.progress-bar-fill,.progress-bar-overflow,.health-status-icon,.warning-card,.trend-indicator{animation:none!important;transition:none!important}.pace-dot{transition:none}}.budget-value-with-trend{display:flex;align-items:center;gap:var(--space-2)}.text-error{color:var(--error)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.budget-health-summary{margin-bottom:var(--space-6)}.summary-bar{background:#fff;border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000000f;overflow:hidden}.summary-primary{display:flex;align-items:center;padding:var(--space-6);gap:var(--space-4);flex-wrap:wrap}.summary-segment{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-4);border-right:1px solid #E5E7EB}.summary-segment:first-child{padding-left:0}.summary-segment:last-child{border-right:none;padding-right:0;margin-left:auto}.summary-status{border-right:none}.status-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-xl);font-size:14px;font-weight:600;white-space:nowrap;font-family:var(--font-body)}.status-badge.status-healthy{background:#6ca86c26;color:var(--success)}.status-badge.status-warning{background:#d8b56a26;color:var(--warning)}.status-badge.status-critical{background:#dc262626;color:var(--error)}.status-badge svg{width:16px;height:16px;stroke-width:2.5}.summary-metric{display:flex;flex-direction:column;gap:var(--space-1)}.metric-label-sm{font-size:12px;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.03em;font-family:var(--font-body)}.metric-value-sm{font-size:20px;font-weight:700;color:var(--ink);font-family:system-ui,-apple-system,sans-serif}.summary-expand{border-right:none;padding-right:0}.expand-icon{width:32px;height:32px;border-radius:8px;background:#234e3f0d;display:flex;align-items:center;justify-content:center;color:var(--forest);cursor:pointer;transition:all .15s ease;border:none;outline:none}.expand-icon:hover{background:#234e3f1a}.expand-icon:focus-visible{outline:2px solid var(--forest);outline-offset:2px}.expand-icon svg{width:18px;height:18px;stroke-width:2.5;transition:transform .25s ease}.expand-icon.expanded svg{transform:rotate(180deg)}.summary-pace{padding:var(--space-6);background:#f9fafb;border-top:1px solid #E5E7EB;display:flex;align-items:center;gap:var(--space-6);flex-wrap:wrap}.pace-label-inline{font-size:13px;font-weight:600;color:#6b7280;white-space:nowrap;font-family:var(--font-body)}.pace-inline{flex:1;min-width:200px;display:flex;align-items:center;gap:var(--space-3)}.pace-bar-mini{flex:1;height:8px;background:#6b72801a;border-radius:6px;overflow:hidden}.pace-fill-mini{height:100%;border-radius:6px;transition:width .3s ease}.pace-fill-mini.pace-fill-on-track{background:linear-gradient(90deg,var(--leaf),var(--success))}.pace-fill-mini.pace-fill-spending-fast{background:linear-gradient(90deg,#d8b56a,#b8956a)}.pace-fill-mini.pace-fill-under-budget{background:linear-gradient(90deg,var(--forest),var(--leaf))}.pace-fill-mini.pace-fill-time{background:linear-gradient(90deg,#6b728099,#6b7280cc)}.pace-value-inline{font-size:14px;font-weight:700;color:var(--ink);font-family:system-ui,-apple-system,sans-serif;min-width:40px;text-align:right}.detail-panel{max-height:0;overflow:hidden;transition:max-height .3s ease-out}.detail-panel.expanded{max-height:400px}.detail-grid{padding:var(--space-6);background:#fff;border-top:1px solid #E5E7EB}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;border-bottom:1px solid #F3F4F6}.detail-row:last-child{border-bottom:none}.detail-label{font-size:14px;color:#6b7280;font-weight:600;font-family:var(--font-body)}.detail-value{font-size:16px;font-weight:700;color:var(--ink);font-family:system-ui,-apple-system,sans-serif}.detail-value.detail-value-healthy{color:var(--success);display:flex;align-items:center;gap:var(--space-2)}.detail-value.detail-value-warning{color:var(--warning);display:flex;align-items:center;gap:var(--space-2)}.detail-value.detail-value-critical{color:var(--error);display:flex;align-items:center;gap:var(--space-2)}.detail-value svg{width:16px;height:16px;stroke-width:2.5}@media (max-width: 768px){.summary-primary{flex-direction:column;align-items:stretch;padding:var(--space-4)}.summary-segment{padding:var(--space-3) 0;border-right:none;border-bottom:1px solid #E5E7EB}.summary-segment:last-child{border-bottom:none;margin-left:0}.summary-pace{flex-direction:column;align-items:stretch;padding:var(--space-4)}.pace-inline{min-width:100%}}.net-worth-link{color:var(--leaf);text-decoration:none;font-weight:600;transition:color .2s ease;font-size:var(--text-xs)}.net-worth-link:hover{color:var(--forest);text-decoration:underline}.category-type-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000000f;margin-bottom:var(--space-4);overflow:visible}.category-type-header{display:grid;grid-template-columns:32px 32px 1fr auto auto;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:linear-gradient(135deg,#234e3f08,#6ca86c05);border-bottom:2px solid rgba(35,78,63,.1);cursor:grab;-webkit-user-select:none;user-select:none;transition:opacity .2s ease,transform .2s ease}.category-type-header:active{cursor:grabbing}.category-type-header.dragging{opacity:.4}.category-type-header.drag-over{border-top:3px solid var(--forest);transform:translateY(2px)}.category-type-header.category-drag-over{background:#6ca86c14;border-bottom:3px solid var(--leaf)}.drag-handle,.category-drag-handle{color:var(--medium-gray);font-size:14px;cursor:grab;-webkit-user-select:none;user-select:none;line-height:1;opacity:.3;transition:opacity .15s ease;text-align:center}.category-type-header .drag-handle{opacity:.3;cursor:grab}.category-row:hover .category-drag-handle{opacity:1}.category-type-header:hover .drag-handle{opacity:1;cursor:grab}.drag-handle:active,.category-drag-handle:active{cursor:grabbing}.category-type-card.dragging{opacity:.5;cursor:grabbing}.category-row.dragging{opacity:.5;cursor:grabbing;background:#6ca86c1a}.category-row.drag-over{border-top:2px solid var(--leaf);background:#6ca86c0d}.category-type-card.drag-over{border:2px solid var(--leaf);box-shadow:0 8px 24px #6ca86c33}.category-drop-zone{padding:var(--space-3) var(--space-5);text-align:center;color:transparent;font-size:var(--font-size-sm);transition:all .2s ease;-webkit-user-select:none;user-select:none;min-height:40px;display:flex;align-items:center;justify-content:center}.category-drop-zone.drag-over{border-top:3px solid var(--leaf);background:#6ca86c14;color:var(--forest);font-weight:600}.group-drop-zone{padding:var(--space-4) var(--space-5);margin-top:var(--space-4);text-align:center;color:transparent;font-size:var(--font-size-sm);transition:all .2s ease;-webkit-user-select:none;user-select:none;min-height:60px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.group-drop-zone.drag-over{border:3px solid var(--forest);background:#234e3f14;color:var(--forest);font-weight:600}.expand-toggle{background:none;border:none;cursor:pointer;padding:var(--space-1);display:flex;align-items:center;justify-content:center;color:var(--forest);transition:all .15s ease}.toggle-icon{display:inline-block;font-size:12px;transition:transform .25s ease}.toggle-icon.expanded{transform:rotate(90deg)}.expand-toggle:hover{background:#234e3f14;border-radius:var(--radius-sm)}.category-type-name{font-family:var(--font-serif);font-size:18px;font-weight:600;color:var(--forest);margin:0;cursor:pointer;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);transition:all .15s ease}.category-type-name:hover{background:#6ca86c1a}.type-summary-stats{display:flex;align-items:center;gap:var(--space-5)}.summary-stat{display:flex;flex-direction:column;align-items:flex-end}.stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--medium-gray);font-weight:600;font-family:var(--font-sans)}.stat-value{font-size:14px;font-weight:700;color:var(--ink);font-family:system-ui,sans-serif;font-variant-numeric:tabular-nums}.stat-value.positive{color:var(--success)}.stat-value.negative{color:var(--error)}.type-actions{display:flex;align-items:center;gap:var(--space-2)}.action-btn{background:none;border:1px solid transparent;cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);color:var(--medium-gray);font-size:16px;transition:all .15s ease;display:flex;align-items:center;justify-content:center;min-width:28px;height:28px}.action-btn:hover{background:#234e3f14;color:var(--forest);border-color:var(--forest)}.action-btn.danger:hover{background:#dc262614;color:var(--error);border-color:var(--error)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.categories-table{display:block;width:100%}.categories-table-header,.category-row,.add-category-row{display:grid;grid-template-columns:32px 1fr 115px 115px 70px 80px 115px 120px 40px;align-items:center;gap:var(--space-2)}.categories-table-header{background:#6b728008;padding:var(--space-3) 20px}.table-header-cell{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--medium-gray);font-weight:700;font-family:var(--font-sans);white-space:nowrap;border:none;text-decoration:none;border-bottom:none!important;padding:var(--space-1) var(--space-2)}.table-header-cell.align-right{text-align:right;padding-right:var(--space-2)}.table-header-cell.mom-header{text-transform:none}.category-row{padding:var(--space-3) 20px;border-bottom:1px solid rgba(229,231,235,.5);transition:all .15s ease;cursor:grab}.category-row:active{cursor:grabbing}.category-row:hover{background:#6ca86c08}.category-row:last-of-type{border-bottom:none}.category-name-cell{font-size:14px;color:var(--ink);font-weight:600;font-family:var(--font-sans);cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:all .15s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-name-cell:hover{background:#6ca86c0f}.category-amount,button.budget-row-editable,button.budget-item-editable,.budget-row-editable,.budget-item-editable,.budget-row-editable .budget-value,.budget-item-editable .budget-value,.budget-row-editable span,.budget-item-editable span,.progress-percent{font-family:system-ui,-apple-system,Segoe UI,sans-serif!important;font-size:14px!important;font-weight:600!important;color:var(--ink)!important;font-variant-numeric:tabular-nums!important;letter-spacing:-.01em!important;line-height:1.2!important}.category-amount{text-align:right!important;display:block;width:100%}.category-amount.align-right{text-align:right!important}.category-amount-cell{display:flex;justify-content:flex-end;align-items:center;width:100%;padding-right:var(--space-2)}.category-amount.editable{cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:all .15s ease}.category-amount.editable:hover{background:#6ca86c1a;color:var(--forest)}.category-amount.negative{color:var(--error)}.progress-cell{display:flex;align-items:center;gap:var(--space-2);padding:0;justify-content:flex-start}.progress-bar-mini{flex:1;min-width:100px;height:8px;background:#6b728026;border-radius:6px;overflow:hidden}.progress-fill-mini{height:100%;background:linear-gradient(90deg,var(--leaf),#5a9c5a);border-radius:6px;transition:width .3s ease}.progress-fill-mini.warning{background:linear-gradient(90deg,var(--soft-gold),#c99a4d)}.progress-fill-mini.danger{background:linear-gradient(90deg,var(--error),#b91c1c)}.progress-percent{min-width:35px;text-align:right}.category-actions-cell{text-align:right;position:relative}.category-actions-btn{background:none;border:none;cursor:pointer;color:var(--medium-gray);font-size:18px;padding:var(--space-1);border-radius:var(--radius-sm);transition:all .15s ease}.category-actions-btn:hover{background:#234e3f14;color:var(--forest)}.context-menu{position:absolute;right:0;top:100%;margin-top:var(--space-1);background:var(--white);border:1px solid var(--light-gray);border-radius:var(--radius-md);box-shadow:0 8px 24px #0000001f;min-width:180px;z-index:100;overflow:hidden}.context-menu.flip-up{top:auto;bottom:100%;margin-top:0;margin-bottom:var(--space-1)}.context-menu-item{display:block;width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;text-align:left;font-size:14px;font-weight:500;color:var(--ink);cursor:pointer;transition:all .15s ease;font-family:var(--font-sans);border-bottom:1px solid rgba(229,231,235,.6)}.context-menu-item:last-child{border-bottom:none}.context-menu-item:hover{background:#6ca86c14;color:var(--forest)}.context-menu-item.danger{color:var(--error)}.context-menu-item.danger:hover{background:#dc262614}.add-category-row{background:transparent;border-top:1px solid rgba(229,231,235,.5);padding:var(--space-4) 20px;grid-column:1 / -1;display:flex;align-items:center;justify-content:flex-start}.add-category-btn{background:var(--white);border:2px dashed rgba(108,168,108,.35);cursor:pointer;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);color:var(--forest);font-size:14px;font-weight:600;font-family:var(--font-sans);transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:40px;min-width:140px}.add-category-btn:hover{background:#6ca86c0f;border-color:var(--leaf);border-style:solid;color:var(--forest);transform:translateY(-1px);box-shadow:0 2px 8px #234e3f1a}.add-category-btn:active{transform:translateY(0);box-shadow:0 1px 2px #234e3f14}.add-category-btn:focus-visible{outline:2px solid var(--forest);outline-offset:2px}.sparkline{display:inline-block;width:60px;height:20px;cursor:crosshair;position:relative}.sparkline svg{width:100%;height:100%}.sparkline-path{fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.sparkline-path.trend-up{stroke:var(--error)}.sparkline-path.trend-down{stroke:var(--success)}.sparkline-path.trend-stable{stroke:var(--medium-gray)}.sparkline-path.trend-na{stroke:var(--medium-gray);opacity:.3}.sparkline-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);background:var(--ink);color:var(--cream);padding:6px 10px;border-radius:4px;font-size:12px;font-family:var(--font-ui);white-space:nowrap;pointer-events:none;z-index:1000;box-shadow:0 2px 8px #0003}.sparkline-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--ink)}.category-trend-cell{display:flex;align-items:center;justify-content:flex-end}.trend-indicator{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:3px 8px;border-radius:4px;font-variant-numeric:tabular-nums;gap:2px}.trend-indicator.trend-increased{color:var(--error);background:#dc26261a}.trend-indicator.trend-decreased{color:var(--success);background:#6ca86c1f}.trend-indicator.trend-stable{color:var(--medium-gray);background:#6b728014}.trend-indicator.trend-na{color:var(--medium-gray);background:#6b72800d}@media (max-width: 768px){.category-type-header{grid-template-columns:32px 32px 1fr;gap:var(--space-2)}.type-summary-stats{grid-column:1 / -1;justify-content:space-around;margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid rgba(229,231,235,.6)}.type-actions{grid-column:1 / -1;justify-content:flex-end}.categories-table-header{display:none}.category-row{grid-template-columns:1fr;gap:var(--space-2);padding:var(--space-4) var(--space-3)}.category-drag-handle{display:none}.progress-cell{padding-left:0}.cross-group-drop-zone{grid-column:1 / -1;margin:var(--space-3) 0}}.categories-table.cross-group-drag-target{background:#6ca86c0f;border:2px dashed var(--leaf);border-radius:var(--radius-md);position:relative}.categories-table.cross-group-drag-target:after{content:"Drop here to move category to this group";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#6ca86cf2;color:#fff;padding:var(--space-4) var(--space-6);border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-size-base);pointer-events:none;z-index:100;box-shadow:0 4px 12px #0003}.cross-group-drop-zone{padding:var(--space-4) var(--space-5);text-align:center;font-size:var(--font-size-sm);transition:all .2s ease;-webkit-user-select:none;user-select:none;min-height:60px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);margin:var(--space-3) var(--space-5)}.cross-group-drop-zone.drag-over{border:3px dashed var(--leaf);background:#6ca86c1f;color:var(--forest);font-weight:600}.month-navigator{display:flex;flex-direction:column;gap:var(--space-2)}.month-navigation{display:flex;align-items:center;gap:var(--space-4)}.month-nav-button{width:44px;height:44px;min-width:44px;border-radius:var(--radius-md);background:var(--forest);color:var(--cream);border:2px solid transparent;font-size:18px;font-weight:600;line-height:1;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.month-nav-button:hover:not(:disabled){background:var(--leaf);transform:translateY(-2px);box-shadow:0 4px 12px #234e3f33}.month-nav-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #234e3f33}.month-nav-button:focus-visible{outline:3px solid var(--forest);outline-offset:3px}.month-nav-button:disabled{opacity:.4;cursor:not-allowed;background:#e5e7eb;color:#6b7280}.month-display-container{position:relative;display:flex;align-items:center;gap:var(--space-2)}.month-display{font-family:var(--font-heading);font-size:28px;font-weight:700;color:var(--forest);padding:0 var(--space-3);min-width:240px;text-align:center;margin:0;line-height:1.2;display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.month-indicator{display:inline-flex;align-items:center;font-size:16px;margin-left:var(--space-2)}.month-indicator-current{color:var(--leaf);font-size:24px;line-height:0}.month-indicator-past{opacity:.6;font-size:14px}.month-indicator-future{color:var(--forest);font-size:14px;opacity:.7}.month-loading-indicator{position:absolute;right:-32px;display:flex;align-items:center;gap:var(--space-2)}.month-loading-indicator .spinner{width:16px;height:16px;border:2px solid rgba(35,78,63,.2);border-top-color:var(--forest);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.today-button{padding:8px 16px;min-height:44px;border-radius:var(--radius-md);background:var(--cream);color:var(--forest);border:2px solid var(--forest);font-family:var(--font-body);font-size:14px;font-weight:700;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.today-button:hover:not(:disabled){background:var(--forest);color:var(--cream);transform:translateY(-1px);box-shadow:0 2px 8px #234e3f26}.today-button:active:not(:disabled){transform:translateY(0)}.today-button:focus-visible{outline:3px solid var(--forest);outline-offset:3px}.today-button:disabled{opacity:.5;cursor:default;border-color:#9ca3af;color:#9ca3af;background:var(--cream)}.keyboard-hint{font-family:var(--font-body);font-size:12px;color:#6b7280;text-align:center;padding:var(--space-1) var(--space-2);opacity:0;animation:fadeIn .3s ease forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.month-navigator{gap:var(--space-3)}.month-navigation{flex-wrap:wrap;justify-content:center;gap:var(--space-3)}.month-display{font-size:24px;min-width:200px}.keyboard-hint{display:none}}@media (max-width: 480px){.month-navigation{width:100%;flex-direction:column;gap:var(--space-2)}.month-display-container{width:100%;order:1}.month-display{font-size:22px;min-width:auto;width:100%}.month-nav-button{width:48px;height:48px;min-width:48px}.month-nav-prev,.month-nav-next,.today-button{order:2}.month-nav-prev,.month-nav-next{flex:1}.today-button{flex:1;padding:8px 12px;font-size:13px}.keyboard-hint{display:none}.month-loading-indicator{position:static;margin-left:var(--space-2)}}@media (prefers-contrast: high){.month-nav-button{border:2px solid currentColor}.today-button{border-width:3px}.month-indicator-current{border:2px solid currentColor;border-radius:50%}}.recurring-transaction-list{display:flex;flex-direction:column;gap:var(--space-6);width:100%}.filter-bar{display:flex;gap:var(--space-4);align-items:flex-end;background:var(--white);padding:var(--space-6);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:var(--space-2);min-width:160px;flex:1}.filter-label{font-size:var(--text-xs);font-weight:600;color:var(--dark-gray);text-transform:uppercase;letter-spacing:.5px}.filter-actions{display:flex;align-items:flex-end;margin-left:auto}.recurring-list{display:flex;flex-direction:column;gap:var(--space-4);width:100%}.recurring-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-6);padding:var(--space-6);background:var(--white);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);border:1px solid var(--light-gray);margin-bottom:var(--space-4)}.recurring-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--forest)}.recurring-card:last-child{margin-bottom:0}.card-main{display:flex;align-items:center;gap:var(--space-4);flex:1;min-width:0}.card-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;min-width:48px;background:var(--cream);border-radius:var(--radius-full);font-size:var(--text-xl);flex-shrink:0}.card-details{display:flex;flex-direction:column;gap:var(--space-2);flex:1;min-width:0}.card-description{font-size:var(--text-base);font-weight:600;color:var(--ink);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-metadata{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center}.card-metadata-item{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--medium-gray)}.metadata-icon{color:var(--forest);opacity:.7;flex-shrink:0}.card-amount{font-family:Merriweather,serif;font-size:var(--text-xl);font-weight:700;color:var(--ink);white-space:nowrap;flex-shrink:0;min-width:120px;text-align:right}.card-amount.income{color:var(--success)}.card-amount.expense{color:var(--danger)}.card-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.icon-btn{display:inline-flex;align-items:center;justify-content:center;min-width:32px;min-height:32px;padding:var(--space-2);background:transparent;border:none;border-radius:var(--button-radius);color:var(--medium-gray);cursor:pointer;transition:all var(--transition-fast)}.icon-btn:hover:not(:disabled){background:var(--light-gray);transform:scale(1.1);color:var(--forest)}.icon-btn:focus-visible{outline:2px solid var(--forest);outline-offset:2px}.icon-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.icon-btn-danger:hover:not(:disabled){background:#dc26261a;color:var(--danger)}.recurring-list-skeleton{display:flex;flex-direction:column;gap:var(--space-4)}.recurring-card-skeleton{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-6);background:var(--white);border-radius:var(--card-radius);box-shadow:var(--shadow-sm)}.skeleton-icon{width:48px;height:48px;min-width:48px;background:linear-gradient(90deg,var(--cream) 25%,var(--light-gray) 50%,var(--cream) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-full)}.skeleton-content{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.skeleton-line{height:16px;background:linear-gradient(90deg,var(--cream) 25%,var(--light-gray) 50%,var(--cream) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-line-title{width:60%;height:20px}.skeleton-line-text{width:40%}.skeleton-amount{width:100px;height:24px;background:linear-gradient(90deg,var(--cream) 25%,var(--light-gray) 50%,var(--cream) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.load-more-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-6) 0}.transaction-count{font-size:var(--text-sm);color:var(--medium-gray);margin:0}@media (max-width: 768px){.recurring-card{flex-direction:column;align-items:stretch;gap:var(--space-4)}.card-main{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.card-icon{width:40px;height:40px;min-width:40px;font-size:var(--text-lg)}.card-amount{text-align:left;min-width:auto;font-size:var(--text-lg)}.card-actions{width:100%;justify-content:space-between}.icon-btn{min-width:44px;min-height:44px}.filter-bar{flex-direction:column;align-items:stretch}.filter-group{min-width:100%}.filter-actions{margin-left:0;width:100%}.filter-actions .btn{width:100%}}@media (max-width: 480px){.recurring-card,.filter-bar{padding:var(--space-4)}.card-metadata{flex-direction:column;align-items:flex-start;gap:var(--space-2)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.recurring-card:focus-visible{outline:2px solid var(--forest);outline-offset:2px}@media (prefers-reduced-motion: reduce){.recurring-card,.icon-btn,.skeleton-icon,.skeleton-line,.skeleton-amount{animation:none;transition:none}.recurring-card:hover{transform:none}.icon-btn:hover:not(:disabled){transform:none}}.page-content{padding:var(--space-6);max-width:var(--container-width);margin:0 auto}.account-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6);margin-bottom:var(--space-8)}.account-summary-card{background:var(--white);border:1px solid var(--light-gray);border-radius:var(--card-radius);padding:var(--space-6);transition:all .2s ease}.account-summary-card:hover{box-shadow:var(--shadow-md)}.account-summary-card-label{font-size:var(--text-sm);color:var(--dark-gray);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2)}.account-summary-card-value{font-size:32px;font-weight:700;font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-variant-numeric:tabular-nums;margin-bottom:var(--space-1)}.account-summary-card-value.positive{color:var(--leaf)}.account-summary-card-value.negative{color:var(--error)}.account-summary-card-change{font-size:var(--text-sm);color:var(--dark-gray)}.account-summary-card-change .change-indicator{display:inline-flex;align-items:center;gap:4px;font-weight:600}.account-summary-card-change .change-indicator.positive{color:var(--success)}.account-summary-card-change .change-indicator.negative{color:var(--error)}.accounts-list{display:flex;flex-direction:column;gap:var(--space-8)}.account-group{background:var(--white);border:1px solid var(--light-gray);border-radius:var(--card-radius);overflow:hidden}.account-group-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:var(--cream);border-bottom:1px solid var(--light-gray);cursor:pointer;-webkit-user-select:none;user-select:none}.account-group-header:hover{background:var(--light-gray)}.account-group-title{font-size:var(--text-lg);font-weight:700;font-family:var(--font-serif);color:var(--forest);display:flex;align-items:center;gap:var(--space-2)}.account-group-count{font-size:var(--text-sm);font-weight:400;color:var(--dark-gray)}.account-group-expand{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:transparent;transition:transform .2s ease,background .2s ease}.account-group-expand svg{width:16px;height:16px;stroke:var(--forest)}.account-group-header:hover .account-group-expand{background:var(--white)}.account-group.collapsed .account-group-expand{transform:rotate(-90deg)}.account-group-items{display:flex;flex-direction:column}.account-group.collapsed .account-group-items{display:none}.account-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--light-gray);transition:background .2s ease;cursor:pointer}.account-item:last-child{border-bottom:none}.account-item:hover{background:var(--light-gray)}.account-item-info{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.account-item-name{font-size:var(--text-base);font-weight:600;color:var(--ink)}.account-item-meta{display:flex;align-items:center;gap:var(--space-4);font-size:var(--text-sm);color:var(--dark-gray)}.account-item-balance{font-size:var(--text-lg);font-weight:700;font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-variant-numeric:tabular-nums;margin-right:var(--space-4)}.account-item-balance.positive{color:var(--forest)}.account-item-balance.negative{color:var(--error)}.account-item-actions{display:flex;align-items:center;gap:var(--space-2)}.account-item-actions button{padding:var(--space-1) var(--space-2);border:1px solid var(--medium-gray);border-radius:var(--button-radius);background:var(--white);font-size:var(--text-sm);cursor:pointer;transition:all .2s ease}.account-item-actions button:hover{background:var(--cream);border-color:var(--forest)}.account-form-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:var(--space-4)}.account-form-dialog{background:var(--white);border-radius:var(--card-radius);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.account-form-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--light-gray)}.account-form-title{font-size:var(--text-xl);font-weight:700;font-family:var(--font-serif);color:var(--forest)}.account-form-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:none;background:transparent;cursor:pointer;transition:background .2s ease}.account-form-close:hover{background:var(--light-gray)}.account-form-content{padding:var(--space-6)}.account-form-group{margin-bottom:var(--space-6)}.account-form-group label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--ink);margin-bottom:var(--space-1)}.account-form-group input,.account-form-group select,.account-form-group textarea{width:100%;padding:var(--space-2) var(--space-4);border:1px solid var(--medium-gray);border-radius:var(--input-radius);font-size:var(--text-base);font-family:var(--font-sans);transition:border-color .2s ease}.account-form-group input:focus,.account-form-group select:focus,.account-form-group textarea:focus{outline:none;border-color:var(--forest)}.account-form-group textarea{resize:vertical;min-height:80px}.account-form-group .error{font-size:var(--text-sm);color:var(--error);margin-top:var(--space-1)}.account-form-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-4);padding:var(--space-6);border-top:1px solid var(--light-gray)}.dashboard-widgets{margin-bottom:var(--space-8)}.net-worth-widget{background:linear-gradient(135deg,var(--forest) 0%,#2d6b50 100%);border-radius:var(--card-radius);padding:var(--space-8);color:var(--white);box-shadow:var(--shadow-md)}.net-worth-widget-header{margin-bottom:var(--space-6)}.net-worth-widget-title{font-size:var(--text-base);font-weight:600;opacity:.9;margin:0}.net-worth-widget-body{display:flex;flex-direction:column;gap:var(--space-4)}.net-worth-widget-value{margin-bottom:var(--space-2)}.net-worth-amount{font-size:48px;font-weight:700;font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-variant-numeric:tabular-nums;line-height:1.1}.net-worth-amount.positive{color:var(--white)}.net-worth-amount.negative{color:#ffffffe6}.net-worth-widget-change{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-3);background:#ffffff26;border-radius:var(--button-radius);width:fit-content}.net-worth-widget-change.positive{background:#6ca86c4d}.net-worth-widget-change.negative{background:#dc26264d}.net-worth-widget-change .change-icon{font-size:12px}.net-worth-widget-change .change-period{opacity:.85}.net-worth-widget-breakdown{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);opacity:.9;padding-top:var(--space-4);border-top:1px solid rgba(255,255,255,.2)}.breakdown-item{display:flex;align-items:center;gap:var(--space-1)}.breakdown-label{opacity:.8}.breakdown-value{font-weight:700;font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-variant-numeric:tabular-nums}.breakdown-separator{opacity:.5;margin:0 var(--space-1)}.net-worth-widget-warning{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:#ffc10733;border-radius:var(--button-radius);font-size:var(--text-sm);margin-top:var(--space-2)}.warning-icon{font-size:16px}.net-worth-widget-footer{padding-top:var(--space-4);border-top:1px solid rgba(255,255,255,.2);margin-top:var(--space-4)}.net-worth-widget-link{color:var(--white);font-size:var(--text-sm);font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:var(--space-1);transition:opacity .2s ease}.net-worth-widget-link:hover{opacity:.8;text-decoration:underline}.net-worth-widget-skeleton{display:flex;flex-direction:column;gap:var(--space-3)}.skeleton-line{height:20px;background:#fff3;border-radius:var(--button-radius);animation:pulse 1.5s ease-in-out infinite}.skeleton-line-large{height:48px}.skeleton-line-medium{height:24px;width:60%}.skeleton-line-small{height:16px;width:40%}.net-worth-widget-error{text-align:center;padding:var(--space-4)}.net-worth-widget-error p{margin-bottom:var(--space-3);opacity:.9}@media (max-width: 768px){.account-summary-cards{grid-template-columns:1fr}.account-item{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.account-item-actions{width:100%;justify-content:flex-end}.net-worth-widget{padding:var(--space-6)}.net-worth-amount{font-size:36px}.net-worth-widget-breakdown{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.breakdown-separator{display:none}}.accounts-empty-state{text-align:center;padding:var(--space-12);background:var(--white);border:1px solid var(--light-gray);border-radius:var(--card-radius)}.accounts-empty-state h3{font-size:var(--text-xl);font-weight:700;font-family:var(--font-serif);color:var(--forest);margin-bottom:var(--space-4)}.accounts-empty-state p{font-size:var(--text-base);color:var(--dark-gray);margin-bottom:var(--space-6);max-width:400px;margin-left:auto;margin-right:auto}.button{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-2) var(--space-6);font-size:var(--text-base);font-weight:600;font-family:var(--font-sans);line-height:1.5;border-radius:var(--button-radius);border:1px solid transparent;cursor:pointer;transition:all .2s ease;text-decoration:none;white-space:nowrap;-webkit-user-select:none;user-select:none}.button:disabled{cursor:not-allowed;opacity:.6}.button-primary{background:var(--forest);color:var(--white);border-color:var(--forest)}.button-primary:hover:not(:disabled){background:#234e3fe6;transform:translateY(-1px);box-shadow:var(--shadow-md)}.button-primary:focus-visible{outline:2px solid var(--forest);outline-offset:2px}.button-primary:active:not(:disabled){transform:translateY(0)}.button-secondary{background:var(--white);color:var(--ink);border-color:var(--light-gray)}.button-secondary:hover:not(:disabled){background:var(--cream);border-color:var(--medium-gray)}.button-secondary:focus-visible{outline:2px solid var(--forest);outline-offset:2px}.button-ghost{background:transparent;color:var(--medium-gray);border-color:transparent;padding:var(--space-2) var(--space-3)}.button-ghost:hover:not(:disabled){background:var(--light-gray);color:var(--ink)}.button-ghost:focus-visible{outline:2px solid var(--forest);outline-offset:2px}.button-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-sm)}.account-form-row{display:flex;gap:var(--space-4);margin-bottom:var(--space-6);width:100%}.account-form-row .account-form-group{flex:1;margin-bottom:0;min-width:0}.account-form-row .account-form-group label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--ink);margin-bottom:var(--space-1)}.account-form-row .account-form-group input,.account-form-row .account-form-group select{width:100%;padding:var(--space-2) var(--space-4);border:1px solid var(--medium-gray);border-radius:var(--input-radius);font-size:var(--text-base);font-family:var(--font-sans);transition:border-color .2s ease;box-sizing:border-box}.account-form-group-narrow{flex:0 0 140px!important}.account-form-group-full{margin-bottom:var(--space-6);width:100%}@media (max-width: 640px){.account-form-row{flex-direction:column;gap:0}.account-form-row .account-form-group{margin-bottom:var(--space-6)}.account-form-group-narrow{flex:1!important}}.account-form-group select,.account-form-row .account-form-group select{appearance:none;background-color:var(--white);background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-4) center;padding-right:var(--space-8);cursor:pointer;color:var(--ink);font-weight:500}.account-form-group select:hover,.account-form-row .account-form-group select:hover{border-color:var(--forest);background-color:var(--cream)}.account-form-group select:focus,.account-form-row .account-form-group select:focus{border-color:var(--forest);box-shadow:0 0 0 3px #234e3f1a}.account-form-group select optgroup{font-weight:600;color:var(--forest);font-style:normal}.account-form-group select option{padding:var(--space-2);color:var(--ink);font-weight:400}.account-form-group select:disabled,.account-form-row .account-form-group select:disabled{background-color:var(--light-gray);color:var(--medium-gray);cursor:not-allowed;opacity:.6}.account-detail-breadcrumb{display:flex;align-items:center;gap:var(--space-2)}.breadcrumb-link{color:var(--dark-gray);text-decoration:none;font-size:var(--text-sm);transition:color .2s ease}.breadcrumb-link:hover{color:var(--forest);text-decoration:underline}.account-detail-actions{display:flex;align-items:center;gap:var(--space-3)}.account-detail-header{background:var(--white);border:1px solid var(--light-gray);border-radius:var(--card-radius);padding:var(--space-8);margin-bottom:var(--space-8)}.account-detail-info{display:flex;flex-direction:column;gap:var(--space-4)}.account-detail-type-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);background:var(--cream);border:1px solid var(--leaf);border-radius:var(--button-radius);font-size:var(--text-sm);font-weight:600;color:var(--forest);width:fit-content}.account-detail-balance{display:flex;flex-direction:column;gap:var(--space-1)}.account-detail-balance-label{font-size:var(--text-sm);color:var(--dark-gray);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.account-detail-balance-value{font-size:40px;font-weight:700;font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-variant-numeric:tabular-nums;color:var(--forest)}.account-detail-meta{font-size:var(--text-sm);color:var(--dark-gray)}.account-detail-transactions{background:var(--white);border:1px solid var(--light-gray);border-radius:var(--card-radius);padding:var(--space-6)}.account-detail-section-title{font-size:var(--text-xl);font-weight:700;font-family:var(--font-serif);color:var(--forest);margin-bottom:var(--space-6)}.account-detail-not-found{text-align:center;padding:var(--space-12);background:var(--white);border:1px solid var(--light-gray);border-radius:var(--card-radius)}.account-detail-not-found h3{font-size:var(--text-xl);font-weight:700;font-family:var(--font-serif);color:var(--forest);margin-bottom:var(--space-4)}.account-detail-not-found p{font-size:var(--text-base);color:var(--dark-gray);margin-bottom:var(--space-6);max-width:400px;margin-left:auto;margin-right:auto}.account-item-clickable{cursor:pointer}.account-item-clickable:hover{background:var(--cream)}.account-item-clickable:focus-visible{outline:2px solid var(--forest);outline-offset:-2px}.button-danger{background:var(--error);color:var(--white);border-color:var(--error)}.button-danger:hover:not(:disabled){background:#dc2626e6;transform:translateY(-1px);box-shadow:var(--shadow-md)}.button-danger:focus-visible{outline:2px solid var(--error);outline-offset:2px}.button-danger:active:not(:disabled){transform:translateY(0)}@media (max-width: 768px){.account-detail-actions{flex-direction:column;width:100%}.account-detail-actions button{width:100%}.account-detail-header{padding:var(--space-6)}.account-detail-balance-value{font-size:32px}}:root{--ease-linear: linear;--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-back: cubic-bezier(.68, -.55, .265, 1.55);--ease-bounce: cubic-bezier(.175, .885, .32, 1.275);--ease-elastic: cubic-bezier(.175, .885, .435, 1.45);--duration-instant: .05s;--duration-fast: .15s;--duration-base: .2s;--duration-slow: .3s;--duration-slower: .5s;--duration-slowest: .8s;--delay-none: 0s;--delay-fast: .1s;--delay-base: .2s;--delay-slow: .3s;--stagger-fast: .05s;--stagger-base: .1s;--stagger-slow: .15s}.animate-fade-in{animation:fadeIn var(--duration-base) var(--ease-out) forwards}.animate-fade-out{animation:fadeOut var(--duration-base) var(--ease-in) forwards}.animate-slide-in-up{animation:slideInUp var(--duration-base) var(--ease-out) forwards}.animate-slide-in-down{animation:slideInDown var(--duration-base) var(--ease-out) forwards}.animate-slide-in-left{animation:slideInLeft var(--duration-base) var(--ease-out) forwards}.animate-slide-in-right{animation:slideInRight var(--duration-base) var(--ease-out) forwards}.animate-scale-in{animation:scaleIn var(--duration-base) var(--ease-back) forwards}.animate-scale-out{animation:scaleOut var(--duration-base) var(--ease-in) forwards}.animate-bounce-in{animation:bounceIn var(--duration-slow) var(--ease-bounce) forwards}.animate-shake{animation:shake var(--duration-base) var(--ease-in-out) forwards}.animate-pulse{animation:pulse var(--duration-slower) var(--ease-in-out) infinite}.animate-spin{animation:spin 1s var(--ease-linear) infinite}.hover-lift{transition:transform var(--duration-fast) var(--ease-out)}.hover-lift:hover{transform:translateY(-2px)}.hover-grow{transition:transform var(--duration-fast) var(--ease-out)}.hover-grow:hover{transform:scale(1.05)}.hover-glow{transition:box-shadow var(--duration-fast) var(--ease-out)}.hover-glow:hover{box-shadow:0 0 20px #6ca86c4d}.focus-ring{transition:box-shadow var(--duration-fast) var(--ease-out)}.focus-ring:focus{box-shadow:0 0 0 3px #234e3f4d}.loading-dots{animation:loadingDots var(--duration-slower) var(--ease-in-out) infinite}.loading-skeleton{background:linear-gradient(90deg,var(--light-gray) 25%,rgba(249,250,251,.5) 50%,var(--light-gray) 75%);background-size:200% 100%;animation:skeleton var(--duration-slower) var(--ease-in-out) infinite}body.dark-mode .loading-skeleton{background:linear-gradient(90deg,var(--dark-surface) 25%,rgba(33,38,45,.5) 50%,var(--dark-surface) 75%);background-size:200% 100%}.stagger-children>*{animation-delay:calc(var(--stagger-base) * var(--stagger-index, 0))}.stagger-fast>*{animation-delay:calc(var(--stagger-fast) * var(--stagger-index, 0))}.stagger-slow>*{animation-delay:calc(var(--stagger-slow) * var(--stagger-index, 0))}.page-enter{animation:pageEnter var(--duration-base) var(--ease-out) forwards}.page-exit{animation:pageExit var(--duration-base) var(--ease-in) forwards}.form-input-focus{transition:all var(--duration-fast) var(--ease-out)}.form-input-error{animation:shake var(--duration-base) var(--ease-in-out);border-color:var(--error)}.form-input-success{animation:successPulse var(--duration-base) var(--ease-out);border-color:var(--success)}.btn-loading{position:relative;color:transparent}.btn-loading:after{content:"";position:absolute;top:50%;left:50%;width:16px;height:16px;margin:-8px 0 0 -8px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin var(--duration-base) var(--ease-linear) infinite}.btn-success{animation:successScale var(--duration-base) var(--ease-back)}.modal-backdrop{animation:backdropFadeIn var(--duration-base) var(--ease-out) forwards}.modal-backdrop.closing{animation:backdropFadeOut var(--duration-base) var(--ease-in) forwards}.modal-content{animation:modalSlideIn var(--duration-slow) var(--ease-back) forwards}.modal-content.closing{animation:modalSlideOut var(--duration-base) var(--ease-in) forwards}.toast-enter{animation:toastSlideIn var(--duration-base) var(--ease-back) forwards}.toast-exit{animation:toastSlideOut var(--duration-base) var(--ease-in) forwards}.dropdown-enter{animation:dropdownSlideIn var(--duration-fast) var(--ease-out) forwards}.dropdown-exit{animation:dropdownSlideOut var(--duration-fast) var(--ease-in) forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-3px)}20%,40%,60%,80%{transform:translate(3px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes loadingDots{0%,20%{opacity:0}50%{opacity:1}to{opacity:0}}@keyframes skeleton{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pageEnter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pageExit{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}@keyframes successPulse{0%{box-shadow:0 0 #05966966}70%{box-shadow:0 0 0 6px #05966900}to{box-shadow:0 0 #05966900}}@keyframes successScale{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}@keyframes backdropFadeOut{0%{opacity:1}to{opacity:0}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes modalSlideOut{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.9) translateY(-10px)}}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes dropdownSlideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.animate-pulse,.animate-spin,.loading-dots,.loading-skeleton{animation:none!important}}.animate-fade-in,.animate-slide-in-up,.animate-slide-in-down,.animate-slide-in-left,.animate-slide-in-right,.animate-scale-in,.animate-scale-out,.animate-bounce-in,.hover-lift,.hover-grow{will-change:transform,opacity}.animation-complete{will-change:auto}.skip-links{position:absolute;top:0;left:0;z-index:var(--z-tooltip);display:flex;flex-direction:column;gap:var(--space-1)}.skip-link{position:absolute;top:-100px;left:var(--space-2);padding:var(--space-3) var(--space-4);background-color:var(--forest);color:var(--white);font-size:var(--text-sm);font-weight:600;text-decoration:none;border-radius:var(--button-radius);box-shadow:var(--shadow-lg);transition:top var(--transition-fast);z-index:var(--z-tooltip)}.skip-link:focus{top:var(--space-2);outline:2px solid var(--soft-gold);outline-offset:2px}.skip-link:hover{background-color:var(--leaf);color:var(--white)}:focus{outline:2px solid var(--forest);outline-offset:2px;border-radius:var(--space-1)}.mouse-focus:focus{outline:none}.keyboard-focus:focus{outline:2px solid var(--forest);outline-offset:2px;box-shadow:0 0 0 4px #234e3f1a}button:focus,.btn:focus,[role=button]:focus{outline:2px solid var(--forest);outline-offset:2px;box-shadow:0 0 0 4px #234e3f1a}input:focus,select:focus,textarea:focus{outline:2px solid var(--forest);outline-offset:0;border-color:var(--forest);box-shadow:0 0 0 3px #234e3f1a}a:focus{outline:2px solid var(--forest);outline-offset:2px;border-radius:var(--space-1);background-color:#234e3f0d}.card:focus-within{box-shadow:var(--shadow-md),0 0 0 2px #234e3f1a}.form-group:focus-within label{color:var(--forest);font-weight:600}.theme-toggle:focus{outline:2px solid var(--forest);outline-offset:3px;border-radius:calc(var(--button-radius) + 3px)}.dropdown-trigger:focus{outline:2px solid var(--forest);outline-offset:2px}.nav-link:focus{outline:2px solid var(--forest);outline-offset:2px;background-color:#234e3f0d;border-radius:var(--space-1)}.focused{position:relative}.focused:before{content:"";position:absolute;inset:-2px;border:2px solid var(--forest);border-radius:inherit;pointer-events:none;opacity:0;animation:focusIndicator var(--transition-fast) ease-out forwards}@keyframes focusIndicator{to{opacity:1}}@media (prefers-contrast: high){:focus{outline:3px solid currentColor;outline-offset:2px}.skip-link{border:2px solid currentColor}.keyboard-focus:focus{outline:3px solid currentColor;box-shadow:0 0 0 6px #0000004d}}body.dark-mode :focus{outline-color:var(--dark-forest)}body.dark-mode .skip-link{background-color:var(--dark-forest);color:var(--white)}body.dark-mode .skip-link:hover{background-color:var(--dark-leaf)}body.dark-mode .keyboard-focus:focus{outline-color:var(--dark-forest);box-shadow:0 0 0 4px #4a966033}body.dark-mode input:focus,body.dark-mode select:focus,body.dark-mode textarea:focus{outline-color:var(--dark-forest);border-color:var(--dark-forest);box-shadow:0 0 0 3px #4a966033}body.dark-mode a:focus{outline-color:var(--dark-forest);background-color:#4a96601a}[aria-modal=true]{position:relative}[aria-modal=true]:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:-1}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}#wrenleaf-announcer{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}.modal-overlay[aria-modal=true]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.modal[aria-modal=true]{position:relative;max-width:90vw;max-height:90vh;background-color:var(--white);border-radius:var(--card-radius);padding:var(--space-6);box-shadow:var(--shadow-lg);overflow:auto}body.dark-mode .modal[aria-modal=true]{background-color:var(--dark-surface);color:var(--dark-text)}.dropdown[aria-expanded=true] .dropdown-menu{display:block;animation:dropdownSlideIn var(--transition-fast) var(--ease-out) forwards}.dropdown-item:focus{background-color:var(--forest);color:var(--white);outline:none}body.dark-mode .dropdown-item:focus{background-color:var(--dark-forest);color:var(--white)}table:focus{outline:2px solid var(--forest);outline-offset:2px}th:focus,td:focus{outline:2px solid var(--forest);outline-offset:-2px;background-color:#234e3f0d}body.dark-mode th:focus,body.dark-mode td:focus{outline-color:var(--dark-forest);background-color:#4a96601a}.form-input.error:focus{outline-color:var(--error);border-color:var(--error);box-shadow:0 0 0 3px #dc26261a}.form-input.success:focus{outline-color:var(--success);border-color:var(--success);box-shadow:0 0 0 3px #0596691a}@media (prefers-reduced-motion: reduce){.skip-link{transition:none}.focused:before{animation:none;opacity:1}.dropdown[aria-expanded=true] .dropdown-menu{animation:none}}@media print{.skip-links,.skip-link,:focus{outline:none!important;box-shadow:none!important;background-color:transparent!important}.focused:before{display:none!important}}@media (hover: none) and (pointer: coarse){.skip-link{padding:var(--space-4) var(--space-6);font-size:var(--text-base)}:focus{outline-width:1px}}@media (prefers-contrast: high){.skip-link{forced-color-adjust:none;background-color:ButtonText;color:ButtonFace;border:1px solid ButtonText}:focus{outline:2px solid Highlight;outline-offset:2px}.focused:before{border-color:Highlight}}body.dark-mode{--cream: var(--dark-bg);--white: var(--dark-surface);--light-gray: var(--dark-border);--medium-gray: var(--dark-text-secondary);--dark-gray: var(--dark-text);--ink: var(--dark-text);--forest: var(--dark-forest);--leaf: var(--dark-leaf);background-color:var(--dark-bg);color:var(--dark-text)}body.dark-mode .card{background-color:var(--dark-surface);border:1px solid var(--dark-border)}body.dark-mode .card:hover{background-color:var(--dark-surface-hover)}body.dark-mode .card-header{border-bottom-color:var(--dark-border);background-color:var(--dark-surface)}body.dark-mode .card-footer{border-top-color:var(--dark-border);background-color:var(--dark-surface-hover)}body.dark-mode .form-input,body.dark-mode .form-select,body.dark-mode .form-textarea{background-color:var(--dark-surface);border-color:var(--dark-border);color:var(--dark-text)}body.dark-mode .form-input:focus{border-color:var(--dark-forest);box-shadow:0 0 0 3px #4a96601a}body.dark-mode .form-label{color:var(--dark-text)}body.dark-mode .btn-secondary{background-color:var(--dark-surface);color:var(--dark-text);border-color:var(--dark-border)}body.dark-mode .btn-secondary:hover:not(:disabled){background-color:var(--dark-surface-hover);color:var(--dark-text)}body.dark-mode .btn-outline{color:var(--dark-forest);border-color:var(--dark-forest)}body.dark-mode .btn-outline:hover:not(:disabled){background-color:var(--dark-forest);color:var(--white)}body.dark-mode .table{color:var(--dark-text)}body.dark-mode .table th{background-color:var(--dark-surface-hover);color:var(--dark-text);border-bottom-color:var(--dark-border)}body.dark-mode .table td{border-bottom-color:var(--dark-border)}body.dark-mode .table tbody tr:hover{background-color:var(--dark-surface-hover)}body.dark-mode .table-striped tbody tr:nth-child(2n){background-color:#21262d80}body.dark-mode .nav-link{color:var(--dark-text)}body.dark-mode .nav-link:hover,body.dark-mode .nav-link.active{color:var(--dark-forest)}body.dark-mode .dropdown-menu{background-color:var(--dark-surface);border-color:var(--dark-border)}body.dark-mode .dropdown-item{color:var(--dark-text)}body.dark-mode .dropdown-item:hover{background-color:var(--dark-surface-hover);color:var(--dark-forest)}body.dark-mode .modal{background-color:var(--dark-surface);color:var(--dark-text)}body.dark-mode .sidebar{background-color:var(--dark-surface);border-right-color:var(--dark-border)}body.dark-mode .content-area{background-color:var(--dark-bg)}body.dark-mode ::-webkit-scrollbar-track{background:var(--dark-surface)}body.dark-mode ::-webkit-scrollbar-thumb{background:var(--dark-border)}body.dark-mode ::-webkit-scrollbar-thumb:hover{background:var(--dark-text-secondary)}.theme-toggle{position:relative;display:inline-flex;align-items:center;width:60px;height:30px;background-color:var(--medium-gray);border-radius:var(--radius-xl);cursor:pointer;transition:background-color var(--transition-base);border:none;padding:0}.theme-toggle:before{content:"";position:absolute;width:26px;height:26px;border-radius:50%;background-color:var(--white);left:2px;transition:transform var(--transition-base);box-shadow:var(--shadow-sm)}body.dark-mode .theme-toggle{background-color:var(--dark-forest)}body.dark-mode .theme-toggle:before{transform:translate(30px);background-color:var(--cream)}.theme-toggle:focus{outline:2px solid var(--forest);outline-offset:2px}.theme-toggle .sun-icon{position:absolute;left:6px;opacity:1;transition:opacity var(--transition-fast);color:var(--soft-gold)}.theme-toggle .moon-icon{position:absolute;right:6px;opacity:.5;transition:opacity var(--transition-fast);color:var(--medium-gray)}body.dark-mode .theme-toggle .sun-icon{opacity:.5}body.dark-mode .theme-toggle .moon-icon{opacity:1;color:var(--cream)}@media print{*{background:transparent!important;color:#000!important;box-shadow:none!important;text-shadow:none!important}.sidebar,.theme-toggle,.btn,.modal-overlay{display:none!important}.page-layout,.content-with-sidebar{display:block}.content-area{background:#fff!important;padding:0}.card{border:1px solid #ccc;page-break-inside:avoid}h1,h2,h3{page-break-after:avoid}.table{border-collapse:collapse}.table th,.table td{border:1px solid #ddd}}@media (prefers-contrast: high){:root{--forest: #000000;--leaf: #000000;--medium-gray: #000000;--dark-gray: #000000;--ink: #000000}body.dark-mode{--dark-text: #ffffff;--dark-forest: #ffffff;--dark-leaf: #ffffff}.btn,.form-input,.card{border:2px solid currentColor}}@media (prefers-reduced-motion: reduce){.theme-toggle,.theme-toggle:before,.theme-toggle .sun-icon,.theme-toggle .moon-icon{transition:none}}@media (prefers-color-scheme: dark){.auto-theme{--cream: var(--dark-bg);--white: var(--dark-surface);--light-gray: var(--dark-border);--medium-gray: var(--dark-text-secondary);--dark-gray: var(--dark-text);--ink: var(--dark-text);--forest: var(--dark-forest);--leaf: var(--dark-leaf);background-color:var(--dark-bg);color:var(--dark-text)}}.theme-transition,body.theme-transition,.theme-transition .card,.theme-transition .form-input,.theme-transition .btn{transition:background-color var(--transition-base),color var(--transition-base),border-color var(--transition-base)}#root{height:100vh;display:flex;flex-direction:column;background-color:var(--cream);color:var(--ink);font-family:var(--font-sans)}.skip-link{position:absolute;top:-40px;left:6px;background:var(--forest);color:var(--white);padding:8px;border-radius:4px;text-decoration:none;z-index:1000;font-size:var(--text-sm);font-weight:600}.skip-link:focus{top:6px}.app-layout{display:flex;height:100vh;background-color:var(--cream)}*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
