.progress-bar{width:100%;height:8px;background:var(--progress-bg);border-radius:var(--radius-full, 9999px);overflow:hidden}.progress-bar-container{width:100%;background:var(--progress-bg);border-radius:var(--radius-full, 9999px);overflow:hidden}.progress-sm,.progress-bar-container.progress-sm,.progress-md,.progress-bar-container.progress-md{height:1px}.progress-lg,.progress-bar-container.progress-lg{height:14px}.progress-bar-fill{height:100%;border-radius:var(--radius-full, 9999px);transition:width var(--transition-normal, .2s ease)}.progress-bar-fill.success{background:var(--progress-success)}.progress-bar-fill.warning{background:var(--progress-warning)}.progress-bar-fill.danger{background:var(--progress-danger)}.progress-bar-fill.primary{background:var(--primary-color)}.progress-bar-fill.under{background:var(--progress-success, #22c55e)}.progress-bar-fill.perfect{background:var(--primary-color)}.progress-bar-fill.over{background:var(--progress-danger, #ef4444)}.progress-container{display:flex;flex-direction:column;gap:.5rem}.progress-label{display:flex;justify-content:space-between;font-size:.8125rem;color:var(--text-muted)}.progress-value{font-weight:500;color:var(--text-color)}.progress-bar-label{font-size:.8125rem;font-weight:500;color:var(--text-muted);white-space:nowrap}.goal-progress .progress-label{font-size:.8125rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:500;font-family:inherit;line-height:1;border:none;border-radius:var(--radius-md, 8px);cursor:pointer;transition:all var(--transition-fast, .15s ease);white-space:nowrap}.btn:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-color);color:#fff;width:11em;height:2.2em}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:active:not(:disabled){transform:translateY(1px)}.btn-secondary{background:var(--secondary-bg);color:var(--text-color);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--primary-light);border-color:var(--primary-color)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:var(--ghost-hover);color:var(--text-color)}.btn-outline{background:transparent;color:var(--secondary-color);border:1px solid var(--secondary-color)}.btn-outline:hover:not(:disabled){background:var(--primary-light)}.btn-danger{background:var(--error-color);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-success{background:var(--success-color);color:#fff}.btn-success:hover:not(:disabled){background:#16a34a}.btn-icon{padding:.5rem;border-radius:var(--radius-full, 9999px)}.btn-icon.btn-sm{padding:.375rem}.btn-icon.btn-lg{padding:.75rem}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-md{padding:.5rem 1rem;font-size:.875rem}.btn-lg{padding:.875rem 1.5rem;font-size:1rem}.btn-full{width:100%}.btn-group{display:flex;gap:.5rem}.btn-group-attached{gap:0}.btn-group-attached .btn{border-radius:0}.btn-group-attached .btn:first-child{border-radius:var(--radius-md, 8px) 0 0 var(--radius-md, 8px)}.btn-group-attached .btn:last-child{border-radius:0 var(--radius-md, 8px) var(--radius-md, 8px) 0}@media(max-width:768px){.btn{min-height:30px;min-width:30px}.btn-sm{min-height:30px;min-width:30px;padding:.5rem .875rem}.btn-icon{min-width:30px;min-height:30px;padding:.625rem}.btn-icon.btn-sm{min-width:30px;min-height:30px;padding:.5rem}.btn-group{gap:.5rem}}.input{width:100%;padding:.625rem .875rem;font-size:.875rem;color:var(--text-color);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-md, 8px);transition:all var(--transition-fast, .15s ease)}.input:hover:not(:disabled):not(:focus){border-color:var(--text-muted)}.input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2196f31a}.input:disabled{opacity:.5;cursor:not-allowed;background:var(--secondary-bg)}.input::placeholder{color:var(--text-placeholder)}.input-error{border-color:var(--error-color)}.input-error:focus{box-shadow:0 0 0 3px #ef44441a}.input-label{display:block;margin-bottom:.5rem;font-size:.8125rem;font-weight:500;color:var(--text-color)}.input-error-text{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--error-color);margin-top:.25rem}.input-error-text svg{flex-shrink:0}.input-helper-text{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.input-wrapper{display:flex;flex-direction:column;gap:.375rem}select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem;cursor:pointer}textarea.input{min-height:100px;resize:vertical;line-height:1.5}.input-sm{padding:.5rem .75rem;font-size:.8125rem}.input-lg{padding:.75rem 1rem;font-size:1rem}.input-with-icon{position:relative}.input-with-icon .input{padding-left:2.5rem}.input-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}@media(max-width:480px){.input{min-height:30px;font-size:1rem}select.input{min-height:30px}}.card{background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm);padding:var(--space-4, 1rem);transition:all var(--transition-fast, .15s ease)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card-clickable{cursor:pointer}.card-clickable:hover{border-color:var(--primary-color)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4, 1rem);padding-bottom:var(--space-4, 1rem)}.card-title{font-size:1rem;font-weight:600;color:var(--text-color);margin:0}.card-content{color:var(--text-color)}.card-footer{margin-top:var(--space-4, 1rem);padding-top:var(--space-4, 1rem)}.card-outlined{background:transparent;box-shadow:none}.card-elevated{box-shadow:var(--shadow-lg);border:none}.card-flat{box-shadow:none}.card-glass{background:#ffffffb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid transparent;box-shadow:var(--shadow-sm)}.dark-theme .card-glass{background:#1e1e2eb3;border:2px solid transparent}.card-lg{padding:var(--space-6, 1.5rem)}.sync-status{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;transition:all .2s ease,opacity .4s ease;background:#8b772a0f;border:1px dashed rgba(139,119,42,.2)}.sync-status--fading{opacity:0}.sync-status__indicator{display:flex;align-items:center;position:relative}.sync-status__icon{flex-shrink:0}.sync-status__icon--spinning{animation:sync-spin 1s linear infinite}@keyframes sync-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sync-status__count{position:absolute;top:-6px;right:-8px;min-width:16px;height:16px;padding:0 4px;border-radius:9999px;background:var(--warning-color, #f59e0b);color:#fff;font-size:.625rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}.sync-status__label{white-space:nowrap;color:var(--text-muted, #636e72)}.sync-status__retry{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border:none;background:transparent;color:var(--secondary-color, #3b82f6);font-size:.6875rem;font-weight:600;cursor:pointer;border-radius:4px;transition:all .15s ease;text-decoration:underline;text-underline-offset:2px}.sync-status__retry:hover{background:#3b82f61a;text-decoration:underline}.sync-status__retry:focus-visible{outline:2px solid var(--secondary-color, #3b82f6);outline-offset:1px}.sync-status--synced{background:#22c55e14;border-color:#22c55e33}.sync-status--synced .sync-status__icon,.sync-status--synced .sync-status__label{color:var(--success-color, #22c55e)}.sync-status--pending{background:#f59e0b14;border-color:#f59e0b33}.sync-status--pending .sync-status__icon,.sync-status--pending .sync-status__label{color:var(--warning-color, #f59e0b)}.sync-status--syncing{background:#3b82f614;border-color:#3b82f633}.sync-status--syncing .sync-status__icon,.sync-status--syncing .sync-status__label{color:var(--primary-color, #3b82f6)}.sync-status--offline{background:#6b728014;border-color:#6b728033}.sync-status--offline .sync-status__icon,.sync-status--offline .sync-status__label{color:var(--text-muted, #6b7280)}.sync-status--error{background:#ef444414;border-color:#ef444433}.sync-status--error .sync-status__icon,.sync-status--error .sync-status__label{color:var(--error-color, #ef4444)}.dark-theme .sync-status{background:#ffffff0d;border-color:#ffffff1a}.dark-theme .sync-status--synced{background:#22c55e1a;border-color:#22c55e40}.dark-theme .sync-status--pending{background:#f59e0b1a;border-color:#f59e0b40}.dark-theme .sync-status--syncing{background:#3b82f61a;border-color:#3b82f640}.dark-theme .sync-status--offline{background:#9ca3af1a;border-color:#9ca3af40}.dark-theme .sync-status--error{background:#ef44441a;border-color:#ef444440}@media(max-width:768px){.sync-status__retry{min-height:30px;min-width:44px;padding:.5rem}}@media(prefers-reduced-motion:reduce){.sync-status__icon--spinning{animation:none}.sync-status{transition:none}.sync-status--fading{opacity:0}}.date-picker-wrapper{display:flex;flex-direction:column;gap:.375rem}.date-picker{position:relative;display:block}.date-picker-trigger{width:100%;display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;color:var(--text-muted);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-md, 8px);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.date-picker-trigger:hover{border-color:var(--text-muted)}.date-picker-trigger.has-value{color:var(--text-color)}.date-picker-trigger.has-error{border-color:var(--error-color)}.date-picker-trigger.disabled{opacity:.5;cursor:not-allowed;background:var(--secondary-bg)}.date-picker-icon{color:var(--text-muted);flex-shrink:0}.date-picker-value{flex:1;white-space:nowrap}.date-picker-clear{display:flex;align-items:center;justify-content:center;margin-left:.25rem;padding:.125rem;color:var(--text-muted);border-radius:4px;transition:all var(--transition-fast)}.date-picker-clear:hover{color:var(--error-color);background:var(--secondary-bg)}.date-picker-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:100;width:280px;padding:.75rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-lg, 0 10px 25px rgba(0, 0, 0, .15))}.date-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.date-picker-month-year{font-size:.9375rem;font-weight:600;color:var(--text-color)}.date-picker-nav{display:flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--text-muted);background:transparent;border:none;border-radius:var(--radius-sm, 6px);cursor:pointer;transition:all var(--transition-fast)}.date-picker-nav:hover{color:var(--text-color);background:var(--secondary-bg)}.date-picker-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:.5rem}.date-picker-weekday{font-size:.75rem;font-weight:500;color:var(--text-muted);text-align:center;padding:.25rem}.date-picker-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.date-picker-day{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1;font-size:.8125rem;color:var(--text-color);background:transparent;border:none;border-radius:var(--radius-sm, 6px);cursor:pointer;transition:all var(--transition-fast)}.date-picker-day:hover:not(:disabled):not(.selected){background:var(--secondary-bg)}.date-picker-day.empty{cursor:default}.date-picker-day.today{font-weight:600;color:var(--secondary-color)}.date-picker-day.selected{color:#fff;background:var(--primary-color);font-weight:600}.date-picker-day.selected.today{color:#fff}@media(max-width:768px){.date-picker-trigger{min-height:30px}.image-picker-trigger{gap:1.5rem;padding:.5rem 7rem}.date-picker-nav{width:44px;height:44px}.date-picker-clear{min-width:44px;min-height:30px;display:flex;align-items:center;justify-content:center}.date-picker-day{min-height:36px}}@media(prefers-color-scheme:dark){.date-picker-dropdown{box-shadow:0 10px 25px #0006}}.skeleton-block{display:block}.skeleton-block+.skeleton-block{margin-top:.5rem}.empty-state-v2{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-12, 3rem) var(--space-6, 1.5rem);min-height:200px}.empty-state-v2__icon-wrapper{width:88px;height:88px;border-radius:var(--radius-full, 9999px);background:var(--primary-light, rgba(59, 130, 246, .1));display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4, 1rem);color:var(--secondary-color)}.empty-state-v2__title{margin:0 0 var(--space-2, .5rem);font-size:var(--font-size-lg, 1.125rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.empty-state-v2__description{margin:0 0 var(--space-6, 1.5rem);font-size:var(--font-size-sm, .875rem);color:var(--text-muted);max-width:320px;line-height:1.5}.empty-state-v2__description:last-child{margin-bottom:0}.guided-tour{position:fixed;inset:0;z-index:9999;pointer-events:auto}.guided-tour__overlay{position:absolute;inset:0;background:#0009;cursor:pointer}[data-theme=dark] .guided-tour__overlay{background:#000000b3}.guided-tour__spotlight{position:fixed;border-radius:var(--radius-md, 8px);box-shadow:0 0 0 9999px #0009;pointer-events:none;z-index:10000;transition:all .3s ease}[data-theme=dark] .guided-tour__spotlight{box-shadow:0 0 0 9999px #000000b3}@media(prefers-reduced-motion:reduce){.guided-tour__spotlight{transition:none}}.guided-tour__tooltip{position:fixed;z-index:10001;width:320px;max-width:calc(100vw - 32px);padding:1.25rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-lg);pointer-events:auto}.guided-tour__tooltip:before{content:"";position:absolute;width:12px;height:12px;background:var(--card-bg);border:1px solid var(--border-color);transform:rotate(45deg)}.guided-tour__tooltip--arrow-top:before{top:-7px;left:50%;margin-left:-6px;border-right:none;border-bottom:none}.guided-tour__tooltip--arrow-bottom:before{bottom:-7px;left:50%;margin-left:-6px;border-left:none;border-top:none}.guided-tour__tooltip--arrow-left:before{left:-7px;top:50%;margin-top:-6px;border-right:none;border-top:none}.guided-tour__tooltip--arrow-right:before{right:-7px;top:50%;margin-top:-6px;border-left:none;border-bottom:none}.guided-tour__close{position:absolute;top:.75rem;right:.75rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm, 4px);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.guided-tour__close:hover{background:var(--bg-secondary);color:var(--text-color)}.guided-tour__close:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.guided-tour__counter{font-size:.75rem;font-weight:500;color:var(--secondary-color);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.guided-tour__title{margin:0 0 .5rem;font-size:1.125rem;font-weight:600;color:var(--text-color);padding-right:2rem}.guided-tour__description{margin:0 0 1rem;font-size:.875rem;color:var(--text-muted);line-height:1.5}.guided-tour__progress{display:flex;justify-content:center;gap:6px;margin-bottom:1rem}.guided-tour__dot{width:8px;height:8px;border-radius:50%;background:var(--border-color);transition:all var(--transition-fast, .15s ease)}.guided-tour__dot--active{background:var(--primary-color);transform:scale(1.2)}.guided-tour__dot--completed{background:var(--primary-color);opacity:.5}.guided-tour__actions{display:flex;justify-content:space-between;gap:.75rem}.guided-tour__actions button{flex:1}.guided-tour__loading{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10002}.guided-tour__spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:guided-tour-spin .8s linear infinite}@keyframes guided-tour-spin{to{transform:rotate(360deg)}}@media(max-width:767px){.guided-tour__tooltip{width:calc(100vw - 32px);max-width:340px;padding:1rem}.guided-tour__title{font-size:1rem}.guided-tour__description{font-size:.8125rem}.guided-tour__actions{flex-direction:column-reverse;gap:.5rem}.guided-tour__actions button{width:100%;min-height:30px}}@media(prefers-reduced-motion:reduce){.guided-tour__dot{transition:none}.guided-tour__spinner{animation:none;border-top-color:var(--primary-color);border-right-color:var(--primary-color)}}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;padding:2rem;text-align:center;gap:1rem}.error-boundary__icon{width:64px;height:64px;border-radius:var(--radius-full, 9999px);background:#ef44441a;color:var(--error-color, #ef4444);display:flex;align-items:center;justify-content:center}.error-boundary__title{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.error-boundary__message{margin:0;font-size:.9375rem;color:var(--text-muted);max-width:400px;line-height:1.5}.error-boundary__actions{display:flex;gap:.75rem;margin-top:.5rem}.category-card{background:var(--card-bg);border-radius:var(--radius-md, 8px);border:2px solid transparent;overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--transition-fast, .15s ease)}.category-header{display:grid;grid-template-columns:32px 1fr 110px 110px 130px;align-items:center;gap:.5rem;padding:1.8rem 1rem;cursor:pointer;background:var(--card-bg);transition:background-color var(--transition-fast, .15s ease)}.category-header:hover{background:var(--primary-light)}.category-header:hover+.category-progress{background:var(--primary-light)}.category-toggle{color:var(--text-muted);display:flex;align-items:center}.category-name{font-weight:600;color:var(--text-color);font-size:.9375rem;cursor:pointer;padding:.25rem .5rem;margin:-.25rem -.5rem;border-radius:var(--radius-sm, 4px)}.category-name.readonly{cursor:pointer}.category-name-input{font-weight:600;font-size:.9375rem;color:var(--text-color);background:var(--card-bg);border:1px solid var(--primary-color);border-radius:var(--radius-sm, 4px);padding:.25rem .5rem;margin:-.25rem -.5rem;outline:none;width:calc(100% + 1rem)}.category-planned,.category-spent{text-align:right;font-size:.875rem;font-weight:500;font-variant-numeric:tabular-nums}.category-planned{color:var(--text-muted)}.category-spent{color:var(--text-color)}.category-spent.over{color:var(--progress-danger, #ef4444)}.category-difference{text-align:right;font-size:.8125rem;font-weight:500;font-variant-numeric:tabular-nums}.category-difference.positive{color:var(--progress-success, #22c55e)}.category-difference.negative{color:var(--progress-danger, #ef4444)}.category-progress{padding:0 1rem}.budget-item{display:grid;grid-template-columns:16px 1fr 110px 110px 130px auto;align-items:center;gap:.5rem;padding:.75rem 1rem .75rem 2rem;background:var(--card-bg);transition:background-color var(--transition-fast, .15s ease);cursor:pointer}.budget-item:last-child{border-bottom:none}.budget-item:hover{background:var(--primary-light)}.budget-item.editing{background:var(--bg-color);cursor:default;padding:.5rem 1rem .5rem 2rem}.budget-item.editing .input{padding:.375rem .5rem;font-size:.875rem}.item-name-input{min-width:0}.item-planned-input,.item-spent-input{width:100%;text-align:right}.budget-item-icon{width:8px;height:8px;border-radius:var(--radius-full, 9999px);background:var(--primary-color);flex-shrink:0}.budget-item-name{color:var(--text-color);font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.budget-item-planned,.budget-item-spent{text-align:right;font-size:.875rem;font-variant-numeric:tabular-nums}.budget-item-planned{color:var(--text-muted)}.budget-item-spent{color:var(--text-color)}.budget-item-spent.over{color:var(--progress-danger, #ef4444)}.budget-item-difference{text-align:right;font-size:.8125rem;font-weight:500;font-variant-numeric:tabular-nums}.budget-item-difference.positive{color:var(--progress-success, #22c55e)}.budget-item-difference.negative{color:var(--progress-danger, #ef4444)}.budget-item-actions{display:flex;gap:.25rem;opacity:0;transition:opacity var(--transition-fast, .15s ease)}.budget-item:hover .budget-item-actions,.budget-item.editing .budget-item-actions{opacity:1}.category-actions-bar{display:flex;gap:.5rem;padding:.375rem 1rem;justify-content:space-between}.add-item-btn{color:var(--secondary-color)}.add-item-btn:hover{background:var(--primary-light)}.delete-category-btn{color:var(--text-muted);opacity:.5;transition:opacity var(--transition-fast, .15s ease)}.delete-category-btn:hover{opacity:1;color:var(--error-color)}.remaining-indicator{font-size:.75rem;padding:.125rem .5rem;border-radius:var(--radius-full, 9999px);font-weight:500}.remaining-indicator.positive{background:#22c55e1a;color:var(--progress-success, #22c55e)}.remaining-indicator.negative{background:#ef44441a;color:var(--progress-danger, #ef4444)}.remaining-indicator.zero{background:#2196f31a;color:var(--secondary-color)}.budget-item.readonly{cursor:default}.budget-item.readonly:hover{background:var(--card-bg)}.goals-category-notice{padding:.75rem 1rem;border-top:1px solid var(--border-color);background:var(--secondary-bg);font-size:.75rem;color:var(--text-muted);text-align:center;font-style:italic}@media(max-width:768px){.category-header{grid-template-columns:24px 1fr;grid-template-rows:auto auto;gap:.25rem .5rem;padding:1rem}.category-name{grid-column:2;font-size:.875rem}.category-planned,.category-spent,.category-difference{display:none}.category-progress{padding:0 1rem 1rem}.budget-item{grid-template-columns:8px 1fr auto;grid-template-rows:auto auto;gap:.125rem .5rem;padding:.75rem 1rem}.budget-item-icon{grid-row:1 / 3;align-self:center}.budget-item-name{grid-column:2;grid-row:1;white-space:normal}.budget-item-planned{grid-column:2;grid-row:2;text-align:left;font-size:.75rem;color:var(--text-muted)}.budget-item-planned:before{content:"Planned: "}.budget-item-spent{grid-column:3;grid-row:1;font-weight:600}.budget-item-difference{grid-column:3;grid-row:2;font-size:.75rem}.budget-item-actions{grid-row:1 / 3;opacity:1}.budget-item.editing{grid-template-columns:1fr 1fr;padding:.75rem 1rem;display:block}.budget-item.editing .item-name-input{grid-column:1 / -1}.category-actions-bar{padding:.5rem 1rem}.category-actions-bar .btn{min-height:30px}.category-toggle{min-width:44px;min-height:30px;display:flex;align-items:center;justify-content:center;margin:-.5rem;padding:.5rem}.budget-item-actions .btn,.budget-item-actions button{min-width:44px;min-height:30px}.add-item-btn{min-height:30px;min-width:44px}.delete-category-btn{min-height:30px;min-width:44px;opacity:.7}}.sidebar{display:flex;flex-direction:column;min-width:220px;height:100%}.dark-theme .sidebar{--text-color: #e2e8f0;--text-muted: #94a3b8;--border-color: rgba(255, 255, 255, .1);--menu-hover: rgba(255, 255, 255, .08);--ghost-hover: rgba(255, 255, 255, .05);--icon-bg: rgba(255, 255, 255, .1)}.sidebar-header{padding-top:1.7rem;padding-bottom:.55rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.sidebar-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--secondary-color);border-top:2px solid var(--secondary-color)}.menu{display:flex;flex-direction:column;padding:.5rem .75rem;gap:.125rem;flex:1;overflow-y:auto;min-height:0}.menu-heading{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:.25rem .875rem .625rem}.menu-item{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;border-radius:var(--radius-md, 8px);border:1.5px solid transparent;color:var(--text-muted);text-decoration:none;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;transition:all var(--transition-fast, .15s ease);position:relative;flex-shrink:0}.menu-item:hover{border-color:var(--primary-color);color:var(--text-color);text-decoration:none}.menu-item:focus-visible{outline:2px solid var(--primary-color);outline-offset:-2px}.menu-item.active{background:var(--primary-light);color:var(--secondary-color);font-weight:600}.menu-item.active svg{color:var(--secondary-color)}.menu-item svg{width:20px;height:20px;flex-shrink:0;color:currentColor;transition:color var(--transition-fast, .15s ease)}.menu-section{display:flex;flex-direction:column;gap:.125rem;margin-top:.75rem;padding-top:.75rem}.sidebar-user-section{margin-top:auto}.user-info{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;max-width:12.5rem}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full, 9999px);background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;color:var(--secondary-color);flex-shrink:0}.user-email{font-size:.8125rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none}.sign-out-button{width:100%;cursor:pointer;background:none}.sync-dot{width:8px;height:8px;border-radius:50%;background:var(--primary-color);margin-left:auto;flex-shrink:0;animation:sync-dot-pulse 2s ease-in-out infinite}@keyframes sync-dot-pulse{0%,to{opacity:1}50%{opacity:.4}}.sidebar-backdrop{display:none}@media(max-width:768px){.sidebar{position:fixed;top:0;left:0;z-index:1000;width:280px;height:100%;background:var(--sidebar-bg);transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);overflow-y:auto}.sidebar.sidebar--open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;inset:0;background:#00000080;z-index:999;opacity:0;transition:opacity .25s ease;pointer-events:none}.sidebar-backdrop.sidebar-backdrop--visible{opacity:1;pointer-events:auto}.menu-item{min-height:30px;padding:.5rem .875rem}.budget-switcher-trigger,.budget-switcher-option{min-height:30px}}.migration-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.migration-modal{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:440px;width:100%;position:relative;animation:modal-appear .2s ease-out}@keyframes modal-appear{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.migration-close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;padding:.5rem;color:var(--text-muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease}.migration-close-btn:hover{background:var(--menu-hover);color:var(--text-color)}.migration-modal-header{padding:2rem 2rem 1rem;text-align:center}.migration-icon{width:56px;height:56px;border-radius:50%;background:var(--primary-light, #e0f2fe);color:var(--primary-color, #0ea5e9);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.migration-icon.success{background:#dcfce7;color:#16a34a}.migration-icon.error{background:#fef2f2;color:#dc2626}.migration-icon.loading{background:var(--primary-light, #e0f2fe);color:var(--primary-color, #0ea5e9)}.migration-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.migration-modal-body{padding:0 2rem 1.5rem}.migration-description,.migration-loading-message,.migration-success-message,.migration-error-message{color:var(--text-muted);font-size:.9375rem;line-height:1.5;text-align:center;margin:0 0 1.5rem}.migration-preview{background:var(--secondary-bg);border-radius:8px;padding:1rem}.migration-preview h3{margin:0 0 .75rem;font-size:.8125rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.migration-preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.75rem}.migration-preview-item{background:var(--card-bg);border-radius:6px;padding:.75rem;text-align:center}.migration-preview-item .count{display:block;font-size:1.25rem;font-weight:600;color:var(--secondary-color)}.migration-preview-item.income .count{font-size:1rem;color:var(--success-color, #16a34a)}.migration-preview-item .label{display:block;font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.migration-counts{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem}.migration-count-item{text-align:center;min-width:70px}.migration-count-item .count{display:block;font-size:1.5rem;font-weight:600;color:var(--success-color, #16a34a)}.migration-count-item .label{display:block;font-size:.75rem;color:var(--text-muted)}.migration-errors{background:#fef2f2;border-radius:6px;padding:.75rem;margin-top:1rem}.migration-error-item{margin:0;font-size:.8125rem;color:#dc2626;line-height:1.4}.migration-error-item+.migration-error-item{margin-top:.5rem}.migration-error-more{margin:.5rem 0 0;font-size:.75rem;color:#991b1b;font-style:italic}.migration-modal-actions{display:flex;gap:.75rem;padding:0 2rem 2rem}.migration-modal-actions .btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:background-color .15s ease,border-color .15s ease}.migration-modal-actions .btn-secondary{background:transparent;border:1px solid var(--border-color);color:var(--text-color)}.migration-modal-actions .btn-secondary:hover{background:var(--menu-hover);border-color:var(--text-muted)}.migration-modal-actions .btn-primary{background:var(--primary-color);border:1px solid var(--primary-color);color:#fff}.migration-modal-actions .btn-primary:hover{background:var(--primary-dark, #0284c7);border-color:var(--primary-dark, #0284c7)}@media(max-width:768px){.migration-modal-overlay .migration-modal{width:95vw;max-width:none;max-height:85vh;margin:auto}.migration-close-btn{min-width:44px;min-height:30px}.migration-modal-actions .btn{min-height:30px;font-size:1rem}}@media(max-width:480px){.migration-modal{margin:1rem;max-width:none}.migration-modal-header{padding:1.5rem 1.5rem 1rem}.migration-modal-body{padding:0 1.5rem 1.5rem}.migration-modal-actions{padding:0 1.5rem 1.5rem;flex-direction:column}.migration-preview-grid{grid-template-columns:repeat(2,1fr)}}.add-category-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.add-category-modal{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:440px;width:100%;max-height:80vh;display:flex;flex-direction:column;position:relative;animation:add-category-modal-appear .2s ease-out}@keyframes add-category-modal-appear{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.add-category-close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;padding:.5rem;color:var(--text-muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease;z-index:1}.add-category-close-btn:hover{background:var(--menu-hover);color:var(--text-color)}.add-category-modal-header{padding:1.5rem 2rem 1rem;flex-shrink:0}.add-category-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.add-category-modal-body{padding:0 2rem 1rem;overflow-y:auto;flex:1;min-height:0}.add-category-search{margin-bottom:1.25rem}.add-category-search .input-with-icon{position:relative}.add-category-search .input-with-icon .input{padding-left:2.5rem}.add-category-search .input-with-icon .input-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.add-category-section-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.8125rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.add-category-count{font-weight:400;text-transform:none;letter-spacing:normal;margin-left:auto;font-size:.75rem}.add-category-templates{margin-bottom:1.5rem}.add-category-template-list{display:flex;flex-direction:column;gap:.25rem;max-height:200px;overflow-y:auto;background:var(--secondary-bg);border-radius:8px;padding:.5rem}.add-category-template-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.625rem .75rem;background:transparent;border:none;border-radius:6px;cursor:pointer;text-align:left;transition:background-color .15s ease}.add-category-template-item:hover:not(.disabled){background:var(--menu-hover)}.add-category-template-item.selected{background:var(--primary-light, #e0f2fe)}.add-category-template-item.disabled{cursor:not-allowed;opacity:.5}.add-category-template-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s ease,background-color .15s ease}.add-category-template-item.selected .add-category-template-radio{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.add-category-template-radio.disabled{border-color:var(--border-color);background:var(--secondary-bg)}.add-category-template-name{flex:1;font-size:.9375rem;color:var(--text-color)}.add-category-template-item.disabled .add-category-template-name{color:var(--text-muted)}.add-category-template-delete{display:flex;align-items:center;justify-content:center;padding:.375rem;background:transparent;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;opacity:0;transition:opacity .15s ease,background-color .15s ease,color .15s ease}.add-category-template-item:hover .add-category-template-delete{opacity:1}.add-category-template-delete:hover{background:var(--danger-bg, rgba(239, 68, 68, .1));color:var(--danger-color, #ef4444)}.add-category-template-badge{font-size:.6875rem;color:var(--text-muted);background:var(--card-bg);padding:.25rem .5rem;border-radius:4px;text-transform:uppercase;letter-spacing:.03em}.add-category-no-results{padding:1rem;text-align:center;color:var(--text-muted);font-size:.875rem}.add-category-new{padding-top:.5rem}.add-category-modal-actions{display:flex;gap:.75rem;padding:1rem 2rem 1.5rem;flex-shrink:0;border-top:1px solid var(--border-color)}.add-category-modal-actions .btn{flex:1}@media(max-width:768px){.add-category-modal-overlay .add-category-modal{width:95vw;max-width:none;max-height:85vh;margin:auto}.add-category-close-btn{min-width:44px;min-height:30px}.add-category-modal-actions .btn{min-height:30px;font-size:1rem}}@media(max-width:480px){.add-category-modal{margin:1rem;max-width:none;max-height:90vh}.add-category-modal-header{padding:1.25rem 1.5rem .75rem}.add-category-modal-body{padding:0 1.5rem 1rem}.add-category-modal-actions{padding:1rem 1.5rem 1.25rem;flex-direction:column}.add-category-template-list{max-height:150px}}.copy-from-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.copy-from-modal{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:480px;width:100%;max-height:80vh;display:flex;flex-direction:column;position:relative;animation:copy-from-modal-appear .2s ease-out}@keyframes copy-from-modal-appear{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.copy-from-close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;padding:.5rem;color:var(--text-muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease;z-index:1}.copy-from-close-btn:hover:not(:disabled){background:var(--menu-hover);color:var(--text-color)}.copy-from-close-btn:disabled{cursor:not-allowed;opacity:.5}.copy-from-modal-header{padding:1.5rem 2rem 1rem;flex-shrink:0}.copy-from-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.copy-from-description{margin:.5rem 0 0;font-size:.875rem;color:var(--text-muted);line-height:1.5}.copy-from-modal-body{padding:0 2rem 1rem;overflow-y:auto;flex:1;min-height:0}.copy-from-no-history{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;text-align:center;color:var(--text-muted)}.copy-from-no-history svg{margin-bottom:1rem;opacity:.5}.copy-from-no-history p{margin:0}.copy-from-hint{font-size:.8125rem;margin-top:.5rem!important;opacity:.7}.copy-from-month-list{display:flex;flex-direction:column;gap:.25rem;max-height:240px;overflow-y:auto;background:var(--secondary-bg);border-radius:8px;padding:.5rem}.copy-from-month-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;background:transparent;border:none;border-radius:6px;cursor:pointer;text-align:left;transition:background-color .15s ease}.copy-from-month-item:hover:not(:disabled){background:var(--menu-hover)}.copy-from-month-item.selected{background:var(--primary-light, #e0f2fe)}.copy-from-month-item:disabled{cursor:not-allowed;opacity:.7}.copy-from-month-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s ease,background-color .15s ease}.copy-from-month-item.selected .copy-from-month-radio{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.copy-from-month-info{flex:1;min-width:0}.copy-from-month-name{display:block;font-size:.9375rem;font-weight:500;color:var(--text-color)}.copy-from-month-details{display:block;font-size:.75rem;color:var(--text-muted);margin-top:.125rem}.copy-from-month-amount{font-size:.875rem;font-weight:500;color:var(--text-color);flex-shrink:0}.copy-from-preview{margin-top:1rem;padding:.875rem;background:var(--secondary-bg);border-radius:8px;border:1px solid var(--border-color)}.copy-from-preview-header{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:600;color:var(--text-color);margin-bottom:.5rem}.copy-from-preview-list{margin:0;padding-left:1.25rem;font-size:.8125rem;color:var(--text-muted);line-height:1.6}.copy-from-preview-list li{margin-bottom:.125rem}.copy-from-modal-actions{display:flex;gap:.75rem;padding:1rem 2rem 1.5rem;flex-shrink:0;border-top:1px solid var(--border-color)}.copy-from-modal-actions .btn{flex:1}@media(max-width:768px){.copy-from-modal-overlay .copy-from-modal{width:95vw;max-width:none;max-height:85vh;margin:auto}.copy-from-close-btn{min-width:44px;min-height:30px}.copy-from-modal-actions .btn{min-height:30px;font-size:1rem}}@media(max-width:480px){.copy-from-modal{margin:1rem;max-width:none;max-height:90vh}.copy-from-modal-header{padding:1.25rem 1.5rem .75rem}.copy-from-modal-body{padding:0 1.5rem 1rem}.copy-from-modal-actions{padding:1rem 1.5rem 1.25rem;flex-direction:column}.copy-from-modal-actions .btn{width:100%}.copy-from-month-list{max-height:200px}}.add-loan-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.add-loan-modal{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:480px;width:100%;position:relative;animation:add-loan-modal-appear .2s ease-out}@keyframes add-loan-modal-appear{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.add-loan-close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;padding:.5rem;color:var(--text-muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease}.add-loan-close-btn:hover{background:var(--menu-hover);color:var(--text-color)}.add-loan-modal-header{padding:2rem 2rem 1rem;text-align:center}.add-loan-icon{width:56px;height:56px;border-radius:50%;background:var(--primary-light, #e0f2fe);color:var(--primary-color, #0ea5e9);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.add-loan-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.loan-type-toggle{display:flex;gap:.5rem;padding:0 2rem;margin-bottom:1rem}.loan-type-btn{flex:1;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--secondary-bg);color:var(--text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.loan-type-btn:hover{background:var(--menu-hover);border-color:var(--text-muted)}.loan-type-btn.active{background:var(--primary-light, #e0f2fe);border-color:var(--primary-color);color:var(--secondary-color)}.loan-type-toggle.disabled .loan-type-btn{opacity:.6;cursor:not-allowed}.loan-type-toggle.disabled .loan-type-btn:hover{background:var(--secondary-bg);border-color:var(--border-color)}.loan-type-toggle.disabled .loan-type-btn.active:hover{background:var(--primary-light, #e0f2fe);border-color:var(--primary-color)}.add-loan-form{padding:0}.add-loan-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:0 2rem 1.5rem;text-align:center}.add-loan-form-grid .input-wrapper:first-child,.add-loan-form-grid .full-width{grid-column:1 / -1}.add-loan-textarea{min-height:80px;resize:vertical;line-height:1.5}.add-loan-modal-actions{display:flex;gap:.75rem;padding:0 2rem 2rem}.add-loan-modal-actions .btn{flex:1}@media(max-width:768px){.add-loan-modal-overlay .add-loan-modal{width:95vw;max-width:none;max-height:85vh;margin:auto;overflow-y:auto;display:flex;flex-direction:column}.add-loan-close-btn{min-width:44px;min-height:30px}.add-loan-modal-actions .btn{min-height:30px;font-size:1rem}}@media(max-width:480px){.add-loan-modal{margin:1rem;max-width:none}.add-loan-modal-header{padding:1.5rem 1.5rem 1rem}.loan-type-toggle{padding:0 1.5rem;flex-direction:column}.add-loan-form-grid{padding:0 1.5rem 1.5rem;grid-template-columns:1fr}.add-loan-modal-actions{padding:0 1.5rem 1.5rem;flex-direction:column}.add-loan-modal-actions .btn{width:100%}}.add-payment-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.add-payment-modal{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:440px;width:100%;position:relative;animation:add-payment-modal-appear .2s ease-out}@keyframes add-payment-modal-appear{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.add-payment-close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;padding:.5rem;color:var(--text-muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease}.add-payment-close-btn:hover{background:var(--menu-hover);color:var(--text-color)}.add-payment-modal-header{padding:2rem 2rem 1rem;text-align:center}.add-payment-icon{width:56px;height:56px;border-radius:50%;background:var(--success-light, #d1fae5);color:var(--success-color, #10b981);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.add-payment-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.add-payment-subtitle{margin:.5rem 0 0;font-size:.875rem;color:var(--text-muted)}.add-payment-loan-info{margin:0 2rem 1.5rem;padding:1rem;background:var(--secondary-bg);border-radius:8px;border:1px solid var(--border-color)}.payment-info-row{display:flex;justify-content:space-between;align-items:center}.payment-info-row+.payment-info-row{margin-top:.5rem}.payment-info-label{font-size:.875rem;color:var(--text-muted)}.payment-info-value{font-size:1rem;font-weight:600;color:var(--text-color)}.payment-info-value.muted{font-weight:400;color:var(--text-muted)}.add-payment-form{padding:0}.add-payment-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:0 2rem 1rem}.add-payment-form-grid .full-width{grid-column:1 / -1}.add-payment-textarea{min-height:60px;resize:vertical;line-height:1.5}.add-payment-warning{display:flex;gap:.75rem;align-items:flex-start;margin:0 2rem 1rem;padding:.75rem 1rem;background:var(--warning-light, #fef3c7);border:1px solid var(--warning-color, #f59e0b);border-radius:8px;font-size:.875rem;color:var(--warning-dark, #92400e)}.warning-icon{flex-shrink:0;width:20px;height:20px;border-radius:50%;background:var(--warning-color, #f59e0b);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem}.add-payment-modal-actions{display:flex;gap:.75rem;padding:1rem 2rem 2rem}.add-payment-modal-actions .btn{flex:1}@media(max-width:768px){.add-payment-modal-overlay .add-payment-modal{width:95vw;max-width:none;max-height:85vh;margin:auto}.add-payment-close-btn{min-width:44px;min-height:30px}.add-payment-modal-actions .btn,.settle-prompt-actions .btn{min-height:30px;font-size:1rem}}@media(max-width:480px){.add-payment-modal{margin:1rem;max-width:none}.add-payment-modal-header{padding:1.5rem 1.5rem 1rem}.add-payment-loan-info{margin:0 1.5rem 1.5rem}.add-payment-form-grid{padding:0 1.5rem 1rem;grid-template-columns:1fr}.add-payment-warning{margin:0 1.5rem 1rem}.add-payment-modal-actions{padding:1rem 1.5rem 1.5rem;flex-direction:column}}.add-payment-success-hint{display:flex;gap:.5rem;align-items:center;margin:0 2rem 1rem;padding:.75rem 1rem;background:var(--success-light, #d1fae5);border:1px solid var(--success-color, #10b981);border-radius:8px;font-size:.875rem;color:var(--success-dark, #065f46)}.add-payment-success-hint svg{flex-shrink:0}.add-payment-modal.settle-prompt{padding:2.5rem 2rem;text-align:center}.settle-prompt-content{display:flex;flex-direction:column;align-items:center}.settle-prompt-icon{width:72px;height:72px;border-radius:50%;background:var(--success-light, #d1fae5);color:var(--success-color, #10b981);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}.settle-prompt-content h2{margin:0 0 .75rem;font-size:1.5rem;font-weight:600;color:var(--text-color)}.settle-prompt-content p{margin:0 0 1.5rem;font-size:.9375rem;color:var(--text-muted);line-height:1.5;max-width:320px}.settle-prompt-actions{display:flex;gap:.75rem;width:100%}.settle-prompt-actions .btn{flex:1}.loan-detail-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.loan-detail-modal{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:loan-detail-modal-appear .2s ease-out}@keyframes loan-detail-modal-appear{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.loan-detail-close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;padding:.5rem;color:var(--text-muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease;z-index:1}.loan-detail-close-btn:hover{background:var(--menu-hover);color:var(--text-color)}.loan-detail-header{padding:2rem 2rem 1.5rem;text-align:center}.loan-detail-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.loan-detail-icon.lent{background:var(--success-light, #d1fae5);color:var(--success-color, #10b981)}.loan-detail-icon.borrowed{background:var(--warning-light, #fef3c7);color:var(--warning-color, #f59e0b)}.loan-detail-title-row{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.5rem}.loan-detail-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-color)}.loan-type-badge{padding:.25rem .75rem;border-radius:99px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.loan-type-badge.lent{background:var(--success-light, #d1fae5);color:var(--success-color, #10b981)}.loan-type-badge.borrowed{background:var(--warning-light, #fef3c7);color:var(--warning-color, #f59e0b)}.loan-status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:99px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.loan-status-badge.settled{background:var(--success-light, #d1fae5);color:var(--success-color, #10b981)}.loan-detail-description{margin:0;font-size:.875rem;color:var(--text-muted)}.loan-detail-summary{padding:1.5rem 2rem}.loan-summary-progress{margin-bottom:1.5rem}.loan-progress-stats{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:var(--text-muted)}.loan-summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.loan-summary-item{display:flex;flex-direction:column;gap:.25rem}.summary-label{font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:.375rem}.summary-value{font-size:1rem;font-weight:600;color:var(--text-color)}.summary-value.success{color:var(--success-color, #10b981)}.summary-value.highlight{color:var(--primary-color, #0ea5e9)}.loan-detail-payments{padding:1.5rem 2rem}.loan-detail-payments h3{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:.875rem;font-weight:600;color:var(--text-color);text-transform:uppercase;letter-spacing:.025em}.payments-empty{text-align:center;padding:1.5rem;color:var(--text-muted)}.payments-empty svg{opacity:.5;margin-bottom:.75rem}.payments-empty p{margin:0;font-size:.875rem;font-weight:500}.payments-empty-hint{display:block;margin-top:.25rem;font-size:.75rem;opacity:.75}.payments-list{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.payment-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--secondary-bg);border-radius:8px;border:1px solid var(--border-color)}.payment-item-left{display:flex;align-items:center;gap:.75rem}.payment-item-icon{width:28px;height:28px;border-radius:50%;background:var(--success-light, #d1fae5);color:var(--success-color, #10b981);display:flex;align-items:center;justify-content:center}.payment-item-info{display:flex;flex-direction:column;gap:.125rem}.payment-date{font-size:.875rem;font-weight:500;color:var(--text-color)}.payment-note{font-size:.75rem;color:var(--text-muted)}.payment-amount{font-size:.875rem;font-weight:600;color:var(--success-color, #10b981)}.loan-detail-actions{display:flex;flex-wrap:wrap;gap:.5rem;padding:1.5rem 2rem}.loan-detail-actions .btn{flex:1;min-width:fit-content}.loan-detail-actions .delete-btn{color:var(--danger-color, #ef4444)}.loan-detail-actions .delete-btn:hover{background:var(--danger-light, #fee2e2)}@media(max-width:768px){.loan-detail-modal-overlay .loan-detail-modal{width:95vw;max-width:none;max-height:85vh;margin:auto}.loan-detail-close-btn{min-width:44px;min-height:30px}.loan-detail-actions .btn{min-height:30px;font-size:1rem}}@media(max-width:480px){.loan-detail-modal{margin:.5rem;max-width:none;max-height:95vh}.loan-detail-header{padding:1.5rem 1.5rem 1rem}.loan-detail-title-row{flex-direction:column;gap:.5rem}.loan-detail-summary{padding:1rem 1.5rem}.loan-summary-grid{grid-template-columns:1fr;gap:.75rem}.loan-detail-payments{padding:1rem 1.5rem}.loan-detail-actions{padding:1rem 1.5rem;flex-direction:column}.loan-detail-actions .btn{width:100%}}.active-collaborators-list{display:flex;flex-direction:column;gap:.75rem}.active-collaborators-loading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;color:var(--text-muted);font-size:.875rem}.active-collaborators-loading .spinning{animation:spin 1s linear infinite}.active-collaborators-empty{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;color:var(--text-muted);font-size:.875rem;background:var(--menu-hover);border-radius:var(--radius-md, 8px)}.active-collaborators-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--error-light, #fef2f2);color:var(--error-color, #dc2626);border-radius:var(--radius-md, 8px);font-size:.875rem;border:1px solid var(--error-color, #dc2626)}.active-collaborators-error span{flex:1}.active-collaborators-error .error-dismiss{background:none;border:none;padding:.25rem;cursor:pointer;color:var(--error-color, #dc2626);display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .15s ease}.active-collaborators-error .error-dismiss:hover{background:#dc26261a}.collaborator-item{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);transition:all var(--transition-fast, .15s ease)}.collaborator-item:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-1px)}.collaborator-main{display:flex;align-items:flex-start;gap:.75rem}.collaborator-avatar{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-full, 50%);background:var(--primary-light);color:var(--secondary-color);flex-shrink:0;overflow:hidden;font-weight:600;font-size:1rem}.collaborator-avatar img{width:100%;height:100%;object-fit:cover}.avatar-initials{font-size:1rem;font-weight:600;text-transform:uppercase}.collaborator-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.collaborator-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.collaborator-name{font-weight:600;font-size:.9375rem;color:var(--text-color);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.collaborator-email{font-size:.8125rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.collaborator-shared-since{font-size:.8125rem;color:var(--text-muted)}.collaborator-permission-badge{font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:var(--radius-md, 8px);background:var(--primary-light);color:var(--secondary-color);white-space:nowrap}.collaborator-actions{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color)}.remove-button{display:flex;align-items:center;gap:.375rem;color:var(--text-muted)}.remove-button:hover{color:var(--error-color, #dc2626)}.confirm-remove{display:flex;flex-direction:column;gap:.75rem;width:100%}.confirm-remove-message{display:flex;flex-direction:column;gap:.25rem}.confirm-title{font-size:.875rem;font-weight:600;color:var(--text-color)}.confirm-description{font-size:.8125rem;color:var(--text-muted)}.confirm-remove-buttons{display:flex;align-items:center;justify-content:flex-end;gap:.5rem}.remove-confirm-button{background:var(--error-color, #dc2626)!important;border-color:var(--error-color, #dc2626)!important}.remove-confirm-button:hover{background:#b91c1c!important;border-color:#b91c1c!important}@media(max-width:480px){.collaborator-header{flex-direction:column;align-items:flex-start;gap:.5rem}.collaborator-actions{flex-direction:column;align-items:stretch}.collaborator-actions button{width:100%;justify-content:center}.confirm-remove-buttons{flex-direction:column;align-items:stretch}.confirm-remove-buttons button{width:100%;justify-content:center}}.dark-theme .active-collaborators-empty{background:var(--menu-hover)}.dark-theme .collaborator-item{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .collaborator-item:hover{border-color:var(--primary-color)}.dark-theme .active-collaborators-error{background:#dc26261a;border-color:var(--error-color, #dc2626)}.dark-theme .remove-button:hover{color:var(--error-color, #dc2626);background:#dc26261a}.invite-modal{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:480px;width:100%;position:relative;animation:invite-modal-appear .2s ease-out}@keyframes invite-modal-appear{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.invite-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color)}.invite-modal-title{display:flex;align-items:center;gap:.75rem;color:var(--secondary-color)}.invite-modal-title h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.close-button{background:transparent;border:none;padding:.5rem;color:var(--text-muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease}.close-button:hover{background:var(--menu-hover);color:var(--text-color)}.invite-tabs{display:flex;border-bottom:1px solid var(--border-color);padding:0 1.5rem}.invite-tab{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .15s ease;margin-bottom:-1px}.invite-tab:hover{color:var(--text-color);background:var(--menu-hover)}.invite-tab.active{color:var(--secondary-color);border-bottom-color:var(--primary-color)}.invite-tab svg{flex-shrink:0}.invite-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.form-group>label{font-size:.875rem;font-weight:600;color:var(--text-color)}.link-display-container{display:flex;flex-direction:column;gap:.5rem}.link-display-container>label{font-size:.875rem;font-weight:600;color:var(--text-color)}.link-display-box{display:flex;gap:.5rem;align-items:stretch}.link-input{flex:1;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg, var(--card-bg));color:var(--text-color);font-size:.875rem;font-family:monospace;overflow:hidden;text-overflow:ellipsis}.link-input:focus{outline:none;border-color:var(--primary-color)}.copy-button{flex-shrink:0;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.link-note{font-size:.8125rem;color:var(--text-muted);margin:0;padding:.5rem;background:var(--primary-light);border-radius:6px;text-align:center}.error-message{background:var(--error-light, #fef2f2);color:var(--error-color, #dc2626);padding:.75rem 1rem;border-radius:6px;font-size:.875rem;border:1px solid var(--error-color, #dc2626)}.invite-config-warning{display:flex;gap:12px;padding:12px 16px;background:var(--warning-light, rgba(234, 179, 8, .1));border:1px solid var(--warning-color, #eab308);border-radius:8px;color:var(--text-color)}.invite-config-warning svg{color:var(--warning-color, #eab308);flex-shrink:0;margin-top:2px}.invite-config-warning p{margin:0;font-size:14px;line-height:1.5}.invite-config-warning p:first-child{margin-bottom:4px}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:.5rem}.invite-success{display:flex;flex-direction:column;align-items:center;text-align:center;padding:3rem 2rem;gap:1rem}.invite-success svg{color:var(--secondary-color)}.invite-success h4{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.invite-success p{margin:0;color:var(--text-muted);font-size:.9375rem}.invite-success .success-note{font-size:.8125rem;color:var(--text-muted)}@media(max-width:768px){.invite-modal{width:95vw;max-width:none;max-height:85vh;margin:auto}.close-button{min-width:44px;min-height:30px}.form-actions button{min-height:30px;font-size:1rem}.copy-button{min-height:30px}}@media(max-width:480px){.invite-modal{margin:1rem;max-width:none}.invite-modal-header{padding:1rem}.invite-tabs{padding:0 1rem}.invite-tab{flex:1;justify-content:center;padding:.75rem .5rem;font-size:.875rem}.invite-form{padding:1rem}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.link-display-box{flex-direction:column}.link-input{font-size:.75rem}}.dark-theme .invite-modal{background:var(--card-bg);box-shadow:0 20px 25px -5px #0000004d,0 10px 10px -5px #0003}.dark-theme .invite-tab:hover{background:var(--menu-hover)}.dark-theme .link-input{background:var(--input-bg, rgba(0, 0, 0, .2));border-color:var(--border-color)}.dark-theme .link-note{background:rgba(var(--primary-rgb),.15)}.dark-theme .error-message{background:#dc26261a;border-color:var(--error-color, #dc2626)}.dark-theme .invite-config-warning{background:#eab30826}.notification-bell{position:relative}.notification-bell-trigger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:var(--radius-md, 8px);cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast, .15s ease);position:relative}.notification-bell-trigger:hover{background:var(--menu-hover);color:var(--text-color)}.notification-bell-trigger:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.notification-bell-trigger.open{background:var(--menu-hover);color:var(--secondary-color)}.notification-bell-trigger svg{width:20px;height:20px}.notification-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;background:var(--error-color, #ef4444);color:#fff;font-size:.625rem;font-weight:600;border-radius:var(--radius-full, 9999px);display:flex;align-items:center;justify-content:center;line-height:1}.notification-panel{position:absolute;top:calc(100% + 8px);left:0;width:320px;max-height:400px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;animation:notificationSlide .15s ease}@keyframes notificationSlide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.notification-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border-color)}.notification-panel-title{font-size:.875rem;font-weight:600;color:var(--text-color)}.notification-mark-read-btn{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:transparent;border:none;border-radius:var(--radius-sm, 4px);font-size:.75rem;font-weight:500;color:var(--secondary-color);cursor:pointer;transition:background var(--transition-fast, .15s ease)}.notification-mark-read-btn:hover{background:var(--primary-light)}.notification-mark-read-btn:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.notification-panel-content{max-height:340px;overflow-y:auto}.notification-loading{padding:2rem;text-align:center;color:var(--text-muted);font-size:.875rem}.notification-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--text-muted)}.notification-empty-icon{opacity:.3;margin-bottom:.5rem}.notification-empty p{margin:0;font-size:.875rem}.notification-group{border-bottom:1px solid var(--border-color)}.notification-group:last-child{border-bottom:none}.notification-group-header{padding:.5rem 1rem;background:var(--menu-hover);font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.025em}.notification-item{display:flex;flex-direction:column;gap:.125rem;padding:.625rem 1rem;transition:background var(--transition-fast, .15s ease)}.notification-item:hover{background:var(--menu-hover)}.notification-item-text{font-size:.8125rem;color:var(--text-color);line-height:1.4}.notification-item-time{font-size:.6875rem;color:var(--text-muted)}.dark-theme .notification-panel{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .notification-group-header,.dark-theme .notification-item:hover{background:var(--menu-hover)}@media(max-width:768px){.notification-bell-trigger{width:44px;height:44px}.notification-mark-read-btn{min-height:30px;padding:.5rem .75rem}.notification-panel{width:calc(100vw - 2rem);max-width:360px;right:-.5rem;left:auto}}.pending-invitations-list{display:flex;flex-direction:column;gap:.75rem}.pending-invitations-loading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;color:var(--text-muted);font-size:.875rem}.pending-invitations-loading .spinning{animation:spin 1s linear infinite}.pending-invitations-empty{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;color:var(--text-muted);font-size:.875rem;background:var(--menu-hover);border-radius:var(--radius-md, 8px)}.pending-invitations-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--error-light, #fef2f2);color:var(--error-color, #dc2626);border-radius:var(--radius-md, 8px);font-size:.875rem;border:1px solid var(--error-color, #dc2626)}.pending-invitations-error span{flex:1}.error-dismiss{background:none;border:none;padding:.25rem;cursor:pointer;color:var(--error-color, #dc2626);display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .15s ease}.error-dismiss:hover{background:#dc26261a}.pending-invitation-item{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);transition:all var(--transition-fast, .15s ease)}.pending-invitation-item:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-1px)}.pending-invitation-item.expired{opacity:.8;background:var(--menu-hover)}.invitation-main{display:flex;align-items:flex-start;gap:.75rem}.invitation-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full, 50%);background:var(--primary-light);color:var(--secondary-color);flex-shrink:0}.invitation-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.invitation-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.invitation-email{font-weight:600;font-size:.9375rem;color:var(--text-color);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invitation-type-badge{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.125rem .375rem;border-radius:4px;white-space:nowrap}.invitation-type-badge.email{background:var(--menu-hover);color:var(--text-muted)}.invitation-type-badge.link,.invitation-icon.link-icon{background:var(--primary-light);color:var(--secondary-color)}.pending-invitation-item.link-type{border-left:3px solid var(--primary-color)}.copy-link-button{display:flex;align-items:center;gap:.375rem}.invitation-dates{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-muted);flex-wrap:wrap}.date-separator{color:var(--text-muted)}.expires-date{display:flex;align-items:center;gap:.25rem}.expired-badge{display:flex;align-items:center;gap:.25rem;color:var(--warning-color, #f59e0b);font-weight:500}.invitation-actions{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color)}.resend-button,.cancel-button{display:flex;align-items:center;gap:.375rem}.resend-button .spinning{animation:spin 1s linear infinite}.cancel-button{color:var(--text-muted)}.cancel-button:hover{color:var(--error-color, #dc2626)}.confirm-cancel{display:flex;align-items:center;gap:.5rem}.confirm-text{font-size:.8125rem;color:var(--text-muted);margin-right:.5rem}@media(max-width:480px){.invitation-header{flex-direction:column;align-items:flex-start;gap:.375rem}.invitation-dates{flex-direction:column;align-items:flex-start;gap:.25rem}.date-separator{display:none}.invitation-actions{flex-direction:column;align-items:stretch}.invitation-actions button{width:100%;justify-content:center}.confirm-cancel{flex-direction:column;align-items:stretch}.confirm-text{text-align:center;margin-right:0;margin-bottom:.25rem}.confirm-cancel button{width:100%;justify-content:center}}.dark-theme .pending-invitations-empty{background:var(--menu-hover)}.dark-theme .pending-invitation-item{background:var(--card-bg);border-color:var(--border-color)}.dark-theme .pending-invitation-item:hover{border-color:var(--primary-color)}.dark-theme .pending-invitation-item.expired{background:var(--menu-hover)}.dark-theme .pending-invitations-error{background:#dc26261a;border-color:var(--error-color, #dc2626)}.dark-theme .cancel-button:hover{color:var(--error-color, #dc2626);background:#dc26261a}.image-picker-trigger{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:500;font-family:inherit;line-height:1;color:var(--text-color);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);cursor:pointer;transition:all var(--transition-fast, .15s ease);white-space:nowrap}.image-picker-trigger:hover{background:var(--primary-light);border-color:var(--primary-color)}.image-picker{padding:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;margin-bottom:1rem}.image-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.image-picker-header h4{margin:0;font-size:.875rem;font-weight:600;color:var(--text-color)}.image-picker-close{display:flex;align-items:center;justify-content:center;padding:.25rem;border:none;border-radius:4px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s}.image-picker-close:hover{background:var(--hover-bg)}.image-picker-presets{display:grid;grid-template-columns:repeat(6,1fr);gap:1.5rem;margin-bottom:1.5rem}.preset-option{display:flex;align-items:center;justify-content:center;padding:0;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:border-color .15s,transform .1s;aspect-ratio:1;min-height:48px;color:#fff}.preset-option:hover{transform:scale(1.05);border-color:#ffffff80}.preset-option.preset-active{border-color:var(--accent-color);box-shadow:0 0 0 2px var(--accent-color-alpha)}.preset-option svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}.preset-option.preset-recent{position:relative;border:2px dashed rgba(255,255,255,.5)}.preset-option.preset-recent:hover{border-style:solid;border-color:#ffffffb3}.preset-option .recent-icon{opacity:.8}.image-picker-actions{display:flex;gap:.5rem;align-items:center}.image-picker-file-input{display:none}.image-picker-custom{margin-bottom:.75rem;border-top:1px solid var(--border-color);padding-top:.75rem}.custom-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;border:1px dashed var(--border-color);border-radius:6px;background:transparent;color:var(--text-secondary);font-family:inherit;font-size:.8125rem;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.custom-toggle:hover{color:var(--accent-color);border-color:var(--accent-color);background:var(--hover-bg)}.custom-check{margin-left:auto;color:var(--success-color, #28a745)}.custom-gradient-builder{margin-top:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:8px}.custom-preview{height:48px;border-radius:6px;margin-bottom:.75rem}.custom-colors{display:flex;gap:1rem;margin-bottom:.75rem}.color-input-group{flex:1;display:flex;flex-direction:column;gap:.25rem}.color-input-group label{font-size:.6875rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.color-input-wrapper{display:flex;align-items:center;gap:.5rem;padding:.375rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px}.color-input{width:32px;height:32px;padding:0;border:none;border-radius:4px;cursor:pointer;background:transparent}.color-input::-webkit-color-swatch-wrapper{padding:0}.color-input::-webkit-color-swatch{border:none;border-radius:4px}.color-input::-moz-color-swatch{border:none;border-radius:4px}.color-value{font-size:.75rem;font-family:monospace;color:var(--text-secondary);text-transform:uppercase}.custom-apply-btn{width:100%}@media(max-width:640px){.image-picker-presets{grid-template-columns:repeat(4,1fr)}.custom-colors{flex-direction:column;gap:.5rem}}.family-tree__members{display:flex;flex-direction:column;gap:var(--space-1, .25rem)}.family-tree__member{display:flex;align-items:center;gap:var(--space-3, .75rem);padding:var(--space-2, .5rem) var(--space-3, .75rem);border-radius:var(--radius-md, 8px);transition:background var(--transition-fast, .15s ease)}.family-tree__avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:600;font-size:.75rem;color:#fff;background:var(--primary-color, #3b82f6);overflow:hidden}.family-tree__avatar img{width:100%;height:100%;object-fit:cover}.family-tree__info{flex:1;min-width:0}.family-tree__name{font-size:.8125rem;font-weight:600;color:var(--text-color);display:flex;align-items:center;gap:var(--space-2, .5rem);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.family-tree__email{font-size:.6875rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.family-tree__badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.625rem;font-weight:500;padding:.125rem .4rem;border-radius:var(--radius-full, 9999px);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.family-tree__badge--parent{background:var(--primary-light, rgba(59, 130, 246, .1));color:var(--primary-color, #3b82f6)}.family-tree__badge--child{background:var(--accent-light, rgba(139, 92, 246, .1));color:var(--accent-color, #8b5cf6)}.family-tree__you-tag{font-size:.5625rem;font-weight:600;padding:.0625rem .3rem;border-radius:var(--radius-full, 9999px);background:var(--success-light, rgba(34, 197, 94, .1));color:var(--success-color, #22c55e);text-transform:uppercase;letter-spacing:.05em}.family-tree__empty{text-align:center;color:var(--text-muted);font-size:.875rem;padding:var(--space-4, 1rem) 0;margin:0}@media(max-width:768px){.family-tree__member{padding:var(--space-2, .5rem);gap:var(--space-2, .5rem)}.family-tree__avatar{width:28px;height:28px;font-size:.6875rem}.family-tree__name{font-size:.75rem}}.add-transaction-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.add-transaction-modal{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:480px;width:100%;position:relative;animation:add-transaction-modal-appear .2s ease-out}@keyframes add-transaction-modal-appear{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.add-transaction-close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;padding:.5rem;color:var(--text-muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease}.add-transaction-close-btn:hover{background:var(--menu-hover);color:var(--text-color)}.add-transaction-modal-header{padding:2rem 2rem 1rem;text-align:center}.add-transaction-icon{width:56px;height:56px;border-radius:50%;background:var(--primary-light, #e0f2fe);color:var(--primary-color, #0ea5e9);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.add-transaction-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.add-transaction-no-accounts{display:flex;flex-direction:column;align-items:center;gap:var(--space-4, 1rem);padding:var(--space-6, 1.5rem) 2rem 2rem;text-align:center}.add-transaction-no-accounts p{margin:0;color:var(--text-muted);font-size:.9375rem}.add-transaction-no-accounts-actions{display:flex;gap:var(--space-3, .75rem);width:100%}.add-transaction-no-accounts-actions .btn{flex:1}.add-transaction-form{padding:0}.add-transaction-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:0 2rem 1.5rem;text-align:center}.add-transaction-form-grid select.input{padding:.625rem 2.5rem .625rem .875rem;border:1px solid var(--input-border);border-radius:var(--radius-md, 8px);background:var(--input-bg);color:var(--text-color);font-size:.875rem;width:100%;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;transition:all var(--transition-fast, .15s ease)}.add-transaction-form-grid select.input:focus{outline:none;border-color:var(--input-focus);box-shadow:0 0 0 3px var(--primary-light)}.add-transaction-modal-actions{display:flex;gap:.75rem;padding:0 2rem 2rem}.add-transaction-modal-actions .btn{flex:1}@media(max-width:768px){.add-transaction-modal-overlay .add-transaction-modal{width:95vw;max-width:none;max-height:85vh;margin:auto;overflow-y:auto;display:flex;flex-direction:column}.add-transaction-close-btn{min-width:44px;min-height:30px}.add-transaction-modal-actions .btn{min-height:30px;font-size:1rem}.add-transaction-no-accounts-actions{flex-direction:column}.add-transaction-no-accounts-actions .btn{width:100%;min-height:30px}}@media(max-width:480px){.add-transaction-modal{margin:1rem;max-width:none}.add-transaction-modal-header{padding:1.5rem 1.5rem 1rem}.add-transaction-form-grid{padding:0 1.5rem 1.5rem;grid-template-columns:1fr}.add-transaction-modal-actions{padding:0 1.5rem 1.5rem;flex-direction:column}.add-transaction-modal-actions .btn{width:100%}}.add-goal-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.add-goal-modal{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:480px;width:100%;position:relative;animation:add-goal-modal-appear .2s ease-out}@keyframes add-goal-modal-appear{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.add-goal-close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;padding:.5rem;color:var(--text-muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease}.add-goal-close-btn:hover{background:var(--menu-hover);color:var(--text-color)}.add-goal-modal-header{padding:2rem 2rem 1rem;text-align:center}.add-goal-icon{width:56px;height:56px;border-radius:50%;background:var(--primary-light, #e0f2fe);color:var(--primary-color, #0ea5e9);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.add-goal-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.add-goal-form{padding:0}.add-goal-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:0 2rem 1.5rem;text-align:center}.add-goal-form-grid .full-width{grid-column:1 / -1}.add-goal-modal-actions{display:flex;gap:.75rem;padding:0 2rem 2rem}.add-goal-modal-actions .btn{flex:1}@media(max-width:768px){.add-goal-modal-overlay .add-goal-modal{width:95vw;max-width:none;max-height:85vh;margin:auto;overflow-y:auto;display:flex;flex-direction:column}.add-goal-close-btn{min-width:44px;min-height:30px}.add-goal-modal-actions .btn{min-height:30px;font-size:1rem}}@media(max-width:480px){.add-goal-modal{margin:1rem;max-width:none}.add-goal-modal-header{padding:1.5rem 1.5rem 1rem}.add-goal-form-grid{padding:0 1.5rem 1.5rem;grid-template-columns:1fr}.add-goal-modal-actions{padding:0 1.5rem 1.5rem;flex-direction:column}.add-goal-modal-actions .btn{width:100%}}.add-project-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.add-project-modal{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:480px;width:100%;position:relative;animation:add-project-modal-appear .2s ease-out}@keyframes add-project-modal-appear{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.add-project-close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;padding:.5rem;color:var(--text-muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease}.add-project-close-btn:hover{background:var(--menu-hover);color:var(--text-color)}.add-project-modal-header{padding:2rem 2rem 1rem;text-align:center}.add-project-icon{width:56px;height:56px;border-radius:50%;background:var(--primary-light, #e0f2fe);color:var(--primary-color, #0ea5e9);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.add-project-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.add-project-form{padding:0}.add-project-form-grid{display:grid;grid-template-columns:1fr;gap:1rem;padding:0 2rem 1.5rem;text-align:center}.add-project-form-grid .full-width{grid-column:1 / -1}.add-project-textarea{min-height:80px;resize:vertical;line-height:1.5}.add-project-modal-actions{display:flex;gap:.75rem;padding:0 2rem 2rem}.add-project-modal-actions .btn{flex:1}@media(max-width:768px){.add-project-modal-overlay .add-project-modal{width:95vw;max-width:none;max-height:85vh;margin:auto;overflow-y:auto;display:flex;flex-direction:column}.add-project-close-btn{min-width:44px;min-height:30px}.add-project-modal-actions .btn{min-height:30px;font-size:1rem}}@media(max-width:480px){.add-project-modal{margin:1rem;max-width:none}.add-project-modal-header{padding:1.5rem 1.5rem 1rem}.add-project-form-grid{padding:0 1.5rem 1.5rem}.add-project-modal-actions{padding:0 1.5rem 1.5rem;flex-direction:column}.add-project-modal-actions .btn{width:100%}}.accept-invitation-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-color) 0%,var(--primary-light) 100%);padding:1rem}.accept-invitation-card{width:100%;max-width:420px;background:var(--card-bg);border-radius:var(--radius-lg, 16px);box-shadow:var(--shadow-lg);padding:2.5rem}.accept-invitation-header{text-align:center;margin-bottom:2rem}.accept-invitation-icon{width:80px;height:80px;margin:0 auto 1.5rem;background:var(--primary-light);border-radius:var(--radius-lg, 20px);display:flex;align-items:center;justify-content:center;color:var(--secondary-color)}.accept-invitation-icon--welcome{width:auto;height:auto;background:transparent}.accept-invitation-icon--error{background:#f443361a;color:var(--error-color)}.accept-invitation-icon--success{background:#4caf501a;color:var(--success-color)}.accept-invitation-title{font-size:1.75rem;font-weight:700;color:var(--text-color);margin-bottom:.5rem}.accept-invitation-subtitle{font-size:1rem;color:var(--text-muted);line-height:1.5}.accept-invitation-subtitle--error{color:var(--error-color)}.accept-invitation-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 0;color:var(--text-muted)}.accept-invitation-content{margin-bottom:2rem}.accept-invitation-message{text-align:center;color:var(--text-muted);line-height:1.6;margin-bottom:1rem}.accept-invitation-owner{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--ghost-hover);border-radius:var(--radius-md, 12px);margin-bottom:1.5rem}.accept-invitation-avatar{width:48px;height:48px;border-radius:var(--radius-full, 50%);background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;flex-shrink:0}.accept-invitation-avatar--large{width:72px;height:72px;font-size:2rem;box-shadow:0 4px 12px #2196f34d}.accept-invitation-owner-info{flex:1;min-width:0}.accept-invitation-owner-text{color:var(--text-color);line-height:1.5;margin:0}.accept-invitation-owner-text strong{color:var(--text-color);font-weight:600}.accept-invitation-permission{text-align:center;padding:1.25rem;background:var(--ghost-hover);border-radius:var(--radius-md, 12px);margin-bottom:1rem}.accept-invitation-permission--centered{padding:1rem;margin-bottom:1.5rem}.accept-invitation-welcome-text{text-align:center;color:var(--text-muted);font-size:.938rem;line-height:1.6;margin:0}.accept-invitation-setup-notice{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#2196f314;border:1px solid rgba(33,150,243,.2);border-radius:var(--radius-md, 12px);margin-bottom:1.5rem;color:var(--secondary-color)}.accept-invitation-setup-notice svg{flex-shrink:0;margin-top:.125rem}.accept-invitation-setup-notice p{margin:0;font-size:.938rem;line-height:1.5;color:var(--text-color)}.permission-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius-full, 100px);font-size:.938rem;font-weight:600;margin-bottom:.75rem}.permission-badge--full{background:#2196f326;color:var(--secondary-color)}.permission-description{font-size:.875rem;color:var(--text-muted);margin:0;line-height:1.5}.accept-invitation-expiry{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:#ff98001a;border-radius:var(--radius-md, 8px);color:var(--warning-color, #f57c00);font-size:.875rem}.accept-invitation-actions{display:flex;flex-direction:column;gap:.75rem}.accept-invitation-primary-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:var(--primary-color);border:none;border-radius:var(--radius-lg, 12px);cursor:pointer;transition:all var(--transition-fast, .15s ease);text-decoration:none}.accept-invitation-primary-btn:hover{background:var(--primary-hover);box-shadow:0 4px 12px #2196f34d}.accept-invitation-primary-btn:active{transform:scale(.98)}.accept-invitation-secondary-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:500;color:var(--text-muted);background:transparent;border:2px solid var(--input-border);border-radius:var(--radius-lg, 12px);cursor:pointer;transition:all var(--transition-fast, .15s ease);text-decoration:none}.accept-invitation-secondary-btn:hover{color:var(--text-color);border-color:var(--text-muted);background:var(--ghost-hover)}.accept-invitation-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color);text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.accept-invitation-footer-text{font-size:.813rem;color:var(--text-muted);line-height:1.5;margin:0}.accept-invitation-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.875rem;text-decoration:none;transition:color var(--transition-fast, .15s ease)}.accept-invitation-link:hover{color:var(--secondary-color)}@media(max-width:480px){.accept-invitation-card{padding:1.5rem;border-radius:var(--radius-lg, 12px)}.accept-invitation-icon{width:64px;height:64px;border-radius:var(--radius-lg, 16px)}.accept-invitation-icon svg{width:36px;height:36px}.accept-invitation-title{font-size:1.5rem}.accept-invitation-owner{flex-direction:column;text-align:center}}.setup-wizard{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.setup-wizard__container{width:100%;max-width:520px;background:#fff;padding:2.5rem;border-radius:16px;box-shadow:0 10px 40px #0003}.setup-wizard__progress{display:flex;align-items:center;justify-content:center;margin-bottom:2rem;gap:0}.progress-dot{width:12px;height:12px;border-radius:50%;background:#e0e0e0;transition:all .3s ease}.progress-dot.active{background:#667eea;box-shadow:0 0 0 4px #667eea33}.progress-dot.completed{background:#4caf50}.progress-line{width:40px;height:2px;background:#e0e0e0}.wizard-step{text-align:center}.welcome-step__icon{margin-bottom:1rem}.welcome-step__emoji{font-size:4rem}.welcome-step__title{font-size:1.75rem;font-weight:700;color:#1a1a2e;margin-bottom:.75rem}.welcome-step__subtitle{color:#666;font-size:1rem;line-height:1.6;margin-bottom:2rem}.welcome-step__requirements{text-align:left;background:#f8f9fa;padding:1.25rem 1.5rem;border-radius:12px;margin-bottom:1.5rem}.welcome-step__requirements h2{font-size:.9rem;font-weight:600;color:#333;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.welcome-step__requirements ul{list-style:none;padding:0;margin:0}.welcome-step__requirements li{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;color:#555;font-size:.95rem}.welcome-step__requirements li svg{color:#667eea;flex-shrink:0}.welcome-step__actions{margin-bottom:1.5rem}.welcome-step__link{display:inline-flex;align-items:center;gap:.5rem;color:#667eea;text-decoration:none;font-size:.9rem;transition:color .2s}.welcome-step__link:hover{color:#5a6fd6;text-decoration:underline}.welcome-step__env-hint{margin-top:1.5rem;font-size:.85rem;color:#888}.welcome-step__env-hint code{background:#f0f0f0;padding:.15rem .4rem;border-radius:4px;font-family:monospace}.welcome-step__env-link{color:#667eea;text-decoration:none}.welcome-step__env-link:hover{text-decoration:underline}.wizard-button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;width:100%}.wizard-button--primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.wizard-button--primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.wizard-button--secondary{background:#f0f0f0;color:#333}.wizard-button--secondary:hover{background:#e0e0e0}.wizard-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.credentials-step__title{font-size:1.5rem;font-weight:700;color:#1a1a2e;margin-bottom:.5rem}.credentials-step__subtitle{color:#666;margin-bottom:1.5rem}.credentials-step__form{text-align:left}.form-group{margin-bottom:1.25rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem;color:#333;margin-bottom:.5rem}.help-button{background:none;border:none;color:#888;cursor:pointer;padding:0;display:flex;align-items:center}.help-button:hover{color:#667eea}.form-group input{width:100%;padding:.75rem 1rem;font-size:.95rem;border:2px solid #e0e0e0;border-radius:8px;transition:border-color .2s,box-shadow .2s;font-family:inherit;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.input-error{border-color:#ef4444}.form-group input::placeholder{color:#aaa}.error-text{display:block;color:#ef4444;font-size:.8rem;margin-top:.4rem}.credentials-step__help{background:#f0f7ff;border:1px solid #bdd8ff;border-radius:8px;padding:1rem 1.25rem;margin-bottom:1.25rem;text-align:left}.credentials-step__help h4{font-size:.9rem;font-weight:600;color:#1a56db;margin-bottom:.75rem}.credentials-step__help ol{margin:0;padding-left:1.25rem;color:#444;font-size:.85rem;line-height:1.6}.credentials-step__help strong{color:#1a56db}.validation-result{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;margin-top:1rem;font-size:.9rem;font-weight:500}.validation-result--success{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0}.validation-result--error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.wizard-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:1.5rem}.wizard-nav .wizard-button{flex:1}.spin{animation:spin 1s linear infinite}.validation-step__title{font-size:1.5rem;font-weight:700;color:#1a1a2e;margin-bottom:.5rem}.validation-step__loading{padding:2rem 0;display:flex;flex-direction:column;align-items:center;gap:1rem}.validation-step__spinner{color:#667eea}.validation-step__loading-text{color:#666;font-size:1rem}.validation-step__status{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;border-radius:12px;margin-bottom:1.5rem}.validation-step__status--success{background:#ecfdf5;border:1px solid #a7f3d0}.validation-step__status--info{background:#eff6ff;border:1px solid #bfdbfe}.validation-step__status--error{background:#fef2f2;border:1px solid #fecaca}.validation-step__icon{margin-bottom:.25rem}.validation-step__icon--success{color:#059669}.validation-step__icon--info{color:#3b82f6}.validation-step__icon--error{color:#dc2626}.validation-step__description{color:#555;line-height:1.6;margin:0}.validation-step__reconfigure{margin-top:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px;font-size:.9rem;color:#666}.validation-step__reconfigure p{margin:0 0 .25rem}.validation-step__link{background:none;border:none;color:#667eea;font-size:.9rem;font-weight:600;cursor:pointer;padding:0;text-decoration:underline}.validation-step__link:hover{color:#5a6fd6}.validation-step__hint{color:#888;font-size:.85rem;margin-left:.25rem}.wizard-nav--single{justify-content:flex-start}.wizard-nav--single .wizard-button{flex:none;width:auto}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:16px;padding:2rem;max-width:400px;width:100%;text-align:center;box-shadow:0 10px 40px #0000004d}.modal__icon{margin-bottom:1rem}.modal__icon--warning{color:#f59e0b}.modal__title{font-size:1.25rem;font-weight:700;color:#1a1a2e;margin:0 0 .75rem}.modal__description{color:#555;margin:0 0 1rem;line-height:1.6}.modal__note{background:#fffbeb;border:1px solid #fde68a;padding:.75rem 1rem;border-radius:8px;font-size:.85rem;color:#92400e;margin-bottom:1.5rem}.modal__note strong{color:#78350f}.modal__actions{display:flex;gap:1rem}.modal__actions .wizard-button{flex:1}.migration-step{text-align:left}.migration-step__header{display:flex;align-items:center;gap:.75rem;justify-content:center;margin-bottom:.75rem}.migration-step__icon{color:#667eea}.migration-step__title{font-size:1.5rem;font-weight:700;color:#1a1a2e;margin:0}.migration-step__instructions{text-align:center;margin-bottom:1.5rem}.migration-step__instructions p{color:#555;margin:0 0 1rem;line-height:1.5}.migration-step__sql-link{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:8px;text-decoration:none;font-size:.9rem;font-weight:600;transition:all var(--transition-fast, .15s ease)}.migration-step__sql-link:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.migration-step__actions{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding:.5rem 0}.migration-step__check-all-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;font-size:.85rem;font-weight:500;border:1px solid #667eea;border-radius:6px;background:transparent;color:#667eea;cursor:pointer;transition:all .2s}.migration-step__check-all-btn:hover{background:#667eea;color:#fff}.migration-step__progress{font-size:.85rem;color:#666;font-weight:500}.migration-step__list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.migration-card{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:12px;padding:1rem 1.25rem;transition:border-color .2s,background .2s}.migration-card--completed{border-color:#4caf50;background:#f0fdf4}.migration-card__header{margin-bottom:.5rem}.migration-card__checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:600;color:#1a1a2e}.migration-card__checkbox{position:absolute;opacity:0;cursor:pointer}.migration-card__checkbox-custom{width:22px;height:22px;border:2px solid #ccc;border-radius:6px;background:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;position:relative}.migration-card__checkbox:checked+.migration-card__checkbox-custom{background:#4caf50;border-color:#4caf50}.migration-card__checkbox:checked+.migration-card__checkbox-custom:after{content:"";width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg);position:absolute;top:3px}.migration-card__checkbox:focus+.migration-card__checkbox-custom{box-shadow:0 0 0 3px #667eea33}.migration-card__title{font-size:.95rem}.migration-card__description{color:#666;font-size:.85rem;margin:0 0 .75rem;line-height:1.5;padding-left:2.375rem}.migration-card__copy-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .75rem;font-size:.8rem;font-weight:600;border:1px solid #ccc;border-radius:6px;background:#fff;color:#555;cursor:pointer;transition:all .2s;margin-left:2.375rem}.migration-card__copy-btn:hover{border-color:#667eea;color:#667eea;background:#f0f4ff}.migration-card__copy-btn--copied{border-color:#4caf50;color:#4caf50;background:#f0fdf4}.verification-overlay{background:#fffffffa;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:2px solid #e0e0e0}.verification-panel{display:flex;flex-direction:column;align-items:center;text-align:center}.verification-panel--loading{padding:1rem 0}.verification-panel--success{padding:1.5rem 0}.verification-panel--warning{padding:1rem 0}.verification-panel__spinner{color:#667eea;margin-bottom:.75rem}.verification-panel__icon{margin-bottom:1rem}.verification-panel__icon--success{color:#059669}.verification-panel__icon--warning{color:#f59e0b}.verification-panel__title{font-size:1.1rem;font-weight:600;color:#1a1a2e;margin:0 0 .5rem}.verification-panel__subtitle{font-size:.9rem;color:#666;margin:0}.verification-progress{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1rem;max-width:100%}.verification-progress__item{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;padding:.25rem .5rem;background:#f0f0f0;border-radius:4px;color:#888;font-family:monospace}.verification-progress__item--checked{background:#ecfdf5;color:#059669}.verification-progress__item--current{background:#eff6ff;color:#3b82f6;font-weight:600}.verification-tables{text-align:left;width:100%;margin:1rem 0;padding:1rem;background:#f8f9fa;border-radius:8px}.verification-tables__section{margin-bottom:.75rem}.verification-tables__section:last-child{margin-bottom:0}.verification-tables__label{display:block;font-size:.8rem;font-weight:600;color:#555;margin-bottom:.25rem}.verification-tables__list{display:block;font-size:.85rem;font-family:monospace;word-break:break-word;line-height:1.5}.verification-tables__list--found{color:#059669}.verification-tables__list--missing{color:#dc2626}.verification-hint{background:#fffbeb;border:1px solid #fde68a;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;text-align:center}.verification-hint p{font-size:.9rem;color:#92400e;margin:0}.verification-hint strong{color:#78350f}.completion-step{text-align:center}.completion-step__icon{color:var(--color-success, #22c55e);margin-bottom:1.5rem;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.completion-step__title{font-size:1.75rem;font-weight:600;margin-bottom:.5rem}.completion-step__summary{color:var(--color-text-secondary, #64748b);margin-bottom:2rem}.completion-step__summary strong{color:var(--color-text-primary, #1e293b);font-family:monospace}.completion-step__actions{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.completion-step__actions .wizard-button{flex:1}.completion-step__info{text-align:left;background:var(--color-bg-secondary, #f8fafc);border-radius:.75rem;padding:1.5rem}.completion-step__info h4{margin-bottom:.75rem;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary, #64748b)}.completion-step__info ul{list-style:none;padding:0;margin:0}.completion-step__info li{padding:.5rem 0;font-size:.9rem;line-height:1.5}.completion-step__info li+li{border-top:1px solid var(--color-border, #e2e8f0)}.completion-step__info code{background:var(--color-bg-tertiary, #e2e8f0);padding:.125rem .375rem;border-radius:.25rem;font-size:.85em}.completion-step__info a{color:var(--color-primary, #3b82f6);text-decoration:none;display:inline-flex;align-items:center;gap:.25rem}.completion-step__info a:hover{text-decoration:underline}.connection-error{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fef3c7,#fde68a);padding:2rem}.connection-error__container{background:#fff;padding:2.5rem;border-radius:1rem;text-align:center;max-width:400px;width:100%;box-shadow:0 4px 20px #0000001a}.connection-error__icon{color:#f59e0b;margin-bottom:1.5rem}.connection-error__title{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;color:#1e293b}.connection-error__description{color:#64748b;margin-bottom:2rem;line-height:1.5}.connection-error__actions{display:flex;gap:1rem;justify-content:center;margin-bottom:1.5rem}.connection-error__button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.connection-error__button--primary{background:#3b82f6;color:#fff}.connection-error__button--primary:hover:not(:disabled){background:#2563eb}.connection-error__button--primary:disabled{opacity:.7;cursor:not-allowed}.connection-error__button--secondary{background:#e2e8f0;color:#475569}.connection-error__button--secondary:hover{background:#cbd5e1}.connection-error__clear{display:inline-flex;align-items:center;gap:.25rem;background:none;border:none;color:#94a3b8;font-size:.875rem;cursor:pointer;padding:.5rem}.connection-error__clear:hover{color:#64748b}.dark-theme .setup-wizard__container{background:var(--card-bg, #1e293b);box-shadow:0 10px 40px #0006}.dark-theme .welcome-step__title,.dark-theme .credentials-step__title,.dark-theme .validation-step__title,.dark-theme .migration-step__title,.dark-theme .completion-step__title,.dark-theme .modal__title,.dark-theme .verification-panel__title{color:var(--text-color, #f1f5f9)}.dark-theme .welcome-step__subtitle,.dark-theme .credentials-step__subtitle,.dark-theme .validation-step__description,.dark-theme .modal__description,.dark-theme .verification-panel__subtitle,.dark-theme .migration-step__instructions p{color:var(--text-muted, #94a3b8)}.dark-theme .welcome-step__requirements{background:var(--secondary-bg, #334155)}.dark-theme .welcome-step__requirements h2{color:var(--text-color, #f1f5f9)}.dark-theme .welcome-step__requirements li,.dark-theme .welcome-step__env-hint{color:var(--text-muted, #94a3b8)}.dark-theme .welcome-step__env-hint code{background:var(--secondary-bg, #334155);color:var(--text-color, #f1f5f9)}.dark-theme .form-group label{color:var(--text-color, #f1f5f9)}.dark-theme .form-group input{background:var(--input-bg, #334155);border-color:var(--input-border, #475569);color:var(--text-color, #f1f5f9)}.dark-theme .form-group input:focus{border-color:var(--primary-color, #667eea);box-shadow:0 0 0 3px #667eea33}.dark-theme .form-group input::placeholder{color:var(--text-placeholder, #64748b)}.dark-theme .credentials-step__help{background:#667eea1a;border-color:#667eea4d}.dark-theme .credentials-step__help h4{color:#93a8f4}.dark-theme .credentials-step__help ol{color:var(--text-muted, #94a3b8)}.dark-theme .credentials-step__help strong{color:#93a8f4}.dark-theme .help-button{color:var(--text-muted, #94a3b8)}.dark-theme .help-button:hover{color:var(--primary-color, #667eea)}.dark-theme .progress-dot,.dark-theme .progress-line{background:var(--secondary-bg, #334155)}.dark-theme .wizard-button--secondary{background:var(--secondary-bg, #334155);color:var(--text-color, #f1f5f9)}.dark-theme .wizard-button--secondary:hover{background:var(--secondary-hover, #475569)}.dark-theme .modal{background:var(--card-bg, #1e293b);box-shadow:0 10px 40px #00000080}.dark-theme .modal__note{background:#f59e0b26;border-color:#f59e0b4d;color:#fbbf24}.dark-theme .modal__note strong{color:#fcd34d}.dark-theme .migration-card{background:var(--secondary-bg, #334155);border-color:var(--border-color, #475569)}.dark-theme .migration-card--completed{border-color:#4caf50;background:#4caf501a}.dark-theme .migration-card__checkbox-label{color:var(--text-color, #f1f5f9)}.dark-theme .migration-card__description{color:var(--text-muted, #94a3b8)}.dark-theme .migration-card__checkbox-custom{border-color:var(--border-color, #475569);background:var(--input-bg, #334155)}.dark-theme .migration-card__copy-btn{border-color:var(--border-color, #475569);background:var(--card-bg, #1e293b);color:var(--text-muted, #94a3b8)}.dark-theme .migration-card__copy-btn:hover{border-color:var(--primary-color, #667eea);color:var(--primary-color, #667eea);background:#667eea1a}.dark-theme .verification-overlay{background:var(--card-bg, #1e293b);border-color:var(--border-color, #475569)}.dark-theme .verification-tables{background:var(--secondary-bg, #334155)}.dark-theme .verification-tables__label{color:var(--text-muted, #94a3b8)}.dark-theme .verification-hint{background:#f59e0b26;border-color:#f59e0b4d}.dark-theme .verification-hint p{color:#fbbf24}.dark-theme .verification-hint strong{color:#fcd34d}.dark-theme .verification-progress__item{background:var(--secondary-bg, #334155);color:var(--text-muted, #94a3b8)}.dark-theme .verification-progress__item--checked{background:#05966926;color:#34d399}.dark-theme .verification-progress__item--current{background:#3b82f626;color:#60a5fa}.dark-theme .completion-step__info{background:var(--secondary-bg, #334155)}.dark-theme .completion-step__info h4{color:var(--text-muted, #94a3b8)}.dark-theme .completion-step__info li{color:var(--text-color, #f1f5f9)}.dark-theme .completion-step__info li+li{border-color:var(--border-color, #475569)}.dark-theme .completion-step__info code{background:var(--card-bg, #1e293b);color:var(--text-color, #f1f5f9)}.dark-theme .completion-step__summary{color:var(--text-muted, #94a3b8)}.dark-theme .completion-step__summary strong{color:var(--text-color, #f1f5f9)}.completion-step__invite-notice{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:#2196f31a;border:1px solid rgba(33,150,243,.25);border-radius:8px;margin-bottom:1.5rem;color:var(--primary-color, #3b82f6)}.completion-step__invite-notice svg{flex-shrink:0}.completion-step__invite-notice p{margin:0;font-size:.9rem}.dark-theme .completion-step__invite-notice{background:#2196f326;border-color:#2196f34d}.edge-functions-step{text-align:left}.edge-functions-step__header{display:flex;align-items:center;gap:.75rem;justify-content:center;margin-bottom:.75rem}.edge-functions-step__icon{color:#667eea}.edge-functions-step__title{font-size:1.5rem;font-weight:700;color:#1a1a2e;margin:0}.edge-functions-step__description{text-align:center;margin-bottom:1.5rem}.edge-functions-step__description p{color:#555;margin:0;line-height:1.5}.edge-functions-step__commands{display:flex;flex-direction:column;border:1px solid #e0e0e0;border-radius:12px;overflow:hidden;margin-bottom:1.5rem}.command-card{padding:.875rem 1rem;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.command-card:last-child{border-bottom:none}.command-card__header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.command-card__step{font-weight:600;color:#667eea}.command-card__title{font-weight:500;color:#333;font-size:.9rem}.command-card__body{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.command-card__code{flex:1;font-family:SF Mono,Monaco,Consolas,monospace;font-size:.85rem;color:#1a1a2e;background:#fff;padding:.5rem .75rem;border-radius:6px;border:1px solid #e0e0e0;overflow-x:auto;white-space:nowrap}.command-card__copy-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .6rem;font-size:.75rem;font-weight:600;border:1px solid #ccc;border-radius:6px;background:#fff;color:#555;cursor:pointer;transition:all .2s;flex-shrink:0}.command-card__copy-btn:hover{border-color:#667eea;color:#667eea;background:#f0f4ff}.command-card__copy-btn--copied{border-color:#4caf50;color:#4caf50;background:#f0fdf4}.edge-functions-step__checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:500;color:#1a1a2e;margin-bottom:1rem;padding:.75rem 1rem;background:#f8f9fa;border-radius:8px;border:2px solid #e0e0e0;transition:border-color .2s,background .2s}.edge-functions-step__checkbox-label:has(.edge-functions-step__checkbox:checked){border-color:#4caf50;background:#f0fdf4}.edge-functions-step__checkbox{position:absolute;opacity:0;cursor:pointer}.edge-functions-step__checkbox-custom{width:22px;height:22px;border:2px solid #ccc;border-radius:6px;background:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;position:relative}.edge-functions-step__checkbox:checked+.edge-functions-step__checkbox-custom{background:#4caf50;border-color:#4caf50}.edge-functions-step__checkbox:checked+.edge-functions-step__checkbox-custom:after{content:"";width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg);position:absolute;top:3px}.edge-functions-step__checkbox:focus+.edge-functions-step__checkbox-custom{box-shadow:0 0 0 3px #667eea33}.edge-functions-step__method-toggle{display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.25rem;background:#f0f0f0;border-radius:8px}.method-toggle-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:500;border:none;border-radius:6px;background:transparent;color:#666;cursor:pointer;transition:all .2s}.method-toggle-btn:hover{color:#333}.method-toggle-btn--active{background:#fff;color:#667eea;box-shadow:0 2px 4px #0000001a}.edge-functions-step__dashboard-method{margin-bottom:1.5rem}.dashboard-instructions{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:12px;padding:1rem 1.25rem;margin-bottom:1rem}.dashboard-instructions__intro{font-weight:500;color:#333;margin:0 0 .75rem}.dashboard-instructions__steps{margin:0;padding-left:1.25rem;color:#555;line-height:1.8}.dashboard-instructions__steps a{display:inline-flex;align-items:center;gap:.35rem;color:#667eea;text-decoration:none;font-weight:500}.dashboard-instructions__steps a:hover{text-decoration:underline}.dashboard-instructions__steps code{background:#e8e8e8;padding:.125rem .375rem;border-radius:4px;font-size:.85em}.dashboard-instructions__steps .jwt-warning{color:#dc2626}.dashboard-instructions__steps .jwt-warning-note{display:block;font-size:.85em;color:#666;margin-top:.25rem}.edge-functions-list{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:12px;padding:1rem}.edge-functions-list h4{margin:0 0 .75rem;font-size:.85rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.05em}.edge-function-card{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.75rem;background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:.5rem}.edge-function-card:last-child{margin-bottom:0}.edge-function-card__info{display:flex;flex-direction:column;gap:.125rem}.edge-function-card__name{font-weight:600;color:#1a1a2e}.edge-function-card__description{font-size:.8125rem;color:#666}.edge-function-card__details{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;flex-shrink:0}.edge-function-card__id{font-family:SF Mono,Monaco,Consolas,monospace;font-size:.8rem;color:#667eea;background:#f0f4ff;padding:.125rem .5rem;border-radius:4px}.edge-function-card__path{font-size:.75rem;color:#888}.edge-function-card__path-btn{display:inline-flex;align-items:center;gap:.35rem;font-size:.75rem;color:#667eea;background:none;border:none;padding:.125rem 0;cursor:pointer;font-family:SF Mono,Monaco,Consolas,monospace;transition:color .2s}.edge-function-card__path-btn:hover{color:#5a6fd6;text-decoration:underline}.code-viewer-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.code-viewer-modal{background:#fff;border-radius:12px;width:100%;max-width:800px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.code-viewer-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e0e0e0;flex-shrink:0}.code-viewer-modal__title{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#1a1a2e}.code-viewer-modal__title code{font-size:.8rem;color:#667eea;background:#f0f4ff;padding:.125rem .5rem;border-radius:4px;font-weight:500}.code-viewer-modal__actions{display:flex;align-items:center;gap:.5rem}.code-viewer-modal__copy-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem .75rem;font-size:.8rem;font-weight:500;border:1px solid #667eea;border-radius:6px;background:#667eea;color:#fff;cursor:pointer;transition:all .2s}.code-viewer-modal__copy-btn:hover{background:#5a6fd6}.code-viewer-modal__copy-btn--copied{background:#4caf50;border-color:#4caf50}.code-viewer-modal__close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:transparent;color:#666;cursor:pointer;transition:background .2s,color .2s}.code-viewer-modal__close-btn:hover{background:#f0f0f0;color:#333}.code-viewer-modal__content{flex:1;overflow:auto;padding:0}.code-viewer-modal__code{margin:0;padding:1rem 1.25rem;font-family:SF Mono,Monaco,Consolas,monospace;font-size:.8rem;line-height:1.6;background:#1e1e1e;color:#d4d4d4;white-space:pre;overflow-x:auto;min-height:100%}.edge-functions-step__cli-method{margin-bottom:1.5rem}.cli-commands{display:flex;flex-direction:column;border:1px solid #e0e0e0;border-radius:12px;overflow:hidden}.edge-functions-step__warning{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem 1rem;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;margin-bottom:1.5rem;font-size:.85rem;color:#92400e}.edge-functions-step__warning svg{flex-shrink:0;margin-top:.1rem;color:#f59e0b}.dark-theme .edge-functions-step__title{color:var(--text-color, #f1f5f9)}.dark-theme .edge-functions-step__description p{color:var(--text-muted, #94a3b8)}.dark-theme .edge-functions-step__commands{border-color:var(--border-color, #475569)}.dark-theme .command-card{background:var(--secondary-bg, #334155);border-color:var(--border-color, #475569)}.dark-theme .command-card__step{color:#93a8f4}.dark-theme .command-card__title{color:var(--text-color, #f1f5f9)}.dark-theme .command-card__code{background:var(--card-bg, #1e293b);border-color:var(--border-color, #475569);color:var(--text-color, #f1f5f9)}.dark-theme .command-card__copy-btn{border-color:var(--border-color, #475569);background:var(--card-bg, #1e293b);color:var(--text-muted, #94a3b8)}.dark-theme .command-card__copy-btn:hover{border-color:var(--primary-color, #667eea);color:var(--primary-color, #667eea);background:#667eea1a}.dark-theme .edge-functions-step__checkbox-label{background:var(--secondary-bg, #334155);border-color:var(--border-color, #475569);color:var(--text-color, #f1f5f9)}.dark-theme .edge-functions-step__checkbox-label:has(.edge-functions-step__checkbox:checked){border-color:#4caf50;background:#4caf501a}.dark-theme .edge-functions-step__checkbox-custom{border-color:var(--border-color, #475569);background:var(--input-bg, #334155)}.dark-theme .edge-functions-step__warning{background:#f59e0b26;border-color:#f59e0b4d;color:#fbbf24}.dark-theme .edge-functions-step__warning svg{color:#fbbf24}.dark-theme .edge-functions-step__method-toggle{background:var(--secondary-bg, #334155)}.dark-theme .method-toggle-btn{color:var(--text-muted, #94a3b8)}.dark-theme .method-toggle-btn:hover{color:var(--text-color, #f1f5f9)}.dark-theme .method-toggle-btn--active{background:var(--card-bg, #1e293b);color:var(--primary-color, #667eea)}.dark-theme .dashboard-instructions{background:var(--secondary-bg, #334155);border-color:var(--border-color, #475569)}.dark-theme .dashboard-instructions__intro{color:var(--text-color, #f1f5f9)}.dark-theme .dashboard-instructions__steps{color:var(--text-muted, #94a3b8)}.dark-theme .dashboard-instructions__steps code{background:var(--card-bg, #1e293b);color:var(--text-color, #f1f5f9)}.dark-theme .dashboard-instructions__steps .jwt-warning{color:#f87171}.dark-theme .dashboard-instructions__steps .jwt-warning-note{color:var(--text-muted, #94a3b8)}.dark-theme .edge-functions-list{background:var(--secondary-bg, #334155);border-color:var(--border-color, #475569)}.dark-theme .edge-functions-list h4{color:var(--text-muted, #94a3b8)}.dark-theme .edge-function-card{background:var(--card-bg, #1e293b);border-color:var(--border-color, #475569)}.dark-theme .edge-function-card__name{color:var(--text-color, #f1f5f9)}.dark-theme .edge-function-card__description{color:var(--text-muted, #94a3b8)}.dark-theme .edge-function-card__id{background:#667eea26;color:#93a8f4}.dark-theme .edge-function-card__path{color:var(--text-muted, #94a3b8)}.dark-theme .cli-commands{border-color:var(--border-color, #475569)}.dark-theme .edge-function-card__path-btn{color:#93a8f4}.dark-theme .edge-function-card__path-btn:hover{color:#a8b8f8}.dark-theme .code-viewer-modal{background:var(--card-bg, #1e293b);box-shadow:0 20px 60px #00000080}.dark-theme .code-viewer-modal__header{border-color:var(--border-color, #475569)}.dark-theme .code-viewer-modal__title{color:var(--text-color, #f1f5f9)}.dark-theme .code-viewer-modal__title code{background:#667eea26;color:#93a8f4}.dark-theme .code-viewer-modal__close-btn{color:var(--text-muted, #94a3b8)}.dark-theme .code-viewer-modal__close-btn:hover{background:var(--secondary-bg, #334155);color:var(--text-color, #f1f5f9)}.dark-theme .migration-step__check-all-btn{border-color:#93a8f4;color:#93a8f4}.dark-theme .migration-step__check-all-btn:hover{background:#93a8f4;color:#1e293b}.dark-theme .migration-step__progress{color:var(--text-muted, #94a3b8)}.dashboard{padding:1.5rem;max-width:1200px;margin:0 auto}.dashboard__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem}.dashboard__header h1{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-color)}.dashboard__today{display:flex;flex-direction:column;align-items:flex-end;gap:0;line-height:1;padding-right:.25rem}.dashboard__today-weekday{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--primary-color)}.dashboard__today-day{font-size:2rem;font-weight:700;color:var(--text-color);line-height:1.1}.dashboard__today-monthyear{font-size:.6875rem;color:var(--text-muted);font-weight:500}.dashboard__kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4, 1rem);margin-bottom:var(--space-6, 1.5rem)}.dashboard__kpi-card{display:flex;align-items:flex-start;gap:.875rem;padding:var(--space-5, 1.25rem);background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm);transition:all var(--transition-fast, .15s ease)}.dashboard__kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.dashboard__kpi-icon{width:40px;height:40px;border-radius:var(--radius-md, 8px);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dashboard__kpi-icon--income{background:none;color:var(--success-color)}.dashboard__kpi-icon--spent{background:none;color:var(--error-color)}.dashboard__kpi-icon--budget{background:none;color:var(--secondary-color)}.dashboard__kpi-icon--savings{background:none;color:var(--accent-color)}.dashboard__kpi-content{display:flex;flex-direction:column;gap:.25rem;min-width:0}.dashboard__kpi-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.dashboard__kpi-value{font-size:1.25rem;font-weight:700;color:var(--text-color)}.dashboard__kpi-value--negative{color:var(--error-color)}.dashboard__kpi-hint{font-size:.6875rem;color:var(--error-color);font-weight:500}.dashboard__trend{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:500;padding:.125rem .375rem;border-radius:var(--radius-sm, 4px)}.dashboard__trend--positive{background:var(--success-light, rgba(34, 197, 94, .1));color:var(--success-color)}.dashboard__trend--negative{background:var(--error-light, rgba(239, 68, 68, .1));color:var(--error-color)}.dashboard__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4, 1rem);align-items:start}.dashboard__section{display:flex;flex-direction:column;gap:var(--space-4, 1rem)}.dashboard__section--budget{align-self:stretch}.dashboard__section--budget .dashboard__card--overview{flex:1}.dashboard__section-title{margin:0 0 var(--space-3, .75rem) 0;font-size:var(--font-size-lg, 1.125rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.dashboard__card{background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm);padding:var(--space-6, 1.5rem);transition:all var(--transition-fast, .15s ease)}.dashboard__overview-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.dashboard__overview-row span:first-child{font-size:.875rem;color:var(--text-muted)}.dashboard__amount{font-size:.9375rem;font-weight:600;color:var(--text-color)}.dashboard__amount--positive{color:var(--success-color)}.dashboard__amount--negative{color:var(--error-color)}.dashboard__progress-section{margin-top:1rem}.dashboard__progress-section--top{margin-top:0;margin-bottom:.75rem}.dashboard__progress-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.5rem}.dashboard__quick-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3, .75rem)}.dashboard__stat-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-4, 1rem);background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm);text-align:center;transition:all var(--transition-fast, .15s ease)}.dashboard__stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.dashboard__stat-value{font-size:1.5rem;font-weight:700;color:var(--text-color)}.dashboard__stat-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-top:.25rem}.dashboard__card-title{margin:0 0 1rem;font-size:var(--font-size-lg, 1.125rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.dashboard__empty-text{margin:0;font-size:.875rem;color:var(--text-muted);text-align:center;padding:1rem 0}.dashboard__mini-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3, .75rem)}.dashboard__mini-card{text-align:center}.dashboard__mini-card .card-content{display:flex;flex-direction:column;align-items:center;gap:.375rem}.dashboard__mini-icon{color:var(--text-muted)}.dashboard__mini-icon--positive{color:var(--success-color)}.dashboard__mini-icon--negative{color:var(--error-color)}.dashboard__mini-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.dashboard__mini-value{font-size:1rem;font-weight:700;color:var(--text-color)}.dashboard__mini-value--positive{color:var(--success-color)}.dashboard__mini-value--negative{color:var(--error-color)}.dashboard__section--chart{grid-column:span 1}.dashboard__card--chart{min-height:380px}.dashboard__card--chart .card-content{padding:var(--space-4, 1rem)}.spending-chart{display:flex;flex-direction:column;gap:1rem}.spending-chart__container{position:relative;width:100%;height:250px}.spending-chart__legend{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.spending-chart__legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8125rem}.spending-chart__legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.spending-chart__legend-name{flex:1;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spending-chart__legend-amount{font-weight:600;color:var(--text-color);white-space:nowrap}.spending-chart__legend-percent{font-size:.75rem;color:var(--text-muted);width:45px;text-align:right}.chart-tooltip{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);padding:.75rem;box-shadow:var(--shadow-md)}.chart-tooltip__name{font-size:.8125rem;font-weight:600;color:var(--text-color);margin-bottom:.25rem}.chart-tooltip__amount{font-size:1rem;font-weight:700;color:var(--text-color)}.chart-tooltip__percentage{font-size:.75rem;color:var(--text-muted);margin-top:.125rem}.chart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.chart-empty__icon{color:var(--text-muted);opacity:.5;margin-bottom:1rem}.chart-empty__text{margin:0;font-size:.9375rem;font-weight:500;color:var(--text-color)}.chart-empty__subtext{margin:.5rem 0 0;font-size:.8125rem;color:var(--text-muted)}.dashboard__section--trend,.dashboard__section--family{grid-column:1 / -1}.spending-trend{display:flex;flex-direction:column;gap:.75rem}.spending-trend__legend{display:flex;justify-content:center;gap:1.5rem}.spending-trend__legend-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-muted)}.spending-trend__legend-line{display:inline-block;width:24px;height:2px}.spending-trend__legend-line--spending{background:var(--primary-color)}.spending-trend__legend-line--budget{background:repeating-linear-gradient(90deg,#94a3b8 0px,#94a3b8 5px,transparent 5px,transparent 10px)}.chart-tooltip__label{font-size:.8125rem;font-weight:600;color:var(--text-color);margin:0 0 .25rem}.chart-tooltip__value{font-size:.875rem;font-weight:500;color:var(--text-color);margin:.125rem 0}.chart-tooltip__value--muted{color:var(--text-muted);font-weight:400}@media(max-width:1024px){.dashboard__kpi-row{grid-template-columns:repeat(2,1fr)}.dashboard__mini-cards{grid-template-columns:1fr}}@media(max-width:768px){.dashboard{padding:1rem}.dashboard__header{flex-wrap:wrap;gap:.5rem}.dashboard__header h1{font-size:1.25rem}.dashboard__kpi-row{grid-template-columns:1fr;gap:.75rem}.dashboard__kpi-card{padding:1rem}.dashboard__kpi-icon{width:36px;height:36px}.dashboard__kpi-value{font-size:1.125rem}.dashboard__grid{grid-template-columns:1fr;gap:1rem}.dashboard__section--budget{grid-row:auto}.dashboard__quick-stats{grid-template-columns:repeat(2,1fr)}.dashboard__mini-cards{grid-template-columns:repeat(3,1fr);gap:.5rem}.dashboard__mini-card{padding:.75rem .5rem}.dashboard__mini-label{font-size:.625rem}.dashboard__mini-value{font-size:.875rem}.dashboard__section--chart{grid-column:span 1}.dashboard__card--chart{min-height:auto}.spending-chart__container{height:200px}.spending-chart__legend{max-height:150px}.spending-chart__legend-item{font-size:.75rem}.spending-chart__legend-percent{width:40px}}@media(max-width:400px){.dashboard{padding:.75rem}.dashboard__mini-cards{grid-template-columns:1fr}.dashboard__mini-card .card-content{flex-direction:row;justify-content:space-between;text-align:left}.dashboard__mini-label{order:1}.dashboard__mini-value{order:2}.dashboard__mini-icon{display:none}}.dashboard__year-glance{margin-top:var(--space-6, 1.5rem)}.year-glance{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4, 1rem);margin-top:var(--space-4, 1rem)}.year-glance__item{display:flex;flex-direction:column;align-items:center;padding:var(--space-4, 1rem);background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm);text-align:center;transition:all var(--transition-fast, .15s ease)}.year-glance__item:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.year-glance__label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.375rem}.year-glance__value{font-size:1.25rem;font-weight:700;color:var(--text-color)}.year-glance__value--positive{color:var(--success-color)}@media(max-width:768px){.year-glance{grid-template-columns:repeat(2,1fr)}}@media(max-width:400px){.year-glance{grid-template-columns:1fr}}.budget-page{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem;min-height:100%;max-width:1200px;margin:0 auto}.budget-categories{display:flex;flex-direction:column;overflow:hidden}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:0}.section-header h1{margin:0;font-size:var(--font-size-2xl, 1.5rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.section-header-actions{display:flex;gap:.5rem;align-items:center}.section-header-actions>*{min-width:143px;text-align:center;justify-content:center}.budget-income-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:var(--space-4, 1rem) 1rem}.income-section{display:flex;align-items:center;gap:.5rem}.income-icon{width:32px;height:32px;border-radius:8px;color:var(--secondary-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.income-label{font-size:.875rem;color:var(--text-muted)}.income-amount{font-size:1.25rem;font-weight:700;color:var(--text-color)}.edit-income-btn{opacity:.5;transition:opacity .2s}.budget-income-bar:hover .edit-income-btn{opacity:1}.income-edit{display:flex;gap:.5rem;align-items:center}.income-edit .input{font-size:1rem;font-weight:600;padding:.375rem .5rem;width:140px}.income-edit-actions{display:flex;gap:.25rem}.left-to-budget-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:var(--radius-md, 8px);font-weight:600}.left-to-budget-indicator.success{background:#dcfce7;color:#16a34a}.left-to-budget-indicator.warning{background:#fef3c7;color:#d97706}.left-to-budget-indicator.danger{background:#fee2e2;color:#dc2626}.left-to-budget-indicator .left-to-budget-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.left-to-budget-indicator .left-to-budget-amount{font-size:1rem}.budget-table-header{display:grid;grid-template-columns:32px 1fr 110px 110px 130px;align-items:center;gap:.5rem;padding:.5rem 1rem .25rem;margin-bottom:-.25rem}.budget-table-header span{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.budget-table-header .sortable-header{display:flex;align-items:center;gap:.25rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s ease}.budget-table-header .sortable-header:hover{color:var(--text-color)}.budget-table-header .col-planned,.budget-table-header .col-spent,.budget-table-header .col-difference{text-align:right;justify-content:flex-end}.categories-list{display:flex;flex-direction:column;background:var(--card-bg);border-radius:var(--radius-lg, 12px);border:none;box-shadow:var(--shadow-sm);overflow:hidden}.categories-list .category-card{border-radius:0;border:none}@media(max-width:768px){.budget-page{padding:1rem;gap:1rem;overflow:hidden;min-width:0;max-width:100%;width:100%;box-sizing:border-box}.budget-categories{min-width:0;overflow:hidden}.categories-list{min-width:0}.categories-list .category-card{min-width:0;overflow:hidden}.section-header{flex-wrap:wrap;gap:.5rem}.section-header-actions{width:100%;flex-wrap:wrap}.section-header-actions>*{min-width:0}.section-header-actions .btn{flex:1;min-height:30px;padding:.375rem .75rem;justify-content:center}.budget-income-bar{flex-direction:column;align-items:stretch;gap:.5rem;padding:.75rem 1rem}.income-section{flex-wrap:wrap;gap:.5rem}.income-amount{font-size:1.125rem}.income-edit{flex:1;width:100%}.income-edit .input{flex:1;width:auto}.left-to-budget-indicator{justify-content:center;padding:.625rem 1rem}.budget-table-header{display:none}}.transactions-page{display:flex;flex-direction:column;height:100%;overflow:hidden;max-width:1200px;margin:0 auto}.transactions-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6, 1.5rem) var(--space-6, 1.5rem) var(--space-5, 1.25rem)}.transactions-header h1{margin:0;font-size:var(--font-size-2xl, 1.5rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.transactions-header-actions{display:flex;gap:var(--space-2, .5rem);align-items:center}.transactions-header-actions>*{min-width:143px;text-align:center;justify-content:center}.transactions-header-actions a{text-decoration:none;display:flex}.transactions-header-actions a:hover{text-decoration:none}.transactions-header-actions a .btn{width:100%}.transactions-page .page-toolbar{padding:var(--space-4, 1rem) var(--space-6, 1.5rem);margin-bottom:0}.transactions-page .page-toolbar__tabs{padding-left:1rem}.transactions-content{flex:1;overflow-y:auto;padding:var(--space-5, 1.25rem) var(--space-6, 1.5rem)}.transactions-table-header{display:grid;grid-template-columns:40px 1fr auto 100px 72px;align-items:center;gap:var(--space-4, 1rem);padding:var(--space-4, 1rem) var(--space-5, 1.25rem);margin-bottom:0}.transactions-table-header span{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.transactions-table-header .sortable-header{display:flex;align-items:center;gap:.25rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s ease}.transactions-table-header .sortable-header:hover{color:var(--text-color)}.transactions-table-header .col-date,.transactions-table-header .col-amount{text-align:right;justify-content:flex-end}.transactions-list{display:flex;flex-direction:column;background:var(--card-bg);border-radius:var(--radius-lg, 12px);border:none;overflow:hidden;box-shadow:var(--shadow-sm)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8, 4rem) var(--space-8, 2rem);color:var(--text-muted);text-align:center;background:var(--card-bg);border-radius:var(--radius-lg, 12px);border:2px solid transparent;box-shadow:var(--shadow-sm)}.empty-state svg{color:var(--border-color);margin-bottom:var(--space-4, 1rem)}.empty-state p{margin:var(--space-2, .5rem) 0 var(--space-1, .25rem) 0;font-size:var(--font-size-lg, 1.125rem);font-weight:var(--font-weight-medium, 500);color:var(--text-color)}.empty-state span{font-size:var(--font-size-sm, .875rem);color:var(--text-muted)}.transaction-item{display:grid;grid-template-columns:40px 1fr auto 100px 72px;align-items:center;gap:var(--space-4, 1rem);padding:var(--space-4, 1rem) var(--space-5, 1.25rem);background:var(--card-bg);transition:background-color var(--transition-fast, .15s ease)}.transaction-item:hover{background:var(--primary-light)}.transaction-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md, 10px);background:none;flex-shrink:0}.transaction-icon .income{color:var(--success-color)}.transaction-icon .expense{color:var(--error-color)}.transaction-details{min-width:0;overflow:hidden}.transaction-description{font-weight:500;color:var(--text-color);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transaction-meta{font-size:var(--font-size-xs, .75rem);color:var(--text-muted);margin-top:.125rem;display:block}.transaction-date{font-size:.8125rem;color:var(--text-muted);white-space:nowrap;text-align:right}.transaction-amount{font-weight:var(--font-weight-semibold, 600);font-size:.9375rem;min-width:100px;text-align:right}.transaction-amount.income{color:var(--success-color)}.transaction-amount.expense{color:var(--text-color)}.transaction-actions{display:flex;align-items:center;gap:var(--space-1, .25rem);opacity:0;transition:opacity var(--transition-fast, .15s ease)}.transaction-item:hover .transaction-actions{opacity:1}.date-group-header{padding:.625rem var(--space-5, 1.25rem);font-size:var(--font-size-xs, .75rem);font-weight:var(--font-weight-semibold, 600);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--secondary-bg)}.transactions-page select.input{padding:.625rem 2.5rem .625rem .875rem;border:1px solid var(--input-border);border-radius:var(--radius-md, 8px);background:var(--input-bg);color:var(--text-color);font-size:.875rem;width:100%;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;transition:all var(--transition-fast, .15s ease)}.transactions-page select.input:focus{outline:none;border-color:var(--input-focus);box-shadow:0 0 0 3px var(--primary-light)}.no-accounts-message{display:flex;flex-direction:column;align-items:center;gap:var(--space-4, 1rem);padding:var(--space-6, 1.5rem);text-align:center}.no-accounts-message p{margin:0;color:var(--text-muted);font-size:.9375rem}.no-accounts-actions{display:flex;gap:var(--space-3, .75rem)}@media(max-width:768px){.transactions-page{height:auto;overflow:visible}.transactions-table-header{display:none}.transactions-header{flex-wrap:wrap;gap:var(--space-3, .75rem);padding:var(--space-4, 1rem)}.transactions-header-actions{width:100%}.transactions-header-actions>*{min-width:0}.transactions-header-actions .btn{flex:1;min-height:30px;justify-content:center}.transactions-header-actions a{flex:1;display:flex}.transactions-header-actions a .btn{width:100%}.transactions-tabs{padding:var(--space-2, .5rem) var(--space-4, 1rem)}.tab-button{flex:1;text-align:center;min-height:30px}.transactions-content{padding:var(--space-4, 1rem)}.transaction-item{display:flex;flex-wrap:wrap;gap:var(--space-3, .75rem);padding:var(--space-3, .75rem) var(--space-4, 1rem)}.transaction-details{flex:1;min-width:0}.transaction-amount{min-width:unset;margin-left:auto}.transaction-date{order:5;width:100%;padding-left:3rem;font-size:var(--font-size-xs, .75rem)}.transaction-actions{opacity:1;display:flex;gap:var(--space-1, .25rem)}.empty-state{padding:var(--space-8, 3rem) var(--space-6, 1.5rem)}.no-accounts-actions{flex-direction:column;width:100%}.no-accounts-actions .btn{min-height:30px;justify-content:center}.transaction-actions .btn,.transaction-actions button{min-width:44px;min-height:30px}}.accounts-page{display:flex;flex-direction:column;gap:var(--space-4, 1rem);padding:var(--space-6, 1.5rem);height:100%;overflow:hidden;max-width:1200px;margin:0 auto}.account-form{padding:var(--space-6, 1.5rem);background:var(--card-bg);border-radius:var(--radius-lg, 12px);border:2px solid transparent;box-shadow:var(--shadow-sm)}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4, 1rem);margin-bottom:var(--space-6, 1.5rem)}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-3, .75rem)}.accounts-list{display:flex;flex-direction:column;gap:var(--space-3, .75rem);overflow-y:auto}.account-card{display:flex;align-items:center;gap:var(--space-4, 1rem);padding:var(--space-5, 1.25rem);background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm);transition:all var(--transition-fast, .15s ease)}.account-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-lg, 12px);background:var(--primary-light);color:var(--secondary-color)}.account-info{flex:1;display:flex;flex-direction:column;gap:var(--space-1, .25rem)}.account-name{font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.account-type{font-size:var(--font-size-xs, .75rem);color:var(--text-muted);text-transform:capitalize}.account-balance{font-size:var(--font-size-xl, 1.25rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.accounts-page select.input{padding:var(--space-2, .5rem) var(--space-3, .75rem);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);background:var(--input-bg);color:var(--text-color);font-size:var(--font-size-sm, .875rem);width:100%;transition:all var(--transition-fast, .15s ease)}.accounts-page select.input:hover{border-color:var(--primary-color)}.accounts-page select.input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}@media(max-width:768px){.accounts-page{padding:var(--space-4, 1rem);gap:var(--space-4, 1rem)}.form-grid{grid-template-columns:1fr}.account-form{padding:var(--space-4, 1rem)}.form-actions{flex-direction:column}.form-actions button,.form-actions .btn{width:100%;min-height:30px}.account-card{flex-wrap:wrap;padding:var(--space-4, 1rem);gap:var(--space-3, .75rem)}.account-balance{font-size:var(--font-size-lg, 1.125rem)}.account-card button,.account-card .btn{min-width:44px;min-height:30px}.section-header{flex-wrap:wrap;gap:var(--space-3, .75rem)}.accounts-page select.input{min-height:30px}}.goals-page{padding:1.5rem;max-width:1200px;margin:0 auto}.goals-page .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4, 1rem)}.goals-page .section-header h1{margin:0;font-size:var(--font-size-2xl, 1.5rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.goals-category-info{background:var(--primary-light);border:1px solid var(--primary-color);border-radius:var(--radius-lg, 12px);margin-bottom:var(--space-6, 1.5rem);padding:var(--space-4, 1rem) var(--space-5, 1.25rem);box-shadow:var(--shadow-sm)}.goals-category-info .info-header{display:flex;align-items:center;gap:var(--space-3, .75rem);font-weight:var(--font-weight-semibold, 600);color:var(--secondary-color);margin-bottom:var(--space-2, .5rem)}.goals-category-info .info-text{margin:0;font-size:.875rem;color:var(--text-muted);line-height:1.5}.goals-list{display:flex;flex-direction:column;gap:var(--space-4, 1rem)}.empty-state{text-align:center;padding:var(--space-8, 3rem);color:var(--text-muted);background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm)}.empty-state svg{margin-bottom:var(--space-4, 1rem);opacity:.5}.empty-state h3{margin:0 0 var(--space-2, .5rem) 0;font-size:var(--font-size-lg, 1.125rem);color:var(--text-color)}.empty-state p{margin:0 0 var(--space-6, 1.5rem) 0;font-size:var(--font-size-sm, .875rem)}.goal-card{padding:0;background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm);transition:all var(--transition-fast, .15s ease);overflow:hidden}.goal-card-banner{width:100%;height:10em;overflow:hidden}.goal-card-banner-gradient{width:100%;height:100%;transition:transform .25s ease}.goal-card-banner-img{width:100%;height:100%;object-fit:cover;transition:transform .25s ease}.goal-card:hover .goal-card-banner-img,.goal-card:hover .goal-card-banner-gradient{transform:scale(1.02)}.goal-header{display:flex;align-items:flex-start;gap:var(--space-4, 1rem);margin-bottom:var(--space-4, 1rem);padding:var(--space-4, 1rem) var(--space-4, 1rem) 0}.goal-icon{width:48px;height:48px;border-radius:var(--radius-lg, 12px);background:none;color:var(--secondary-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.goal-title{flex:1;min-width:0}.goal-title h2{margin:0 0 var(--space-1, .25rem) 0;font-size:var(--font-size-lg, 1.125rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.goal-deadline{display:inline-flex;align-items:center;gap:var(--space-1, .375rem);font-size:var(--font-size-xs, .75rem);color:var(--text-muted)}.delete-goal-btn{opacity:.5;transition:opacity .15s ease}.goal-card:hover .delete-goal-btn{opacity:1}.goal-amounts{display:flex;justify-content:space-between;margin-bottom:var(--space-3, .75rem);padding:0 var(--space-4, 1rem)}.goal-amount-row{display:flex;flex-direction:column}.goal-amount-row .amount-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.goal-amount-row .amount-value{font-size:var(--font-size-base, 1rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.goal-progress{margin-bottom:var(--space-4, 1rem);padding:0 var(--space-4, 1rem)}.goal-progress .progress-label{display:block;text-align:right;font-size:var(--font-size-xs, .75rem);color:var(--text-muted);margin-top:var(--space-1, .375rem)}.goal-details{display:flex;gap:var(--space-6, 1.5rem);padding:var(--space-4, 1rem) var(--space-4, 1rem) var(--space-4, 1rem)}.detail-item{display:flex;flex-direction:column}.detail-item .detail-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.detail-item .detail-value{font-size:var(--font-size-sm, .875rem);font-weight:var(--font-weight-medium, 500);color:var(--text-color)}.goal-actions{display:flex;gap:var(--space-1, .25rem)}.edit-goal-btn,.delete-goal-btn{opacity:.5;transition:opacity var(--transition-fast, .15s ease)}.goal-card:hover .edit-goal-btn,.goal-card:hover .delete-goal-btn{opacity:1}.edit-goal-btn:hover{color:var(--secondary-color)}.delete-goal-btn:hover{color:var(--error-color)}.goal-card.editing{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.goal-edit-form{display:flex;flex-direction:column;gap:var(--space-4, 1rem);padding:var(--space-4, 1rem)}.edit-row{display:flex;flex-direction:column;gap:var(--space-1, .375rem)}.edit-row label{font-size:var(--font-size-xs, .75rem);font-weight:var(--font-weight-medium, 500);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.edit-input{width:100%;padding:.625rem .75rem;font-size:.9375rem;color:var(--text-color);background:var(--input-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);transition:border-color var(--transition-fast, .15s ease),box-shadow var(--transition-fast, .15s ease)}.edit-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.edit-input::placeholder{color:var(--text-muted)}.edit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4, 1rem)}.edit-actions{display:flex;justify-content:flex-end;gap:var(--space-3, .75rem);padding-top:var(--space-4, 1rem)}@media(max-width:768px){.goals-page{padding:1rem}.goals-page .section-header{flex-wrap:wrap;gap:.75rem}.goals-category-info{padding:.875rem 1rem}.goal-header{flex-wrap:wrap}.goal-actions{opacity:1}.edit-goal-btn,.delete-goal-btn{opacity:1;min-width:44px;min-height:30px}.goal-amounts,.goal-details{flex-wrap:wrap;gap:.75rem}.detail-item{min-width:80px}.edit-grid{grid-template-columns:1fr}.edit-actions{flex-direction:column}.edit-actions .btn{width:100%;min-height:30px;justify-content:center}.edit-input{min-height:30px}.empty-state{padding:2rem}.view-project-link{min-height:30px;display:flex;align-items:center}}@media(max-width:640px){.goal-details{flex-wrap:wrap;gap:1rem}.detail-item{flex:1;min-width:80px}.edit-grid{grid-template-columns:1fr}}.view-project-link{display:inline-flex;align-items:center;gap:var(--space-1, .375rem);padding:var(--space-2, .5rem) var(--space-4, 1rem);margin-top:var(--space-2, .5rem);font-size:.8125rem;font-weight:var(--font-weight-medium, 500);color:var(--accent-color);text-decoration:none;border-top:1px solid var(--border-color);width:100%}.view-project-link:hover{color:var(--accent-hover);text-decoration:underline}.projects-page{padding:var(--space-6, 1.5rem);max-width:1200px;margin:0 auto}.projects-page .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4, 1rem)}.projects-page .section-header h1{margin:0;font-size:var(--font-size-2xl, 1.5rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.projects-list{display:flex;flex-direction:column;gap:var(--space-4, 1rem)}.project-card{padding:0;cursor:pointer;transition:all var(--transition-fast, .15s ease);overflow:hidden}.project-card-banner{width:100%;height:10em;overflow:hidden}.project-card-banner-gradient{width:100%;height:100%;transition:transform .25s ease}.project-card-banner-img{width:100%;height:100%;object-fit:cover;transition:transform .25s ease}.project-card:hover .project-card-banner-img,.project-card:hover .project-card-banner-gradient{transform:scale(1.02)}.project-card-header{display:flex;align-items:flex-start;gap:var(--space-3, .875rem);padding:var(--space-4, 1rem) var(--space-5, 1.25rem) 0;margin-bottom:var(--space-4, 1rem)}.project-card:not(:has(.project-card-banner)) .project-card-header{padding-top:var(--space-5, 1.25rem)}.project-title-group{flex:1;min-width:0}.project-title-group h2{margin:0;font-size:var(--font-size-lg, 1.125rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color);line-height:1.3}.project-date{display:inline-flex;align-items:center;gap:var(--space-1, .25rem);font-size:var(--font-size-xs, .75rem);color:var(--text-muted);margin-top:var(--space-1, .25rem)}.project-actions{display:flex;gap:var(--space-1, .25rem);flex-shrink:0}.icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s}.icon-btn:hover{background:var(--hover-bg);color:var(--text-color)}.icon-btn--danger:hover{background:var(--error-light, #fee2e2);color:var(--error-color, #dc3545)}.project-stats-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--space-3, .75rem);padding:0 var(--space-5, 1.25rem)}.stat-group{display:flex;flex-direction:column;gap:.125rem}.stat-group--right{text-align:right}.stat-label{font-size:.6875rem;font-weight:var(--font-weight-medium, 500);letter-spacing:.05em;color:var(--text-muted)}.stat-value{font-size:var(--font-size-base, 1rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color);font-variant-numeric:tabular-nums}.project-progress-container{margin-bottom:var(--space-3, .75rem);padding:0 var(--space-5, 1.25rem)}.project-progress-bar{height:1px;background:var(--bg-secondary);border-radius:3px;overflow:hidden;margin-bottom:var(--space-1, .375rem)}.project-progress-fill{height:100%;background:var(--success-color, #28a745);border-radius:3px;transition:width .3s ease}.project-progress-label{display:block;text-align:right;font-size:var(--font-size-xs, .75rem);color:var(--text-muted)}.project-meta-row{display:flex;gap:var(--space-8, 2rem);padding:var(--space-3, .75rem) var(--space-5, 1.25rem) var(--space-5, 1.25rem);margin-top:var(--space-3, .75rem)}.meta-group{display:flex;flex-direction:column;gap:var(--space-1, .25rem)}.meta-label{font-size:.6875rem;font-weight:var(--font-weight-medium, 500);letter-spacing:.05em;color:var(--text-muted)}.project-status{display:inline-block;padding:.125rem var(--space-2, .5rem);border-radius:var(--radius-sm, 4px);font-size:var(--font-size-xs, .75rem);font-weight:var(--font-weight-medium, 500);text-transform:capitalize;background:var(--bg-secondary)}.project-status--planning{background:var(--warning-light, #fef3cd);color:var(--warning-color, #856404)}.project-status--active{background:var(--primary-light);color:var(--secondary-color)}.project-status--completed{background:var(--success-light, #d4edda);color:var(--success-color, #155724)}.project-status--archived{background:var(--bg-tertiary, #e9ecef);color:var(--text-muted)}.project-priority{display:inline-block;padding:.125rem var(--space-2, .5rem);border-radius:var(--radius-sm, 4px);font-size:var(--font-size-xs, .75rem);font-weight:var(--font-weight-medium, 500);text-transform:capitalize}.project-priority--high{background:var(--error-light, #f8d7da);color:var(--error-color, #dc3545)}.project-priority--medium{background:var(--warning-light, #fef3cd);color:var(--warning-color, #856404)}.project-priority--low{background:var(--bg-secondary);color:var(--text-muted)}@media(max-width:768px){.projects-page{padding:var(--space-4, 1rem)}.projects-page .section-header{flex-wrap:wrap;gap:var(--space-3, .75rem)}.projects-summary{grid-template-columns:1fr;gap:var(--space-3, .75rem)}.summary-card{flex-direction:row;justify-content:space-between;padding:var(--space-4, 1rem)}.summary-label{margin-bottom:0}.project-card-banner{height:8em}.project-card-header{flex-wrap:wrap}.project-actions{width:100%;justify-content:flex-end;margin-top:var(--space-2, .5rem)}.project-stats-row,.project-meta-row{flex-wrap:wrap;gap:var(--space-3, .75rem)}.icon-btn{min-width:44px;min-height:30px}.projects-search-input{min-height:30px}}@media(max-width:640px){.projects-summary{grid-template-columns:1fr;gap:var(--space-3, .75rem)}.summary-card{flex-direction:row;justify-content:space-between;padding:var(--space-4, 1rem);flex-direction:column}.summary-label{margin-bottom:0}.project-card-header{flex-wrap:wrap}.project-actions{width:100%;justify-content:flex-end;margin-top:var(--space-2, .5rem)}.project-meta-row{flex-wrap:wrap;gap:var(--space-4, 1rem)}}.project-detail-page{padding:2rem;max-width:900px;margin:0 auto}.project-detail-header{margin-bottom:2rem}.project-detail-banner{width:100%;height:160px;border-radius:12px;overflow:hidden;margin:.75rem 0}.project-detail-banner-preset{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.project-detail-banner-img{width:100%;height:100%;object-fit:cover}.project-detail-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-color)}.project-name-input{flex:1;margin:0;padding:.25rem .5rem;font-size:1.5rem;font-weight:600;font-family:inherit;color:var(--text-color);background:transparent;border:1px solid transparent;border-radius:6px;transition:border-color .15s,background-color .15s}.project-name-input:hover{background:var(--hover-bg, rgba(0, 0, 0, .03))}.project-name-input:focus{outline:none;background:var(--input-bg);border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-alpha)}.project-description-input{display:block;width:100%;margin:1.25rem 0 0;padding:.5rem .625rem;font-size:.875rem;font-family:inherit;color:var(--text-secondary);background:transparent;border:1px solid transparent;border-radius:6px;resize:vertical;min-height:4.5rem;line-height:1.6;transition:border-color .15s,background-color .15s,color .15s}.project-description-input:hover{background:var(--hover-bg, rgba(0, 0, 0, .03))}.project-description-input:focus{outline:none;background:var(--input-bg);border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-alpha);color:var(--text-color)}.project-description-input::placeholder{color:var(--text-secondary);opacity:.7}.project-date-row{margin-top:.75rem}.project-date-wrapper{display:inline-flex;align-items:center;gap:.375rem}.date-icon{color:var(--text-secondary)}.project-date-input{padding:.25rem .5rem;font-size:.8125rem;font-family:inherit;color:var(--text-secondary);background:transparent;border:1px solid transparent;border-radius:6px;transition:border-color .15s,background-color .15s}.project-date-input:hover{background:var(--hover-bg, rgba(0, 0, 0, .03))}.project-date-input:focus{outline:none;background:var(--input-bg);border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-alpha);color:var(--text-color)}.set-date-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .5rem;font-size:.8125rem;font-family:inherit;color:var(--text-secondary);background:transparent;border:1px dashed var(--border-color);border-radius:6px;cursor:pointer;transition:border-color .15s,color .15s,background-color .15s}.set-date-btn:hover{color:var(--accent-color);border-color:var(--accent-color);background:var(--hover-bg, rgba(0, 0, 0, .03))}.project-title-row{display:flex;align-items:center;gap:.75rem;margin-top:1.75rem}.project-meta-controls{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.project-meta-controls .image-picker{flex:0 0 100%;width:100%;margin-top:.25rem}.project-header-image-picker{margin-top:.75rem}.project-top-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;font-size:.875rem;margin-bottom:.25rem}.back-link:hover{color:var(--text-color)}.status-badge{display:inline-block;padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize}.status-planning{background:var(--warning-bg, #fef3c7);color:var(--warning-text, #92400e)}.status-active{background:var(--info-bg, #dbeafe);color:var(--info-text, #1e40af)}.status-completed{background:var(--success-bg, #d1fae5);color:var(--success-text, #065f46)}.status-archived{background:var(--muted-bg, #f3f4f6);color:var(--muted-text, #6b7280)}.status-select{padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize;border:1px solid transparent;cursor:pointer;transition:border-color .15s}.status-select:hover{border-color:var(--border-color)}.status-select:focus{outline:none;border-color:var(--primary-color)}.status-select.status-planning{background:var(--warning-bg, #fef3c7);color:var(--warning-text, #92400e)}.status-select.status-active{background:var(--info-bg, #dbeafe);color:var(--info-text, #1e40af)}.status-select.status-completed{background:var(--success-bg, #d1fae5);color:var(--success-text, #065f46)}.status-select.status-archived{background:var(--muted-bg, #f3f4f6);color:var(--muted-text, #6b7280)}.priority-select{padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize;border:1px solid transparent;cursor:pointer;transition:border-color .15s}.priority-select:hover{border-color:var(--border-color)}.priority-select:focus{outline:none;border-color:var(--primary-color)}.priority-high{background:var(--error-light, #f8d7da);color:var(--error-color, #dc3545)}.priority-medium{background:var(--warning-bg, #fef3c7);color:var(--warning-text, #92400e)}.priority-low{background:var(--muted-bg, #f3f4f6);color:var(--muted-text, #6b7280)}.project-total-card{display:flex;align-items:center;gap:1rem;padding:1.125rem 1.25rem;margin-bottom:2rem}.total-label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.total-value{font-size:1.5rem;font-weight:700;color:var(--text-color)}.total-items{font-size:.8125rem;color:var(--text-secondary);margin-left:auto}.project-items-section{margin-top:.5rem}.items-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.items-header h2{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-color)}.items-loading{color:var(--text-secondary);text-align:center;padding:2rem}.empty-items{text-align:center;padding:2rem;color:var(--text-secondary)}.empty-items p{margin:0}.items-list{display:flex;flex-direction:column;gap:.625rem}.items-list-header{display:grid;grid-template-columns:24px 1fr 70px 80px 100px 100px 36px;gap:.5rem;padding:.5rem .75rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em;margin-bottom:.25rem}.item-header-checkbox{width:24px}.item-header-name{text-align:left}.item-header-qty,.item-header-uom,.item-header-amount,.item-header-total{text-align:right}.item-header-actions{width:36px}.item-row{display:grid;grid-template-columns:24px 1fr 70px 80px 100px 100px 36px;gap:.5rem;align-items:center;padding:.75rem}.item-name-input{flex:1;padding:.375rem .5rem;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-color);font-size:.875rem;font-family:inherit}.item-name-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-alpha)}.item-amount-input{width:100%;padding:.375rem .5rem;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-color);font-size:.875rem;font-family:inherit;text-align:right}.item-amount-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-alpha)}.item-qty-input{width:100%;padding:.375rem .5rem;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-color);font-size:.875rem;font-family:inherit;text-align:right}.item-qty-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-alpha)}.item-uom-input{width:100%;padding:.375rem .5rem;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-color);font-size:.875rem;font-family:inherit;text-align:center}.item-uom-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-alpha)}.item-line-total{font-size:.875rem;font-weight:500;color:var(--text-color);text-align:right}.item-delete-btn{display:flex;align-items:center;justify-content:center;padding:.375rem;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background-color .15s,color .15s}.item-delete-btn:hover{background:var(--danger-bg, #fee2e2);color:var(--danger-text, #dc2626)}.item-checkbox{-webkit-appearance:none;appearance:none;width:20px;height:20px;flex-shrink:0;cursor:pointer;border:2px solid var(--border-color);border-radius:var(--radius-sm, 4px);background:transparent;transition:border-color var(--transition-fast, .15s ease),background-color var(--transition-fast, .15s ease);position:relative}.item-checkbox:hover{border-color:var(--primary-color)}.item-checkbox:focus-visible{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.item-checkbox:checked{background-color:var(--primary-color);border-color:var(--primary-color)}.item-checkbox:checked:after{content:"";position:absolute;left:5px;top:2px;width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.item-row.item-completed .item-name-input{text-decoration:line-through;opacity:.5}.item-row.item-completed .item-qty-input,.item-row.item-completed .item-uom-input,.item-row.item-completed .item-amount-input,.item-row.item-completed .item-line-total{opacity:.5}.items-progress{margin:0 0 1rem;font-size:.8125rem;color:var(--text-secondary)}.goal-linked-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;font-size:.75rem;font-weight:500;color:var(--success-text, #065f46);background:var(--success-bg, #d1fae5);border-radius:9999px;text-decoration:none;transition:opacity .15s}.goal-linked-badge:hover{opacity:.85}.promote-dialog{padding:1.25rem;margin-bottom:1.5rem;border:2px solid var(--accent-color);background:var(--card-bg)}.promote-dialog h3{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:var(--text-color)}.promote-summary{margin:0 0 1rem;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.promote-summary strong{color:var(--text-color)}.promote-input-row{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem}.promote-input-row label{font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.promote-input-row input{max-width:200px}.promote-actions{display:flex;gap:.75rem;justify-content:flex-end}.goal-progress-card{margin-bottom:2rem;padding:1.125rem 1.25rem}.goal-progress-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:var(--text-color)}.goal-progress-title{font-size:.9375rem;font-weight:600}.goal-progress-amounts{display:flex;align-items:baseline;gap:.375rem;margin-bottom:.5rem}.goal-saved{font-size:1.125rem;font-weight:600;color:var(--success-color, #22c55e)}.goal-target{font-size:.8125rem;color:var(--text-secondary)}.goal-monthly{display:block;margin-top:.375rem;font-size:.8125rem;color:var(--text-secondary)}.goal-sync-toast{position:fixed;top:1rem;right:1rem;background:var(--success-color, #22c55e);color:#fff;padding:.625rem 1rem;border-radius:.5rem;font-size:.8125rem;font-weight:500;z-index:1000;animation:slideIn .2s ease-out;box-shadow:0 2px 8px #00000026}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.delete-project-section{margin-top:3rem;display:flex;justify-content:flex-end}.delete-project-btn{color:var(--danger-text, #dc2626)!important}.delete-project-btn:hover{background:var(--danger-bg, #fee2e2)!important}.delete-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}.delete-dialog{max-width:420px;width:90%;padding:1.5rem;text-align:center}.delete-dialog-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;margin:0 auto 1rem;background:var(--danger-bg, #fee2e2);color:var(--danger-text, #dc2626);border-radius:50%}.delete-dialog h3{margin:0 0 .5rem;font-size:1.125rem;font-weight:600;color:var(--text-color)}.delete-dialog-message{margin:0 0 1rem;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.delete-dialog-message strong{color:var(--text-color)}.delete-dialog-warning{margin:0 0 1rem;padding:.75rem;background:var(--warning-bg, #fef3c7);color:var(--warning-text, #92400e);border-radius:8px;font-size:.8125rem;line-height:1.5;text-align:left}.delete-dialog-actions{display:flex;gap:.75rem;justify-content:center}.delete-confirm-btn{background:var(--danger-text, #dc2626)!important;border-color:var(--danger-text, #dc2626)!important}.delete-confirm-btn:hover{background:#b91c1c!important;border-color:#b91c1c!important}@media(max-width:768px){.project-detail-page{padding:1rem}.project-detail-banner{height:120px}.project-title-row{flex-wrap:wrap;gap:.75rem}.project-name-input{flex:0 0 100%;width:100%;font-size:1.25rem;min-height:30px;padding:1em 0 0}.project-meta-controls{flex:0 0 100%;width:100%}.project-description-input{width:100%;min-height:65px}.status-badge{flex-shrink:0}.status-select{flex-shrink:0;min-height:20px}.priority-select{min-height:20px}.goal-linked-badge{flex-shrink:0}.project-total-card{flex-wrap:wrap;gap:.75rem}.total-items{width:100%;margin-left:0;text-align:left}.items-list-header{display:none}.item-row{grid-template-columns:24px 1fr auto;grid-template-rows:auto auto;gap:.5rem .75rem;padding:.75rem;align-items:center}.item-checkbox{grid-row:1 / 3;width:24px;height:24px;min-width:24px;min-height:24px}.item-checkbox:checked:after{left:6px;top:2px;width:7px;height:12px}.item-name-input{grid-column:2;grid-row:1;min-height:30px}.item-delete-btn{grid-column:3;grid-row:1;min-width:44px;min-height:30px}.item-qty-input{grid-column:2;grid-row:2;width:auto;min-width:60px;max-width:80px;min-height:30px}.item-uom-input{display:none}.item-amount-input{grid-column:2;grid-row:2;width:auto;min-width:80px;max-width:100px;min-height:30px;margin-left:auto}.item-line-total{grid-column:3;grid-row:2;font-size:.8125rem}.promote-dialog{padding:1rem}.promote-input-row input{max-width:none;width:100%;min-height:30px}.promote-actions{flex-direction:column}.promote-actions .btn{width:100%;min-height:30px;justify-content:center}.goal-progress-card{padding:1rem}.goal-progress-amounts{flex-wrap:wrap;gap:.25rem}.delete-project-section{justify-content:center}.delete-project-section .btn{min-height:30px}.delete-dialog{padding:1.25rem}.delete-dialog-actions{flex-direction:column;gap:.5rem}.delete-dialog-actions .btn{width:100%;min-height:30px;justify-content:center}}.lending-page{padding:var(--space-6, 1.5rem);max-width:1200px;margin:0 auto}.lending-page .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4, 1rem)}.lending-page .section-header h1{margin:0;font-size:var(--font-size-2xl, 1.5rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.lending-page .page-toolbar__tabs{padding-left:.925rem}.loans-section.settled-direct .loans-section-header{display:flex;align-items:center;gap:var(--space-2, .5rem);margin-bottom:var(--space-4, 1rem);color:var(--text-muted)}.loans-section.settled-direct .loans-section-header h2{margin:0;font-size:var(--font-size-lg, 1.125rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-muted)}.loans-section{margin-bottom:var(--space-6, 1.5rem)}.loans-section-header{display:flex;align-items:center;gap:var(--space-2, .5rem);margin-bottom:var(--space-4, 1rem)}.loans-section-header h2{margin:0;font-size:var(--font-size-lg, 1.125rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.loans-section-header .section-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 var(--space-2, .5rem);font-size:var(--font-size-xs, .75rem);font-weight:var(--font-weight-semibold, 600);border-radius:var(--radius-full);background:var(--secondary-bg);color:var(--text-muted)}.loans-section.lent .loans-section-header .section-badge{background:#22c55e1a;color:var(--success-color)}.loans-section.borrowed .loans-section-header .section-badge{background:#ef44441a;color:var(--error-color)}.loans-section-header .section-add-btn{margin-left:auto;opacity:.6;transition:opacity var(--transition-fast, .15s ease)}.loans-section-header .section-add-btn:hover{opacity:1}.loans-list{display:flex;flex-direction:column;gap:var(--space-3, .75rem)}.loans-list-empty{padding:var(--space-6, 1.5rem);text-align:center;color:var(--text-muted);font-size:var(--font-size-sm, .875rem);background:var(--card-bg);border:2px dashed transparent;border-radius:var(--radius-lg, 12px);display:flex;flex-direction:column;align-items:center;gap:var(--space-3, .75rem)}.loans-list-empty .btn{opacity:.8}.loans-list-empty .btn:hover{opacity:1}.loan-card{padding:var(--space-4, 1rem) var(--space-5, 1.25rem);background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm);transition:all var(--transition-fast, .15s ease)}.loan-card.clickable{cursor:pointer}.loan-card-header{display:flex;align-items:center;gap:var(--space-4, 1rem);margin-bottom:var(--space-3, .75rem)}.loan-card-icon{width:40px;height:40px;border-radius:var(--radius-lg, 12px);display:flex;align-items:center;justify-content:center;flex-shrink:0}.loan-card.lent .loan-card-icon{background:none;color:var(--success-color)}.loan-card.borrowed .loan-card-icon{background:#ef44441a;color:var(--error-color)}.loan-card-info{flex:1;min-width:0}.loan-card-info h3{margin:0 0 .125rem;font-size:var(--font-size-lg, 1.125rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.loan-card-info .loan-description{font-size:.8125rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loan-card-amounts{text-align:right;flex-shrink:0}.loan-card-amounts .loan-balance{font-size:var(--font-size-base, 1rem);font-weight:var(--font-weight-bold, 700);margin:5px}.loan-card.lent .loan-card-amounts .loan-balance{color:var(--success-color)}.loan-card.borrowed .loan-card-amounts .loan-balance{color:var(--error-color)}.loan-card-amounts .loan-original{font-size:var(--font-size-xs, .75rem);color:var(--text-muted)}.loan-progress{margin-bottom:var(--space-2, .5rem)}.loan-progress-label{display:flex;justify-content:space-between;font-size:var(--font-size-xs, .75rem);color:var(--text-muted);margin-top:var(--space-1, .375rem)}.loan-details{display:flex;gap:var(--space-6, 1.5rem);padding-top:var(--space-3, .75rem);font-size:var(--font-size-xs, .75rem)}.loan-detail-item{display:flex;flex-direction:column}.loan-detail-item .detail-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.125rem}.loan-detail-item .detail-value{font-weight:var(--font-weight-medium, 500);color:var(--text-color)}.loan-card-actions{display:flex;justify-content:flex-end;padding-top:var(--space-3, .75rem);margin-top:var(--space-2, .5rem)}.loan-card-actions .btn{display:inline-flex;align-items:center;gap:var(--space-1, .375rem)}.loan-card-actions .delete-btn{color:var(--text-muted);transition:color var(--transition-fast, .15s ease)}.loan-card-actions .delete-btn:hover{color:var(--error-color);background:#ef44441a}.lending-empty-state{text-align:center;padding:var(--space-8, 3rem);color:var(--text-muted);background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm)}.lending-empty-state svg{margin-bottom:var(--space-4, 1rem);opacity:.5}.lending-empty-state h3{margin:0 0 var(--space-2, .5rem) 0;font-size:var(--font-size-lg, 1.125rem);color:var(--text-color)}.lending-empty-state p{margin:0 0 var(--space-6, 1.5rem) 0;font-size:var(--font-size-sm, .875rem)}@media(max-width:640px){.loan-card-header{flex-wrap:wrap}.loan-card-amounts{text-align:left;width:100%;margin-top:var(--space-2, .5rem)}.loan-details{flex-wrap:wrap;gap:var(--space-4, 1rem)}.loan-detail-item{flex:1;min-width:80px}}.loans-section.history{margin-top:var(--space-8, 2rem)}.loans-section-header.history-toggle{width:100%;display:flex;align-items:center;gap:var(--space-2, .5rem);padding:var(--space-3, .75rem) var(--space-4, 1rem);margin-bottom:0;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg, 12px);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.loans-section-header.history-toggle:hover{border-color:var(--primary-color);background:var(--card-bg)}.loans-section-header.history-toggle h2{margin:0;font-size:var(--font-size-base, 1rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-muted)}.loans-section-header.history-toggle .toggle-icon{margin-left:auto;color:var(--text-muted);display:flex;align-items:center}.loans-section.history .section-badge{background:var(--secondary-bg);color:var(--text-muted);border:1px solid var(--border-color)}.history-list{margin-top:var(--space-4, 1rem)}.loan-card.settled{opacity:.75;border-style:dashed}.loan-card.settled:hover{opacity:1}.loan-card.settled .loan-card-icon,.loan-card.settled .loan-card-icon.settled{background:var(--secondary-bg);color:var(--text-muted)}.loan-card.settled .loan-card-amounts .loan-balance{color:var(--text-muted)}.loan-card-amounts.settled{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.settled-badge{display:inline-flex;align-items:center;gap:var(--space-1, .25rem);font-size:.6875rem;font-weight:var(--font-weight-semibold, 600);text-transform:uppercase;letter-spacing:.05em;color:var(--success-color);background:#22c55e1a;padding:.125rem var(--space-2, .5rem);border-radius:var(--radius-full)}@media(max-width:768px){.lending-page{padding:var(--space-4, 1rem)}.lending-page .section-header{flex-wrap:wrap;gap:var(--space-3, .75rem);margin-bottom:var(--space-4, 1rem)}.lending-page .section-header .btn{min-height:30px}.loans-section{margin-bottom:var(--space-4, 1rem)}.loan-card{padding:var(--space-3, .75rem) var(--space-4, 1rem)}.loan-card-header{flex-wrap:wrap;gap:var(--space-3, .75rem)}.loan-card-amounts{text-align:left;width:100%}.loan-details{flex-wrap:wrap;gap:var(--space-3, .75rem)}.loan-detail-item{flex:1;min-width:80px}.loan-card-actions{flex-direction:row;gap:var(--space-2, .5rem)}.loan-card-actions .btn{flex:1;min-height:30px;justify-content:center}.loans-section-header .section-add-btn{opacity:1;min-height:30px;min-width:44px}.lending-empty-state{padding:var(--space-8, 2rem) var(--space-4, 1rem)}.lending-empty-state .btn{min-height:30px}}.roadmap-page{padding:var(--spacing-lg, 1.5rem);max-width:1200px;margin:0 auto}.roadmap-page .section-header{margin-bottom:var(--spacing-md, 1rem)}.overall-progress-card{padding:var(--spacing-lg, 1.5rem);margin-bottom:var(--spacing-lg, 1.5rem);background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;border:none;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-md)}.overall-progress-card .progress-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.overall-progress-card .progress-icon{width:48px;height:48px;background:#fff3;border-radius:var(--radius-lg, 12px);display:flex;align-items:center;justify-content:center}.overall-progress-card .progress-info{flex:1}.overall-progress-card .progress-info h2{margin:0 0 .25rem;font-size:1.125rem;font-weight:600}.overall-progress-card .progress-info p{margin:0;opacity:.85;font-size:.875rem}.overall-progress-card .progress-amount{text-align:right}.overall-progress-card .progress-amount .saved{font-size:1.5rem;font-weight:700}.overall-progress-card .progress-amount .separator{margin:0 .25rem;opacity:.6}.overall-progress-card .progress-amount .target{opacity:.85;font-size:.9375rem}.overall-progress-bar{position:relative;height:12px;background:#fff3;border-radius:var(--radius-sm, 6px);margin-bottom:var(--spacing-md, 1rem);overflow:visible}.overall-progress-bar .progress-fill{height:100%;background:#fff;border-radius:var(--radius-sm, 6px);transition:width .6s var(--ease-out, ease)}.overall-progress-bar .milestone-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:#ffffff4d;border-radius:50%;transition:all var(--transition-normal, .3s ease)}.overall-progress-bar .milestone-marker.reached{background:#fff;box-shadow:0 0 0 3px #ffffff4d}.overall-progress-bar .milestone-marker .milestone-label{position:absolute;top:16px;left:50%;transform:translate(-50%);font-size:.6875rem;opacity:.7;white-space:nowrap}.overall-progress-card .progress-stats{display:flex;gap:1.5rem;padding-top:.75rem}.overall-progress-card .progress-stats .stat{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.overall-progress-card .progress-stats .stat-icon{opacity:.9}.overall-progress-card .progress-stats .stat-icon.gold{color:gold}.overall-progress-card .progress-stats .stat-icon.blue{color:#90caf9}.overall-progress-card .progress-stats .stat-icon.purple{color:#ce93d8}.empty-roadmap{text-align:center;padding:var(--spacing-2xl, 4rem) var(--spacing-xl, 2rem);background:var(--card-bg);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm)}.empty-roadmap .empty-icon{width:80px;height:80px;margin:0 auto var(--spacing-lg, 1.5rem);background:var(--primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--secondary-color)}.empty-roadmap h3{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-color)}.empty-roadmap p{margin:0 0 1.5rem;color:var(--text-muted)}.next-milestone-card{display:flex;align-items:center;gap:var(--spacing-md, 1rem);padding:var(--spacing-md, 1rem) var(--spacing-lg, 1.25rem);margin-bottom:var(--spacing-lg, 1.5rem);background:linear-gradient(90deg,var(--primary-light) 0%,transparent 100%);border-left:3px solid var(--primary-color);border-radius:var(--radius-md, 8px);box-shadow:var(--shadow-sm)}.next-milestone-card .sparkle-icon{color:var(--secondary-color)}.next-milestone-card .milestone-info{flex:1;display:flex;flex-direction:column}.next-milestone-card .milestone-info .milestone-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.next-milestone-card .milestone-info .milestone-goal{font-weight:600;color:var(--text-color)}.next-milestone-card .milestone-progress{display:flex;align-items:center;gap:.25rem;font-weight:700;color:var(--secondary-color);font-size:1.125rem}.goals-timeline{margin-top:1rem}.timeline-title{display:flex;align-items:center;gap:.75rem;margin:0 0 1.5rem;font-size:1.125rem;font-weight:600;color:var(--text-color)}.timeline-container{display:flex;flex-direction:column;gap:0}.timeline-card{display:flex;gap:1rem;animation:slideIn .4s ease forwards;opacity:0}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.timeline-connector{display:flex;flex-direction:column;align-items:center;width:40px;flex-shrink:0}.connector-dot{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:2px solid var(--border-color);color:var(--text-muted);transition:all var(--transition-normal, .3s ease);z-index:1}.connector-dot.completed{background:var(--success-color);border-color:var(--success-color);color:#fff}.connector-dot.almost{background:var(--warning-color);border-color:var(--warning-color);color:#fff}.connector-dot.in-progress{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.connector-line{width:2px;flex:1;min-height:20px;background:var(--border-color)}.timeline-card-content{flex:1;margin-bottom:var(--spacing-md, 1rem);padding:var(--spacing-lg, 1.25rem);cursor:pointer;transition:all var(--transition-fast, .15s ease);border:2px solid transparent;background:var(--card-bg);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm)}.timeline-card-content:hover{border-color:var(--primary-color);transform:translateY(-1px);box-shadow:var(--shadow-md)}.timeline-card.selected .timeline-card-content{border-color:var(--primary-color);box-shadow:var(--shadow-lg, 0 4px 12px rgba(33, 150, 243, .15))}.timeline-card-content .card-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.goal-badge{width:36px;height:36px;border-radius:var(--radius-md, 10px);background:none;color:var(--secondary-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.timeline-card.completed .goal-badge{background:none;color:var(--success-color)}.goal-info{flex:1;min-width:0}.goal-info h2{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:var(--text-color)}.status-badge{display:inline-block;padding:.125rem .5rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;border-radius:var(--radius-xs, 4px)}.status-badge.completed{background:var(--success-light, rgba(76, 175, 80, .1));color:var(--success-color)}.status-badge.almost{background:var(--warning-light, rgba(255, 152, 0, .1));color:var(--warning-color)}.status-badge.in-progress{background:var(--primary-light);color:var(--secondary-color)}.status-badge.not-started{background:var(--bg-secondary);color:var(--text-muted)}.trophy-icon{color:var(--gold-color, #ffd700);animation:bounce .5s ease}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.card-progress{display:flex;align-items:center;gap:1rem}.card-progress .progress-amounts{min-width:100px}.card-progress .progress-amounts .current{font-weight:600;color:var(--text-color)}.card-progress .progress-amounts .target{font-size:.8125rem;color:var(--text-muted);margin-left:.25rem}.card-progress .progress-track{flex:1;height:8px;background:var(--bg-secondary);border-radius:var(--radius-xs, 4px);position:relative;overflow:visible}.card-progress .progress-fill{height:100%;border-radius:var(--radius-xs, 4px);transition:width .6s var(--ease-out, ease)}.card-progress .progress-fill.completed{background:var(--success-color)}.card-progress .progress-fill.almost{background:var(--warning-color)}.card-progress .progress-fill.in-progress{background:var(--primary-color)}.card-progress .progress-fill.not-started{background:var(--text-muted)}.card-progress .progress-milestone{position:absolute;top:50%;transform:translate(-50%,-50%);width:6px;height:6px;background:var(--bg-color);border:2px solid var(--border-color);border-radius:50%;z-index:1}.card-progress .progress-milestone.reached{background:var(--primary-color);border-color:var(--primary-color)}.card-progress .progress-percentage{min-width:48px;text-align:right;font-weight:700;font-size:1rem;color:var(--text-color)}.card-details{margin-top:1.25rem;padding-top:1.25rem;animation:expandIn .3s ease}@keyframes expandIn{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.milestones-section{margin-bottom:1.25rem}.milestones-section h3{margin:0 0 .75rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.milestones-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.milestone-item{display:flex;align-items:center;gap:var(--spacing-sm, .5rem);padding:var(--spacing-sm, .5rem);background:var(--bg-secondary);border-radius:var(--radius-md, 8px);opacity:.5;transition:all var(--transition-fast, .15s ease)}.milestone-item.reached{opacity:1;background:var(--success-light, rgba(76, 175, 80, .1))}.milestone-item .milestone-check{color:var(--text-muted)}.milestone-item.reached .milestone-check{color:var(--success-color)}.milestone-item .milestone-details{display:flex;flex-direction:column}.milestone-item .milestone-percent{font-weight:600;font-size:.875rem;color:var(--text-color)}.milestone-item .milestone-amount{font-size:.75rem;color:var(--text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.stat-item{display:flex;align-items:center;gap:var(--spacing-md, .75rem);padding:var(--spacing-md, .75rem);background:var(--bg-secondary);border-radius:var(--radius-md, 8px);transition:background var(--transition-fast, .15s ease)}.stat-item:hover{background:var(--hover-bg)}.stat-item svg{color:var(--secondary-color);flex-shrink:0}.stat-item .stat-content{display:flex;flex-direction:column}.stat-item .stat-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.stat-item .stat-value{font-weight:600;color:var(--text-color)}.next-milestone-message{display:flex;align-items:center;gap:var(--spacing-sm, .5rem);padding:var(--spacing-md, .75rem);background:var(--primary-light);border-radius:var(--radius-md, 8px);font-size:.875rem;color:var(--secondary-color)}.card-footer{display:flex;align-items:center;justify-content:flex-end;gap:.25rem;margin-top:.75rem;padding-top:.75rem}.click-hint{font-size:.75rem;color:var(--text-muted)}.card-footer .chevron{color:var(--text-muted);transition:transform var(--transition-fast, .15s ease)}.card-footer .chevron.expanded{transform:rotate(90deg)}[data-theme=dark] .overall-progress-card{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%)}[data-theme=dark] .timeline-card-content:hover{border-color:var(--primary-color)}[data-theme=dark] .milestone-item{background:#ffffff0d}[data-theme=dark] .milestone-item.reached{background:var(--success-light, rgba(76, 175, 80, .15))}[data-theme=dark] .stat-item{background:#ffffff0d}@media(max-width:768px){.roadmap-page,.overall-progress-card{padding:1rem}.overall-progress-card .progress-header{flex-wrap:wrap}.overall-progress-card .progress-icon{width:40px;height:40px}.overall-progress-card .progress-amount{width:100%;text-align:left}.overall-progress-card .progress-amount .saved{font-size:1.25rem}.overall-progress-card .progress-stats{flex-wrap:wrap;gap:.75rem}.timeline-connector{width:32px}.connector-dot{width:32px;height:32px}.connector-dot svg{width:16px;height:16px}.timeline-card-content{padding:1rem}.milestones-grid{grid-template-columns:repeat(2,1fr)}.stats-grid{grid-template-columns:1fr}.next-milestone-card,.card-progress{flex-wrap:wrap}.card-progress .progress-track{order:3;width:100%}.card-progress .progress-amounts{min-width:auto}.next-milestone-message{font-size:.8125rem}}@media(max-width:640px){.overall-progress-card .progress-header{flex-wrap:wrap}.overall-progress-card .progress-amount{width:100%;text-align:left;margin-top:.5rem}.overall-progress-card .progress-stats{flex-direction:column;gap:.5rem}.timeline-connector{width:32px}.connector-dot{width:32px;height:32px}.connector-dot svg{width:16px;height:16px}.milestones-grid{grid-template-columns:repeat(2,1fr)}.stats-grid{grid-template-columns:1fr}.card-progress{flex-wrap:wrap}.card-progress .progress-track{order:3;width:100%;margin-top:.5rem}}@media(prefers-reduced-motion:reduce){.timeline-card{animation:none;opacity:1}.trophy-icon,.card-details{animation:none}.overall-progress-bar .progress-fill,.card-progress .progress-fill{transition:none}}.notes-page{display:flex;flex-direction:column;height:100%;padding:var(--space-6, 1.5rem) var(--space-6, 1.5rem) 0;overflow:hidden;box-sizing:border-box}.notes-page .section-header{display:flex;align-items:center;gap:var(--space-2, .5rem);margin-bottom:0;padding-bottom:var(--space-5, 1.25rem)}.notes-page .section-header h1{margin:0;font-size:var(--font-size-2xl, 1.5rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.notes-page .notes-count{font-size:var(--font-size-sm, .875rem);color:var(--text-muted);font-weight:var(--font-weight-normal, 400)}.notes-content{display:flex;flex:1;min-height:0;overflow:hidden;border-radius:var(--radius-lg, .75rem);border:1px solid var(--border-color);background:var(--card-bg)}.notes-sidebar{width:300px;min-width:300px;display:flex;flex-direction:column;background:var(--card-bg)}.notes-new-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2, .5rem);padding:var(--space-2, .5rem) var(--space-3, .75rem);min-width:143px;background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-md, 8px);font-size:var(--font-size-sm, .875rem);font-weight:var(--font-weight-medium, 500);cursor:pointer;transition:background var(--transition-fast, .15s ease)}.notes-new-btn:hover{background:var(--primary-hover)}.notes-search{position:relative;padding:var(--space-3, .75rem) var(--space-4, 1rem)}.notes-search-icon{position:absolute;left:calc(var(--space-4, 1rem) + var(--space-2, .5rem));top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.notes-search-input{width:100%;padding:var(--space-2, .5rem) var(--space-3, .75rem) var(--space-2, .5rem) calc(var(--space-3, .75rem) + 20px + var(--space-2, .5rem));background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);font-size:var(--font-size-sm, .875rem);color:var(--text-color);outline:none;transition:border-color var(--transition-fast, .15s ease)}.notes-search-input::placeholder{color:var(--text-muted)}.notes-search-input:focus{border-color:var(--primary-color)}.notes-list{flex:1;overflow-y:auto;padding:var(--space-3, .75rem) var(--space-4, 1rem)}.notes-list-empty{padding:var(--space-6, 1.5rem);text-align:center;color:var(--text-muted);font-size:var(--font-size-sm, .875rem)}.note-item{display:flex;flex-direction:column;gap:var(--space-1, .25rem);padding:var(--space-3, .75rem);margin-bottom:var(--space-1, .25rem);background:transparent;border:none;border-radius:var(--radius-md, 8px);cursor:pointer;text-align:left;width:100%;transition:background var(--transition-fast, .15s ease)}.note-item:hover{background:var(--secondary-bg)}.note-item.selected{background:var(--primary-color);color:#fff}.note-item.selected .note-item-preview,.note-item.selected .note-item-date{color:#fffc}.note-item-header{display:flex;align-items:center;gap:var(--space-2, .5rem)}.note-item-title{flex:1;font-size:var(--font-size-sm, .875rem);font-weight:var(--font-weight-semibold, 600);color:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-item-pin{flex-shrink:0;color:var(--warning-color)}.note-item.selected .note-item-pin{color:#ffffffe6}.note-item-preview{font-size:var(--font-size-xs, .75rem);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-item-date{font-size:.6875rem;color:var(--text-muted)}.notes-editor{flex:1;display:flex;flex-direction:column;background:var(--card-bg);min-width:0}.notes-editor-header{display:flex;align-items:center;gap:var(--space-3, .75rem);padding:var(--space-4, 1rem)}.notes-editor-title{flex:1;padding:var(--space-2, .5rem) var(--space-3, .75rem);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);font-size:var(--font-size-base, 1rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color);outline:none;transition:border-color var(--transition-fast, .15s ease)}.notes-editor-title:focus{border-color:var(--primary-color)}.notes-editor-actions{display:flex;align-items:center;gap:var(--space-2, .5rem)}.notes-editor-meta{display:flex;align-items:center;gap:var(--space-2, .5rem);padding:var(--space-2, .5rem) var(--space-4, 1rem);font-size:var(--font-size-xs, .75rem);color:var(--text-muted)}.notes-editor-meta-item strong{font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.notes-editor-meta-separator{opacity:.5}.notes-pin-btn,.notes-delete-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.notes-pin-btn:hover{background:var(--secondary-bg);color:var(--warning-color);border-color:var(--warning-color)}.notes-pin-btn.pinned{background:#f59e0b1a;color:var(--warning-color);border-color:var(--warning-color)}.notes-delete-btn:hover{background:#ef44441a;color:var(--error-color);border-color:var(--error-color)}.notes-editor-content{flex:1;padding:var(--space-4, 1rem);overflow:hidden}.notes-editor-textarea{width:calc(100% - var(--space-4, 1rem) * 2);height:100%;margin:0 var(--space-4, 1rem) var(--space-4, 1rem);padding:var(--space-3, .75rem);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);font-size:var(--font-size-sm, .875rem);font-family:inherit;color:var(--text-color);line-height:1.6;resize:none;outline:none;transition:border-color var(--transition-fast, .15s ease)}.notes-editor-textarea:focus{border-color:var(--primary-color)}.notes-editor-textarea::placeholder{color:var(--text-muted)}.notes-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8, 2rem);color:var(--text-muted);text-align:center}.notes-empty-state svg{margin-bottom:var(--space-4, 1rem);opacity:.5}.notes-empty-state h3{margin:0 0 var(--space-2, .5rem) 0;font-size:var(--font-size-lg, 1.125rem);color:var(--text-color)}.notes-empty-state p{margin:0;font-size:var(--font-size-sm, .875rem)}.notes-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:var(--font-size-sm, .875rem)}@media(max-width:900px){.notes-sidebar{width:250px;min-width:250px}}@media(max-width:768px){.notes-page{padding:var(--space-4, 1rem) var(--space-4, 1rem) 0}.notes-page .section-header{flex-wrap:wrap;gap:var(--space-3, .75rem)}.notes-new-btn{min-width:0;flex:1}.notes-content{flex-direction:column}.notes-sidebar{width:100%;min-width:100%;max-height:40vh;border-right:none;border-bottom:1px solid var(--border-color)}.notes-editor{flex:1;min-height:0}.notes-editor-header{flex-wrap:wrap;gap:var(--space-2, .5rem)}.notes-editor-title{width:100%;order:1}.notes-editor-actions{order:0;margin-left:auto}.notes-empty-state{padding:var(--space-6, 1.5rem)}.notes-empty-state h3{font-size:var(--font-size-base, 1rem)}}.event-modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem}.event-modal{position:relative;width:100%;max-width:480px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-xl);animation:modal-slide-in .2s ease-out}@keyframes modal-slide-in{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.event-modal-close-btn{position:absolute;top:1rem;right:1rem;z-index:10;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm, 6px);transition:all var(--transition-fast, .15s ease)}.event-modal-close-btn:hover{background:var(--bg-hover);color:var(--text-color)}.event-modal-header{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 2rem 1rem;text-align:center}.event-modal-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:color-mix(in srgb,var(--primary-color) 15%,transparent);color:var(--secondary-color);border-radius:var(--radius-lg, 12px)}.event-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color)}.event-modal-notice{margin:0 2rem;padding:.75rem 1rem;background:color-mix(in srgb,var(--warning-color, #f59e0b) 10%,transparent);border:1px solid color-mix(in srgb,var(--warning-color, #f59e0b) 30%,transparent);border-radius:var(--radius-md, 8px);font-size:.8125rem;color:var(--text-muted)}.event-modal-form{padding:1.5rem 2rem 2rem}.event-modal-form-grid{display:flex;flex-direction:column;gap:1rem}.event-modal-textarea{min-height:80px;resize:vertical}.event-modal-category-select{width:100%;cursor:pointer}.event-modal-header-view{position:relative;padding-bottom:1.5rem;margin-bottom:1.5rem}.event-modal-header-view:after{content:"";position:absolute;bottom:0;left:2rem;right:2rem;height:1px;background:var(--border-color)}.event-modal-header-view h2{word-break:break-word}.event-modal-view-body{display:flex;flex-direction:column;gap:.75rem;padding:0 2rem 1.5rem}.event-modal-view-row{display:flex;align-items:center;gap:.75rem;font-size:.9375rem;color:var(--text-color)}.event-modal-view-row svg{flex-shrink:0;color:var(--text-muted)}.event-modal-view-category{display:inline-flex;padding:.25rem .625rem;border-radius:var(--radius-sm, 6px);font-size:.8125rem;font-weight:500}.event-modal-view-description{margin-top:.5rem;padding:1rem;background:var(--bg-secondary, color-mix(in srgb, var(--card-bg) 90%, black));border-radius:var(--radius-md, 8px);font-size:.9375rem;line-height:1.6;color:var(--text-muted);white-space:pre-wrap}.event-modal-view-body+.event-modal-actions{margin:0 2rem 2rem;padding-top:1.5rem}.event-modal-actions{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem}.event-modal-actions-right{display:flex;gap:.75rem;margin-left:auto}.event-modal-delete-btn{margin-right:auto;background:#fff!important;color:var(--error-color, #ef4444)!important;border-color:var(--error-color, #ef4444)!important}.event-modal-delete-btn:hover{background:var(--error-color, #ef4444)!important;color:#fff!important}.event-modal-icon-danger{background:color-mix(in srgb,var(--error-color, #ef4444) 15%,transparent);color:var(--error-color, #ef4444)}.event-modal-confirm{padding:0 2rem 1.5rem;text-align:center}.event-modal-confirm p{margin:0 0 .5rem;color:var(--text-color);font-size:.9375rem}.event-modal-confirm-hint{color:var(--text-muted)!important;font-size:.8125rem!important}.event-modal-recurrence{display:flex;flex-direction:column;gap:1rem}.event-modal-recurrence-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:var(--text-color)}.event-modal-recurrence-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary-color);cursor:pointer}.event-modal-recurrence-toggle svg{color:var(--text-muted)}.event-modal-recurrence-toggle input:checked+svg{color:var(--secondary-color)}.event-modal-recurrence-options{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;padding:1rem;background:var(--bg-secondary, color-mix(in srgb, var(--card-bg) 90%, black));border-radius:var(--radius-md, 8px);border:1px solid var(--border-color)}.event-modal-recurrence-options select.input{width:100%}.event-modal-scope-options{display:flex;flex-direction:column;gap:.5rem;padding:0 2rem 1.5rem}.event-modal-scope-btn{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:1rem;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);cursor:pointer;transition:all var(--transition-fast, .15s ease);text-align:left}.event-modal-scope-btn:hover{background:var(--bg-hover);border-color:var(--primary-color)}.event-modal-scope-title{font-size:.9375rem;font-weight:500;color:var(--text-color)}.event-modal-scope-desc{font-size:.8125rem;color:var(--text-muted)}@media(max-width:768px){.event-modal-overlay .event-modal{width:95vw;max-width:none;max-height:85vh;margin:auto}.event-modal-close-btn{min-width:44px;min-height:30px}.event-modal-actions button{min-height:30px;font-size:1rem}.event-modal-scope-btn{min-height:30px}}@media(max-width:640px){.event-modal-overlay{padding:0;align-items:flex-end}.event-modal{max-width:100%;border-radius:var(--radius-lg, 12px) var(--radius-lg, 12px) 0 0;max-height:90vh;overflow-y:auto}.event-modal-header{padding:1.5rem 1.5rem 1rem}.event-modal-form{padding:1rem 1.5rem 1.5rem}.event-modal-notice{margin:0 1.5rem}.event-modal-actions{flex-wrap:wrap}.event-modal-actions-right{width:100%;flex-direction:column}.event-modal-actions-right button{width:100%}}.calendar-page{padding:1.5rem;max-width:1200px;margin:0 auto}.calendar-page .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.calendar-page .section-header h1{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-color)}.calendar-page .section-header-actions{display:flex;gap:.5rem;align-items:center}.calendar-page .section-header-actions>*{min-width:143px;text-align:center;justify-content:center}.calendar-view-toggle{padding:0 var(--space-6, 1.5rem);margin-bottom:var(--space-3, .75rem)}.calendar-page .empty-state{text-align:center;padding:3rem;color:var(--text-muted);background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm)}.calendar-page .empty-state svg{margin-bottom:1rem;opacity:.5;color:var(--secondary-color)}.calendar-page .empty-state h3{margin:0 0 .5rem;font-size:1.125rem;color:var(--text-color)}.calendar-page .empty-state p{margin:0 0 1.5rem;font-size:.875rem;max-width:400px;margin-left:auto;margin-right:auto}.calendar-content{background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm);overflow:hidden}.calendar-nav{display:flex;align-items:center;justify-content:center;padding:1rem 1.5rem}.calendar-nav-controls{display:flex;align-items:center;gap:.75rem}.calendar-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:var(--card-bg);border-radius:var(--radius-sm, 6px);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.calendar-nav-btn:hover{color:var(--text-color);background:var(--bg-hover)}.calendar-nav-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-color);min-width:180px;text-align:center}.calendar-today-btn{padding:.375rem .75rem;font-size:.8125rem;font-weight:500;line-height:1;color:var(--text-color);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.calendar-today-btn:hover{background:var(--primary-light);border-color:var(--primary-color)}.month-view{padding:0}.month-grid-header{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border-color)}.month-weekday{padding:.75rem;text-align:center;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-secondary)}.month-grid{display:grid;grid-template-columns:repeat(7,1fr)}.month-day{position:relative;min-height:100px;padding:.5rem;border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);cursor:pointer;transition:background-color var(--transition-fast, .15s ease)}.month-day:nth-child(7n){border-right:none}.month-day:nth-last-child(-n+7){border-bottom:none}.month-day:hover{background:var(--bg-hover)}.month-day.other-month{background:var(--bg-secondary)}.month-day.other-month .month-day-number{color:var(--text-muted);opacity:.5}.month-day.today .month-day-number{background:var(--primary-color);color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.month-day.selected{background:var(--bg-hover)}.month-day-number{font-size:.875rem;font-weight:500;color:var(--text-color);margin-bottom:.25rem}.month-day-events{display:flex;flex-direction:column;gap:2px;max-height:68px;overflow:hidden}.month-day-more{font-size:.625rem;color:var(--text-muted);padding:2px 4px}.event-pill{display:flex;align-items:center;gap:4px;padding:2px 6px;font-size:.625rem;font-weight:500;color:#fff;background:var(--event-color, var(--primary-color));border:none;border-radius:3px;cursor:pointer;text-align:left;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;transition:opacity var(--transition-fast, .15s ease)}.event-pill:hover{opacity:.9}.event-pill-title{overflow:hidden;text-overflow:ellipsis}.event-pill-recurring{opacity:.75;flex-shrink:0}.day-detail-popover{position:absolute;top:0;left:100%;z-index:100;width:280px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);box-shadow:var(--shadow-lg);margin-left:8px}.month-day:nth-child(7n) .day-detail-popover,.month-day:nth-child(7n-1) .day-detail-popover{left:auto;right:100%;margin-left:0;margin-right:8px}.month-day:nth-child(n+29) .day-detail-popover{top:auto;bottom:0}.month-day:nth-child(n+22) .day-detail-popover{top:auto;bottom:0}.day-detail-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border-color)}.day-detail-header h4{margin:0;font-size:.875rem;font-weight:600;color:var(--text-color)}.day-detail-close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm, 6px)}.day-detail-close:hover{background:var(--bg-hover);color:var(--text-color)}.day-detail-events{padding:.5rem;max-height:300px;overflow-y:auto}.day-detail-empty{padding:1rem;text-align:center;color:var(--text-muted);font-size:.875rem;margin:0}.day-detail-event{display:flex;align-items:flex-start;gap:.75rem;width:100%;padding:.75rem;border:none;background:transparent;cursor:pointer;border-radius:var(--radius-sm, 6px);text-align:left;transition:background-color var(--transition-fast, .15s ease)}.day-detail-event:hover{background:var(--bg-hover)}.day-detail-event-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--event-color, var(--primary-color));color:#fff;border-radius:var(--radius-sm, 6px);flex-shrink:0}.day-detail-event-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.day-detail-event-title{font-size:.875rem;font-weight:500;color:var(--text-color)}.day-detail-event-desc{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.day-detail-actions{padding:.5rem}.day-detail-actions button{width:100%;justify-content:center}.week-view{padding:0}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);min-height:400px}.week-day-column{display:flex;flex-direction:column;border-right:1px solid var(--border-color);min-height:100%}.week-day-column:last-child{border-right:none}.week-day-column.today{background:var(--bg-hover)}.week-day-header{display:flex;flex-direction:column;align-items:center;padding:.75rem .5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);gap:.25rem}.week-day-name{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.week-day-date{font-size:1.25rem;font-weight:600;color:var(--text-color);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%}.week-day-date.today{background:var(--primary-color);color:#fff}.week-day-events{flex:1;padding:.5rem;display:flex;flex-direction:column;gap:.5rem;min-height:200px}.week-day-add{display:flex;align-items:center;justify-content:center;gap:.25rem;padding:.75rem;border:2px dashed var(--border-color);background:transparent;border-radius:var(--radius-md, 8px);color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:all var(--transition-fast, .15s ease)}.week-day-add:hover{border-color:var(--primary-color);color:var(--secondary-color);background:var(--bg-hover)}.week-day-add-more{display:flex;align-items:center;justify-content:center;padding:.5rem;border:none;background:var(--bg-secondary);border-top:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.week-day-add-more:hover{background:var(--bg-hover);color:var(--secondary-color)}.event-card{display:flex;flex-direction:column;gap:.25rem;padding:.5rem .75rem;background:var(--event-color, var(--primary-color));border:none;border-radius:var(--radius-sm, 6px);cursor:pointer;text-align:left;color:#fff;transition:opacity var(--transition-fast, .15s ease)}.event-card:hover{opacity:.9}.event-card-header{display:flex;align-items:center;gap:.375rem}.event-card-icon{display:flex;align-items:center;opacity:.9}.event-card-title{font-size:.8125rem;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-card-recurring{display:flex;align-items:center;opacity:.75}.event-card-desc{font-size:.6875rem;opacity:.85;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.agenda-view{padding:0;max-height:600px;overflow-y:auto}.agenda-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:var(--text-muted)}.agenda-empty svg{opacity:.5;margin-bottom:1rem;color:var(--secondary-color)}.agenda-empty h3{margin:0 0 .5rem;font-size:1.125rem;color:var(--text-color)}.agenda-empty p{margin:0;font-size:.875rem}.agenda-list{display:flex;flex-direction:column}.agenda-group{border-bottom:1px solid var(--border-color)}.agenda-group:last-child{border-bottom:none}.agenda-date-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;background:var(--bg-secondary);position:sticky;top:0;z-index:10}.agenda-date-header.today{background:color-mix(in srgb,var(--primary-color) 10%,var(--bg-secondary))}.agenda-date-label{font-size:.875rem;font-weight:600;color:var(--text-color)}.agenda-today-badge{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.125rem .5rem;background:var(--primary-color);color:#fff;border-radius:var(--radius-full, 9999px)}.agenda-events{display:flex;flex-direction:column}.agenda-event{display:flex;align-items:flex-start;gap:.75rem;width:100%;padding:1rem 1.5rem;border:none;background:transparent;cursor:pointer;text-align:left;transition:background-color var(--transition-fast, .15s ease)}.agenda-event:hover{background:var(--bg-hover)}.agenda-event-indicator{width:4px;height:100%;min-height:40px;background:var(--event-color, var(--primary-color));border-radius:2px;flex-shrink:0}.agenda-event-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.agenda-event-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.agenda-event-title{font-size:.9375rem;font-weight:500;color:var(--text-color)}.agenda-event-badge{display:flex;align-items:center;gap:.25rem;font-size:.6875rem;font-weight:500;text-transform:capitalize;padding:.125rem .5rem;background:var(--bg-secondary);color:var(--text-muted);border-radius:var(--radius-sm, 6px)}.agenda-event-recurring{display:flex;align-items:center;color:var(--text-muted)}.agenda-event-desc{font-size:.8125rem;color:var(--text-muted);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.agenda-load-more{display:flex;justify-content:center;padding:1.5rem}.calendar-agenda-view{padding:3rem;text-align:center;color:var(--text-muted);font-size:.875rem}@media(max-width:768px){.calendar-page{padding:1rem}.calendar-page .section-header-actions>*{flex:1;min-width:0}.calendar-view-toggle{padding:0 var(--space-4, 1rem)}.calendar-nav{flex-direction:column;gap:.75rem;padding:.75rem 1rem}.calendar-nav-btn{min-width:44px;min-height:30px}.calendar-nav-title{min-width:auto;text-align:center}.calendar-today-btn{min-height:30px}.month-day{min-height:70px;padding:.375rem}.month-day-events{max-height:42px}.month-weekday{padding:.5rem .25rem;font-size:.6875rem}.event-pill{font-size:.5625rem}.day-detail-popover{position:fixed;inset:auto 0 0;width:100%;border-radius:var(--radius-lg, 12px) var(--radius-lg, 12px) 0 0;margin:0;max-height:70vh}.month-day:nth-child(7n) .day-detail-popover,.month-day:nth-child(7n-1) .day-detail-popover,.month-day:nth-child(n+29) .day-detail-popover,.month-day:nth-child(n+22) .day-detail-popover{inset:auto 0 0;margin:0}.week-grid{grid-template-columns:repeat(7,1fr);min-height:350px}.week-day-header{padding:.5rem .375rem}.week-day-name{font-size:.6875rem}.week-day-date{font-size:1.125rem;width:32px;height:32px}.week-day-events{padding:.375rem;min-height:180px}.event-card{padding:.375rem .5rem}.event-card-title{font-size:.75rem}.event-card-desc{display:none}.week-day-add{padding:.5rem}.agenda-view{max-height:none}.agenda-date-header{padding:.625rem 1rem}.agenda-event{padding:.75rem 1rem}.event-detail-modal{max-width:100%}.event-detail-modal .modal-body{padding:0 1rem 1.5rem}.event-detail-modal .modal-footer{flex-direction:column;padding:1rem 1rem 1.5rem}.event-detail-modal .modal-footer button{width:100%;min-height:30px}.event-detail-header{padding:1.5rem 1rem 1rem}.day-detail-close{min-width:44px;min-height:30px}.reschedule-confirm-modal{max-width:100%}}@media(max-width:640px){.calendar-view-toggle{padding:0 var(--space-4, 1rem)}.calendar-nav{flex-direction:column;gap:.75rem}.month-day{min-height:60px;padding:.25rem}.month-day-events{max-height:36px}.event-pill{font-size:.5rem;padding:1px 3px}.day-detail-popover{position:fixed;inset:auto 0 0;width:100%;border-radius:var(--radius-lg, 12px) var(--radius-lg, 12px) 0 0;margin:0;max-height:60vh}.month-day:nth-child(7n) .day-detail-popover,.month-day:nth-child(7n-1) .day-detail-popover{left:0;right:0;margin:0}.week-grid{grid-template-columns:repeat(7,1fr);min-height:300px}.week-day-header{padding:.5rem .25rem}.week-day-name{font-size:.625rem}.week-day-date{font-size:1rem;width:28px;height:28px}.week-day-events{padding:.25rem;gap:.25rem;min-height:150px}.event-card{padding:.375rem .5rem}.event-card-title{font-size:.6875rem}.event-card-desc{display:none}.week-day-add{padding:.5rem;font-size:.625rem}.week-day-add span{display:none}.agenda-view{max-height:none}.agenda-date-header{padding:.625rem 1rem}.agenda-event{padding:.75rem 1rem}.agenda-event-title{font-size:.875rem}}.event-detail-modal{position:relative;max-width:420px}.event-detail-close-btn{position:absolute;top:1rem;right:1rem;z-index:10;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm, 6px);transition:all var(--transition-fast, .15s ease)}.event-detail-close-btn:hover{background:var(--bg-hover);color:var(--text-color)}.event-detail-header{position:relative;display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 2rem 1.5rem;text-align:center;margin-bottom:.5rem}.event-detail-header:after{content:"";position:absolute;bottom:0;left:2rem;right:2rem;height:1px;background:var(--border-color)}.event-detail-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-lg, 12px);background:var(--bg-secondary);flex-shrink:0}.event-detail-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-color);word-break:break-word}.event-detail-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 0;color:var(--text-muted)}.event-detail-row span{color:var(--text-color);font-size:.9375rem}.event-detail-category-badge{display:inline-flex;padding:.25rem .625rem;border-radius:var(--radius-sm, 6px);font-size:.8125rem;font-weight:500}.event-detail-description{padding:.75rem 0;font-size:.875rem;color:var(--text-muted);line-height:1.5}.event-detail-source{padding-top:2.5rem}.event-detail-source h4{margin:0 0 .75rem;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.event-detail-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.event-detail-label{font-size:.875rem;color:var(--text-muted);padding-right:.3em}.event-detail-value{font-size:.875rem;font-weight:500;color:var(--text-color);text-align:right}.event-pill.draggable{cursor:grab}.event-pill.draggable:active{cursor:grabbing;opacity:.8}.month-day.drag-over{background-color:var(--primary-color-alpha, rgba(59, 130, 246, .1));outline:2px dashed var(--primary-color, #3b82f6);outline-offset:-2px}.reschedule-confirm-modal{max-width:400px}.reschedule-confirm-header{display:flex;align-items:center;gap:.5rem;color:var(--primary-color, #3b82f6)}.reschedule-confirm-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-color)}.reschedule-confirm-message{font-size:1rem;color:var(--text-color);margin:0 0 .75rem}.reschedule-confirm-message strong{color:var(--primary-color, #3b82f6)}.reschedule-confirm-note{font-size:.875rem;color:var(--text-muted);margin:0}.event-detail-modal .modal-body{padding:0 2rem 1.5rem}.event-detail-modal .modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 2rem 2rem}.learn-page{padding:1.5rem;max-width:1200px;margin:0 auto}.learn-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4, 1rem)}.learn-header h1{margin:0;font-size:var(--font-size-2xl, 1.5rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.quick-start-banner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.25rem 1.5rem;margin-bottom:2rem;background:var(--card-bg);border:2px solid transparent;border-left:4px solid var(--primary-color);border-radius:var(--radius-md, 8px);box-shadow:var(--shadow-sm)}.tour-card{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.25rem 1.5rem;margin-bottom:1rem;background:var(--card-bg);border:2px solid transparent;border-left:4px solid #10b981;border-radius:var(--radius-md, 8px);box-shadow:var(--shadow-sm)}.tour-card-content{display:flex;align-items:center;gap:1rem}.tour-card .tour-icon{color:#10b981;flex-shrink:0}.tour-card .tour-text h3{margin:0 0 .125rem;font-size:1rem;font-weight:600;color:var(--text-color)}.tour-card .tour-text p{margin:0;font-size:.875rem;color:var(--text-muted)}.tour-card button{flex-shrink:0;display:flex;align-items:center;gap:.5rem}.quick-start-banner .banner-content{display:flex;align-items:center;gap:1rem}.quick-start-banner .play-icon{color:var(--secondary-color);flex-shrink:0}.quick-start-banner .banner-text h3{margin:0 0 .125rem;font-size:1rem;font-weight:600;color:var(--text-color)}.quick-start-banner .banner-text p{margin:0;font-size:.875rem;color:var(--text-muted)}.quick-start-banner button{flex-shrink:0;display:flex;align-items:center;gap:.5rem}.quick-tips-section{margin-bottom:2rem}.quick-tips-section h2{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:var(--text-color)}.tips-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.tip-card{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm);transition:all var(--transition-fast, .15s ease)}.tip-card .tip-icon{width:36px;height:36px;border-radius:var(--radius-md, 10px);background:var(--primary-light);color:var(--secondary-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.tip-card .tip-content h4{margin:0 0 .25rem;font-size:.9375rem;font-weight:600;color:var(--text-color)}.tip-card .tip-content p{margin:0;font-size:.8125rem;color:var(--text-muted);line-height:1.4}.lessons-section{margin-bottom:2rem}.lessons-section h2{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:var(--text-color)}.lessons-list{display:flex;flex-direction:column;gap:.75rem}.lesson-card{overflow:hidden;transition:all var(--transition-fast, .15s ease);background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm)}.lesson-card.expanded{box-shadow:var(--shadow-md)}.lesson-header{display:flex;align-items:center;gap:1rem;padding:1.25rem;cursor:pointer;transition:background-color var(--transition-fast, .15s ease)}.lesson-header:hover{background:var(--bg-secondary)}.lesson-icon{width:48px;height:48px;border-radius:var(--radius-lg, 12px);background:var(--primary-light);color:var(--secondary-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.lesson-info{flex:1;min-width:0}.lesson-info h3{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:var(--text-color)}.lesson-info p{margin:0;font-size:.8125rem;color:var(--text-muted);line-height:1.4}.lesson-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.lesson-duration{font-size:.75rem;color:var(--text-muted);background:var(--secondary-bg);padding:.25rem .5rem;border-radius:var(--radius-sm, 4px)}.lesson-progress{font-size:.75rem;font-weight:600;color:var(--secondary-color)}.lesson-progress.complete{color:var(--success-color)}.lesson-chevron{color:var(--text-muted);transition:transform var(--transition-fast, .15s ease)}.lesson-card.expanded .lesson-chevron{transform:rotate(0)}.lesson-steps{padding:0 1.25rem 1.25rem;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.lesson-step{display:flex;gap:1rem}.step-connector{display:flex;flex-direction:column;align-items:center;width:32px;flex-shrink:0}.step-check{width:32px;height:32px;border-radius:var(--radius-full, 50%);border:none;background:var(--secondary-bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast, .15s ease);z-index:1}.step-check:hover{background:var(--primary-light);color:var(--secondary-color)}.lesson-step.completed .step-check{background:var(--success-color);color:#fff}.step-line{width:2px;flex:1;min-height:20px;background:var(--border-color);margin:4px 0}.lesson-step.completed .step-line{background:var(--success-color)}.step-content{flex:1;padding-bottom:1.5rem}.lesson-step:last-child .step-content{padding-bottom:0}.step-content h4{margin:0 0 .5rem;font-size:.9375rem;font-weight:600;color:var(--text-color);line-height:32px}.lesson-step.completed .step-content h4{color:var(--text-muted)}.step-content p{margin:0;font-size:.875rem;color:var(--text-muted);line-height:1.5}.step-action{margin-top:.75rem;display:inline-flex;align-items:center;gap:.25rem}.help-cta{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.5rem;background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm)}.help-cta .cta-content h3{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:var(--text-color)}.help-cta .cta-content p{margin:0;font-size:.875rem;color:var(--text-muted)}.help-cta button{flex-shrink:0;display:flex;align-items:center;gap:.5rem}[data-theme=dark] .quick-start-banner,[data-theme=dark] .tour-card{background:var(--card-bg)}[data-theme=dark] .lesson-card.expanded{box-shadow:var(--shadow-md)}@media(max-width:768px){.learn-page{padding:1rem}.learn-header{gap:.75rem}.learn-header h1{font-size:1.375rem}.quick-start-banner{flex-direction:column;gap:1rem;padding:1rem 1.25rem}.quick-start-banner button{width:100%;min-height:30px;justify-content:center}.tips-grid{grid-template-columns:1fr}.tip-card{padding:.875rem}.lesson-header{padding:1rem;gap:.75rem}.lesson-icon{width:40px;height:40px}.lesson-icon svg{width:20px;height:20px}.lesson-steps{padding:0 1rem 1rem}.step-action{min-height:30px}.help-cta{flex-direction:column;gap:1rem}.help-cta button{width:100%;min-height:30px}}@media(max-width:640px){.learn-header,.tour-card{flex-direction:column;text-align:center}.tour-card .tour-card-content{flex-direction:column}.quick-start-banner{flex-direction:column;text-align:center}.quick-start-banner .banner-content{flex-direction:column}.tips-grid{grid-template-columns:1fr}.lesson-header{flex-wrap:wrap}.lesson-meta{flex-direction:row;gap:.5rem;width:100%;margin-top:.5rem;padding-left:64px}.lesson-chevron{position:absolute;right:1rem;top:1.25rem}.lesson-card{position:relative}.help-cta{flex-direction:column;text-align:center}}@media(prefers-reduced-motion:reduce){.lesson-steps{animation:none}.lesson-chevron{transition:none}}.chat-message{display:flex;flex-direction:column;gap:.25rem;max-width:85%}.chat-message--user{align-self:flex-end;align-items:flex-end}.chat-message--assistant{align-self:flex-start;align-items:flex-start}.chat-message__label{font-size:.75rem;font-weight:500;color:var(--text-muted);padding:0 .5rem}.chat-message__bubble{padding:.75rem 1rem;border-radius:var(--radius-lg, 12px);line-height:1.5;font-size:.9375rem}.chat-message--user .chat-message__bubble{background:var(--primary-color);color:#fff;border-bottom-right-radius:var(--radius-sm, 4px)}.chat-message--assistant .chat-message__bubble{background:var(--card-bg);color:var(--text-color);border:1px solid var(--border-color);border-bottom-left-radius:var(--radius-sm, 4px)}.chat-message--system .chat-message__bubble{background:var(--secondary-bg);color:var(--text-muted);font-size:.875rem;font-style:italic}.chat-message__content{word-wrap:break-word;overflow-wrap:break-word}.chat-message__content strong{font-weight:600}.chat-message__content em{font-style:italic}.chat-inline-code{background:#0000001a;padding:.125rem .375rem;border-radius:var(--radius-sm, 4px);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.875em}.chat-message--user .chat-inline-code{background:#fff3}.chat-code-block{margin:.5rem 0;padding:.75rem;background:var(--secondary-bg);border-radius:var(--radius-md, 8px);overflow-x:auto}.chat-code-block code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.8125rem;color:var(--text-color);white-space:pre}.chat-message--user .chat-code-block{background:#00000026}.chat-message--user .chat-code-block code{color:#fff}.chat-list{margin:.5rem 0;padding-left:1.25rem}.chat-list-item{margin:.25rem 0}.chat-list-item--numbered{list-style-type:decimal}.chat-message__loading{display:flex;gap:.25rem;padding:.25rem 0}.chat-message__dot{width:8px;height:8px;background:var(--text-muted);border-radius:50%;animation:chat-dot-bounce 1.4s infinite ease-in-out both}.chat-message__dot:nth-child(1){animation-delay:-.32s}.chat-message__dot:nth-child(2){animation-delay:-.16s}.chat-message__dot:nth-child(3){animation-delay:0s}@keyframes chat-dot-bounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}[data-theme=dark] .chat-inline-code{background:#ffffff1a}[data-theme=dark] .chat-message--user .chat-inline-code{background:#fff3}[data-theme=dark] .chat-code-block{background:#0000004d}@media(max-width:640px){.chat-message{max-width:90%}.chat-message__bubble{padding:.625rem .875rem;font-size:.875rem}}.ai-chat{display:flex;flex-direction:column;height:100%;min-height:500px;max-height:700px;padding:0;overflow:hidden}.ai-chat__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);background:var(--card-bg)}.ai-chat__header-left{display:flex;align-items:center;gap:.75rem}.ai-chat__icon{width:36px;height:36px;border-radius:var(--radius-md, 8px);background:linear-gradient(135deg,var(--primary-color) 0%,#1976d2 100%);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ai-chat__title{margin:0;font-size:1rem;font-weight:600;color:var(--text-color)}.ai-chat__badge{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.25rem .5rem;border-radius:var(--radius-sm, 4px)}.ai-chat__badge--active{background:#dcfce7;color:#166534}[data-theme=dark] .ai-chat__badge--active{background:#22c55e33;color:#4ade80}.ai-chat__settings-btn{padding:.5rem;background:transparent;border:none;border-radius:var(--radius-md, 8px);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.ai-chat__settings-btn:hover{background:var(--secondary-bg);color:var(--text-color)}.ai-chat__messages{flex:1;overflow-y:auto;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:1rem;background:var(--secondary-bg)}.ai-chat__messages::-webkit-scrollbar{width:6px}.ai-chat__messages::-webkit-scrollbar-track{background:transparent}.ai-chat__messages::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.ai-chat__messages::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.ai-chat__error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef2f2;border-top:1px solid #fecaca;color:#991b1b;font-size:.875rem}[data-theme=dark] .ai-chat__error{background:#ef44441a;border-color:#ef44444d;color:#fca5a5}.ai-chat__error svg{flex-shrink:0}.ai-chat__error span{flex:1}.ai-chat__error-dismiss,.ai-chat__error-action{padding:.25rem .5rem;font-size:.75rem;font-weight:500;background:transparent;border:1px solid currentColor;border-radius:var(--radius-sm, 4px);color:inherit;cursor:pointer;transition:all var(--transition-fast, .15s ease)}.ai-chat__error-dismiss:hover,.ai-chat__error-action:hover{background:#0000001a}.ai-chat__error-action{background:#991b1b;border-color:#991b1b;color:#fff}[data-theme=dark] .ai-chat__error-action{background:#dc2626;border-color:#dc2626}.ai-chat__input-area{display:flex;align-items:flex-end;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid var(--border-color);background:var(--card-bg)}.ai-chat__input{flex:1;padding:.75rem 1rem;min-height:30px;max-height:120px;font-size:.9375rem;font-family:inherit;line-height:1.5;color:var(--text-color);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-md, 8px);resize:none;overflow-y:auto;transition:border-color var(--transition-fast, .15s ease)}.ai-chat__input:focus{outline:none;border-color:var(--primary-color)}.ai-chat__input:disabled{opacity:.6;cursor:not-allowed}.ai-chat__input::placeholder{color:var(--text-placeholder)}.ai-chat__send-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--primary-color);border:none;border-radius:var(--radius-md, 8px);color:#fff;cursor:pointer;transition:all var(--transition-fast, .15s ease);flex-shrink:0}.ai-chat__send-btn:hover:not(:disabled){background:var(--primary-hover, #1565c0)}.ai-chat__send-btn:disabled{opacity:.5;cursor:not-allowed}.ai-chat__send-btn:active:not(:disabled){transform:scale(.95)}.ai-chat__footer{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1.25rem;border-top:1px solid var(--border-color);background:var(--card-bg)}.ai-chat__action-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;font-size:.8125rem;font-weight:500;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);color:var(--text-color);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.ai-chat__action-btn:hover:not(:disabled){background:var(--secondary-hover);border-color:var(--primary-color);color:var(--secondary-color)}.ai-chat__action-btn:disabled{opacity:.5;cursor:not-allowed}.ai-chat__action-btn--secondary{background:transparent;border-color:transparent;color:var(--text-muted)}.ai-chat__action-btn--secondary:hover:not(:disabled){background:var(--secondary-bg);border-color:transparent;color:var(--text-color)}.ai-chat__loading-session{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--text-muted);font-size:.875rem}@media(max-width:768px){.ai-chat{min-height:0;max-height:none;height:calc(100vh - 180px);height:calc(100dvh - 180px)}.ai-chat__header{padding:.875rem 1rem}.ai-chat__messages{padding:1rem}.ai-chat__input-area{padding:.875rem 1rem;position:sticky;bottom:0}.ai-chat__input{min-height:30px}.ai-chat__footer{padding:.625rem 1rem;flex-wrap:wrap;gap:.5rem}.ai-chat__action-btn span{display:none}.ai-chat__action-btn{padding:.5rem;min-width:44px;min-height:30px;justify-content:center}}@media(max-width:640px){.ai-chat{min-height:400px;max-height:none;height:calc(100vh - 200px)}.ai-chat__header,.ai-chat__messages,.ai-chat__input-area{padding:.875rem 1rem}.ai-chat__footer{padding:.625rem 1rem;flex-wrap:wrap}.ai-chat__action-btn span{display:none}.ai-chat__action-btn{padding:.5rem}}[data-theme=dark] .ai-chat__icon{background:linear-gradient(135deg,var(--primary-color) 0%,#1565c0 100%)}.ai-chat-placeholder{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;border-radius:var(--radius-lg, 12px);background:var(--card-bg);border:1px solid var(--border-color)}.ai-chat-placeholder--disabled{position:relative}.ai-chat-placeholder__header{display:flex;align-items:center;gap:.75rem}.ai-chat-placeholder__icon{width:48px;height:48px;border-radius:var(--radius-lg, 12px);background:linear-gradient(135deg,var(--primary-color) 0%,#1976d2 100%);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ai-chat-placeholder--disabled .ai-chat-placeholder__icon{background:linear-gradient(135deg,#6b7280,#9ca3af);opacity:.7}.ai-chat-placeholder__title{display:flex;align-items:center;gap:.75rem;flex:1}.ai-chat-placeholder__title h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-color)}.ai-chat-placeholder__badge{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.25rem .5rem;background:var(--secondary-bg);color:var(--text-muted);border-radius:var(--radius-sm, 4px)}.ai-chat-placeholder__badge--setup{background:#fef3c7;color:#92400e}[data-theme=dark] .ai-chat-placeholder__badge--setup{background:#fbbf2433;color:#fbbf24}.ai-chat-placeholder__body{display:flex;flex-direction:column;gap:1rem}.ai-chat-placeholder__description{margin:0;font-size:.9375rem;color:var(--text-muted);line-height:1.5}.ai-chat-placeholder__features{display:flex;flex-direction:column;gap:.5rem}.ai-chat-placeholder__features-intro{margin:0;font-size:.875rem;font-weight:500;color:var(--text-color)}.ai-chat-placeholder__features-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.ai-chat-placeholder__features-list li{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-muted)}.ai-chat-placeholder__features-list li svg{color:var(--secondary-color);flex-shrink:0}.ai-chat-placeholder__preview{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--secondary-bg);border-radius:var(--radius-md, 8px);opacity:.7}.ai-chat-placeholder__preview--disabled{opacity:.4;filter:grayscale(40%)}.ai-chat-placeholder__message{padding:.625rem .875rem;border-radius:var(--radius-md, 8px);font-size:.875rem;line-height:1.4;max-width:85%}.ai-chat-placeholder__message--user{background:var(--primary-color);color:#fff;align-self:flex-end}.ai-chat-placeholder__message--ai{background:var(--card-bg);color:var(--text-color);border:1px solid var(--border-color);align-self:flex-start}.ai-chat-placeholder__message--disabled{opacity:.6}.ai-chat-placeholder__message--disabled.ai-chat-placeholder__message--user{background:#9ca3af}.ai-chat-placeholder__input-preview{margin-top:.25rem}.ai-chat-placeholder__input{width:100%;padding:.75rem 1rem;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);font-size:.875rem;color:var(--text-muted);cursor:not-allowed;opacity:.5}.ai-chat-placeholder__input:disabled{background:var(--secondary-bg)}.ai-chat-placeholder__input::placeholder{color:var(--text-muted);opacity:.7}.ai-chat-placeholder__setup-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem 1rem;background:var(--secondary-bg);border:1px dashed var(--border-color);border-radius:var(--radius-md, 8px);color:var(--text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast, .15s ease)}.ai-chat-placeholder__setup-button--primary{background:var(--primary-color);border:none;color:#fff;padding:.875rem 1.5rem;font-weight:600;box-shadow:0 2px 4px #0000001a}.ai-chat-placeholder__setup-button--primary:hover{background:var(--primary-hover, #1565c0);transform:translateY(-1px);box-shadow:var(--shadow-md)}.ai-chat-placeholder__setup-button:hover{background:var(--secondary-hover);border-color:var(--primary-color);color:var(--secondary-color)}.ai-chat-placeholder__setup-button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}@media(max-width:768px){.ai-chat-placeholder{padding:1.25rem}.ai-chat-placeholder__icon{width:40px;height:40px}.ai-chat-placeholder__icon svg{width:20px;height:20px}.ai-chat-placeholder__title h3{font-size:1rem}.ai-chat-placeholder__message{max-width:90%}.ai-chat-placeholder__setup-button,.ai-chat-placeholder__setup-button--primary{min-height:30px}}@media(max-width:640px){.ai-chat-placeholder{padding:1.25rem}.ai-chat-placeholder__icon{width:40px;height:40px}.ai-chat-placeholder__icon svg{width:20px;height:20px}.ai-chat-placeholder__title h3{font-size:1rem}.ai-chat-placeholder__features-list li{font-size:.8125rem}}.chat-history{display:flex;flex-direction:column;height:100%;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg, 12px);overflow:hidden}.chat-history__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);background:var(--card-bg)}.chat-history__title{margin:0;font-size:.9375rem;font-weight:600;color:var(--text-color);display:flex;align-items:center;gap:.5rem}.chat-history__title svg{color:var(--text-muted)}.chat-history__new-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;font-size:.8125rem;font-weight:500;background:var(--primary-color);border:none;border-radius:var(--radius-md, 8px);color:#fff;cursor:pointer;transition:all var(--transition-fast, .15s ease)}.chat-history__new-btn:hover{background:var(--primary-hover, #1565c0)}.chat-history__new-btn:active{transform:scale(.98)}.chat-history__list{flex:1;overflow-y:auto;padding:.5rem}.chat-history__list::-webkit-scrollbar{width:6px}.chat-history__list::-webkit-scrollbar-track{background:transparent}.chat-history__list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.chat-history__list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.chat-history__group{margin-bottom:.75rem}.chat-history__group-title{padding:.5rem .75rem .375rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.chat-history__item{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;margin-bottom:.25rem;background:transparent;border:none;border-radius:var(--radius-md, 8px);cursor:pointer;transition:all var(--transition-fast, .15s ease);width:100%;text-align:left}.chat-history__item:hover{background:var(--secondary-bg)}.chat-history__item--active{background:var(--primary-light, rgba(33, 150, 243, .1));border:1px solid var(--primary-color)}.chat-history__item-content{flex:1;min-width:0}.chat-history__item-title{font-size:.875rem;font-weight:500;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0 0 .125rem}.chat-history__item-date{font-size:.75rem;color:var(--text-muted);margin:0}.chat-history__item-edit{width:100%;padding:.25rem .5rem;font-size:.875rem;font-family:inherit;color:var(--text-color);background:var(--input-bg);border:1px solid var(--primary-color);border-radius:var(--radius-sm, 4px);outline:none}.chat-history__item-actions{display:flex;gap:.25rem;opacity:0;transition:opacity var(--transition-fast, .15s ease)}.chat-history__item:hover .chat-history__item-actions{opacity:1}.chat-history__item-btn{padding:.375rem;background:transparent;border:none;border-radius:var(--radius-sm, 4px);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.chat-history__item-btn:hover{background:var(--secondary-hover);color:var(--text-color)}.chat-history__item-btn--danger:hover{background:#ef44441a;color:#dc2626}[data-theme=dark] .chat-history__item-btn--danger:hover{background:#ef444433;color:#f87171}.chat-history__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;text-align:center;color:var(--text-muted)}.chat-history__empty-icon{width:48px;height:48px;margin-bottom:1rem;padding:.75rem;background:var(--secondary-bg);border-radius:50%;color:var(--text-muted)}.chat-history__empty p{margin:0 0 .25rem;font-size:.875rem;font-weight:500;color:var(--text-color)}.chat-history__empty span{font-size:.8125rem}.chat-history__loading{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--text-muted);font-size:.875rem}.chat-history__confirm{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#00000080;z-index:1000;padding:1rem}.chat-history__confirm-content{background:var(--card-bg);border-radius:var(--radius-lg, 12px);padding:1.5rem;max-width:320px;width:100%;box-shadow:var(--shadow-lg)}.chat-history__confirm-title{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--text-color)}.chat-history__confirm-text{margin:0 0 1.25rem;font-size:.875rem;color:var(--text-muted);line-height:1.5}.chat-history__confirm-actions{display:flex;gap:.75rem;justify-content:flex-end}.chat-history__confirm-btn{padding:.5rem 1rem;font-size:.8125rem;font-weight:500;border-radius:var(--radius-md, 8px);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.chat-history__confirm-btn--cancel{background:var(--secondary-bg);border:1px solid var(--border-color);color:var(--text-color)}.chat-history__confirm-btn--cancel:hover{background:var(--secondary-hover)}.chat-history__confirm-btn--delete{background:#dc2626;border:none;color:#fff}.chat-history__confirm-btn--delete:hover{background:#b91c1c}@media(max-width:1024px){.chat-history{position:fixed;top:0;left:-280px;width:280px;height:100vh;border-radius:0;border-right:1px solid var(--border-color);z-index:100;transition:left var(--transition-normal, .2s ease)}.chat-history--open{left:0}.chat-history__overlay{position:fixed;inset:0;background:#0000004d;z-index:99}}.flow-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.5rem 1rem;gap:.75rem;cursor:pointer;border-radius:var(--radius-lg, 12px);transition:all var(--transition-fast, .15s ease)}.flow-card__icon{width:48px;height:48px;border-radius:var(--radius-lg, 12px);background:var(--primary-light);color:var(--secondary-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.flow-card__content{display:flex;flex-direction:column;gap:.25rem}.flow-card__title{margin:0;font-size:.9375rem;font-weight:600;color:var(--text-color);line-height:1.3}.flow-card__description{margin:0;font-size:.8125rem;color:var(--text-muted);line-height:1.4}@media(max-width:768px){.flow-card{padding:1.25rem .875rem;min-height:30px}.flow-card__icon{width:40px;height:40px}.flow-card__icon svg{width:20px;height:20px}.flow-card__title{font-size:.875rem}.flow-card__description{font-size:.75rem}}@media(max-width:640px){.flow-card{padding:1.25rem 1rem}.flow-card__icon{width:40px;height:40px}.flow-card__icon svg{width:20px;height:20px}}.flow-modal-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#00000080;z-index:1000;padding:1rem;animation:fadeIn .15s ease-out}.flow-modal-overlay--animated{animation:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.flow-modal{width:100%;max-width:520px;max-height:calc(100vh - 2rem);background:var(--card-bg);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-lg, 0 10px 40px rgba(0, 0, 0, .15));display:flex;flex-direction:column;overflow:hidden;animation:slideIn .2s ease-out}.flow-modal--animated{animation:none}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.flow-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.flow-modal__title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-color)}.flow-modal__close{margin:-.5rem;color:var(--text-muted)}.flow-modal__close:hover{color:var(--text-color)}.flow-modal__inner{display:contents}.flow-modal__content{flex:1;overflow-y:auto;padding:1.5rem}@media(max-width:768px){.flow-modal{width:95vw;max-width:none;max-height:85vh}.flow-modal__close{min-width:44px;min-height:30px}.flow-modal__content{overflow-y:auto}}@media(max-width:640px){.flow-modal-overlay{padding:0;align-items:flex-end}.flow-modal:not(.flow-modal--animated){max-width:100%;max-height:90vh;border-radius:var(--radius-lg, 12px) var(--radius-lg, 12px) 0 0;animation:slideUp .25s ease-out}.flow-modal--animated{max-width:100%;max-height:90vh;border-radius:var(--radius-lg, 12px) var(--radius-lg, 12px) 0 0}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.flow-modal__header{padding:1rem 1.25rem}.flow-modal__content{padding:1.25rem}}[data-theme=dark] .flow-modal-overlay{background:#000000b3}.affordability-form{display:flex;flex-direction:column;gap:1.5rem}.affordability-form__field{display:flex;flex-direction:column;gap:.5rem}.affordability-form__label{font-size:.875rem;font-weight:500;color:var(--text-color)}.affordability-form__helper{font-size:.75rem;color:var(--text-muted)}.affordability-form__input-wrapper{position:relative;display:flex;align-items:center}.affordability-form__currency{position:absolute;left:.875rem;font-size:1.25rem;font-weight:500;color:var(--text-muted);pointer-events:none}.affordability-form__amount{padding-left:2rem;font-size:1.5rem;font-weight:600;height:3.5rem}.affordability-form__amount::placeholder{font-weight:400}.affordability-form__toggle-group{display:flex;gap:0;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);overflow:hidden}.affordability-form__toggle{flex:1;padding:.75rem 1rem;font-size:.875rem;font-weight:500;font-family:inherit;background:var(--card-bg);border:none;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.affordability-form__toggle:not(:last-child){border-right:1px solid var(--border-color)}.affordability-form__toggle:hover{background:var(--secondary-bg)}.affordability-form__toggle--active{background:var(--primary-color);color:#fff}.affordability-form__toggle--active:hover{background:var(--primary-hover, #1565c0)}.affordability-form__actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.affordability-result{display:flex;flex-direction:column;gap:1.25rem}.affordability-verdict{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.5rem;border-radius:var(--radius-md, 8px)}.affordability-verdict__icon{margin-bottom:.5rem}.affordability-verdict__title{margin:0;font-size:1.5rem;font-weight:700}.affordability-verdict__reason{margin:.5rem 0 0;font-size:.9375rem;opacity:.9}.affordability-verdict--yes{background:#dcfce7;color:#166534}.affordability-verdict--yes .affordability-verdict__icon{color:#22c55e}.affordability-verdict--maybe{background:#fef3c7;color:#92400e}.affordability-verdict--maybe .affordability-verdict__icon{color:#f59e0b}.affordability-verdict--no{background:#fef2f2;color:#991b1b}.affordability-verdict--no .affordability-verdict__icon{color:#ef4444}[data-theme=dark] .affordability-verdict--yes{background:#22c55e26;color:#86efac}[data-theme=dark] .affordability-verdict--maybe{background:#f59e0b26;color:#fcd34d}[data-theme=dark] .affordability-verdict--no{background:#ef444426;color:#fca5a5}.affordability-card{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);padding:1rem}.affordability-card__title{margin:0 0 .75rem;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.affordability-card__row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;font-size:.9375rem;color:var(--text-color)}.affordability-card__row:not(:last-child){border-bottom:1px solid var(--border-color)}.affordability-card__row span:last-child{font-weight:500;text-align:right}.affordability-card__arrow{color:var(--text-muted);margin:0 .25rem}.affordability-card__negative{color:var(--error-color, #ef4444)}.affordability-card__positive{color:var(--success-color, #22c55e)}.affordability-insight{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#eff6ff;border-radius:var(--radius-md, 8px);color:#1e40af;font-size:.9375rem}.affordability-insight svg{flex-shrink:0;margin-top:.125rem}[data-theme=dark] .affordability-insight{background:#3b82f626;color:#93c5fd}.affordability-result__actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem;padding-top:1rem;border-top:1px solid var(--border-color);flex-wrap:wrap}@media(max-width:768px){.affordability-form__actions button,.affordability-result__actions button{min-height:30px;font-size:1rem}.affordability-form__toggle{min-height:30px}.affordability-card{overflow-x:auto}}@media(max-width:480px){.affordability-verdict{padding:1rem}.affordability-verdict__title{font-size:1.25rem}.affordability-verdict__reason{font-size:.875rem}.affordability-card__row{flex-direction:column;align-items:flex-start;gap:.25rem}.affordability-card__row span:last-child{text-align:left}.affordability-result__actions{flex-direction:column}.affordability-result__actions button{width:100%}}.health-flow{display:flex;flex-direction:column;gap:1.25rem}.health-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;gap:1rem}.health-loading__spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.health-loading p{color:var(--text-muted);font-size:.9375rem}.health-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;gap:1rem;text-align:center}.health-error p{color:var(--text-muted)}.health-score{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;border-radius:var(--radius-lg, 12px);text-align:center}.health-score__grade{font-size:3.5rem;font-weight:800;line-height:1}.health-score__percent{font-size:1.25rem;font-weight:600;margin-top:.25rem}.health-score__label{font-size:1rem;font-weight:500;margin-top:.25rem;opacity:.9}.health-score--a{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534}.health-score--b{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857}.health-score--c{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.health-score--d{background:linear-gradient(135deg,#ffedd5,#fed7aa);color:#c2410c}.health-score--f{background:linear-gradient(135deg,#fef2f2,#fecaca);color:#991b1b}[data-theme=dark] .health-score--a{background:linear-gradient(135deg,#22c55e33,#22c55e1a);color:#86efac}[data-theme=dark] .health-score--b{background:linear-gradient(135deg,#10b98133,#10b9811a);color:#6ee7b7}[data-theme=dark] .health-score--c{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);color:#fcd34d}[data-theme=dark] .health-score--d{background:linear-gradient(135deg,#f9731633,#f973161a);color:#fdba74}[data-theme=dark] .health-score--f{background:linear-gradient(135deg,#ef444433,#ef44441a);color:#fca5a5}.health-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);overflow:hidden}.health-section__title{display:flex;align-items:center;gap:.5rem;margin:0;padding:.875rem 1rem;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color)}.health-section--concerns .health-section__title{color:var(--error-color, #ef4444);background:#ef44440d}.health-section--strengths .health-section__title{color:var(--success-color, #22c55e);background:#22c55e0d}.health-section--actions .health-section__title{color:var(--primary-color, #1976d2);background:#1976d20d}[data-theme=dark] .health-section--concerns .health-section__title{background:#ef44441a}[data-theme=dark] .health-section--strengths .health-section__title{background:#22c55e1a}[data-theme=dark] .health-section--actions .health-section__title{background:#1976d21a}.health-section__list{display:flex;flex-direction:column}.health-item{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;border-bottom:1px solid var(--border-color)}.health-item:last-child{border-bottom:none}.health-item__icon{font-size:1.125rem;line-height:1.4;flex-shrink:0}.health-item__content{display:flex;flex-direction:column;gap:.125rem;min-width:0}.health-item__title{font-size:.9375rem;font-weight:500;color:var(--text-color)}.health-item__description{font-size:.8125rem;color:var(--text-muted)}.health-item--high{background:#ef444408}.health-item--medium{background:#f59e0b08}.health-item--strength{background:#22c55e08}[data-theme=dark] .health-item--high{background:#ef44440d}[data-theme=dark] .health-item--medium{background:#f59e0b0d}[data-theme=dark] .health-item--strength{background:#22c55e0d}.health-action{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;border-bottom:1px solid var(--border-color)}.health-action:last-child{border-bottom:none}.health-action__number{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;background:var(--primary-color);color:#fff;font-size:.75rem;font-weight:600;border-radius:50%;flex-shrink:0}.health-action__content{display:flex;flex-direction:column;gap:.125rem;min-width:0}.health-action__title{font-size:.9375rem;font-weight:500;color:var(--text-color)}.health-action__description{font-size:.8125rem;color:var(--text-muted)}.health-flow__actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}@media(max-width:768px){.health-flow__actions button{min-height:30px;font-size:1rem}.health-section{overflow-x:auto}.health-item,.health-action{min-height:30px}}@media(max-width:480px){.health-score{padding:1.25rem}.health-score__grade{font-size:2.5rem}.health-score__percent{font-size:1rem}.health-item,.health-action{padding:.75rem}.health-flow__actions{flex-direction:column}.health-flow__actions button{width:100%}}.savings-flow{display:flex;flex-direction:column;gap:1.5rem;padding:.5rem}.savings-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.savings-loading__spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.savings-error{text-align:center;padding:2rem}.savings-current{display:flex;flex-direction:column;align-items:center;padding:1.5rem;background:var(--color-surface-secondary);border-radius:12px;gap:.5rem}.savings-current__label{font-size:.875rem;color:var(--color-text-secondary)}.savings-current__rate{display:flex;align-items:center;gap:.5rem;color:var(--color-primary)}.savings-current__percent{font-size:2.5rem;font-weight:700}.savings-current__amount{font-size:.875rem;color:var(--color-text-secondary)}.savings-target{display:flex;flex-direction:column;gap:.75rem}.savings-target__title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;margin:0;color:var(--color-text-primary)}.savings-target__presets{display:flex;gap:.5rem;flex-wrap:wrap}.savings-target__preset{display:flex;flex-direction:column;align-items:center;padding:.75rem 1rem;border:2px solid var(--color-border);border-radius:8px;background:var(--color-surface);cursor:pointer;transition:all .15s ease;min-width:70px}.savings-target__preset:hover{border-color:var(--color-primary);background:var(--color-surface-secondary)}.savings-target__preset--active{border-color:var(--color-primary);background:var(--color-primary-light)}.savings-target__preset-value{font-weight:600;font-size:1rem}.savings-target__preset-desc{font-size:.75rem;color:var(--color-text-secondary)}.savings-target__custom{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.savings-target__input{width:80px;padding:.5rem;border:2px solid var(--color-border);border-radius:6px;font-size:1rem;text-align:center;background:var(--color-surface);color:var(--color-text-primary)}.savings-target__input:focus{outline:none;border-color:var(--color-primary)}.savings-target__input-suffix{font-weight:600;color:var(--color-text-secondary)}.savings-gap{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.5rem;padding:1rem;background:var(--color-warning-light, #fef3cd);border-radius:8px;font-size:.9375rem}.savings-gap--success{background:var(--color-success-light, #d4edda);color:var(--color-success, #155724)}.savings-gap__label{color:var(--color-text-secondary)}.savings-gap__amount{font-weight:700;color:var(--color-warning-dark, #856404)}.savings-gap__percent{color:var(--color-text-secondary)}.savings-suggestions{display:flex;flex-direction:column;gap:.75rem}.savings-suggestions__title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;margin:0;color:var(--color-text-primary)}.savings-suggestions__subtitle{font-size:.875rem;color:var(--color-text-secondary);margin:0}.savings-suggestions__list{display:flex;flex-direction:column;gap:.5rem}.suggestion-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border:2px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .15s ease;background:var(--color-surface)}.suggestion-item:hover{border-color:var(--color-primary);background:var(--color-surface-secondary)}.suggestion-item--selected{border-color:var(--color-primary);background:var(--color-primary-light)}.suggestion-item__checkbox{margin-top:.25rem;accent-color:var(--color-primary);width:18px;height:18px;cursor:pointer}.suggestion-item__content{flex:1;min-width:0}.suggestion-item__header{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.suggestion-item__name{font-weight:600;color:var(--color-text-primary)}.suggestion-item__reduction{font-weight:700;color:var(--color-success);white-space:nowrap}.suggestion-item__details{display:flex;flex-direction:column;gap:.25rem;margin-top:.25rem}.suggestion-item__current{font-size:.8125rem;color:var(--color-text-secondary)}.suggestion-item__rationale{font-size:.8125rem;font-style:italic;color:var(--color-text-tertiary)}.savings-projected{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:var(--color-surface-secondary);border-radius:8px;margin-top:.5rem}.savings-projected__label{font-size:.875rem;color:var(--color-text-secondary)}.savings-projected__rate{font-size:1.25rem;font-weight:700;color:var(--color-primary)}.savings-projected__check{color:var(--color-success)}.savings-no-suggestions{text-align:center;padding:1.5rem;background:var(--color-surface-secondary);border-radius:8px}.savings-no-suggestions__hint{font-size:.875rem;color:var(--color-text-secondary);margin-top:.5rem}.savings-flow__actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--color-border)}@media(max-width:768px){.savings-flow__actions button{min-height:30px;font-size:1rem}.savings-target__preset,.suggestion-item{min-height:30px}.savings-suggestions__list{overflow-x:auto}}@media(max-width:480px){.savings-target__presets{justify-content:center}.savings-current__percent{font-size:2rem}.savings-gap{flex-direction:column;text-align:center}}.debt-flow{display:flex;flex-direction:column;gap:1.5rem;padding:.5rem}.debt-list{display:flex;flex-direction:column;gap:.5rem}.debt-list__title{font-size:.875rem;font-weight:600;color:var(--color-text-secondary);margin:0 0 .25rem}.debt-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:var(--color-surface-secondary);border-radius:8px;gap:.75rem}.debt-item__info{display:flex;flex-direction:column;gap:.125rem;flex:1;min-width:0}.debt-item__name{font-weight:600;color:var(--color-text-primary)}.debt-item__details{font-size:.8125rem;color:var(--color-text-secondary)}.debt-item__remove{color:var(--color-error);flex-shrink:0}.debt-form{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:var(--color-surface-secondary);border-radius:12px}.debt-form__title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;margin:0;color:var(--color-text-primary)}.debt-form__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.debt-form__field{display:flex;flex-direction:column;gap:.25rem}.debt-form__field label{font-size:.75rem;font-weight:500;color:var(--color-text-secondary)}.debt-form__add-btn{align-self:flex-start;margin-top:.25rem}.debt-extra{display:flex;flex-direction:column;gap:.5rem}.debt-extra__label{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.debt-extra__hint{font-weight:400;color:var(--color-text-secondary);margin-left:.25rem}.debt-extra__input{display:flex;align-items:center;gap:.25rem;max-width:150px}.debt-extra__prefix{font-weight:600;color:var(--color-text-secondary)}.debt-results{display:flex;flex-direction:column;gap:1.25rem}.debt-summary{display:flex;justify-content:center;gap:2rem;padding:1rem;background:var(--color-surface-secondary);border-radius:12px}.debt-summary__stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.debt-summary__label{font-size:.75rem;color:var(--color-text-secondary)}.debt-summary__value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.debt-recommendation{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:var(--color-primary-light);border-radius:10px;border-left:4px solid var(--color-primary)}.debt-recommendation__icon{color:var(--color-primary);flex-shrink:0;margin-top:.125rem}.debt-recommendation__content{display:flex;flex-direction:column;gap:.25rem}.debt-recommendation__title{font-weight:600;color:var(--color-text-primary)}.debt-recommendation__reason{font-size:.875rem;color:var(--color-text-secondary)}.debt-methods{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.debt-method{display:flex;flex-direction:column;gap:.75rem;padding:1rem;border:2px solid var(--color-border);border-radius:12px;background:var(--color-surface);cursor:pointer;transition:all .15s ease;text-align:left}.debt-method:hover{border-color:var(--color-primary);background:var(--color-surface-secondary)}.debt-method--active{border-color:var(--color-primary);background:var(--color-primary-light)}.debt-method__header{display:flex;align-items:center;gap:.5rem;color:var(--color-text-primary)}.debt-method__name{font-weight:600}.debt-method__badge{font-size:.625rem;font-weight:700;text-transform:uppercase;padding:.125rem .375rem;background:var(--color-success);color:#fff;border-radius:4px;margin-left:auto}.debt-method__snowball-icon{font-size:1rem}.debt-method__stats{display:flex;flex-direction:column;gap:.5rem}.debt-method__stat{display:flex;justify-content:space-between;align-items:center;font-size:.8125rem}.debt-method__stat-label{color:var(--color-text-secondary)}.debt-method__stat-value{font-weight:600;color:var(--color-text-primary)}.debt-savings{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--color-success-light, #d4edda);border-radius:8px;font-size:.875rem;color:var(--color-success-dark, #155724)}.debt-savings strong{font-weight:700}.debt-timeline{display:flex;flex-direction:column;gap:.75rem}.debt-timeline__title{font-size:.875rem;font-weight:600;margin:0;color:var(--color-text-primary)}.debt-timeline__list{display:flex;flex-direction:column;gap:.5rem}.debt-timeline__item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;background:var(--color-surface-secondary);border-radius:8px}.debt-timeline__order{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--color-primary);color:#fff;border-radius:50%;font-size:.75rem;font-weight:700;flex-shrink:0}.debt-timeline__info{display:flex;flex-direction:column;gap:.125rem;flex:1;min-width:0}.debt-timeline__name{font-weight:600;color:var(--color-text-primary)}.debt-timeline__detail{font-size:.8125rem;color:var(--color-text-secondary)}.debt-timeline__interest{font-size:.75rem;color:var(--color-text-tertiary);white-space:nowrap}.debt-flow__actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--color-border)}@media(max-width:768px){.debt-flow__actions button{min-height:30px;font-size:1rem}.debt-form__add-btn,.debt-method{min-height:30px}.debt-item__remove{min-width:44px;min-height:30px}}@media(max-width:480px){.debt-form__grid,.debt-methods{grid-template-columns:1fr}.debt-summary{flex-direction:column;gap:1rem}}.emergency-flow{display:flex;flex-direction:column;gap:1.5rem;padding:.5rem}.emergency-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.emergency-loading__spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.emergency-error{text-align:center;padding:2rem}.emergency-expenses{background:var(--color-surface-secondary);border-radius:12px;padding:1rem}.emergency-expenses__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.emergency-expenses__label{font-size:.875rem;color:var(--color-text-secondary)}.emergency-expenses__amount{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.emergency-expenses__breakdown{display:flex;flex-direction:column;gap:.375rem}.emergency-expenses__item{display:flex;justify-content:space-between;font-size:.8125rem}.emergency-expenses__category{color:var(--color-text-secondary)}.emergency-expenses__value{color:var(--color-text-primary);font-weight:500}.emergency-target{display:flex;flex-direction:column;gap:.75rem}.emergency-target__title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;margin:0;color:var(--color-text-primary)}.emergency-target__options{display:flex;gap:.5rem}.emergency-target__option{flex:1;display:flex;flex-direction:column;align-items:center;padding:.75rem;border:2px solid var(--color-border);border-radius:8px;background:var(--color-surface);cursor:pointer;transition:all .15s ease}.emergency-target__option:hover{border-color:var(--color-primary);background:var(--color-surface-secondary)}.emergency-target__option--active{border-color:var(--color-primary);background:var(--color-primary-light)}.emergency-target__option-value{font-weight:600;font-size:.9375rem;color:var(--color-text-primary)}.emergency-target__option-desc{font-size:.6875rem;color:var(--color-text-secondary);margin-top:.125rem}.emergency-goal{display:flex;justify-content:center}.emergency-goal__target{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:var(--color-primary-light);border-radius:12px;color:var(--color-primary)}.emergency-goal__info{display:flex;flex-direction:column;gap:.125rem}.emergency-goal__label{font-size:.75rem;opacity:.8}.emergency-goal__amount{font-size:1.5rem;font-weight:700}.emergency-progress{display:flex;flex-direction:column;gap:.5rem}.emergency-progress__header{display:flex;justify-content:space-between;align-items:center}.emergency-progress__label{font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.emergency-progress__percent{font-size:.875rem;font-weight:700;color:var(--color-primary)}.emergency-progress__bar{height:12px;background:var(--color-border);border-radius:6px;overflow:hidden}.emergency-progress__fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-success));border-radius:6px;transition:width .3s ease}.emergency-progress__amounts{display:flex;justify-content:space-between;font-size:.8125rem;color:var(--color-text-secondary)}.emergency-plan{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:var(--color-surface-secondary);border-radius:12px}.emergency-plan__title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;margin:0;color:var(--color-text-primary)}.emergency-plan__grid{display:flex;justify-content:space-around;gap:1rem}.emergency-plan__stat{display:flex;flex-direction:column;align-items:center;gap:.25rem;text-align:center}.emergency-plan__stat svg{color:var(--color-text-tertiary);margin-bottom:.125rem}.emergency-plan__stat-value{font-size:1.125rem;font-weight:700;color:var(--color-text-primary)}.emergency-plan__stat-label{font-size:.75rem;color:var(--color-text-secondary)}.emergency-recommendations{display:flex;flex-direction:column;gap:.5rem}.emergency-recommendation{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;background:var(--color-surface-secondary);border-radius:8px;font-size:.875rem;color:var(--color-text-secondary)}.emergency-recommendation__bullet{flex-shrink:0}.emergency-flow__actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--color-border)}@media(max-width:768px){.emergency-flow__actions button{min-height:30px;font-size:1rem}.emergency-target__option{min-height:30px}.emergency-expenses{overflow-x:auto}}@media(max-width:480px){.emergency-target__options{flex-direction:column}.emergency-plan__grid{flex-direction:column;gap:.75rem}}.patterns-flow{display:flex;flex-direction:column;gap:1.5rem;padding:.5rem}.patterns-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.patterns-loading__spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.patterns-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem;text-align:center;color:var(--text-muted)}.patterns-empty__hint{font-size:.875rem;color:var(--text-muted);opacity:.8}.donut-chart{position:relative;display:flex;justify-content:center;align-items:center;padding:.5rem 0}.donut-chart__center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.donut-chart__total{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.donut-chart__label{font-size:.75rem;color:var(--text-muted)}.patterns-flow .chart-tooltip{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:.75rem 1rem;box-shadow:0 4px 12px #00000026}.patterns-flow .chart-tooltip__name{font-size:.8125rem;color:var(--text-muted);margin-bottom:.25rem}.patterns-flow .chart-tooltip__amount{font-size:1rem;font-weight:600;color:var(--text-color)}.patterns-flow .chart-tooltip__percentage{font-size:.75rem;color:var(--text-muted);margin-top:.125rem}.patterns-summary{display:flex;justify-content:center;gap:3rem}.patterns-summary__stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.patterns-summary__value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.patterns-summary__label{font-size:.75rem;color:var(--text-muted)}.patterns-breakdown{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:var(--surface-secondary);border-radius:12px}.patterns-breakdown__title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;margin:0;color:var(--text-primary)}.patterns-breakdown__bars{display:flex;flex-direction:column;gap:.75rem}.patterns-bar__header{display:flex;justify-content:space-between;font-size:.8125rem;color:var(--text-muted);margin-bottom:.25rem}.patterns-bar__track{height:8px;background:var(--border-color);border-radius:4px;overflow:hidden}.patterns-bar__fill{height:100%;border-radius:4px;transition:width .3s ease}.patterns-bar__fill--recurring{background:var(--primary-color)}.patterns-bar__fill--onetime{background:var(--warning-color, #f59e0b)}.patterns-callouts{display:flex;flex-direction:column;gap:.5rem}.patterns-callout{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;font-size:.875rem}.patterns-callout--increase{background:var(--warning-bg, #fef3cd);color:var(--warning-text, #856404)}.patterns-callout--decrease{background:var(--success-bg, #d4edda);color:var(--success-text, #155724)}.patterns-callout strong{font-weight:600}.patterns-categories{display:flex;flex-direction:column;gap:.5rem}.patterns-categories__title{font-size:.875rem;font-weight:600;margin:0 0 .25rem;color:var(--text-primary)}.category-row{display:flex;flex-direction:column;border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.category-row__header{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--surface-color);cursor:pointer;border:none;width:100%;text-align:left;transition:background .15s ease;font-family:inherit;font-size:inherit}.category-row__header:hover:not(:disabled){background:var(--surface-secondary)}.category-row__header:disabled{cursor:default}.category-row__color{width:12px;height:12px;border-radius:3px;flex-shrink:0}.category-row__name{flex:1;font-weight:500;color:var(--text-primary)}.category-row__amount{font-weight:600;color:var(--text-primary)}.category-row__percent{font-size:.8125rem;color:var(--text-muted);min-width:45px;text-align:right}.category-row__chevron{color:var(--text-muted);display:flex;align-items:center}.category-row__items{display:flex;flex-direction:column;background:var(--surface-secondary);border-top:1px solid var(--border-color)}.category-row__item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem .5rem 2rem;font-size:.8125rem}.category-row__item:not(:last-child){border-bottom:1px solid var(--border-color)}.category-row__item-name{display:flex;align-items:center;gap:.5rem;color:var(--text-muted)}.category-row__item-badge{font-size:.625rem;font-weight:600;text-transform:uppercase;padding:.125rem .375rem;background:var(--primary-light, #e0e7ff);color:var(--secondary-color);border-radius:4px}.category-row__item-amount{font-weight:500;color:var(--text-primary)}.patterns-flow__actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--border-color)}@media(max-width:768px){.patterns-flow__actions button{min-height:30px;font-size:1rem}.category-row__header{min-height:30px}.donut-chart{max-width:100%;overflow:hidden}.patterns-breakdown{overflow-x:auto}}@media(max-width:480px){.patterns-summary{gap:2rem}.category-row__percent{display:none}}.coach-page{padding:1.5rem;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:1rem}.coach-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.coach-header h1{margin:0;font-size:var(--font-size-2xl, 1.5rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.coach-header__actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.coach-header__actions>button{display:flex;align-items:center;gap:.375rem}.coach-header__history-btn{display:none!important}.coach-section{display:flex;flex-direction:column;gap:1rem}.coach-section__loading{display:flex;align-items:center;justify-content:center;padding:3rem;background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);color:var(--text-muted);font-size:.9375rem}.coach-section__title{margin:0;font-size:1rem;font-weight:600;color:var(--text-color);display:flex;align-items:center;gap:.5rem}.coach-section__title:after{content:"";flex:1;height:1px;background:var(--border-color)}.coach-section--with-history{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;position:relative}.coach-history-sidebar{display:block}.coach-chat-area{min-width:0}.coach-history-overlay{display:none}.coach-flows-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}@media(min-width:768px){.coach-flows-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.coach-flows-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:1024px){.coach-section--with-history{display:block}.coach-header__history-btn{display:flex!important}.coach-history-sidebar{position:fixed;top:0;left:-300px;width:280px;height:100vh;z-index:200;transition:left var(--transition-normal, .2s ease)}.coach-history-sidebar--open{left:0}.coach-history-sidebar--open+.coach-history-overlay{display:block}.coach-history-overlay{position:fixed;inset:0;background:#0006;z-index:199;cursor:pointer}.coach-chat-area{width:100%}}@media(max-width:768px){.coach-page{padding:1rem}.coach-header{flex-direction:column;align-items:stretch;gap:.75rem}.coach-header h1{font-size:1.375rem}.coach-header__actions{justify-content:center;width:100%}.coach-header__actions>button{min-height:30px}.coach-flows-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}}@media(max-width:640px){.coach-page{padding:1rem}.coach-header{flex-direction:column;align-items:stretch}.coach-header__actions{justify-content:flex-end}.coach-flows-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:400px){.coach-flows-grid{grid-template-columns:1fr}}.feed-page{padding:1.5rem;max-width:1200px;margin:0 auto;position:relative}.pull-indicator{position:absolute;top:0;left:0;right:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--text-muted);font-size:.875rem;overflow:hidden;opacity:0;transition:opacity .2s ease}.pull-indicator.visible{opacity:1}.pull-indicator.ready{color:var(--secondary-color)}.pull-indicator .pull-icon{transition:transform .2s ease}.feed-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4, 1rem)}.feed-header h1{margin:0;font-size:var(--font-size-2xl, 1.5rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.feed-header .refresh-btn{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.articles-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:1.25rem}@media(min-width:640px){.articles-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.articles-grid{grid-template-columns:repeat(3,1fr)}}.article-card{display:flex;flex-direction:column;background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px);overflow:hidden;text-decoration:none;color:inherit;transition:all var(--transition-fast, .15s ease)}.article-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:var(--primary-color)}.article-card:focus{outline:2px solid var(--primary-color);outline-offset:2px}.article-image{position:relative;width:100%;padding-top:56.25%;overflow:hidden;background:var(--secondary-bg)}.article-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.article-card:hover .article-image img{transform:scale(1.05)}.bookmark-btn{position:absolute;top:.75rem;right:.75rem;width:36px;height:36px;border-radius:var(--radius-full, 999px);background:#ffffffe6;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.bookmark-btn:hover{background:#fff;color:var(--secondary-color);transform:scale(1.1)}.bookmark-btn.bookmarked{background:var(--primary-color);color:#fff}.bookmark-btn.bookmarked:hover{background:var(--primary-color);opacity:.9}.article-content{padding:1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.article-title{margin:0;font-size:1rem;font-weight:600;color:var(--text-color);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article-excerpt{margin:0;font-size:.875rem;color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.article-tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.25rem}.article-tag{display:inline-flex;align-items:center;padding:.25rem .625rem;background:var(--secondary-bg);color:var(--text-muted);font-size:.75rem;font-weight:500;border-radius:var(--radius-full, 999px);white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis}.article-meta{display:flex;align-items:center;gap:.5rem;margin-top:auto;padding-top:.5rem;font-size:.8125rem;color:var(--text-muted)}.article-source{font-weight:500;color:var(--secondary-color)}.article-separator{opacity:.5}.external-icon{margin-left:auto;opacity:0;transition:opacity .15s ease}.article-card:hover .external-icon{opacity:1}.feed-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem;gap:1rem;background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-lg, 12px)}.feed-empty-state .empty-icon{width:80px;height:80px;border-radius:var(--radius-full, 999px);background:var(--secondary-bg);color:var(--text-muted);display:flex;align-items:center;justify-content:center}.feed-empty-state h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-color)}.feed-empty-state p{margin:0;font-size:.9375rem;color:var(--text-muted);max-width:300px}.feed-empty-state button{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.feed-error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem;gap:1rem;background:var(--card-bg);border:1px solid var(--error-color, #ef4444);border-radius:var(--radius-lg, 12px)}.feed-error-state .error-icon{width:80px;height:80px;border-radius:var(--radius-full, 999px);background:#ef44441a;color:var(--error-color, #ef4444);display:flex;align-items:center;justify-content:center}.feed-error-state h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-color)}.feed-error-state .error-message{margin:0;font-size:.9375rem;color:var(--text-muted);max-width:400px}.feed-error-state button{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.article-card.skeleton{pointer-events:none}.article-card.skeleton .skeleton-image{border-radius:var(--radius-lg, 12px) var(--radius-lg, 12px) 0 0}.fetching-overlay{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-full, 999px);box-shadow:var(--shadow-lg);color:var(--text-muted);font-size:.875rem;z-index:100}.desktop-only{display:none}@media(min-width:640px){.desktop-only{display:flex}}[data-theme=dark] .bookmark-btn{background:#1e1e1ee6;color:var(--text-muted)}[data-theme=dark] .bookmark-btn:hover{background:#282828;color:var(--secondary-color)}[data-theme=dark] .bookmark-btn.bookmarked{background:var(--primary-color);color:#fff}@media(max-width:768px){.feed-page{padding:1rem}.feed-header h1{font-size:1.375rem}.bookmark-btn{width:44px;height:44px}.article-content{padding:.75rem}.fetching-overlay{bottom:calc(1rem + env(safe-area-inset-bottom))}}@media(max-width:640px){.feed-page{padding:1rem}.feed-header{flex-direction:column;text-align:center}}@media(prefers-reduced-motion:reduce){.article-card,.article-image img,.bookmark-btn,.pull-indicator .pull-icon{transition:none}.skeleton-image,.skeleton-title,.skeleton-excerpt,.skeleton-meta{animation:none;background:var(--secondary-bg)}.spinning{animation:none}}.settings-page{display:flex;flex-direction:column;gap:var(--space-4, 1rem);padding:var(--space-6);max-width:1200px;margin:0 auto}.settings-page h1{margin:0;color:var(--text-color);font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold)}.settings-list{display:flex;flex-direction:column;gap:var(--space-3)}.settings-item{display:flex;flex-direction:column;padding:0;overflow:hidden}.settings-item-header,.settings-item:not(.expandable){display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);cursor:pointer;transition:background-color var(--transition-fast, .15s ease)}.settings-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-lg, 12px);color:var(--secondary-color);flex-shrink:0}.settings-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.settings-name{font-weight:600;color:var(--text-color)}.settings-description{font-size:.875rem;color:var(--text-muted)}.settings-chevron{color:var(--text-muted);transition:transform var(--transition-fast, .15s ease)}.settings-item.expanded .settings-chevron{transform:rotate(0)}.settings-content{padding:0 var(--space-5) var(--space-5);margin-top:0;display:flex;flex-direction:column;gap:var(--space-6);padding-top:var(--space-5)}.setting-group{display:flex;flex-direction:column;gap:var(--space-3)}.setting-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.theme-options{display:flex;gap:.5rem}.theme-option{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);background:var(--card-bg);color:var(--text-color);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast, .15s ease);position:relative}.theme-option:hover{border-color:var(--primary-color);background:var(--primary-light)}.theme-option.active{border-color:var(--primary-color);background:var(--primary-light);color:var(--secondary-color)}.theme-option .check-icon{position:absolute;top:4px;right:4px;color:var(--secondary-color)}.color-options{display:flex;gap:.75rem}.color-option{width:40px;height:40px;border-radius:var(--radius-full, 50%);border:3px solid transparent;background:var(--color);cursor:pointer;transition:all var(--transition-fast, .15s ease);display:flex;align-items:center;justify-content:center;color:#fff}.color-option:hover{transform:scale(1.1)}.color-option.active{border-color:var(--text-color);box-shadow:0 0 0 2px var(--card-bg),0 0 0 4px var(--color)}.color-option-custom-wrapper{position:relative;display:inline-flex}.color-option-custom{background:conic-gradient(from 0deg,red,#ff8000,#ff0,#80ff00,#0f0,#00ff80,#0ff,#0080ff,#00f,#8000ff,#f0f,#ff0080,red)!important}.color-option-custom.active{background:var(--color)!important}.custom-color-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.setting-select{padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);background:var(--card-bg);color:var(--text-color);font-size:.875rem;cursor:pointer;transition:border-color var(--transition-fast, .15s ease)}.setting-select:hover{border-color:var(--primary-color)}.setting-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.toggle-option{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0}.toggle-info{display:flex;flex-direction:column;gap:.125rem}.toggle-name{font-size:.875rem;font-weight:500;color:var(--text-color)}.toggle-description{font-size:.75rem;color:var(--text-muted)}.toggle-switch{position:relative;width:44px;height:24px;border-radius:var(--radius-full, 12px);border:none;background:var(--border-color);cursor:pointer;transition:background-color var(--transition-fast, .15s ease);padding:0}.toggle-switch.active{background:var(--primary-color)}.toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:var(--radius-full, 50%);background:#fff;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast, .15s ease)}.toggle-switch.active .toggle-thumb{transform:translate(20px)}.reset-button{align-self:flex-start;margin-top:.5rem}@media(max-width:480px){.theme-options{flex-direction:column}.theme-option{justify-content:flex-start}}.setting-info-text{font-size:.875rem;color:var(--text-muted);margin-bottom:1rem;line-height:1.5}.reconfigure-button{color:var(--warning-color, #f59e0b)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal-content{background:var(--card-bg);padding:var(--space-6);border-radius:var(--radius-lg, 12px);max-width:600px;width:90%;box-shadow:var(--shadow-lg)}.modal-content h3{margin:0 0 .2rem;font-size:1.25rem;color:var(--text-color)}.modal-content p{color:var(--text-muted, #64748b);margin-bottom:.75rem;line-height:1.5}.modal-note{background:var(--primary-light);color:var(--text-color);padding:.75rem;border-radius:var(--radius-md, 8px);font-size:.875rem}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.dark-theme .theme-option{border-color:var(--border-color);background:var(--card-bg);color:var(--text-color)}.dark-theme .theme-option:hover{border-color:var(--primary-color);background:var(--primary-light)}.dark-theme .theme-option.active{border-color:var(--primary-color);background:var(--primary-light);color:var(--secondary-color)}.dark-theme .color-option{border-color:transparent}.dark-theme .color-option.active{border-color:var(--text-color);box-shadow:0 0 0 2px var(--card-bg),0 0 0 4px var(--color)}.dark-theme .setting-select{background:var(--input-bg);border-color:var(--input-border);color:var(--text-color)}.dark-theme .setting-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.dark-theme .toggle-switch{background:var(--input-border)}.dark-theme .toggle-switch.active{background:var(--primary-color)}.dark-theme .toggle-thumb{background:var(--text-color)}.dark-theme .modal-content{background:var(--card-bg);box-shadow:var(--shadow-lg)}.dark-theme .modal-content h3{color:var(--text-color)}.dark-theme .modal-content p{color:var(--text-muted)}.dark-theme .modal-note{background:var(--primary-light);color:var(--text-color)}.invite-collaborator-button{align-self:flex-start;display:flex;align-items:center;gap:.5rem}.ai-coach-icon{color:var(--secondary-color)}.ai-status-badge{display:inline-flex;align-items:center;margin-left:.5rem;padding:.125rem .5rem;font-size:.75rem;font-weight:500;border-radius:var(--radius-full, 9999px);background:var(--success-light, rgba(34, 197, 94, .1));color:var(--success-color, #22c55e)}.ai-status-badge.active{background:var(--success-light, rgba(34, 197, 94, .1));color:var(--success-color, #22c55e)}.ai-enabled-status{display:flex;align-items:center;gap:.5rem;font-weight:500;color:var(--success-color, #22c55e);margin-bottom:.5rem}.ai-enabled-icon{color:var(--success-color, #22c55e)}.ai-actions{display:flex;gap:.75rem;flex-wrap:wrap}.remove-api-key-button{color:var(--error-color, #ef4444)}.remove-api-key-button:hover{background:var(--error-light, rgba(239, 68, 68, .1))}.ai-get-key-link{display:inline-flex;align-items:center;gap:.375rem;color:var(--secondary-color);font-size:.875rem;font-weight:500;text-decoration:underline;transition:opacity var(--transition-fast, .15s ease)}.ai-get-key-link:hover{opacity:.8}.api-key-input-wrapper{display:flex;gap:.5rem;align-items:center}.setting-input{flex:1;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);background:var(--card-bg);color:var(--text-color);font-size:.875rem;font-family:monospace;transition:border-color var(--transition-fast, .15s ease)}.setting-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.setting-input::placeholder{color:var(--text-muted);opacity:.6}.api-key-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);background:var(--card-bg);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.api-key-toggle:hover{border-color:var(--primary-color);color:var(--text-color)}.ai-form-actions{display:flex;gap:.75rem;flex-wrap:wrap}.spinner{animation:spin 1s linear infinite}.ai-status-message{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:var(--radius-md, 8px);font-size:.875rem}.ai-status-message.success{background:var(--success-light, rgba(34, 197, 94, .1));color:var(--success-color, #22c55e)}.ai-status-message.error{background:var(--error-light, rgba(239, 68, 68, .1));color:var(--error-color, #ef4444)}.remove-confirm-button{background:var(--error-color, #ef4444);color:#fff}.remove-confirm-button:hover{background:var(--error-color-dark, #dc2626)}.dark-theme .setting-input{background:var(--input-bg);border-color:var(--input-border)}.dark-theme .setting-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.dark-theme .api-key-toggle{background:var(--input-bg);border-color:var(--input-border)}.dark-theme .api-key-toggle:hover{border-color:var(--primary-color);color:var(--text-color)}.version-display{text-align:center;font-size:.75rem;color:var(--text-muted);padding:1rem 0;cursor:pointer;transition:color var(--transition-fast, .15s ease);-webkit-user-select:none;user-select:none}.version-display:hover{color:var(--text-color)}.version-display:active{color:var(--secondary-color)}.security-status{padding:1rem;background:var(--success-light, rgba(34, 197, 94, .1));border-radius:var(--radius-md, 8px);border:1px solid var(--success-color, #22c55e)}.security-status-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.security-status-icon{color:var(--success-color, #22c55e)}.security-status-text{font-weight:600;color:var(--success-color, #22c55e);font-size:1rem}.security-features-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.security-features-list li{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-muted)}.security-features-list li svg{color:var(--success-color, #22c55e);flex-shrink:0}.session-info-card{padding:1rem;background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-md, 8px);transition:all var(--transition-fast, .15s ease)}.session-device{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.session-device-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md, 8px);background:var(--primary-light);color:var(--secondary-color)}.session-device-info{display:flex;flex-direction:column;gap:.125rem}.session-device-name{font-weight:600;color:var(--text-color)}.session-browser{font-size:.875rem;color:var(--text-muted)}.session-details{display:flex;flex-direction:column;gap:.5rem}.session-detail-row{display:flex;justify-content:space-between;align-items:center}.session-detail-label{font-size:.875rem;color:var(--text-muted)}.session-detail-value{font-size:.875rem;color:var(--text-color)}.session-active{color:var(--success-color, #22c55e);font-weight:500}.connected-account-card{padding:1rem;background:var(--card-bg);border:none;border-radius:var(--radius-md, 8px);transition:all var(--transition-fast, .15s ease)}.connected-account-card:hover{transform:translateY(-1px)}.connected-account-provider{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.provider-icon{flex-shrink:0}.provider-icon.email{color:var(--secondary-color)}.provider-icon.github{color:var(--text-color)}.provider-name{font-weight:600;color:var(--text-color)}.connected-account-email{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-muted)}.connected-account-email svg{flex-shrink:0}.settings-page .sign-out-button{color:var(--secondary-color)}.settings-page .sign-out-button:hover{border-color:var(--primary-color);background:none}.dark-theme .security-status{background:#22c55e26;border-color:#22c55e4d}.dark-theme .session-info-card,.dark-theme .connected-account-card{background:var(--input-bg)}.notifications-icon{color:var(--secondary-color)}.settings-status-badge{display:inline-flex;align-items:center;margin-left:.5rem;padding:.125rem .5rem;font-size:.75rem;font-weight:500;border-radius:var(--radius-full, 9999px)}.settings-status-badge.muted{background:var(--border-color);color:var(--text-muted)}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:.875rem 0;gap:1rem}.settings-toggle-row.master-toggle{padding:1rem;background:var(--bg-secondary, rgba(0, 0, 0, .02));border-radius:var(--radius-md, 8px);margin-bottom:.5rem}.settings-toggle-row.disabled{opacity:.5;pointer-events:none}.settings-toggle-info{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.settings-toggle-label{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:500;color:var(--text-color)}.settings-toggle-label svg{flex-shrink:0;color:var(--text-muted)}.settings-toggle-description{font-size:.8125rem;color:var(--text-muted);line-height:1.4}label.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}label.toggle-switch input{opacity:0;width:0;height:0}label.toggle-switch .toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--border-color);border-radius:var(--radius-full, 12px);transition:background-color var(--transition-fast, .15s ease)}label.toggle-switch .toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:2px;bottom:2px;background:#fff;border-radius:var(--radius-full, 50%);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast, .15s ease)}label.toggle-switch input:checked+.toggle-slider{background:var(--primary-color)}label.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}label.toggle-switch input:disabled+.toggle-slider{cursor:not-allowed;opacity:.5}.quiet-hours-times{display:flex;align-items:flex-end;gap:1rem;margin-top:1rem;padding:1rem;background:var(--bg-secondary, rgba(0, 0, 0, .02));border-radius:var(--radius-md, 8px)}.quiet-hours-time-picker{display:flex;flex-direction:column;gap:.375rem;flex:1}.quiet-hours-label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.025em}.quiet-hours-input{padding:.625rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);background:var(--card-bg);color:var(--text-color);font-size:.9375rem;font-family:inherit;cursor:pointer;transition:border-color var(--transition-fast, .15s ease)}.quiet-hours-input:hover{border-color:var(--primary-color)}.quiet-hours-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.quiet-hours-separator{font-size:.875rem;color:var(--text-muted);padding-bottom:.75rem}.notification-saved-toast{display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem 1rem;background:var(--success-color, #22c55e);color:#fff;font-size:.8125rem;font-weight:500;border-radius:var(--radius-md, 8px);animation:toast-fade-in .2s ease}@keyframes toast-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dark-theme .settings-toggle-row.master-toggle,.dark-theme .quiet-hours-times{background:#ffffff08}.dark-theme .quiet-hours-input{background:var(--input-bg);border-color:var(--input-border)}.dark-theme .quiet-hours-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.dark-theme label.toggle-switch .toggle-slider{background:var(--input-border)}.dark-theme label.toggle-switch input:checked+.toggle-slider{background:var(--primary-color)}.dark-theme label.toggle-switch .toggle-slider:before{background:var(--text-color)}@media(max-width:480px){.quiet-hours-times{flex-direction:column;align-items:stretch;gap:.75rem}.quiet-hours-separator{text-align:center;padding:0}}.export-buttons{display:flex;gap:.75rem;flex-wrap:wrap}.export-button{display:flex;align-items:center;gap:.375rem}.export-success-message{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:var(--radius-md, 8px);font-size:.875rem;background:var(--success-light, rgba(34, 197, 94, .1));color:var(--success-color, #22c55e)}.export-success-message.error{background:var(--error-light, rgba(239, 68, 68, .1));color:var(--error-color, #ef4444)}.export-month-selector{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.export-month-label{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--text-muted);white-space:nowrap}.export-month-select{flex:1;max-width:200px;padding:.375rem .5rem;border-radius:var(--radius-sm, 6px);border:1px solid var(--border-color);background:var(--input-bg, var(--card-bg));color:var(--text-color);font-size:.8125rem;cursor:pointer}.export-month-select:focus{outline:none;border-color:var(--primary-color)}.export-history{margin-top:.25rem}.export-history-loading,.export-history-empty{font-size:.8125rem;color:var(--text-muted);padding:.5rem 0;display:flex;align-items:center;gap:.5rem}.export-history-list{display:flex;flex-direction:column;gap:.25rem}.export-history-item{display:flex;align-items:center;justify-content:space-between;padding:.375rem .5rem;border-radius:var(--radius-sm, 6px);font-size:.8125rem;transition:background var(--transition-fast, .15s ease)}.export-history-item:hover{background:var(--hover-bg, rgba(0, 0, 0, .04))}.export-history-info{display:flex;align-items:center;gap:.5rem;color:var(--text-color);min-width:0}.export-history-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.export-history-date{color:var(--text-muted);font-size:.75rem;white-space:nowrap}.export-history-download{flex-shrink:0;padding:.25rem;color:var(--text-muted)}.export-history-download:hover{color:var(--primary-color)}.storage-usage{padding:1rem;background:var(--card-bg);border:2px solid transparent;border-radius:var(--radius-md, 8px);transition:all var(--transition-fast, .15s ease)}.storage-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.storage-header svg{color:var(--text-muted)}.storage-total{font-size:.9375rem;font-weight:500;color:var(--text-color)}.storage-warning{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:var(--warning-light, rgba(245, 158, 11, .1));color:var(--warning-color, #f59e0b);font-size:.8125rem;border-radius:var(--radius-sm, 4px);margin-bottom:.75rem}.storage-progress-container{height:8px;background:var(--border-color);border-radius:var(--radius-full, 9999px);overflow:hidden;margin-bottom:.75rem}.storage-progress-bar{height:100%;background:var(--primary-color);border-radius:var(--radius-full, 9999px);transition:width var(--transition-fast, .15s ease)}.storage-breakdown{display:flex;flex-direction:column;gap:.375rem}.storage-breakdown-item{display:flex;justify-content:space-between;font-size:.8125rem}.storage-key{color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:70%}.storage-size{color:var(--text-color);flex-shrink:0}.clear-cache-button,.reset-month-button{display:flex;align-items:center;gap:.375rem;align-self:flex-start}.reset-month-button{color:var(--warning-color, #f59e0b)}.reset-month-button:hover{background:var(--warning-light, rgba(245, 158, 11, .1))}.reset-month-modal{max-width:420px}.reset-section-label{font-weight:500;color:var(--text-color);margin-bottom:.5rem;margin-top:.75rem}.reset-section-label:first-of-type{margin-top:0}.reset-info-list{margin:0 0 .75rem;padding-left:1.25rem;font-size:.875rem;color:var(--text-muted);line-height:1.6}.reset-info-list li{margin-bottom:.25rem}.reset-month-modal .modal-note{margin-top:1rem}.warning-button{background:var(--warning-color, #f59e0b);color:#fff}.warning-button:hover:not(:disabled){background:var(--warning-color-dark, #d97706)}.dark-theme .storage-usage{background:var(--input-bg);border-color:var(--input-border)}.dark-theme .storage-progress-container{background:var(--input-border)}.change-password-button{gap:.5rem;align-self:flex-start}.change-password-form{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--bg-secondary, rgba(0,0,0,.02));border-radius:var(--radius-md, 8px)}.password-input-group{display:flex;flex-direction:column;gap:.375rem}.password-input-group label{font-size:.813rem;color:var(--text-muted)}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .settings-input{padding-right:2.5rem;width:100%}.password-toggle-btn{position:absolute;right:.75rem;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.85rem;display:flex;align-items:center;justify-content:center}.password-toggle-btn:hover{color:var(--text-color)}.password-error{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#f443361a;border-radius:var(--radius-sm, 4px);color:var(--error-color);font-size:.813rem}.password-success{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#4caf501a;border-radius:var(--radius-sm, 4px);color:var(--success-color, #4CAF50);font-size:.875rem}.password-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.dark-theme .change-password-form{background:#ffffff08}.dark-theme .password-input-wrapper .settings-input{background:var(--input-bg);border-color:var(--input-border)}@media(max-width:768px){.settings-page{padding:1rem;gap:1rem}.settings-page h1{font-size:1.25rem}.settings-item-header,.settings-item:not(.expandable){padding:1rem;gap:.75rem}.settings-icon{width:40px;height:40px}.settings-icon svg{width:20px;height:20px}.settings-content{padding:1rem;gap:1rem}.theme-options{flex-direction:column}.theme-option{justify-content:flex-start;min-height:30px}.color-options{flex-wrap:wrap;gap:.5rem}.color-option{width:44px;height:44px}.setting-select{min-height:30px;width:100%}.setting-input{min-height:30px}.toggle-option{gap:.75rem}.toggle-switch{min-width:44px}.api-key-input-wrapper{flex-direction:column;align-items:stretch}.api-key-toggle{width:100%;height:44px}.modal-content{width:95%;padding:1.25rem}.modal-actions{flex-direction:column}.modal-actions button{width:100%;min-height:30px}.export-buttons{flex-direction:column}.export-button{width:100%;min-height:30px;justify-content:center}.export-month-select{max-width:none}.ai-form-actions{flex-direction:column}.ai-form-actions button{width:100%;min-height:30px}.security-status{padding:.875rem}.quiet-hours-times{flex-direction:column;align-items:stretch;gap:.75rem}.quiet-hours-separator{text-align:center;padding:0}.reset-button,.clear-cache-button,.reset-month-button,.change-password-button{width:100%;min-height:30px;justify-content:center;align-self:stretch}.password-actions{flex-direction:column}.password-actions button{width:100%;min-height:30px}.storage-key{max-width:60%}.session-detail-row{flex-direction:column;align-items:flex-start;gap:.25rem}.settings-toggle-row{gap:.75rem}.settings-toggle-label{font-size:.875rem}.connected-account-card{padding:.875rem}}.profile-page{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;max-width:1200px;margin:0 auto}.profile-page h1{margin:0;color:var(--text-color);font-size:1.5rem;font-weight:600}.profile-card{display:flex;align-items:center;gap:1.5rem;padding:2rem}.profile-avatar{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:var(--radius-full, 50%);background:linear-gradient(135deg,var(--primary-color) 0%,#1976d2 100%);color:#fff}.profile-info h2{margin:0;font-size:1.5rem;color:var(--text-color)}.profile-role{color:var(--secondary-color);font-size:.875rem;font-weight:500}.profile-details{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem}.profile-details h2{margin:0;font-size:1rem;color:var(--text-color)}.detail-item{display:flex;align-items:center;gap:1rem;color:var(--text-muted)}.detail-info{display:flex;flex-direction:column;gap:.125rem}.detail-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.detail-value{color:var(--text-color)}@media(max-width:768px){.profile-page{padding:1rem;gap:1rem}.profile-card{flex-direction:column;text-align:center;padding:1.5rem;gap:1rem}.profile-avatar{width:64px;height:64px}.profile-info h2{font-size:1.25rem}.profile-details{padding:1rem;gap:1rem}.detail-item{min-height:30px}}.insights-page{display:flex;flex-direction:column;height:100%;overflow:hidden;max-width:1200px;margin:0 auto}.insights-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6) var(--space-6) var(--space-4, 1rem)}.insights-header h1{margin:0;font-size:var(--font-size-2xl, 1.5rem);font-weight:var(--font-weight-semibold, 600);color:var(--text-color)}.view-toggle{display:flex;background:var(--secondary-bg);border-radius:var(--radius-md, 8px);padding:4px}.toggle-btn{padding:.5rem 1rem;border:none;background:transparent;color:var(--text-muted);font-size:.875rem;font-weight:500;cursor:pointer;border-radius:var(--radius-md, 6px);transition:all var(--transition-fast, .15s ease)}.toggle-btn.active{background:var(--card-bg);color:var(--text-color);box-shadow:var(--shadow-sm)}.year-selector{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);color:var(--text-muted)}.year-select{width:20em;padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);background:var(--card-bg);color:var(--text-color);font-size:.9375rem;font-weight:500;cursor:pointer;transition:border-color var(--transition-fast, .15s ease)}.year-select:hover{border-color:var(--primary-color)}.yearly-view{flex:1;padding:0 var(--space-6) var(--space-6)}.summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.summary-card{background:var(--card-bg);border-radius:var(--radius-lg, 12px);border:2px solid transparent;padding:var(--space-5);box-shadow:var(--shadow-sm);transition:all var(--transition-fast, .15s ease)}.summary-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.summary-label{font-size:.8125rem;color:var(--text-muted);margin-bottom:.5rem}.summary-value{font-size:1.5rem;font-weight:700;color:var(--text-color);margin-bottom:.25rem}.summary-value.positive{color:var(--success-color)}.summary-value.negative{color:var(--error-color)}.summary-detail{font-size:.75rem;color:var(--text-muted)}.monthly-chart{background:var(--card-bg);border-radius:var(--radius-lg, 12px);border:2px solid transparent;padding:var(--space-5);box-shadow:var(--shadow-sm);transition:all var(--transition-fast, .15s ease)}.monthly-chart:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.monthly-chart h2{margin:0 0 var(--space-4) 0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--text-color)}.insights-chart-container{margin-top:.5rem}.insights-page .chart-tooltip{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);padding:.75rem 1rem;box-shadow:var(--shadow-md)}.insights-page .chart-tooltip__name{font-size:.8125rem;color:var(--text-muted);margin-bottom:.25rem}.insights-page .chart-tooltip__amount{font-size:1rem;font-weight:600;color:var(--text-color)}.monthly-view{flex:1;overflow-y:auto;padding:0 var(--space-6) var(--space-6)}.months-list{display:flex;flex-direction:column;gap:var(--space-3)}.month-card{background:var(--card-bg);border-radius:var(--radius-lg, 12px);border:2px solid transparent;overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--transition-fast, .15s ease)}.month-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.month-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);cursor:pointer;transition:background-color var(--transition-fast, .15s ease)}.month-header:hover{background:var(--menu-hover)}.month-toggle{color:var(--text-muted)}.month-info{flex:1;display:flex;flex-direction:column;gap:.125rem}.month-name{font-weight:600;color:var(--text-color)}.month-summary{font-size:.8125rem;color:var(--text-muted)}.month-saved{display:flex;align-items:center;gap:.25rem;font-weight:600;font-size:.9375rem}.month-saved.positive{color:var(--success-color)}.month-saved.negative{color:var(--error-color)}.month-progress{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-5) var(--space-4) 3rem}.month-progress .progress-bar-container{flex:1}.progress-label{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.month-details{padding:var(--space-4) var(--space-5);background:var(--bg-color)}.month-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-4);padding-bottom:var(--space-4)}.stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.75rem;color:var(--text-muted)}.stat-value{font-weight:600;color:var(--text-color)}.month-details h3{margin:0 0 var(--space-3) 0;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.categories-breakdown{display:flex;flex-direction:column;gap:var(--space-2)}.category-row{display:grid;grid-template-columns:1fr 2fr auto;align-items:center;gap:var(--space-4)}.category-row .category-name{font-size:.875rem;color:var(--text-color)}.category-bar{flex:1}.category-amounts{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.no-data,.no-data-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12, 3rem) var(--space-8);text-align:center;color:var(--text-muted)}.no-data-card{background:var(--card-bg);border-radius:var(--radius-lg, 12px);border:2px solid transparent;box-shadow:var(--shadow-sm);transition:all var(--transition-fast, .15s ease)}.no-data-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.no-data-card svg{color:var(--border-color);margin-bottom:var(--space-4)}.no-data p,.no-data-card p{margin:0 0 .5rem;font-size:1rem;font-weight:500;color:var(--text-color)}.no-data span,.no-data-card span{font-size:.875rem}@media(max-width:768px){.insights-header{flex-direction:column;align-items:stretch;gap:var(--space-3);padding:var(--space-4)}.view-toggle{width:100%;justify-content:space-between}.toggle-btn{flex:1;min-height:30px}.yearly-view,.monthly-view{padding:0 var(--space-4) var(--space-4)}.year-selector{padding:var(--space-3) var(--space-4)}.insights-chart-container{margin-left:-.5rem;margin-right:-.5rem}.month-header{flex-wrap:wrap}.month-progress{padding-left:var(--space-4)}.summary-cards{grid-template-columns:1fr}.summary-value{font-size:var(--font-size-xl)}.month-stats{grid-template-columns:1fr}.category-row{grid-template-columns:1fr;gap:var(--space-1)}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-color) 0%,var(--primary-light) 100%);padding:1rem}.auth-card{width:100%;max-width:420px;background:var(--card-bg);border-radius:var(--radius-lg, 16px);box-shadow:var(--shadow-lg);padding:2.5rem;position:relative}.auth-invitation-banner{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;margin:-.5rem -.5rem 1.5rem;background:var(--primary-light);border-radius:var(--radius-md, 8px);color:var(--secondary-color);font-size:.875rem;line-height:1.4;text-align:center}.auth-invitation-banner strong{font-weight:600}.back-button{position:absolute;top:1.5rem;left:1.5rem;display:flex;align-items:center;gap:.5rem;background:none;border:none;color:var(--text-muted);font-size:.875rem;cursor:pointer;padding:.5rem;margin:-.5rem;border-radius:var(--radius-md, 8px);transition:color var(--transition-fast, .15s ease),background-color var(--transition-fast, .15s ease)}.back-button:hover{color:var(--text-color);background-color:var(--ghost-hover)}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{width:80px;height:80px;margin:0 auto 1.5rem;background:var(--primary-light);border-radius:var(--radius-lg, 20px);display:flex;align-items:center;justify-content:center;color:var(--secondary-color)}.auth-title{font-size:1.75rem;font-weight:700;color:var(--text-color);margin-bottom:.5rem}.auth-tagline{font-size:.875rem;color:var(--text-muted);font-weight:500;letter-spacing:.05em;text-transform:uppercase;margin-top:.25rem;margin-bottom:.5rem}.auth-subtitle{font-size:1rem;color:var(--text-muted);line-height:1.5;margin-top:2em}.auth-subtitle strong{color:var(--text-color);word-break:break-all}.social-login-section{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.social-button{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:500;border:2px solid var(--input-border);border-radius:var(--radius-lg, 12px);cursor:pointer;transition:all var(--transition-fast, .15s ease);background:var(--card-bg);color:var(--text-color)}.social-button:hover:not(:disabled){background:var(--ghost-hover);border-color:var(--text-muted)}.social-button:active:not(:disabled){transform:scale(.98)}.social-button:disabled{opacity:.6;cursor:not-allowed}.google-button:hover:not(:disabled){border-color:#4285f4}.github-button:hover:not(:disabled){border-color:#333}.auth-divider{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.auth-divider span{font-size:.875rem;color:var(--text-muted);text-transform:lowercase}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:500;color:var(--text-color)}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;color:var(--text-muted);pointer-events:none}.form-input{width:100%;padding:.875rem 1rem .875rem 3rem;font-size:1rem;border:2px solid var(--input-border);border-radius:var(--radius-lg, 12px);background:var(--input-bg);color:var(--text-color);transition:border-color var(--transition-fast, .15s ease),box-shadow var(--transition-fast, .15s ease)}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.form-input::placeholder{color:var(--text-placeholder)}.form-input:disabled{opacity:.6;cursor:not-allowed}.form-input.input-error{border-color:var(--error-color)}.form-input.input-error:focus{box-shadow:0 0 0 3px #f4433626}.code-input-wrapper{display:flex;gap:.5rem;justify-content:center}.code-input{width:48px;height:56px;text-align:center;font-size:1.5rem;font-weight:600;border:2px solid var(--input-border);border-radius:var(--radius-lg, 12px);background:var(--input-bg);color:var(--text-color);transition:all var(--transition-fast, .15s ease)}.code-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light);transform:scale(1.05)}.code-input.has-value{border-color:var(--primary-color)}.code-input:disabled{opacity:.6;cursor:not-allowed}.code-input.input-error{border-color:var(--error-color)}.error-message{display:flex;align-items:center;gap:.25rem;font-size:.813rem;color:var(--error-color);margin-top:.25rem}.auth-error{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;background:#f443361a;border:1px solid rgba(244,67,54,.2);border-radius:var(--radius-md, 8px);color:var(--error-color);font-size:.875rem;text-align:center}.auth-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:var(--primary-color);border:none;border-radius:var(--radius-lg, 12px);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.auth-button:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 12px #84cc164d}.auth-button:active:not(:disabled){transform:scale(.98)}.auth-button:disabled{opacity:.6;cursor:not-allowed}.button-icon{flex-shrink:0}.resend-button{background:none;border:none;color:var(--secondary-color);font-size:.875rem;cursor:pointer;padding:.5rem;transition:color var(--transition-fast, .15s ease);text-decoration:underline;text-underline-offset:2px}.resend-button:hover:not(:disabled){color:var(--primary-hover);text-decoration:underline}.resend-button:disabled{opacity:.6;cursor:not-allowed}.magic-link-sent{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem 0}.magic-link-icon{width:80px;height:80px;background:var(--primary-light);border-radius:var(--radius-full, 50%);display:flex;align-items:center;justify-content:center;color:var(--secondary-color);margin-bottom:.5rem}.magic-link-message{text-align:center;color:var(--text-muted);font-size:.938rem;line-height:1.6}.back-to-login-button{background:none;border:none;color:var(--text-muted);font-size:.875rem;cursor:pointer;padding:.5rem;margin-top:.5rem;transition:color var(--transition-fast, .15s ease)}.back-to-login-button:hover{color:var(--text-color);text-decoration:underline}.password-toggle{position:absolute;right:1rem;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.85rem;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--text-color)}.auth-mode-links{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-top:1.5rem}.auth-mode-link{background:none;border:none;color:var(--secondary-color);font-size:.875rem;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}.auth-mode-link:hover{text-decoration:underline;text-decoration-thickness:2px}.auth-mode-secondary{color:var(--text-muted)}.auth-mode-secondary:hover{color:var(--text-color)}.auth-footer{margin-top:2rem;padding-top:1.5rem}.auth-footer-text{font-size:.813rem;color:var(--text-muted);text-align:center;line-height:1.6}.auth-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-muted)}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:480px){.auth-card{padding:1.5rem;border-radius:var(--radius-lg, 12px)}.auth-logo{width:64px;height:64px;border-radius:var(--radius-lg, 16px)}.auth-logo svg{width:36px;height:36px}.auth-title{font-size:1.5rem}.code-input{width:40px;height:48px;font-size:1.25rem}}:root,.light-theme{color-scheme:light;--bg-color: #f8fafc;--sidebar-bg: #ffffff;--card-bg: #ffffff;--card-hover: #f1f5f9;--border-color: #e2e8f0;--primary-color: #f6bb04;--primary-hover: #a17b05;--primary-light: #fffef2;--primary-text: #8a6914;--secondary-color: #8a6914;--secondary-hover: #6b5210;--secondary-light: rgba(138, 105, 20, .1);--text-color: #0f172a;--text-muted: #64748b;--text-placeholder: #6b7a8f;--text-light: #6b7a8f;--input-bg: #ffffff;--input-border: #e2e8f0;--input-focus: #f6bb04;--icon-bg: #f8fafc;--menu-hover: #f1f5f9;--ghost-hover: rgba(0, 0, 0, .04);--secondary-bg: #f8fafc;--secondary-hover: #f1f5f9;--progress-bg: #e2e8f0;--progress-success: #22c55e;--progress-warning: #f59e0b;--progress-danger: #ef4444;--success-color: #22c55e;--error-color: #ef4444;--spent-color: #f6bb04;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700}.dark-theme{color-scheme:dark;--bg-color: #0c1929;--sidebar-bg: #152238;--card-bg: #1a2d47;--card-hover: #243b5c;--border-color: #2a4a6b;--primary-light: rgba(250, 204, 21, .15);--primary-text: var(--primary-color);--secondary-color: var(--primary-color);--secondary-hover: var(--primary-hover);--secondary-light: var(--primary-light);--text-color: #e2e8f0;--text-muted: #94a3b8;--text-placeholder: #8494a7;--text-light: #8494a7;--input-bg: #1a2d47;--input-border: #2a4a6b;--icon-bg: #1a2d47;--menu-hover: #1a2d47;--ghost-hover: rgba(255, 255, 255, .05);--secondary-bg: #1a2d47;--secondary-hover: #243b5c;--progress-bg: #1a2d47;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .4);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5), 0 2px 4px -2px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .6), 0 4px 6px -4px rgba(0, 0, 0, .5)}.accent-lime{--primary-color: #84cc16;--primary-hover: #65a30d;--primary-light: rgba(132, 204, 22, .1);--primary-text: #4d7c0f;--secondary-color: #4d7c0f;--secondary-hover: #3a5d0b;--secondary-light: rgba(77, 124, 15, .1)}.accent-blue{--primary-color: #2196F3;--primary-hover: #1976D2;--primary-light: rgba(33, 150, 243, .1);--primary-text: #1565c0;--secondary-color: #1565c0;--secondary-hover: #104e90;--secondary-light: rgba(21, 101, 192, .1)}.accent-green{--primary-color: #22c55e;--primary-hover: #16a34a;--primary-light: rgba(34, 197, 94, .1);--primary-text: #15803d;--secondary-color: #15803d;--secondary-hover: #10602e;--secondary-light: rgba(21, 128, 61, .1)}.accent-purple{--primary-color: #8b5cf6;--primary-hover: #7c3aed;--primary-light: rgba(139, 92, 246, .1);--primary-text: #6d28d9;--secondary-color: #6d28d9;--secondary-hover: #521ea3;--secondary-light: rgba(109, 40, 217, .1)}.accent-orange{--primary-color: #f97316;--primary-hover: #ea580c;--primary-light: rgba(249, 115, 22, .1);--primary-text: #c2410c;--secondary-color: #c2410c;--secondary-hover: #923109;--secondary-light: rgba(194, 65, 12, .1)}.accent-pink{--primary-color: #ec4899;--primary-hover: #db2777;--primary-light: rgba(236, 72, 153, .1);--primary-text: #be185d;--secondary-color: #be185d;--secondary-hover: #8f1246;--secondary-light: rgba(190, 24, 93, .1)}.accent-beach{--primary-color: #FACC15;--primary-hover: #ca8a04;--primary-light: rgba(250, 204, 21, .1);--primary-text: #a16207;--secondary-color: #a16207;--secondary-hover: #854d0e;--secondary-light: rgba(161, 98, 7, .1)}.dark-theme.accent-lime{--primary-light: rgba(132, 204, 22, .15);--primary-text: var(--primary-color);--secondary-color: var(--primary-color);--secondary-hover: var(--primary-hover);--secondary-light: var(--primary-light)}.dark-theme.accent-blue{--primary-light: rgba(33, 150, 243, .15);--primary-text: var(--primary-color);--secondary-color: var(--primary-color);--secondary-hover: var(--primary-hover);--secondary-light: var(--primary-light)}.dark-theme.accent-green{--primary-light: rgba(34, 197, 94, .15);--primary-text: var(--primary-color);--secondary-color: var(--primary-color);--secondary-hover: var(--primary-hover);--secondary-light: var(--primary-light)}.dark-theme.accent-purple{--primary-light: rgba(139, 92, 246, .15);--primary-text: var(--primary-color);--secondary-color: var(--primary-color);--secondary-hover: var(--primary-hover);--secondary-light: var(--primary-light)}.dark-theme.accent-orange{--primary-light: rgba(249, 115, 22, .15);--primary-text: var(--primary-color);--secondary-color: var(--primary-color);--secondary-hover: var(--primary-hover);--secondary-light: var(--primary-light)}.dark-theme.accent-pink{--primary-light: rgba(236, 72, 153, .15);--primary-text: var(--primary-color);--secondary-color: var(--primary-color);--secondary-hover: var(--primary-hover);--secondary-light: var(--primary-light)}.dark-theme.accent-beach{--primary-light: rgba(250, 204, 21, .15);--primary-text: var(--primary-color);--secondary-color: var(--primary-color);--secondary-hover: var(--primary-hover);--secondary-light: var(--primary-light)}.compact-mode{font-size:13px}.compact-mode .category-header{padding:.625rem .875rem}.compact-mode .budget-item{padding:.5rem .875rem .5rem 2rem}.compact-mode .category-progress{padding:0 .875rem .5rem}.reduce-motion *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{overflow:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-weight:var(--font-weight-normal);background-color:var(--bg-color);color:var(--text-color);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}.app-container{display:flex;height:100%;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-color);position:relative}.main-content__page{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.main-content__header{display:flex;justify-content:flex-end;align-items:center;padding:.5rem 1.5rem;position:absolute;top:0;right:0;z-index:10;pointer-events:none}.main-content__header>*{pointer-events:auto}.page-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4, 1rem);padding:var(--space-2, .5rem) 0em;margin-bottom:var(--space-4, 1rem)}.page-toolbar__tabs{display:flex;gap:var(--space-1, .25rem)}.page-toolbar__tab{padding:.625rem var(--space-4, 1rem);font-size:var(--font-size-sm, .875rem);font-weight:var(--font-weight-medium, 500);color:var(--text-muted);background:transparent;border:none;border-radius:var(--radius-md, 8px);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.page-toolbar__tab:hover{color:var(--text-color)}.page-toolbar__tab.active{color:var(--text-color);background:transparent;font-weight:var(--font-weight-semibold, 600)}.page-toolbar__tab-count{margin-left:var(--space-1, .375rem);padding:.125rem var(--space-2, .5rem);font-size:var(--font-size-xs, .75rem);font-weight:var(--font-weight-semibold, 600);border-radius:var(--radius-full, 12px);background:var(--secondary-bg);color:var(--text-muted)}.page-toolbar__tab.active .page-toolbar__tab-count{color:var(--secondary-color)}.page-toolbar__search{position:relative;flex:0 1 280px;min-width:0}.page-toolbar__search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;z-index:1}.page-toolbar__search-input{width:100%;padding:.5rem .75rem .5rem 2.25rem;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);background:var(--input-bg);color:var(--text-color);font-family:inherit;font-size:var(--font-size-sm, .875rem);transition:border-color .15s,box-shadow .15s}.page-toolbar__search-input::placeholder{color:var(--text-muted)}.page-toolbar__search-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-color-alpha)}.page-toolbar--search-only{justify-content:flex-start}@media(max-width:640px){.page-toolbar{flex-direction:column;align-items:stretch;gap:var(--space-2, .5rem)}.page-toolbar__tabs{justify-content:center}.page-toolbar__search{flex:1;max-width:none}}.hamburger-button{display:none;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-color);padding:8px;border-radius:var(--radius-md);margin-right:auto;transition:background var(--transition-fast)}.hamburger-button:hover{background:var(--menu-hover)}.hamburger-button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.skip-link{position:absolute;top:-100%;left:16px;z-index:10000;padding:12px 24px;background:var(--primary-color);color:#fff;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-decoration:none;transition:top .2s ease}.skip-link:focus{top:16px}.skip-link:hover{text-decoration:none}@media(max-width:768px){.app-container{padding-top:env(safe-area-inset-top)}.main-content__page{padding-bottom:env(safe-area-inset-bottom)}.hamburger-button{display:flex}.main-content__header{position:relative;justify-content:space-between;background:var(--bg-color);pointer-events:auto}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}.dark-theme ::-webkit-scrollbar-thumb{background:#475569}.dark-theme ::-webkit-scrollbar-thumb:hover{background:#64748b}::selection{background:var(--primary-color);color:#fff}a{color:var(--secondary-color);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}a:hover{text-decoration:underline;text-decoration-thickness:2px}a.skip-link,a.menu-item,a.nav-link,a[class*=button],a[class*=btn],a[class*=card]{text-decoration:none}:focus-visible{outline:2px solid var(--secondary-color, var(--primary-color));outline-offset:2px}:focus:not(:focus-visible){outline:none}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--secondary-color, var(--primary-color));outline-offset:2px}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/assets/InterVariable-CWi-zmRD.woff2) format("woff2")}@font-face{font-family:Inter;font-style:italic;font-weight:100 900;font-display:swap;src:url(/assets/InterVariable-Italic-d6KXgdvN.woff2) format("woff2")}
