:root{--color-primary: #b59c80;--color-primary-hover: #9E8769;--color-primary-dark: #7d6b54;--color-primary-tint: rgba(181, 156, 128, .35);--color-primary-tint-border: rgba(181, 156, 128, .8);--color-primary-tint-light: rgba(181, 156, 128, .15);--color-primary-tint-hover: rgba(181, 156, 128, .1);--color-primary-tint-focus: rgba(181, 156, 128, .15);--color-bg: #FAF9F6;--color-card: #ffffff;--color-text: #3d3629;--color-text-secondary: #797169;--color-text-muted: #999999;--color-border: #E0D9D0;--color-border-light: #eeeeee;--color-border-input: #dddddd;--color-success: #12ae63;--color-success-alt: #2e7d32;--color-danger: #ef4444;--color-danger-tint: rgba(239, 68, 68, .1);--color-danger-hover-bg: #fef2f2;--color-danger-hover-border: #dc2626;--color-danger-focus: rgba(239, 68, 68, .35);--color-error: #d32f2f;--color-table-header: #dfdad3;--color-row-hover: #F5F2ED;--color-row-alt: #FAF8F5;--color-manual-bg: rgba(205, 216, 190, .6);--color-manual-border: rgba(148, 172, 156, 1);--color-subscription: #8faab3;--color-backdrop: rgba(0, 0, 0, .35);--color-backdrop-light: rgba(0, 0, 0, .25);--color-backdrop-subtle: rgba(0, 0, 0, .3);--color-border-subtle: rgba(0, 0, 0, .08);--color-progress-track: #e5e0da;--color-progress-safe: #4caf50;--color-progress-warn: #ff9800;--color-progress-danger: #f44336;--color-on-primary: #ffffff;--select-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='%233d3629'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19.5 8.25-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");--shadow-card: 0 1px 3px rgba(0, 0, 0, .1);--shadow-modal: 0 18px 50px rgba(0, 0, 0, .35);--shadow-modal-sm: 0 8px 24px rgba(0, 0, 0, .15);--shadow-dialog: 0 20px 60px rgba(0, 0, 0, .3);--shadow-popover: 0 8px 24px -4px rgba(0, 0, 0, .15);--shadow-toast: 0 4px 12px rgba(0, 0, 0, .15);--shadow-focus: 0 0 0 3px rgba(191, 165, 136, .35);--space-xs: .5rem;--space-sm: 1rem;--space-md: 1.5rem;--space-lg: 2rem;--transition: all .2s ease;--chart-max-width: 260px;--z-topbar: 10;--z-dropdown: 100;--z-popover: 1000;--z-modal: 999;--z-modal-high: 9999;--z-modal-top: 10000;--scrollbar-track: #FAF9F7;--scrollbar-thumb: #e5e0da;--scrollbar-thumb-hover: #d8d2ca}[data-theme=rose]{--color-primary: #c06373;--color-primary-hover: #a8515f;--color-primary-dark: #8c3f4c;--color-primary-tint: rgba(192, 99, 115, .35);--color-primary-tint-border: rgba(192, 99, 115, .8);--color-primary-tint-light: rgba(192, 99, 115, .15);--color-primary-tint-hover: rgba(192, 99, 115, .1);--color-primary-tint-focus: rgba(192, 99, 115, .15);--color-bg: #fcf8f5;--color-card: #ffffff;--color-text: #3a2328;--color-text-secondary: #7a5f65;--color-text-muted: #a08890;--color-border: #e2c8cf;--color-border-light: #f0dde2;--color-border-input: #ddc4cb;--color-border-subtle: rgba(192, 99, 115, .08);--color-table-header: #e8cdd4;--color-row-hover: #faf0f2;--color-row-alt: #fdf6f8;--color-progress-track: #efd0d9;--color-progress-safe: #60a97e;--color-progress-warn: #d2853c;--color-progress-danger: #c03f54;--select-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='%233a2328'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19.5 8.25-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");--shadow-focus: 0 0 0 3px rgba(192, 99, 115, .3);--scrollbar-track: #fcf8f5;--scrollbar-thumb: #efd0d9;--scrollbar-thumb-hover: #bb9eab;--color-subscription: #b89ab4;--icon-checkin-color: #9884b4;--color-manual-bg: rgba(168, 152, 196, .3);--color-manual-border: rgba(152, 132, 180, 1)}[data-theme=dawn]{--color-primary: #92a8d1;--color-primary-hover: #7d97c4;--color-primary-dark: #6482b4;--color-primary-tint: rgba(247, 202, 201, .45);--color-primary-tint-border: rgba(146, 168, 209, .75);--color-primary-tint-light: rgba(146, 168, 209, .14);--color-primary-tint-hover: rgba(146, 168, 209, .09);--color-primary-tint-focus: rgba(146, 168, 209, .15);--color-bg: #f4f0f8;--color-card: #ffffff;--color-text: #323550;--color-text-secondary: #707c98;--color-text-muted: #a8b5cb;--color-border: #e0d4ee;--color-border-light: #ece6f5;--color-border-input: #d6c8e8;--color-border-subtle: rgba(146, 168, 209, .1);--color-table-header: #fce8eb;--color-row-hover: #fdf0f4;--color-row-alt: #fdf8fe;--color-progress-track: #e0d4ee;--color-progress-safe: #5a9e78;--color-progress-warn: #c4904a;--color-progress-danger: #c45470;--select-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='%2338334a'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19.5 8.25-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");--shadow-focus: 0 0 0 3px rgba(146, 168, 209, .3);--scrollbar-track: #f4f0f8;--scrollbar-thumb: #e0d4ee;--scrollbar-thumb-hover: #c8bade;--color-subscription: #92a8d1;--icon-checkin-color: #92a8d1;--color-manual-bg: rgba(146, 168, 209, .3);--color-manual-border: rgba(100, 135, 190, .85)}[data-theme=dawn] body{background:linear-gradient(150deg,#fceef2,#edf0fb) fixed}[data-theme=dawn] .streak-calendar__day--transaction .streak-calendar__day-inner,[data-theme=dawn] .streak-calendar__legend-item--transaction:before,[data-theme=dawn] .split-member-avatar{border-color:#d28c8ccc}[data-theme=dawn] .split-member-avatar{color:#a06060}[data-theme=graphite]{--color-primary: #656a6c;--color-primary-hover: #535859;--color-primary-dark: #424647;--color-primary-tint: rgba(101, 106, 108, .35);--color-primary-tint-border: rgba(101, 106, 108, .8);--color-primary-tint-light: rgba(101, 106, 108, .15);--color-primary-tint-hover: rgba(101, 106, 108, .1);--color-primary-tint-focus: rgba(101, 106, 108, .15);--color-bg: #eef1f4;--color-card: #fdfeff;--color-text: #2c3235;--color-text-secondary: #656a6c;--color-text-muted: #aba4a3;--color-border: #cfd6db;--color-border-light: #dde4e8;--color-border-input: #c5cdd2;--color-border-subtle: rgba(101, 106, 108, .08);--color-table-header: #dae0e4;--color-row-hover: #f0f4f6;--color-row-alt: #f7f9fa;--color-progress-track: #cfd6db;--color-progress-safe: #4a9e68;--color-progress-warn: #c49040;--color-progress-danger: #c45454;--select-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='%232c3235'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19.5 8.25-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");--shadow-focus: 0 0 0 3px rgba(101, 106, 108, .3);--scrollbar-track: #eef1f4;--scrollbar-thumb: #cfd6db;--scrollbar-thumb-hover: #b0babe;--color-subscription: #8fa7b0;--icon-checkin-color: #7a9aa8;--color-manual-bg: rgba(130, 160, 178, .22);--color-manual-border: rgba(110, 148, 168, .88)}[data-theme=graphite] .streak-calendar{background:var(--color-card)}[data-theme=graphite] .streak-calendar__day--transaction .streak-calendar__day-inner{background:#78787824;border-color:#7878786b}[data-theme=graphite] .streak-calendar__legend-item--transaction:before{background:#78787824;border-color:#7878786b}[data-theme=soda]{--color-primary: #2e8cb8;--color-primary-hover: #2278a0;--color-primary-dark: #185f80;--color-primary-tint: rgba(130, 210, 225, .32);--color-primary-tint-border: rgba(46, 140, 184, .42);--color-primary-tint-light: rgba(208, 246, 254, .55);--color-primary-tint-hover: rgba(208, 246, 254, .35);--color-primary-tint-focus: rgba(130, 210, 225, .22);--color-bg: #f0fafd;--color-card: #ffffff;--color-text: #1e4a55;--color-text-secondary: #3d6870;--color-text-muted: #82b4bc;--color-border: #caeef7;--color-border-light: #d8f4fa;--color-border-input: #bce8f2;--color-border-subtle: rgba(34, 120, 160, .07);--color-table-header: #d4f4fb;--color-row-hover: #e6faff;--color-row-alt: #f2fdff;--color-progress-track: #b8e6f2;--color-progress-safe: #5a9e78;--color-progress-warn: #c4904a;--color-progress-danger: #c45470;--select-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='%231e4a55'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19.5 8.25-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");--shadow-focus: 0 0 0 3px rgba(130, 210, 225, .42);--scrollbar-track: #f0fafd;--scrollbar-thumb: #b8e6f2;--scrollbar-thumb-hover: #95d7d3;--color-subscription: #2e8cb8;--icon-checkin-color: #95d7d3;--color-manual-bg: rgba(46, 140, 184, .3);--color-manual-border: rgba(46, 140, 184, .78)}[data-theme=lavender]{--color-primary: #8a7ebc;--color-primary-hover: #7a6eac;--color-primary-dark: #635a96;--color-primary-tint: rgba(173, 155, 215, .32);--color-primary-tint-border: rgba(115, 106, 175, .45);--color-primary-tint-light: rgba(173, 155, 215, .15);--color-primary-tint-hover: rgba(173, 155, 215, .1);--color-primary-tint-focus: rgba(173, 155, 215, .18);--color-bg: #f9f7fb;--color-card: #ffffff;--color-text: #3a3354;--color-text-secondary: #6e6490;--color-text-muted: #a89cb8;--color-border: #dad4e4;--color-border-light: #e6e0ee;--color-border-input: #d0c8dc;--color-border-subtle: rgba(115, 106, 175, .08);--color-table-header: #eae5f2;--color-row-hover: #f5f2f8;--color-row-alt: #faf8fc;--color-progress-track: #dad4e4;--color-progress-safe: #5a9e78;--color-progress-warn: #c4904a;--color-progress-danger: #c45470;--select-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='%233a3354'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19.5 8.25-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");--shadow-focus: 0 0 0 3px rgba(173, 155, 215, .35);--scrollbar-track: #f9f7fb;--scrollbar-thumb: #dad4e4;--scrollbar-thumb-hover: #ad9bd7;--color-subscription: #8a7ebc;--icon-checkin-color: #ad9bd7;--color-manual-bg: rgba(175, 105, 160, .25);--color-manual-border: rgba(155, 80, 140, .72)}[data-theme=peach]{--color-primary: #f99584;--color-primary-hover: #e58070;--color-primary-dark: #c86a5c;--color-primary-tint: rgba(249, 149, 132, .35);--color-primary-tint-border: rgba(249, 149, 132, .55);--color-primary-tint-light: rgba(249, 149, 132, .15);--color-primary-tint-hover: rgba(249, 149, 132, .1);--color-primary-tint-focus: rgba(249, 149, 132, .15);--color-bg: #fef5f3;--color-card: #ffffff;--color-text: #4c2c28;--color-text-secondary: #8a6860;--color-text-muted: #b09088;--color-border: #f4dbd6;--color-border-light: #f9e8e4;--color-border-input: #f0d0ca;--color-border-subtle: rgba(249, 149, 132, .08);--color-table-header: #f4cec7;--color-row-hover: #fdeae5;--color-row-alt: #fdf9f8;--color-progress-track: #f4dbd6;--color-progress-safe: #5a9e78;--color-progress-warn: #d4903c;--color-progress-danger: #d04848;--select-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='%234c2c28'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19.5 8.25-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");--shadow-focus: 0 0 0 3px rgba(249, 149, 132, .3);--scrollbar-track: #fef5f3;--scrollbar-thumb: #f4dbd6;--scrollbar-thumb-hover: #e8c4bc;--color-subscription: #d4887a;--icon-checkin-color: #f99584;--color-manual-bg: rgba(249, 149, 132, .18);--color-manual-border: rgba(220, 120, 100, .85)}[data-theme=lime]{--color-primary: #aec22a;--color-primary-hover: #9aae22;--color-primary-dark: #78881a;--color-primary-tint: rgba(174, 194, 42, .35);--color-primary-tint-border: rgba(174, 194, 42, .5);--color-primary-tint-light: rgba(174, 194, 42, .15);--color-primary-tint-hover: rgba(174, 194, 42, .1);--color-primary-tint-focus: rgba(174, 194, 42, .15);--color-bg: #f6f9ea;--color-card: #ffffff;--color-text: #303410;--color-text-secondary: #606438;--color-text-muted: #92946a;--color-border: #e0e6c0;--color-border-light: #eaeed2;--color-border-input: #d6deb4;--color-border-subtle: rgba(174, 194, 42, .08);--color-table-header: #eef0cc;--color-row-hover: #f2f5e0;--color-row-alt: #fafcf2;--color-progress-track: #e0e6c0;--color-progress-safe: #5a9e60;--color-progress-warn: #d4903c;--color-progress-danger: #d04848;--color-on-primary: #3d5016;--select-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='%23303410'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19.5 8.25-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");--shadow-focus: 0 0 0 3px rgba(174, 194, 42, .3);--scrollbar-track: #f6f9ea;--scrollbar-thumb: #e0e6c0;--scrollbar-thumb-hover: #c8d0a4;--color-subscription: #8a9e48;--icon-checkin-color: #aec22a;--color-manual-bg: rgba(174, 194, 42, .18);--color-manual-border: rgba(140, 160, 30, .85)}[data-theme=sorbet]{--color-primary: #ee9248;--color-primary-hover: #dc8038;--color-primary-dark: #b8682a;--color-primary-tint: rgba(238, 146, 72, .35);--color-primary-tint-border: rgba(238, 146, 72, .8);--color-primary-tint-light: rgba(238, 146, 72, .15);--color-primary-tint-hover: rgba(238, 146, 72, .1);--color-primary-tint-focus: rgba(238, 146, 72, .15);--color-bg: #f4fafe;--color-card: #ffffff;--color-text: #2a3e4c;--color-text-secondary: #6c8c9c;--color-text-muted: #94b0be;--color-border: #d6eaf4;--color-border-light: #e4f0f8;--color-border-input: #c8e0ee;--color-border-subtle: rgba(90, 176, 212, .08);--color-table-header: rgba(240, 190, 58, .2);--color-row-hover: #eef6fb;--color-row-alt: #f6fbfe;--color-progress-track: #d6eaf4;--color-progress-safe: #5a9e78;--color-progress-warn: #f0be3a;--color-progress-danger: #e05454;--select-arrow: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='%232a3e4c'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19.5 8.25-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");--shadow-focus: 0 0 0 3px rgba(238, 146, 72, .3);--scrollbar-track: #f4fafe;--scrollbar-thumb: #d6eaf4;--scrollbar-thumb-hover: #b0d4e6;--color-subscription: #5ab0d4;--icon-checkin-color: #f0be3a;--color-manual-bg: rgba(240, 190, 58, .22);--color-manual-border: rgba(218, 168, 30, .85)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}*,*:before,*:after{box-sizing:border-box}html{overflow-x:hidden;width:100%;max-width:100vw;min-height:100vh;box-sizing:border-box}body{margin:0;width:100%;max-width:100vw;min-height:100vh;overflow-x:hidden;padding:1.25rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans TC,sans-serif;font-size:1rem;font-weight:400;color:var(--color-text);background:var(--color-bg);line-height:1.6;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h2{font-size:1.5rem;font-weight:600;margin-top:0;margin-bottom:var(--space-sm);color:var(--color-text)}h3{font-size:1.25rem;font-weight:600;color:var(--color-text)}.app-top-bar{display:none}.more-menu-btn{display:inline-flex;align-items:center;justify-content:center;padding:0;background:transparent;border:none;cursor:pointer;color:var(--color-primary);transition:var(--transition);position:relative}.more-menu-btn:hover{opacity:.7}.more-menu-btn:focus{outline:none;opacity:.7}.more-menu-icon{width:1.5rem;height:1.5rem;display:block}.more-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;z-index:var(--z-dropdown);min-width:10rem;padding:.5rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;box-shadow:var(--shadow-card);display:none;opacity:0;transform:translateY(-10px);transition:opacity .2s ease,transform .2s ease}.more-menu-dropdown.is-open{display:block;opacity:1;transform:translateY(0)}.more-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.625rem .75rem;background:transparent;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;color:var(--color-text);text-align:left;transition:var(--transition)}.more-menu-item:hover{background:var(--color-primary-tint-hover);color:var(--color-primary)}.more-menu-item:focus{outline:none;box-shadow:var(--shadow-focus)}.more-menu-item-icon{width:1.125rem;height:1.125rem;flex-shrink:0}.app-container{display:grid;grid-template-columns:minmax(0,30%) minmax(0,70%);grid-template-rows:1fr;gap:var(--space-lg);width:100%;max-width:100%;height:100vh;min-height:100vh;margin:0 auto;padding-top:var(--space-lg);padding-bottom:var(--space-lg);padding-left:1.25rem;padding-right:1.25rem;overflow:visible;box-sizing:border-box}.form-column{display:flex;flex-direction:column;justify-content:center;align-items:stretch;min-height:0;min-width:0;overflow-y:auto;padding-left:.5rem;padding-right:.75rem}.user-avatar-wrapper--desktop{display:flex;align-items:center;position:relative}.user-avatar-wrapper--mobile{display:none;align-items:center;position:relative}.user-avatar-btn{width:2.05rem;height:2.05rem;min-width:2.05rem;min-height:2.05rem;padding:0;border:none;border-radius:50%;background:var(--color-primary);color:var(--color-on-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:var(--transition);flex-shrink:0}.user-avatar-btn:hover{opacity:.85}.user-avatar-btn:focus{outline:none;box-shadow:var(--shadow-focus)}.user-avatar-inner{font-size:.9rem;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.user-avatar-btn img{width:100%;height:100%;object-fit:cover}.user-avatar-dropdown{position:absolute;top:calc(100% + .75rem);left:0;z-index:var(--z-dropdown);min-width:12rem;padding:.5rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;box-shadow:var(--shadow-card);display:none;opacity:0;transform:translateY(-10px);transition:opacity .2s ease,transform .2s ease}.user-avatar-dropdown.is-open{display:block;opacity:1;transform:translateY(0)}.user-avatar-dropdown__email{padding:.5rem .75rem;font-size:.875rem;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);margin-bottom:.25rem}.user-avatar-dropdown--desktop .user-avatar-dropdown__email{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-avatar-dropdown--mobile .user-avatar-dropdown__email{word-break:break-all}.user-avatar-dropdown--mobile{position:fixed;top:4.25rem;left:.75rem;right:auto}.dashboard-column{display:flex;flex-direction:column;gap:var(--space-md);min-height:0;min-width:0;overflow-y:auto;overflow-x:clip;padding-right:1.5rem;padding-bottom:1rem}.stats-cards{display:flex;gap:var(--space-sm)}.stats-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm);position:relative}.stats-section-header h2{margin-bottom:0}.stats-section-header__title-group{display:flex;align-items:center;gap:1rem}.month-picker{position:relative;display:flex;align-items:center}.month-picker-trigger{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.9rem;background-color:var(--color-card);color:var(--color-text);cursor:pointer;transition:var(--transition)}.month-picker-trigger:hover{border-color:var(--color-primary);background:var(--color-primary-tint-hover)}.month-picker-trigger:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.month-picker-trigger[aria-expanded=true]{border-color:var(--color-primary)}.month-picker-trigger__icon{width:.8rem;height:.8rem;flex-shrink:0;transition:transform .2s}.month-picker-trigger[aria-expanded=true] .month-picker-trigger__icon{transform:rotate(180deg)}.month-picker-popover{position:fixed;min-width:9rem;max-width:16rem;padding:.6rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;box-shadow:var(--shadow-popover);z-index:var(--z-popover);display:none}.month-picker-popover.is-open{display:block}.month-picker-year-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem;padding-bottom:.4rem;border-bottom:1px solid var(--color-border)}.month-picker-year-btn{width:1.75rem;height:1.75rem;padding:0;border:1px solid var(--color-border);border-radius:6px;background:var(--color-card);color:var(--color-text);font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.month-picker-year-btn:hover{background:var(--color-primary-tint-light);border-color:var(--color-primary)}.month-picker-year-display{font-weight:600;font-size:.9rem;color:var(--color-text)}.month-picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.25rem}.month-picker-item{padding:.4rem .5rem;border:none;border-radius:5px;font-size:.85rem;background:transparent;color:var(--color-text);cursor:pointer;text-align:center;transition:var(--transition)}.month-picker-item:hover{background:var(--color-primary-tint-light)}.month-picker-item.is-selected{background:var(--color-primary);color:var(--color-on-primary)}.month-picker-item:focus{outline:none;box-shadow:var(--shadow-focus)}.month-picker-trigger[disabled]{opacity:.6;cursor:default}.stat-card{flex:1;display:flex;flex-direction:column;background:var(--color-card);padding:var(--space-md);border-radius:10px;box-shadow:var(--shadow-card);position:relative}.stat-card:nth-child(1):after{content:"";position:absolute;right:.75rem;top:50%;transform:translateY(-50%);width:5rem;height:5rem;right:0rem;background-image:url(/my-smart-finance/images/maltese-gif-3.gif);background-size:contain;background-repeat:no-repeat;background-position:center;opacity:.85}.stat-card:nth-child(2):after{content:"";position:absolute;right:0rem;top:50%;transform:translateY(-50%);width:11rem;height:11rem;background-image:url(/my-smart-finance/images/maltese-gif-5.png);background-size:contain;background-repeat:no-repeat;background-position:center;opacity:.85}.stat-card:nth-child(3):after{content:"";position:absolute;right:.75rem;top:50%;transform:translateY(-50%);width:6rem;height:6rem;background-image:url(/my-smart-finance/images/maltese-gif-6.png);background-size:contain;background-repeat:no-repeat;background-position:center;opacity:.85}.app-sidebar:not(.is-collapsed)~.app-layout__main .stat-card:nth-child(2):after{width:6rem;height:6rem;right:-1.1rem;top:calc(50% + .4rem)}.app-sidebar:not(.is-collapsed)~.app-layout__main .stat-card:nth-child(3):after{width:4.5rem;height:4.5rem;right:-.5rem;top:calc(50% + .25rem)}.app-sidebar.is-collapsed~.app-layout__main .stat-card:nth-child(1):after{width:5rem;height:5rem;right:0rem}.app-sidebar.is-collapsed~.app-layout__main .stat-card:nth-child(2):after{width:8rem;height:8rem;right:-1rem}.app-sidebar.is-collapsed~.app-layout__main .stat-card:nth-child(3):after{width:6rem;height:6rem;right:0rem}.stat-label{font-size:.75rem;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs)}.stat-value{font-size:2rem;font-weight:700;color:var(--color-text)}.stat-card:nth-child(1) .stat-value{color:var(--color-success)}.stat-card:nth-child(2) .stat-value{color:var(--color-danger)}.stat-card:nth-child(3) .stat-value{color:var(--color-text)}.balance-positive{color:var(--color-success)!important}.balance-negative{color:var(--color-danger)!important}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.analytics-col{background:var(--color-card);padding:var(--space-md);border-radius:10px;box-shadow:var(--shadow-card)}.analytics-col h3{margin-top:0;margin-bottom:var(--space-sm)}#categoryChart{max-width:var(--chart-max-width);margin:var(--space-sm) auto;display:block}#categoryStats,#paymentStats{margin-top:var(--space-sm);font-size:.9375rem;color:var(--color-text-secondary)}.category-chart-legend{display:grid;grid-template-columns:repeat(4,max-content);justify-content:center;gap:.35rem .75rem;margin-top:var(--space-sm);font-size:.8125rem;color:var(--color-text-secondary)}.category-chart-legend .legend-item{display:flex;align-items:center;gap:.35rem}.category-chart-legend .legend-color{flex-shrink:0;width:10px;height:10px;border-radius:2px}.category-stats-list,.payment-stats-list{list-style:none;padding:0;margin:0}.category-stats-list li,.payment-stats-list li{display:flex;justify-content:space-between;align-items:center;padding:.35rem 0;border-bottom:1px solid var(--color-border)}.category-stats-list li:last-child,.payment-stats-list li:last-child{border-bottom:none}.cat-name,.pay-name{font-weight:500;color:var(--color-text)}.cat-amount,.pay-amount{font-weight:600;color:var(--color-text)}.category-stats-empty,.payment-stats-empty{margin:0;color:var(--color-text-secondary);font-style:italic}.payment-stats-list li.clickable{cursor:pointer;transition:var(--transition);-webkit-tap-highlight-color:var(--color-primary-tint-focus);min-height:44px}.payment-stats-list li.clickable:hover{background:var(--color-row-hover);border-radius:6px;padding-left:.5rem}.transaction-form-section{background:var(--color-card);border-radius:12px;box-shadow:var(--shadow-card);padding:var(--space-lg)}.transaction-form-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-md)}.btn-checkin{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .75rem;border-radius:999px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-checkin-icon{width:1rem;height:1rem;display:inline-flex;align-items:center;justify-content:center}.btn-checkin:hover{background:var(--color-row-hover);border-color:var(--color-primary);color:var(--color-text)}.btn-checkin:focus{outline:none;box-shadow:var(--shadow-focus)}.btn-checkin[disabled],.btn-checkin.btn-checkin-disabled{opacity:.6;cursor:default;border-color:var(--color-border)}.form-group{margin-bottom:1.25rem;width:100%;max-width:100%}.form-group--currency-amount .form-group__amount-label{display:block;margin-bottom:var(--space-xs)}.form-group--currency-amount .form-group__currency-amount-row{display:flex;gap:var(--space-sm);align-items:stretch}.form-group--currency-amount .form-group__currency{flex:0 0 auto;min-width:0;width:30%}.form-group--currency-amount .form-group__currency select{width:100%;height:100%;min-height:2.75rem}.form-group--currency-amount .form-group__amount{flex:1;min-width:0}.form-group--currency-amount .form-group__amount input{width:100%}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.form-group input[type=text],.form-group input[type=number],.form-group input[type=date]{width:100%;max-width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:8px;font-size:1rem;color:var(--color-text);transition:var(--transition);box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.form-group select{width:100%;padding:.75rem 1.25rem .75rem .75rem;border:1px solid var(--color-border);border-radius:8px;font-size:1rem;color:var(--color-text);background-color:var(--color-card);background-image:var(--select-arrow);background-repeat:no-repeat;background-position:right .5rem center;background-size:1rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:var(--transition)}.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:8px;font-size:1rem;font-family:inherit;color:var(--color-text);resize:vertical;transition:var(--transition)}.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.transaction-form-section button[type=submit]{width:100%;padding:.875rem;background:var(--color-primary);color:var(--color-on-primary);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition)}.transaction-form-section button[type=submit]:hover{background:var(--color-primary-hover)}.transaction-form-section button[type=submit]:focus{outline:none;box-shadow:var(--shadow-focus)}.form-actions{display:flex;gap:.5rem;flex-wrap:wrap}.form-actions button[type=submit]{flex:1;min-width:0}.btn-cancel{flex:0 0 auto;padding:.875rem 1rem;font-size:1rem;font-weight:500;color:var(--color-text-secondary);background:transparent;border:1px solid var(--color-border);border-radius:8px;cursor:pointer;transition:var(--transition)}.btn-cancel:hover{background:var(--color-row-hover);color:var(--color-text);border-color:var(--color-text-secondary)}.btn-cancel:focus{outline:none;box-shadow:var(--shadow-focus)}.settings-manage-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.settings-manage__section{display:flex;flex-direction:column;gap:1rem}.settings-manage__section-title{margin:0 0 .5rem;font-size:1.125rem;color:var(--color-text);font-weight:600;border-bottom:2px solid var(--color-primary);padding-bottom:.5rem}[data-theme=dawn] .settings-manage__section-title{border-bottom:none;position:relative}[data-theme=dawn] .settings-manage__section-title:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#f7cac9,#92a8d1);border-radius:1px}.settings-manage__loading{margin:0;color:var(--color-text-secondary)}@media(max-width:860px){.settings-manage-grid{grid-template-columns:1fr}}.theme-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(68px,1fr));gap:.5rem}.theme-picker__item{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.5rem .6rem;border-radius:10px;border:2px solid var(--color-border);background:var(--color-card);cursor:pointer;transition:var(--transition);position:relative;min-width:0}.theme-picker__item:hover{border-color:var(--color-primary)}.theme-picker__item.is-active{border-color:var(--color-primary);background:var(--color-primary-tint-light)}.theme-picker__swatch{display:flex;border-radius:6px;overflow:hidden;width:100%;height:22px;border:1px solid var(--color-border-subtle)}.theme-picker__swatch span{flex:1}.theme-picker__label{font-size:.7rem;font-weight:500;color:var(--color-text-secondary)}.theme-picker__item.is-active .theme-picker__label{color:var(--color-primary-dark);font-weight:600}.theme-picker__check{position:absolute;top:.3rem;right:.3rem;width:14px;height:14px;color:var(--color-primary)}@media(max-width:600px){.theme-picker{grid-template-columns:repeat(4,1fr)}.theme-picker__item{padding:.75rem .4rem}.theme-picker__label{font-size:.6rem;white-space:nowrap}}.theme-shuffle{display:flex;flex-direction:column;gap:1rem}.theme-shuffle__toggle-row{display:flex;align-items:center;justify-content:space-between;cursor:pointer}.theme-shuffle__toggle-label{font-size:.9rem;color:var(--color-text)}.theme-shuffle__options{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--color-bg);border-radius:10px;border:1px solid var(--color-border)}.theme-shuffle__field{display:flex;flex-direction:column;gap:.5rem}.theme-shuffle__field-label{font-size:.8rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.theme-shuffle__themes{display:grid;grid-template-columns:repeat(auto-fill,minmax(68px,1fr));gap:.5rem}.theme-shuffle__theme-item{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.5rem .6rem;border-radius:10px;border:2px solid var(--color-border);background:var(--color-card);cursor:pointer;transition:var(--transition);min-width:0}@media(max-width:600px){.theme-shuffle__themes{grid-template-columns:repeat(4,1fr)}.theme-shuffle__theme-item{padding:.75rem .4rem}.theme-shuffle__theme-label{font-size:.6rem;white-space:nowrap}}.theme-shuffle__theme-item:hover:not(.is-checked){background:var(--color-row-hover)}.theme-shuffle__theme-item.is-checked{border-color:var(--color-primary);background:var(--color-primary-tint-light)}.theme-shuffle__theme-swatch{display:flex;border-radius:6px;overflow:hidden;width:100%;height:20px;border:1px solid var(--color-border-subtle)}.theme-shuffle__theme-swatch span{flex:1}.theme-shuffle__theme-label{font-size:.7rem;font-weight:500;color:var(--color-text-secondary)}.theme-shuffle__theme-item.is-checked .theme-shuffle__theme-label{color:var(--color-primary-dark);font-weight:600}.theme-shuffle__intervals{display:flex;gap:.5rem;flex-wrap:wrap}.theme-shuffle__interval-item{display:flex;align-items:center;padding:.4rem .9rem;border-radius:20px;border:2px solid var(--color-border);background:var(--color-card);font-size:.825rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:var(--transition)}.theme-shuffle__interval-item:hover{border-color:var(--color-primary);color:var(--color-primary)}.theme-shuffle__interval-item.is-checked{border-color:var(--color-primary);background:var(--color-primary-tint-light);color:var(--color-primary-dark);font-weight:600}.category-manager{display:flex;flex-direction:column;gap:1rem}.category-group{background:var(--color-bg);border-radius:10px;padding:1rem;border:1px solid var(--color-border)}.category-group__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.category-group__header h4{margin:0;font-size:1rem;color:var(--color-text);font-weight:600}.category-group__inline-add{flex:1;min-width:0}.btn-add-category{padding:.4rem .8rem;border-radius:8px;border:1px solid var(--color-primary);background:var(--color-card);color:var(--color-primary);font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition)}.btn-add-category:hover{background:var(--color-primary);color:var(--color-on-primary)}.category-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.category-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem .8rem;background:var(--color-card);border-radius:8px;border:1px solid var(--color-border)}.category-item__name{flex:1;font-size:.9rem;font-weight:700;color:var(--color-text)}.category-item__actions{display:flex;gap:.5rem}.category-item__btn{padding:.25rem .5rem;border-radius:6px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:.75rem;cursor:pointer;transition:var(--transition)}.category-item__btn:hover{background:var(--color-row-hover);border-color:var(--color-primary);color:var(--color-primary)}.category-item__btn:disabled{opacity:.5;cursor:default}.category-item__btn--delete:hover{background:var(--color-danger-hover-bg);border-color:var(--color-danger-hover-border);color:var(--color-danger-hover-border)}.category-inline-input{display:flex;align-items:center;gap:.4rem;width:100%}.category-inline-input__field{flex:1;min-width:0;padding:.3rem .5rem;border:1px solid var(--color-primary);border-radius:6px;font-size:.875rem;color:var(--color-text);background:var(--color-card)}.category-inline-input__field:focus{outline:none;box-shadow:var(--shadow-focus)}.category-item .category-inline-input{flex:1;min-width:0}.account-manager__empty{color:var(--color-text-secondary);text-align:center;padding:1rem;margin:0}.accounts-header{margin-bottom:1rem}.btn-add-account{padding:.6rem 1.2rem;border-radius:8px;border:1px solid var(--color-primary);background:var(--color-primary);color:var(--color-on-primary);font-size:.9rem;font-weight:600;cursor:pointer;transition:var(--transition)}.btn-add-account:hover{background:var(--color-primary-hover)}.accounts-list{display:flex;flex-direction:column;gap:.75rem}.account-item{background:var(--color-bg);border-radius:10px;padding:1rem;border:1px solid var(--color-border)}.account-item__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.account-item__actions{display:flex;gap:.5rem}.account-item__btn{padding:.35rem .7rem;border-radius:6px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:.8rem;cursor:pointer;transition:var(--transition)}.account-item__details{font-size:.85rem;color:var(--color-text-secondary);line-height:1.5}.account-item__detail{margin:.1rem 0}.account-form{background:var(--color-bg);border-radius:10px;padding:1.25rem;border:1px solid var(--color-primary);margin-top:1rem}.account-form h4{margin:0 0 1rem;font-size:1rem;color:var(--color-text)}.account-form .form-group{margin-bottom:1rem}.account-form .form-group label{display:block;margin-bottom:.4rem;font-size:.875rem;font-weight:600;color:var(--color-text)}.account-form .form-group input,.account-form .form-group select{width:100%;padding:.6rem;border-radius:8px;border:1px solid var(--color-border);font-size:.9rem;background:var(--color-card);color:var(--color-text)}.account-form .form-group input:focus,.account-form .form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.account-form .form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.25rem}.account-form .btn-cancel{padding:.6rem 1.2rem;border-radius:8px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:.9rem;cursor:pointer;transition:var(--transition)}.account-form .btn-cancel:hover{background:var(--color-row-hover)}.account-form .btn-save{padding:.6rem 1.2rem;border-radius:8px;border:none;background:var(--color-primary);color:var(--color-on-primary);font-size:.9rem;font-weight:600;cursor:pointer;transition:var(--transition)}.account-form .btn-save:hover{background:var(--color-primary-hover)}.table-wrapper{overflow-x:auto;background:var(--color-card);border-radius:10px;box-shadow:var(--shadow-card)}.transaction-history-section table{width:100%;table-layout:fixed;border-collapse:collapse;background:var(--color-card)}.transaction-history-section thead{background:var(--color-table-header)}.transaction-history-section thead tr{background:var(--color-table-header);padding:0 .45rem}.transaction-history-section th{background:var(--color-table-header);padding:.75rem .5rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--color-text);border-bottom:1px solid var(--color-border);white-space:nowrap;min-width:0}.transaction-history-section th:nth-child(1){text-align:left}.transaction-history-section th:nth-child(2){text-align:left}.transaction-history-section th:nth-child(3){text-align:left}.transaction-history-section th:nth-child(4){text-align:left}.transaction-history-section th:nth-child(5){text-align:right}.transaction-history-section th:nth-child(6){text-align:center}.transaction-history-section th .th-filter-btn{display:inline-flex;align-items:center;justify-content:center;margin-left:.25rem;padding:.2rem;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:4px;vertical-align:middle}.transaction-history-section th .th-filter-btn:hover{color:var(--color-primary);background:var(--color-primary-tint-light)}.transaction-history-section th .th-filter-btn:focus{outline:none;box-shadow:var(--shadow-focus)}.icon-filter{width:1rem;height:1rem;display:block}.filter-popover{position:fixed;z-index:var(--z-dropdown);min-width:10rem;max-height:20rem;overflow-y:auto;padding:.5rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;box-shadow:var(--shadow-card);display:none}.filter-popover.is-open{display:block}.filter-popover__actions{display:flex;gap:.5rem;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.filter-popover__action{padding:.25rem .5rem;font-size:.8125rem;font-weight:500;color:var(--color-primary);background:transparent;border:1px solid var(--color-primary);border-radius:4px;cursor:pointer}.filter-popover__action:hover{background:var(--color-primary-tint-light)}.filter-popover__action:focus{outline:none;box-shadow:var(--shadow-focus)}.filter-popover__list{display:flex;flex-direction:column;gap:.25rem}.filter-popover__list label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:400;cursor:pointer;padding:.25rem 0}.filter-popover__list input[type=checkbox]{margin:0}.transaction-history-section td{padding:.75rem;font-size:.9375rem}.transaction-history-section tbody tr:nth-child(2n) .swipe-content,.transaction-history-section tbody tr:nth-child(2n).transaction-row--semantic td{background:var(--color-row-alt)}.transaction-history-section tbody tr:hover .swipe-content,.transaction-history-section tbody tr:hover.transaction-row--semantic td{background:var(--color-row-hover)}.transaction-history-section tbody tr:last-child .swipe-content,.transaction-history-section tbody tr:last-child.transaction-row--semantic td{border-bottom:none}.transaction-history-section tbody tr:last-child .row-slider-container{border-bottom:none}.amount-income{color:var(--color-success);font-weight:600}.amount-expense{color:var(--color-danger);font-weight:600}.row-actions{display:flex;gap:.5rem;flex-wrap:wrap}.transaction-row{position:relative}.transaction-row--subscription td:first-child{box-shadow:inset 3px 0 0 var(--color-subscription)}.transaction-row--semantic td{position:relative;padding:.5rem;border-bottom:1px solid var(--color-border);background:var(--color-card);min-width:0}.transaction-row-cell{padding:0!important;position:relative;border-bottom:none!important}.swipe-container{position:relative;width:100%;overflow:hidden}.swipe-content{display:grid;grid-template-columns:1.2fr 1fr 1.3fr 1fr 1.3fr 1.4fr;align-items:center;width:100%;background:var(--color-card);position:relative;z-index:2;padding:.5rem .75rem;border-bottom:1px solid var(--color-border);box-sizing:border-box;will-change:transform;transition:transform .3s cubic-bezier(.4,0,.2,1)}.transaction-row--semantic .cell-date-inner,.transaction-row--semantic .cell-category-inner,.transaction-row--semantic .cell-item-inner,.transaction-row--semantic .cell-payment-inner,.transaction-row--semantic .cell-amount-inner,.transaction-row--semantic .cell-actions-inner{position:relative;z-index:2;will-change:transform;min-height:1.5rem}.cell-date{font-size:.875rem;text-align:left;padding:0 .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cell-category,.cell-item{text-align:left;padding:0 .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cell-payment{font-size:.875rem;text-align:left;padding:0 .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cell-amount{text-align:right;font-weight:600;padding:0 .5rem;white-space:nowrap}.cell-actions{padding:0 .5rem;text-align:center;vertical-align:middle}.cell-actions .row-actions{justify-content:center}.swipe-action{position:absolute;top:0;bottom:0;width:90px;min-height:100%;display:none;flex-direction:column;align-items:center;justify-content:center;z-index:1}.swipe-action--delete{right:0;background:var(--color-danger)!important}.swipe-action--edit{left:0;background:var(--color-primary)!important}.swipe-action-btn{display:flex;align-items:center;justify-content:center;width:100%;height:100%;padding:.5rem;border:none;background:transparent;color:var(--color-on-primary);cursor:pointer;transition:var(--transition)}.swipe-action-btn svg{width:1.75rem;height:1.75rem;color:var(--color-on-primary)}.swipe-action-btn:active{opacity:.8;transform:scale(.9)}.btn-edit,.btn-delete{padding:.5rem;border-radius:6px;cursor:pointer;transition:var(--transition);border:none;background:transparent;display:inline-flex;align-items:center;justify-content:center;min-width:36px;min-height:36px}.btn-edit .icon-edit,.btn-delete .icon-delete{width:1.125rem;height:1.125rem;display:block}.btn-edit{color:var(--color-primary)}.btn-edit:hover{background:var(--color-primary-tint-hover);color:var(--color-primary)}.btn-edit:focus{outline:none;box-shadow:var(--shadow-focus)}.btn-delete{color:var(--color-danger)}.btn-delete:hover{background:var(--color-danger-tint);color:var(--color-danger)}.btn-delete:focus{outline:none;box-shadow:0 0 0 2px var(--color-danger-focus)}.settings-manage-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:none;z-index:var(--z-modal)}.settings-manage-modal.is-open{display:block}.settings-manage-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-backdrop)}.settings-manage-modal__dialog{position:relative;width:min(960px,calc(100% - 2rem));max-height:92dvh;margin:4dvh auto 0;background:var(--color-card);border-radius:14px;padding:1.5rem;box-shadow:var(--shadow-modal);border:1px solid var(--color-border-subtle);overflow-y:auto}.settings-manage-modal__close{position:absolute;top:.75rem;right:.75rem;width:40px;height:40px;border-radius:10px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:1.5rem;line-height:1;cursor:pointer;transition:var(--transition);z-index:1}.settings-manage-modal__close:hover{background:var(--color-row-hover)}.settings-manage-modal__close:focus{outline:none;box-shadow:var(--shadow-focus)}.settings-manage-modal__title{margin:0 0 1.5rem;font-size:1.5rem;font-weight:700;color:var(--color-text)}.usm{position:fixed;top:0;right:0;bottom:0;left:0;display:none;z-index:var(--z-modal)}.usm.is-open{display:block}.usm__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-backdrop)}.usm__dialog{position:relative;width:min(860px,calc(100% - 2rem));max-height:min(780px,calc(100dvh - 4rem));margin:4dvh auto 0;background:var(--color-card);border-radius:16px;box-shadow:var(--shadow-modal);border:1px solid var(--color-border-subtle);display:flex;flex-direction:column;overflow:hidden}.usm__close{position:absolute;top:.6rem;right:.6rem;z-index:1;width:32px;height:32px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:1.3rem;line-height:1;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.usm__close:hover{background:var(--color-row-hover)}.usm__close:focus{outline:none;box-shadow:var(--shadow-focus)}.usm__body{display:flex;flex:1;min-height:0}.usm__sidebar{width:152px;flex-shrink:0;border-right:1px solid var(--color-border-light);padding:.75rem .5rem;display:flex;flex-direction:column;gap:.25rem;background:var(--color-row-alt)}.usm__nav-item{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:9px;border:none;background:transparent;color:var(--color-text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition);text-align:left;width:100%}.usm__nav-item svg{width:16px;height:16px;flex-shrink:0}.usm__nav-item:hover{background:var(--color-primary-tint-hover);color:var(--color-text)}.usm__nav-item.is-active{background:var(--color-primary-tint-light);color:var(--color-primary-dark);font-weight:600}.usm__tabs{display:none}.usm__content{flex:1;overflow-y:auto;padding:1.25rem 1.5rem;min-width:0}.usm-panel{width:100%;display:flex;flex-direction:column;gap:1rem}.usm-panel>.settings-manage__section-title{margin-bottom:0}@media(max-width:600px){.usm__dialog{width:100%;max-height:calc(100dvh - 1rem);border-radius:16px 16px 0 0;position:fixed;bottom:0;left:0;right:0;margin:0}.usm__sidebar{display:none}.usm__tabs{display:flex;border-top:1px solid var(--color-border-light);background:var(--color-row-alt);flex-shrink:0;order:1}.usm__tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.6rem .5rem;border:none;background:transparent;color:var(--color-text-muted);font-size:.7rem;cursor:pointer;transition:var(--transition);border-top:2px solid transparent;margin-top:-1px}.usm__tab svg{width:18px;height:18px}.usm__tab.is-active{color:var(--color-primary-dark);border-top-color:var(--color-primary);font-weight:600}.usm__body{flex-direction:column}.usm__content{padding:1rem;order:0}}.reminder-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:none;z-index:var(--z-modal)}.reminder-modal.is-open{display:block}.reminder-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-backdrop)}.reminder-modal__dialog{position:relative;width:min(480px,calc(100% - 2rem));max-height:92dvh;margin:4dvh auto 0;background:var(--color-card);border-radius:14px;padding:1.5rem;box-shadow:var(--shadow-modal);border:1px solid var(--color-border-subtle);overflow-y:auto}.reminder-modal__close{position:absolute;top:.75rem;right:.75rem;width:40px;height:40px;border-radius:10px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:1.5rem;line-height:1;cursor:pointer;transition:var(--transition);z-index:1}.reminder-modal__close:hover{background:var(--color-row-hover)}.reminder-modal__close:focus{outline:none;box-shadow:var(--shadow-focus)}.reminder-modal__title{margin:0 0 1rem;font-size:1.5rem;font-weight:700;color:var(--color-text)}.reminder-modal__loading{color:var(--color-text-secondary);font-size:.9rem}.reminder-modal__content{display:flex;flex-direction:column;gap:.75rem}.reminder-modal__desc{margin:0;font-size:.9rem;color:var(--color-text-secondary);line-height:1.6}.reminder-modal__field{display:flex;flex-direction:column;gap:.5rem}.reminder-modal__toggle-label{display:flex;align-items:center;justify-content:space-between;font-size:.95rem;font-weight:600;color:var(--color-text);cursor:pointer}.reminder-modal__toggle{position:relative;width:48px;height:26px;border-radius:13px;border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;transition:background .2s ease,border-color .2s ease;padding:0;flex-shrink:0}.reminder-modal__toggle.is-on{background:var(--color-primary);border-color:var(--color-primary)}.reminder-modal__toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--color-card);box-shadow:0 1px 3px #00000026;transition:transform .2s ease}.reminder-modal__toggle.is-on .reminder-modal__toggle-knob{transform:translate(22px)}.reminder-modal__settings{display:flex;flex-direction:column;gap:1rem;transition:opacity .2s ease}.reminder-modal__settings.is-disabled{opacity:.45;pointer-events:none}.reminder-modal__label{font-size:.9rem;font-weight:600;color:var(--color-text)}.reminder-modal__select{width:100%;padding:.6rem .75rem;border-radius:8px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:.9rem;cursor:pointer;transition:var(--transition)}.reminder-modal__select:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.reminder-modal__detect-btn{background:none;border:none;color:var(--color-primary);font-size:.8rem;cursor:pointer;text-align:left;padding:0;text-decoration:underline;transition:opacity .2s ease}.reminder-modal__detect-btn:hover{opacity:.7}.reminder-modal__time-wheels{display:flex;align-items:center;justify-content:center;gap:.25rem;border:1px solid var(--color-border);border-radius:12px;overflow:hidden;background:var(--color-card)}.reminder-modal__time-sep{font-size:1.4rem;font-weight:600;color:var(--color-text);line-height:1;flex-shrink:0;padding-bottom:2px}.reminder-modal__time-wheels .wheel-picker{flex:1}.wheel-picker{position:relative;height:120px;overflow:hidden;user-select:none;-webkit-user-select:none}.wheel-picker__scroll{height:100%;overflow-y:scroll;overflow-x:hidden;scroll-snap-type:y mandatory;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;scrollbar-width:none}.wheel-picker__scroll::-webkit-scrollbar{display:none}.wheel-picker__item{display:flex;align-items:center;justify-content:center;height:40px;font-size:1.05rem;color:var(--color-text-secondary);cursor:pointer;scroll-snap-align:center;flex-shrink:0;transition:color .12s,font-size .12s,font-weight .12s}.wheel-picker__item.is-selected{color:var(--color-text);font-size:1.2rem;font-weight:700}.wheel-picker__fade{position:absolute;left:0;right:0;height:42%;pointer-events:none;z-index:2}.wheel-picker__fade--top{top:0;background:linear-gradient(to bottom,var(--color-card) 20%,transparent)}.wheel-picker__fade--bottom{bottom:0;background:linear-gradient(to top,var(--color-card) 20%,transparent)}.wheel-picker__highlight{position:absolute;left:12px;right:12px;top:50%;transform:translateY(-50%);height:40px;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);pointer-events:none;z-index:1}.wheel-picker.is-disabled{opacity:.4;pointer-events:none}.reminder-modal__actions{display:flex;justify-content:flex-end;padding-top:.5rem}.reminder-modal__save-btn{padding:.7rem 1.5rem;border-radius:10px;border:none;background:var(--color-primary);color:var(--color-on-primary);font-weight:700;font-size:.95rem;cursor:pointer;transition:var(--transition)}.reminder-modal__save-btn:hover{background:var(--color-primary-hover)}.reminder-modal__save-btn:focus{outline:none;box-shadow:var(--shadow-focus)}.reminder-modal__save-btn:disabled{opacity:.6;cursor:not-allowed}.push-panel{display:flex;flex-direction:column;gap:1.25rem;padding:.25rem 0}.push-panel__desc{margin:0;font-size:.9rem;color:var(--color-text-secondary);line-height:1.6}.push-panel__toggle-row{display:flex;align-items:center;justify-content:space-between;font-size:.95rem;font-weight:600;color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none}.push-panel__toggle{position:relative;width:48px;height:26px;border-radius:13px;border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;transition:background .2s ease,border-color .2s ease;padding:0;flex-shrink:0}.push-panel__toggle.is-on{background:var(--color-primary);border-color:var(--color-primary)}.push-panel__toggle:disabled{opacity:.5;cursor:not-allowed}.push-panel__toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--color-card);box-shadow:0 1px 3px #00000026;transition:transform .2s ease}.push-panel__toggle.is-on .push-panel__toggle-knob{transform:translate(22px)}.push-panel__warning{margin:0;font-size:.88rem;color:var(--color-text-secondary);line-height:1.5;padding:.75rem 1rem;border-radius:8px;background:var(--color-row-hover);border:1px solid var(--color-border-subtle)}.push-panel__hint{margin:0;font-size:.82rem;color:var(--color-text-secondary);line-height:1.5}.credit-notif-panel{display:flex;flex-direction:column;gap:1.25rem;padding:.25rem 0}.credit-notif-panel__desc{margin:0;font-size:.9rem;color:var(--color-text-secondary);line-height:1.6}.credit-notif-panel__row{display:flex;flex-direction:column;gap:.75rem}.credit-notif-panel__toggle-row{display:flex;align-items:center;justify-content:space-between;font-size:.95rem;font-weight:600;color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none}.credit-notif-panel__label{pointer-events:none}.credit-notif-panel__sub{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--color-row-hover);border-radius:8px;border:1px solid var(--color-border-subtle)}.credit-notif-panel__sub-label{font-size:.88rem;color:var(--color-text-secondary)}.credit-notif-panel__chip-row{display:flex;flex-wrap:wrap;gap:.5rem}.credit-notif-panel__chip{padding:.3rem .85rem;border-radius:20px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:.88rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.credit-notif-panel__chip.is-selected{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-on-primary)}.credit-notif-panel__hint{margin:0;font-size:.82rem;color:var(--color-text-secondary);line-height:1.5}.subscription-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:none;z-index:var(--z-modal)}.subscription-modal.is-open{display:block}.subscription-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-backdrop)}.subscription-modal__dialog{position:relative;width:min(520px,calc(100% - 2rem));max-height:92dvh;margin:4dvh auto 0;background:var(--color-card);border-radius:14px;padding:1.5rem;box-shadow:var(--shadow-modal);border:1px solid var(--color-border-subtle);overflow-y:auto}.subscription-modal__close{position:absolute;top:.75rem;right:.75rem;width:40px;height:40px;border-radius:10px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:1.5rem;line-height:1;cursor:pointer;transition:var(--transition);z-index:1}.subscription-modal__close:hover{background:var(--color-row-hover)}.subscription-modal__close:focus{outline:none;box-shadow:var(--shadow-focus)}.subscription-modal__title{margin:0 0 1.25rem;font-size:1.5rem;font-weight:700;color:var(--color-text)}.subscription-modal__loading{color:var(--color-text-secondary);font-size:.9rem}.subscription-list__items{list-style:none;padding:0;margin:0 0 1rem;display:flex;flex-direction:column;gap:.5rem}.subscription-list__empty{color:var(--color-text-secondary);font-size:.9rem;margin:0 0 1rem}.subscription-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;transition:var(--transition)}.subscription-item--inactive{opacity:.5}.subscription-item__main{display:flex;flex-direction:column;gap:.2rem;min-width:0}.subscription-item__name{font-weight:600;font-size:.95rem;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.subscription-item__meta{font-size:.8rem;color:var(--color-text-secondary)}.subscription-item__payment{font-size:.78rem;color:var(--color-text-muted)}.subscription-item__actions{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.subscription-item__toggle{position:relative;width:40px;height:22px;border-radius:11px;border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;transition:background .2s ease,border-color .2s ease;padding:0;flex-shrink:0}.subscription-item__toggle.is-on{background:var(--color-primary);border-color:var(--color-primary)}.subscription-item__toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--color-card);box-shadow:0 1px 3px #00000026;transition:transform .2s ease}.subscription-item__toggle.is-on .subscription-item__toggle-knob{transform:translate(18px)}.subscription-item__edit-btn,.subscription-item__delete-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:none;background:transparent;cursor:pointer;transition:var(--transition);padding:0}.subscription-item__edit-btn svg,.subscription-item__delete-btn svg{width:1rem;height:1rem}.subscription-item__edit-btn{color:var(--color-primary)}.subscription-item__edit-btn:hover{background:var(--color-primary-tint-hover)}.subscription-item__delete-btn{color:var(--color-danger)}.subscription-item__delete-btn:hover{background:var(--color-danger-tint)}.subscription-list__footer{display:flex;justify-content:flex-end;padding-top:.25rem}.subscription-list__add-btn{padding:.6rem 1.25rem;border-radius:10px;border:1px dashed var(--color-primary);background:transparent;color:var(--color-primary);font-size:.9rem;font-weight:600;cursor:pointer;transition:var(--transition)}.subscription-list__add-btn:hover{background:var(--color-primary-tint-hover)}.subscription-list__add-btn:focus{outline:none;box-shadow:var(--shadow-focus)}.subscription-form{display:flex;flex-direction:column;gap:1rem}.subscription-form__field{display:flex;flex-direction:column;gap:.4rem}.subscription-form__field--grow{flex:1}.subscription-form__field--fixed{flex:0 0 90px}.subscription-form__row{display:flex;gap:.75rem;align-items:flex-end}.subscription-form__label{font-size:.875rem;font-weight:600;color:var(--color-text)}.subscription-form__input,.subscription-form__select{width:100%;padding:.6rem .75rem;border-radius:8px;border:1px solid var(--color-border-input);background:var(--color-card);color:var(--color-text);font-size:.9rem;transition:var(--transition);box-sizing:border-box}.subscription-form__input:focus,.subscription-form__select:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.subscription-form__input--day{width:72px;flex-shrink:0}.subscription-form__day-row{display:flex;align-items:center;gap:.5rem}.subscription-form__day-hint{font-size:.8rem;color:var(--color-text-muted)}.subscription-form__actions{display:flex;justify-content:flex-end;gap:.5rem;padding-top:.25rem}.subscription-form__cancel-btn{padding:.6rem 1.1rem;border-radius:10px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:var(--transition)}.subscription-form__cancel-btn:hover{background:var(--color-row-hover)}.subscription-form__cancel-btn:disabled{opacity:.6;cursor:not-allowed}.subscription-form__save-btn{padding:.6rem 1.25rem;border-radius:10px;border:none;background:var(--color-primary);color:var(--color-on-primary);font-size:.9rem;font-weight:700;cursor:pointer;transition:var(--transition)}.subscription-form__save-btn:hover{background:var(--color-primary-hover)}.subscription-form__save-btn:focus{outline:none;box-shadow:var(--shadow-focus)}.subscription-form__save-btn:disabled{opacity:.6;cursor:not-allowed}.reaction-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:none;z-index:var(--z-modal)}.reaction-modal.is-open{display:block}.reaction-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-backdrop)}.reaction-modal__dialog{position:relative;width:min(560px,calc(100% - 2rem));margin:8dvh auto 0;background:var(--color-card);border-radius:14px;padding:1.25rem 1.25rem 1.1rem;box-shadow:var(--shadow-modal);border:1px solid var(--color-border-subtle)}.reaction-modal__close{position:absolute;top:.75rem;right:.75rem;width:40px;height:40px;border-radius:10px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:1.5rem;line-height:1;cursor:pointer;transition:var(--transition)}.reaction-modal__close:hover{background:var(--color-row-hover)}.reaction-modal__close:focus{outline:none;box-shadow:var(--shadow-focus)}.reaction-modal__title{margin:0 0 .75rem}.reaction-modal__text{display:none;margin:0}.reaction-modal__actions{display:flex;justify-content:flex-end;gap:.5rem}.reaction-modal__primary{padding:.85rem 1rem;border-radius:10px;border:none;background:var(--color-primary);color:var(--color-on-primary);font-weight:800;cursor:pointer;transition:var(--transition)}.reaction-modal__primary:hover{background:var(--color-primary-hover)}.reaction-modal__primary:focus{outline:none;box-shadow:var(--shadow-focus)}.streak-calendar-root{margin-top:.5rem}.streak-calendar{background:var(--color-bg);border-radius:12px;padding:.75rem .75rem .5rem;border:1px solid var(--color-border)}.streak-calendar__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.streak-calendar__month{font-weight:600;color:var(--color-text)}.streak-calendar__nav-btn{width:28px;height:28px;border-radius:999px;border:1px solid var(--color-border);background:var(--color-card);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--color-text-secondary);font-size:.8rem;transition:var(--transition);-webkit-tap-highlight-color:transparent}@media(hover:hover){.streak-calendar__nav-btn:hover{background:var(--color-row-hover)}}.streak-calendar__nav-btn:active{background:var(--color-row-hover)}.streak-calendar__nav-btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.streak-calendar__nav-btn:focus:not(:focus-visible){outline:none;box-shadow:none;background:var(--color-card)}.streak-calendar__weekdays,.streak-calendar__grid{display:grid;grid-template-columns:repeat(7,1fr);text-align:center}.streak-calendar__weekdays{margin-bottom:.25rem;font-size:.75rem;color:var(--color-text-secondary)}.streak-calendar__weekday{padding:.15rem 0}.streak-calendar__grid{row-gap:.25rem}.streak-calendar__day{padding:.2rem 0;font-size:.85rem;color:var(--color-text-secondary)}.streak-calendar__day-inner{width:28px;height:28px;margin:0 auto;border-radius:999px;display:flex;align-items:center;justify-content:center}.streak-calendar__day--empty .streak-calendar__day-inner{background:transparent}.streak-calendar__day--transaction .streak-calendar__day-inner{background:var(--color-primary-tint);border:1px solid var(--color-primary-tint-border);color:var(--color-text);font-weight:600}.streak-calendar__day--manual .streak-calendar__day-inner{background:var(--color-manual-bg);border:1px solid var(--color-manual-border);color:var(--color-text);font-weight:600}.streak-calendar__day--today .streak-calendar__day-inner{border:1px solid var(--color-primary)}.streak-calendar__day--today.streak-calendar__day--transaction .streak-calendar__day-inner{background:var(--color-primary-tint)}.streak-calendar__day--today.streak-calendar__day--manual .streak-calendar__day-inner{background:var(--color-manual-bg);border:1px solid var(--color-manual-border)}.streak-calendar__day--today:not(.streak-calendar__day--transaction):not(.streak-calendar__day--manual) .streak-calendar__day-inner{background:var(--color-primary-tint-light)}.streak-calendar__legend{display:flex;justify-content:center;gap:1rem;margin-top:.5rem;font-size:.75rem;color:var(--color-text-secondary)}.streak-calendar__legend-item{display:inline-flex;align-items:center;gap:.35rem}.streak-calendar__legend-item:before{content:"";width:12px;height:12px;border-radius:999px}.streak-calendar__legend-item--transaction:before{background:var(--color-primary-tint);border:1px solid var(--color-primary-tint-border)}.streak-calendar__legend-item--manual:before{background:var(--color-manual-bg);border:1px solid var(--color-manual-border)}.streak-summary{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:.5rem;margin-top:.75rem}.streak-summary__card{background:var(--color-card);border-radius:10px;padding:.6rem .75rem;border:1px solid var(--color-border);position:relative}.streak-summary__card:first-child:after{content:"";position:absolute;right:.3rem;top:50%;transform:translateY(-50%);width:4.5rem;height:4.5rem;background-image:url(/my-smart-finance/images/maltese-icon-2.png);background-size:contain;background-repeat:no-repeat;background-position:center;opacity:.85}.streak-summary__card:nth-child(3):after{content:"";position:absolute;right:.5rem;top:50%;transform:translateY(-50%);width:3.2rem;height:3.2rem;background-image:url(/my-smart-finance/images/maltese-gif-2.gif);background-size:contain;background-repeat:no-repeat;background-position:center;opacity:.85}[data-theme=rose] .streak-summary__card:nth-child(3):after{background-image:url(/my-smart-finance/images/maltese-gif-4.gif);width:4rem;height:4rem;right:.3rem}.streak-summary__label{font-size:.75rem;color:var(--color-text-secondary);margin-bottom:.2rem}.streak-summary__value{font-size:1.1rem;font-weight:700;color:var(--color-text);display:flex;align-items:center;gap:.25rem}.streak-summary__value-emoji{font-size:1rem;display:inline-flex;align-items:center;justify-content:center}.streak-summary__value-number{font-size:1.2rem}.icon-fire{width:1.1rem;height:1.1rem;display:block}.icon-checkin{width:1.2rem;height:1.2rem;display:block}.changelog-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:none;z-index:var(--z-modal)}.changelog-modal.is-open{display:block}.changelog-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-backdrop)}.changelog-modal__dialog{position:relative;width:min(560px,calc(100% - 2rem));max-height:92dvh;margin:4dvh auto 0;background:var(--color-card);border-radius:14px;box-shadow:var(--shadow-modal);border:1px solid var(--color-border-subtle);display:flex;flex-direction:column;overflow:hidden}.changelog-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.5rem 1rem;flex-shrink:0}.changelog-modal__header .changelog-modal__title{margin:0}.changelog-modal__body{flex:1;overflow-y:auto;padding:0 1.5rem 1.5rem;min-height:0}.changelog-modal__close{width:40px;height:40px;border-radius:10px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:1.5rem;line-height:1;cursor:pointer;transition:var(--transition);flex-shrink:0}.changelog-modal__close:hover{background:var(--color-row-hover)}.changelog-modal__close:focus{outline:none;box-shadow:var(--shadow-focus)}.changelog-modal__title{margin:0;font-size:1.5rem;color:var(--color-text)}.changelog-content{margin:0;padding:0;font-size:.9375rem;color:var(--color-text);line-height:1.6}.changelog-entry{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.changelog-entry:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.changelog-entry__header{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.5rem}.changelog-entry__version{font-weight:600;font-size:1rem;color:var(--color-text)}.changelog-entry__date{font-weight:400;font-size:.875rem;color:var(--color-text-secondary)}.changelog-entry__list{list-style:none;padding:0;margin:0}.changelog-entry__list li{position:relative;padding-left:1.25rem;margin-bottom:.35rem}.changelog-entry__list li:before{content:"•";position:absolute;left:0;color:var(--color-primary);font-weight:700}.changelog-empty{color:var(--color-text-secondary);font-size:.9rem;margin:0}.changelog-empty code{background:var(--color-bg);padding:.2em .4em;border-radius:4px;font-size:.85em}.credit-card-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:none;z-index:var(--z-modal)}.credit-card-modal.is-open{display:block}.credit-card-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-backdrop)}.credit-card-modal__dialog{position:relative;width:min(480px,calc(100% - 2rem));max-height:92dvh;margin:4dvh auto;padding:2rem;background:var(--color-card);border-radius:16px;box-shadow:var(--shadow-modal-sm);border:1px solid var(--color-border-subtle);overflow-y:auto}.credit-card-modal__close{position:absolute;top:.75rem;right:.75rem;width:40px;height:40px;border-radius:10px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:1}.credit-card-modal__close:hover{background:var(--color-row-hover)}.credit-card-modal__close:focus{outline:none;box-shadow:var(--shadow-focus)}.credit-card-modal__title{margin:0 0 1.5rem;font-size:1.5rem;color:var(--color-text)}.credit-card-info{display:flex;flex-direction:column;gap:1.5rem}.credit-limit-section{background:var(--color-bg);padding:1.25rem;border-radius:12px;border:1px solid var(--color-border)}.credit-limit-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem}.credit-limit-label{font-size:.9rem;color:var(--color-text-secondary);font-weight:500}.credit-limit-amount{font-size:1.75rem;font-weight:700;color:var(--color-primary)}.credit-limit-progress-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.credit-limit-progress{flex:1;min-width:0;height:24px;background:var(--color-progress-track);border-radius:12px;overflow:hidden}.credit-limit-percent{flex-shrink:0;font-size:.9rem;font-weight:600}.credit-limit-bar{height:100%;background:var(--color-success);transition:width .3s ease,background-color .3s ease;border-radius:12px}.credit-limit-detail{display:flex;justify-content:space-between;font-size:.875rem;color:var(--color-text-secondary)}.credit-dates{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.credit-date-item{background:var(--color-bg);padding:1rem;border-radius:10px;border:1px solid var(--color-border);text-align:center}.credit-date-label{display:block;font-size:.85rem;color:var(--color-text-secondary);margin-bottom:.5rem}.credit-date-value{display:block;font-size:1.25rem;font-weight:600;color:var(--color-text)}.credit-payment-countdown,.credit-billing-countdown{display:block;font-size:.75rem;color:var(--color-text-secondary);margin-top:.25rem}.credit-countdown-num{font-weight:700}.credit-countdown-num.credit-countdown-urgent{color:var(--color-danger)}.transaction-detail-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--color-backdrop-subtle);z-index:var(--z-modal-high);display:none;align-items:center;justify-content:center;padding:1rem;opacity:0;transition:opacity .3s ease}.transaction-detail-modal.is-open{display:flex;opacity:1}.transaction-detail-content{background:var(--color-card);border-radius:12px;box-shadow:var(--shadow-dialog);max-width:500px;width:100%;max-height:90dvh;overflow:hidden;display:flex;flex-direction:column}@media(prefers-reduced-motion:no-preference){.transaction-detail-content{animation:slideUp .3s ease}}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.transaction-detail-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--color-border)}.transaction-detail-title{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0}.transaction-detail-close{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--color-text-secondary);border-radius:4px;transition:var(--transition);display:flex;align-items:center;justify-content:center}.transaction-detail-close:hover{background:var(--color-row-hover);color:var(--color-text)}.transaction-detail-close:active{transform:scale(.95)}.transaction-detail-body{padding:1.5rem;overflow-y:auto;flex:1}.transaction-detail-item{display:flex;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--color-border)}.transaction-detail-item:last-child{border-bottom:none}.transaction-detail-item--note{align-items:flex-start}.transaction-detail-label{flex:0 0 100px;font-weight:600;color:var(--color-text-secondary);font-size:.875rem}.transaction-detail-value{flex:1;color:var(--color-text);font-size:1rem;word-break:break-word}.transaction-detail-amount{font-size:1.125rem;font-weight:600;color:var(--color-primary)}.transaction-detail-note{color:var(--color-text-secondary);line-height:1.6;white-space:pre-wrap}.streak-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .7rem;border-radius:999px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:var(--transition)}.streak-badge__icon{font-size:1rem;display:inline-flex;align-items:center;justify-content:center}.streak-badge__count{font-weight:700;color:var(--color-text)}.streak-badge__unit{font-size:.8rem;opacity:.8}.streak-badge:hover{background:var(--color-row-hover);border-color:var(--color-primary);color:var(--color-text)}.transaction-detail-value .badge{display:inline-block}.split-page{width:100%;flex:1;overflow-y:auto;scrollbar-width:none;background:var(--color-bg);padding:1.5rem 1rem;max-width:860px;margin:0 auto}.split-page::-webkit-scrollbar{display:none}.split-page__header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.75rem}.split-page__back-btn{display:flex;align-items:center;gap:.4rem;background:none;border:none;cursor:pointer;color:var(--color-text-secondary);font-size:.9rem;padding:.4rem .5rem;border-radius:8px;transition:background .15s,color .15s}.split-page__back-btn:hover{background:var(--color-primary-tint-hover);color:var(--color-text)}.split-page__back-btn svg{width:18px;height:18px;flex-shrink:0}.split-page__title{font-size:1.35rem;font-weight:600;color:var(--color-text);margin:0;flex:1}.split-group-list{display:grid;grid-template-columns:repeat(2,1fr);gap:.875rem;align-items:start}.split-group-list__empty{text-align:center;color:var(--color-text-muted);padding:3rem 1rem;font-size:.95rem}.split-group-list__actions{display:flex;gap:.75rem;position:sticky;bottom:0;z-index:1;background:var(--color-bg);padding:1rem 0;border-top:1px solid var(--color-border);margin-top:.875rem}.split-group-card{position:relative;overflow:hidden;background:var(--color-card);border:1px solid var(--color-border);border-radius:14px;cursor:pointer;transition:box-shadow .15s,border-color .15s;box-shadow:var(--shadow-card)}.split-group-card:hover{border-color:var(--color-primary-tint-border);box-shadow:var(--shadow-card-hover, var(--shadow-card))}.split-group-card__swipe-action{position:absolute;top:0;right:0;bottom:0;width:90px;display:flex;align-items:center;justify-content:center;background:var(--color-danger)}.split-group-card__swipe-btn{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:none;border:none;cursor:pointer;padding:0}.split-group-card__swipe-btn svg{width:1.5rem;height:1.5rem;color:var(--color-on-primary)}.split-group-card__swipe-btn:active{opacity:.8;transform:scale(.9)}.split-group-card__content{position:relative;z-index:1;background:var(--color-card);padding:1rem 1.25rem}.split-group-card__top{display:flex;align-items:flex-start;justify-content:space-between}.split-group-card__delete{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:.15rem;border-radius:6px;display:flex;align-items:center;transition:color .15s,background .15s;flex-shrink:0}.split-group-card__delete:hover{color:var(--color-danger);background:var(--color-danger-tint)}.split-group-card__delete svg{width:16px;height:16px}.split-group-card__name{font-size:1rem;font-weight:600;color:var(--color-text);margin:0 0 .35rem}.split-group-card__meta{display:flex;gap:1rem;font-size:.8rem;color:var(--color-text-secondary)}.split-group-card__members{display:flex;gap:.35rem;flex-wrap:wrap;margin-top:.6rem}.split-member-avatar{width:28px;height:28px;border-radius:50%;background:var(--color-primary-tint);border:1.5px solid var(--color-primary-tint-border);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:var(--color-primary-dark);overflow:hidden;flex-shrink:0}.split-member-avatar img{width:100%;height:100%;object-fit:cover}.split-btn-primary{display:flex;align-items:center;justify-content:center;gap:.4rem;width:100%;padding:.75rem 1rem;background:var(--color-primary);color:var(--color-on-primary);border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.split-btn-primary:hover{background:var(--color-primary-hover)}.split-btn-primary:disabled{opacity:.6;cursor:not-allowed}.split-btn-secondary{display:flex;align-items:center;justify-content:center;gap:.4rem;width:100%;padding:.7rem 1rem;background:none;color:var(--color-primary-dark);border:1.5px solid var(--color-primary-tint-border);border-radius:10px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s}.split-btn-secondary:hover{background:var(--color-primary-tint-hover)}.split-entry-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .7rem;border-radius:999px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:var(--transition)}.split-entry-btn:hover{background:var(--color-row-hover);border-color:var(--color-primary);color:var(--color-text)}.split-entry-btn svg{width:16px;height:16px;flex-shrink:0}.form-column__right-actions{display:flex;align-items:center;gap:.25rem;position:relative}.form-column__right-actions .more-menu-wrapper--desktop{flex:none}.split-join-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;background:var(--color-bg)}.split-join-page__card{background:var(--color-card);border:1px solid var(--color-border);border-radius:18px;padding:2rem 1.75rem;width:100%;max-width:400px;box-shadow:var(--shadow-modal-sm);text-align:center}.split-join-page__title{font-size:1.1rem;font-weight:700;color:var(--color-text);margin:0 0 .4rem}.split-join-page__subtitle{font-size:.85rem;color:var(--color-text-secondary);margin:0 0 1.5rem}.split-join-page__code-input{text-align:center;font-size:1.25rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;font-family:monospace}.split-join-page__group-info{background:var(--color-primary-tint-light);border-radius:10px;padding:1rem;margin:1rem 0;text-align:left}.split-join-page__group-name{font-weight:700;font-size:1rem;color:var(--color-text);margin-bottom:.5rem}.split-join-page__members-label{font-size:.78rem;color:var(--color-text-secondary);margin-bottom:.4rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.split-join-page__member-option{display:flex;align-items:center;gap:.5rem;padding:.5rem .6rem;border-radius:8px;cursor:pointer;font-size:.875rem;color:var(--color-text);border:1.5px solid transparent;transition:background .15s,border-color .15s;margin-bottom:.3rem}.split-join-page__member-option:hover{background:var(--color-primary-tint-hover)}.split-join-page__member-option.is-selected{border-color:var(--color-primary);background:var(--color-primary-tint-light);font-weight:600}.split-join-page__member-option.is-taken{opacity:.45;cursor:not-allowed}@media(max-width:640px){.split-group-list{grid-template-columns:1fr}}@media(max-width:1200px){.split-page{flex:1 0 auto;overflow-y:visible}.split-group-list__actions{bottom:calc(56px + env(safe-area-inset-bottom,0))}}.split-loading{text-align:center;padding:2rem;color:var(--color-text-muted);font-size:.9rem}.split-group-detail__header{margin-bottom:1.25rem}.split-group-detail__name-row{display:flex;align-items:center;gap:.4rem;margin-bottom:.35rem}.split-group-detail__name{font-size:1.25rem;font-weight:700;color:var(--color-text);margin:0}.split-group-detail__edit-name-btn{display:flex;align-items:center;background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:.2rem;border-radius:6px;transition:color .15s,background .15s;flex-shrink:0}.split-group-detail__edit-name-btn:hover{color:var(--color-primary);background:var(--color-primary-tint-hover)}.split-group-detail__edit-name-btn svg{width:18px;height:18px}.split-group-detail__name-input{font-size:1.25rem;font-weight:700;color:var(--color-text);background:var(--color-bg);border:1.5px solid var(--color-primary);border-radius:8px;padding:.15rem .5rem;outline:none;box-shadow:var(--shadow-focus);flex:1;min-width:0;max-width:300px}.split-group-detail__name-confirm{display:flex;align-items:center;background:none;border:none;padding:.2rem;cursor:pointer;color:var(--color-primary);flex-shrink:0;transition:color .15s}.split-group-detail__name-confirm:hover{color:var(--color-primary-hover)}.split-group-detail__name-confirm svg{width:20px;height:20px}.split-group-detail__members-row{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.split-group-detail__member-chip{display:flex;align-items:center;gap:.3rem;font-size:.8rem;color:var(--color-text-secondary);background:var(--color-primary-tint-light);border-radius:20px;padding:.2rem .6rem}.split-group-detail__member-add-btn{cursor:pointer;border:1px dashed var(--color-border);background:transparent;color:var(--color-text-muted);font-size:.85rem;padding:.2rem .55rem}.split-group-detail__member-add-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.split-group-detail__invite{display:flex;align-items:center;gap:.5rem;background:var(--color-primary-tint-light);border:1px solid var(--color-border);border-radius:10px;padding:.65rem 1rem;margin-bottom:1.25rem;flex-wrap:wrap}.split-group-detail__invite-label{font-size:.78rem;color:var(--color-text-secondary);flex-shrink:0}.split-group-detail__invite-code{font-size:1rem;font-weight:700;letter-spacing:.15em;color:var(--color-primary-dark);font-family:monospace}.split-group-detail__invite-copy{background:none;border:1px solid var(--color-border);border-radius:7px;padding:.25rem .65rem;font-size:.78rem;cursor:pointer;color:var(--color-text-secondary);transition:background .15s;margin-left:auto}.split-group-detail__invite-copy:hover{background:var(--color-primary-tint-hover);color:var(--color-text)}.split-group-detail__section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.split-group-detail__section-title{font-size:.9rem;font-weight:600;color:var(--color-text);margin:0}.split-group-detail__section-header--summary{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--color-border)}.split-expense-item{position:relative;overflow:hidden;background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;margin-bottom:.6rem;cursor:pointer;transition:box-shadow .15s}.split-expense-item:hover{box-shadow:var(--shadow-card-hover, var(--shadow-card))}.split-expense-item__content{position:relative;z-index:1;background:var(--color-card);padding:.85rem 1rem}.split-expense-item__swipe-action{position:absolute;top:0;bottom:0;width:90px;display:flex;align-items:center;justify-content:center}.split-expense-item__swipe-action--edit{left:0;background:var(--color-primary)}.split-expense-item__swipe-action--delete{right:0;background:var(--color-danger)}.split-expense-item__swipe-btn{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:none;border:none;cursor:pointer;padding:0}.split-expense-item__swipe-btn svg{width:1.5rem;height:1.5rem;color:var(--color-on-primary)}.split-expense-item__swipe-btn:active{opacity:.8;transform:scale(.9)}.split-expense-item__header{display:flex;align-items:flex-start;gap:.75rem}.split-expense-item__info{flex:1;min-width:0}.split-expense-item__title{font-size:.9rem;font-weight:600;color:var(--color-text);margin:0 0 .2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.split-expense-item__meta{font-size:.78rem;color:var(--color-text-secondary)}.split-expense-item__right{display:flex;flex-direction:column;align-items:flex-end;gap:.3rem;flex-shrink:0}.split-expense-item__amount{font-size:.95rem;font-weight:700;color:var(--color-text);white-space:nowrap}.split-expense-item__actions{display:flex;gap:.2rem}.split-expense-item__action-btn{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:.2rem;border-radius:6px;display:flex;align-items:center;transition:color .15s,background .15s}.split-expense-item__action-btn:hover{color:var(--color-primary)}.split-expense-item__action-btn.split-expense-item__delete:hover{color:var(--color-danger);background:var(--color-danger-tint)}.split-expense-item__action-btn svg{width:16px;height:16px}.split-expense-item__detail{margin-top:.65rem;padding-top:.65rem;border-top:1px dashed var(--color-border-light)}.split-expense-item__note{font-size:.8rem;color:var(--color-text-secondary);margin:0 0 .5rem;font-style:italic}.split-expense-item__shares-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);margin:0 0 .3rem;text-transform:uppercase;letter-spacing:.03em}.split-expense-item__share-row{display:flex;align-items:center;justify-content:space-between;padding:.2rem 0;font-size:.82rem}.split-expense-item__share-name{color:var(--color-text)}.split-expense-item__share-amount{color:var(--color-text-secondary);font-weight:500}.split-group-detail__show-more{display:block;width:100%;padding:.5rem 0;font-size:.82rem;color:var(--color-text-muted);background:none;border:none;cursor:pointer;text-align:center;transition:color .15s}.split-group-detail__show-more:hover{color:var(--color-primary)}.split-member-totals{background:var(--color-card);border:1px solid var(--color-border);border-left:3px solid var(--color-primary);border-radius:12px;padding:1rem 1.25rem}.split-member-totals__row{display:flex;align-items:center;gap:.75rem;padding:.55rem 0;border-bottom:1px solid var(--color-border-light)}.split-member-totals__row:last-child{border-bottom:none}.split-member-totals__avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;color:var(--color-primary);background:var(--color-primary-tint-light);overflow:hidden}.split-member-totals__avatar img{width:100%;height:100%;object-fit:cover}.split-member-totals__name{flex:1;min-width:0;font-size:.875rem;font-weight:600;color:var(--color-text)}.split-member-totals__amount{font-size:.9rem;font-weight:700;color:var(--color-text);white-space:nowrap}.split-settlement{background:var(--color-card);border:1px solid var(--color-border);border-left:3px solid var(--color-primary);border-radius:12px;padding:1rem 1.25rem;margin-top:.6rem}.split-settlement__row{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--color-border-light);font-size:.875rem;color:var(--color-text)}.split-settlement__row:last-child{border-bottom:none}.split-settlement__info{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.split-settlement__from{font-weight:600;color:var(--color-danger)}.split-settlement__arrow{color:var(--color-text-muted)}.split-settlement__to{font-weight:600;color:var(--color-success-alt)}.split-settlement__amount{margin-left:auto;font-weight:700;white-space:nowrap}.split-settlement__settle-btn{flex-shrink:0;padding:.25rem .6rem;font-size:.75rem;font-weight:600;color:var(--color-primary);background:none;border:1px solid var(--color-primary);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.split-settlement__settle-btn:hover{background:var(--color-primary);color:var(--color-card)}.split-settlement__empty{font-size:.875rem;color:var(--color-text-muted);text-align:center;padding:.5rem 0}.split-settlement__history-toggle{display:flex;align-items:center;justify-content:center;gap:.3rem;width:100%;margin-top:.75rem;padding:.4rem 0;font-size:.78rem;color:var(--color-text-muted);background:none;border:none;border-top:1px solid var(--color-border-light);cursor:pointer}.split-settlement__history-toggle:hover{color:var(--color-text)}.split-settlement__history-chevron{width:14px;height:14px;transition:transform .2s}.split-settlement__history-chevron.is-open{transform:rotate(180deg)}.split-settlement__history{margin-top:.4rem}.split-settlement__history-row{display:flex;align-items:center;gap:.5rem;padding:.35rem 0;border-bottom:1px dashed var(--color-border-light);font-size:.8rem;color:var(--color-text);opacity:.75}.split-settlement__history-row:last-child{border-bottom:none}.split-settlement__history-info{display:flex;align-items:center;gap:.4rem;flex:1;min-width:0}.split-settlement__history-actions{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.split-settlement__history-date{font-size:.7rem;color:var(--color-text-muted);white-space:nowrap}.split-settlement__history-delete{display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;background:none;border:none;border-radius:4px;cursor:pointer;color:var(--color-text-muted);transition:color .15s}.split-settlement__history-delete:hover{color:var(--color-danger)}.split-settlement__history-delete svg{width:14px;height:14px}.split-modal__input.is-calc,.split-modal__participant-share.is-calc{cursor:pointer}@media(hover:none)and (pointer:coarse){.split-modal__input.is-calc,.split-modal__participant-share.is-calc{font-size:16px}}.split-modal__dialog{background:var(--color-card);border-radius:18px;padding:1.75rem;width:min(460px,calc(100% - 2rem));max-height:calc(100dvh - 8vh);overflow-y:auto;margin:4vh auto;position:relative;box-shadow:var(--shadow-modal);-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:transparent transparent;transition:scrollbar-color .3s,max-height .22s ease,margin-top .22s ease}body.calc-keypad-open .split-modal__dialog{max-height:calc(100dvh - 3vh);margin:2vh auto;padding-bottom:24.75rem}.split-modal__dialog:hover,.split-modal__dialog:active{scrollbar-color:var(--color-border) transparent}.split-modal__dialog::-webkit-scrollbar{width:4px}.split-modal__dialog::-webkit-scrollbar-track{background:transparent}.split-modal__dialog::-webkit-scrollbar-thumb{background:transparent;border-radius:4px}.split-modal__dialog:hover::-webkit-scrollbar-thumb,.split-modal__dialog:active::-webkit-scrollbar-thumb{background:var(--color-border)}.split-modal__title{font-size:1.1rem;font-weight:700;color:var(--color-text);margin:0 0 1.25rem}.split-modal__field{margin-bottom:1rem}.split-modal__label{display:block;font-size:.82rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.03em}.split-modal__input{width:100%;max-width:100%;padding:.6rem .8rem;border:1px solid var(--color-border-input);border-radius:9px;font-size:.9rem;color:var(--color-text);background:var(--color-bg);outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box;-webkit-appearance:none}.split-modal__input:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.split-modal__input::placeholder{color:var(--color-text-muted)}.split-modal__select{width:100%;padding:.6rem 2rem .6rem .8rem;border:1px solid var(--color-border-input);border-radius:9px;font-size:.9rem;color:var(--color-text);background:var(--color-bg) var(--select-arrow) right .6rem center / 16px no-repeat;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;cursor:pointer;box-sizing:border-box}.split-modal__select:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.split-modal__members-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.5rem}.split-modal__member-row{display:flex;align-items:center;gap:.5rem}.split-modal__member-row--existing{padding:.35rem 0;border-bottom:1px solid var(--color-border-light)}.split-modal__member-row--existing:last-child{border-bottom:none}.split-modal__member-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}.split-modal__member-avatar--initial{display:flex;align-items:center;justify-content:center;background:var(--color-primary-tint-light);color:var(--color-primary);font-size:.75rem;font-weight:600}.split-modal__member-name{flex:1;font-size:.875rem;color:var(--color-text)}.split-modal__member-name--editable{cursor:pointer;border-bottom:1px dashed var(--color-border);transition:border-color .15s}.split-modal__member-name--editable:hover{border-color:var(--color-primary)}.split-modal__input--inline-edit{flex:1;padding:.2rem .4rem;font-size:.875rem}.split-modal__member-linked{font-size:.7rem;color:var(--color-text-muted);opacity:.7}.split-modal__member-row .split-modal__input{flex:1}.split-modal__member-remove{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:.3rem;border-radius:6px;display:flex;align-items:center;transition:color .15s,background .15s;flex-shrink:0}.split-modal__member-remove:hover{color:var(--color-danger);background:var(--color-danger-tint)}.split-modal__member-remove svg{width:16px;height:16px}.split-modal__add-member-btn{background:none;border:1px dashed var(--color-border);border-radius:8px;padding:.4rem .75rem;font-size:.82rem;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;gap:.3rem;transition:border-color .15s,color .15s;width:100%}.split-modal__add-member-btn:hover{border-color:var(--color-primary-tint-border);color:var(--color-primary-dark)}.split-modal__actions{display:flex;gap:.6rem;margin-top:1.5rem}.split-modal__actions .split-btn-primary{flex:1}.split-modal__share-modes{display:flex;gap:.5rem;margin-bottom:.75rem}.split-modal__share-mode-btn{flex:1;padding:.5rem;border:1.5px solid var(--color-border);border-radius:8px;background:none;font-size:.82rem;cursor:pointer;color:var(--color-text-secondary);transition:border-color .15s,background .15s,color .15s}.split-modal__share-mode-btn.is-active{border-color:var(--color-primary);background:var(--color-primary-tint-light);color:var(--color-primary-dark);font-weight:600}.split-modal__participant-row{display:flex;align-items:center;gap:.5rem;padding:.35rem 0}.split-modal__participant-check{accent-color:var(--color-primary);width:16px;height:16px;cursor:pointer;flex-shrink:0}.split-modal__participant-name{flex:1;font-size:.875rem;color:var(--color-text)}.split-modal__participant-share{width:90px;padding:.35rem .5rem;border:1px solid var(--color-border-input);border-radius:7px;font-size:.85rem;text-align:right;color:var(--color-text);background:var(--color-bg);outline:none}.split-modal__participant-share:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus)}.split-modal__participant-share.is-auto{color:var(--color-text-secondary, var(--color-text));opacity:.55}.split-modal__share-input-wrap{position:relative;display:flex;align-items:center}.split-modal__auto-tag{position:absolute;right:100%;margin-right:.3rem;font-size:.65rem;color:var(--color-text-secondary, var(--color-text));opacity:.5;white-space:nowrap}.split-modal__share-status{font-size:.78rem;color:var(--color-text-secondary, var(--color-text));padding:.3rem .5rem;margin-bottom:.35rem;border-radius:6px;background:var(--color-bg);text-align:center}.split-modal__share-status.is-balanced{color:var(--color-progress-safe)}.split-modal__share-status.is-over{color:var(--color-error)}.split-modal__error{font-size:.82rem;color:var(--color-error);margin-top:.35rem}.split-modal__amount-row{display:flex;gap:.5rem}.split-modal__amount-row .split-modal__input{flex:1}.split-modal__currency-select{width:auto!important;padding-left:.6rem!important;padding-right:1.75rem!important;flex-shrink:0}.split-sync-box{background:var(--color-card);border:1px solid var(--color-border);border-left:3px solid var(--color-primary);border-radius:12px;padding:1rem 1.25rem;margin-top:.6rem}.split-sync-box__desc{font-size:.85rem;color:var(--color-text-secondary);margin:0 0 .75rem;line-height:1.5}.split-sync-box__desc strong{color:var(--color-text);font-weight:600}.split-sync-box__actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.split-sync-box__btn{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .85rem;font-size:.82rem;font-weight:600;border-radius:8px;cursor:pointer;transition:background .15s,color .15s,opacity .15s;border:none}.split-sync-box__btn:disabled{opacity:.6;cursor:not-allowed}.split-sync-box__btn svg{width:15px;height:15px;flex-shrink:0}.split-sync-box__btn--primary{background:var(--color-primary);color:var(--color-card)}.split-sync-box__btn--primary:hover:not(:disabled){opacity:.88}.split-sync-box__btn--secondary{background:none;color:var(--color-primary);border:1px solid var(--color-primary)}.split-sync-box__btn--secondary:hover:not(:disabled){background:var(--color-primary);color:var(--color-card)}.split-sync-box__synced-info{display:flex;align-items:center;gap:.45rem;margin-bottom:.75rem}.split-sync-box__check-icon{width:16px;height:16px;color:var(--color-success-alt);flex-shrink:0}.split-sync-box__synced-label{font-size:.875rem;font-weight:600;color:var(--color-success-alt)}.split-sync-box__synced-amount{font-size:.875rem;font-weight:700;color:var(--color-text);margin-left:auto}.split-sync-box__update-info{display:flex;align-items:center;gap:.45rem;margin-bottom:.5rem}.split-sync-box__dot{width:8px;height:8px;border-radius:50%;background:var(--color-warning, #f59e0b);flex-shrink:0}.split-sync-box__update-text{font-size:.875rem;font-weight:600;color:var(--color-warning, #f59e0b)}.split-share-detail__group-name{font-size:1rem;font-weight:600;color:var(--color-text);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.split-share-detail__empty{font-size:.875rem;color:var(--color-text-muted);text-align:center;padding:1rem 0;margin:0}.split-share-detail__table{width:100%;border-collapse:collapse;font-size:.875rem}.split-share-detail__th{text-align:left;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);padding:0 0 .5rem;border-bottom:1px solid var(--color-border)}.split-share-detail__th--amount,.split-share-detail__td--amount{text-align:right}.split-share-detail__row{border-bottom:1px solid var(--color-border-light)}.split-share-detail__row:last-child{border-bottom:none}.split-share-detail__td{padding:.6rem 0;color:var(--color-text);vertical-align:middle}.split-share-detail__td--date{white-space:nowrap;color:var(--color-text-muted);font-size:.8rem;padding-right:.75rem;min-width:80px}.split-share-detail__td--title{word-break:break-word}.split-share-detail__td--amount{white-space:nowrap;font-weight:600;font-variant-numeric:tabular-nums;padding-left:.75rem}.split-share-detail__total-row{border-top:2px solid var(--color-border)}.split-share-detail__total-label{padding-top:.65rem;font-size:.8rem;color:var(--color-text-secondary);font-weight:600}.split-share-detail__total-amount{padding-top:.65rem;text-align:right;font-size:1rem;font-weight:700;color:var(--color-primary);white-space:nowrap;font-variant-numeric:tabular-nums}.calc-keypad__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:calc(var(--z-modal) - 1);background:transparent}.calc-keypad{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-modal-high);background:var(--color-card);border-top:1px solid var(--color-border);box-shadow:0 -4px 24px #0000001f;padding:.75rem .75rem calc(.75rem + env(safe-area-inset-bottom));animation:calcKeypadSlideUp .22s ease}@keyframes calcKeypadSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.calc-keypad__display{display:flex;align-items:baseline;justify-content:flex-end;gap:.75rem;padding:.5rem .75rem .75rem;min-height:2.5rem;border-bottom:1px solid var(--color-border-light);margin-bottom:.5rem}.calc-keypad__expr{font-size:1.4rem;font-weight:500;color:var(--color-text);letter-spacing:.02em}.calc-keypad__preview{font-size:1rem;color:var(--color-text-secondary)}.calc-keypad__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.calc-keypad__btn{height:52px;border:none;border-radius:10px;background:var(--color-bg);color:var(--color-text);font-size:1.2rem;font-weight:500;cursor:pointer;transition:background .12s ease,transform .08s ease;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.calc-keypad__btn:active{transform:scale(.93);background:var(--color-border)}.calc-keypad__btn.is-op{background:var(--color-primary-tint-light);color:var(--color-primary-dark);font-weight:600}.calc-keypad__btn.is-op:active{background:var(--color-primary-tint)}.calc-keypad__btn.is-del{background:var(--color-bg);color:var(--color-text-secondary);font-size:1.1rem}.calc-keypad__btn.is-eq{grid-column:1 / -1;background:var(--color-primary);color:var(--color-on-primary);font-size:1.3rem;font-weight:600;height:48px;border-radius:10px}.calc-keypad__btn.is-eq:active{background:var(--color-primary-hover);transform:scale(.98)}.app-sidebar{display:flex;flex-direction:column;width:220px;min-width:220px;height:100vh;position:sticky;top:0;background:var(--color-card);border-right:1px solid var(--color-border);padding:1rem .75rem;transition:width .25s ease,min-width .25s ease;z-index:var(--z-topbar);overflow:hidden}.app-sidebar.is-collapsed{width:60px;min-width:60px}.app-sidebar__header{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem;min-height:2rem}.app-sidebar__title{font-size:1rem;font-weight:700;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.app-sidebar__toggle{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;flex-shrink:0;padding:0;border:none;border-radius:6px;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:var(--transition)}.app-sidebar__toggle:hover{background:var(--color-primary-tint-hover);color:var(--color-primary)}.app-sidebar__toggle svg{width:1.125rem;height:1.125rem}.app-sidebar.is-collapsed .app-sidebar__header{justify-content:center}.app-sidebar__nav{display:flex;flex-direction:column;gap:.25rem;flex:1}.app-sidebar__item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.625rem .75rem;border:none;border-radius:8px;background:transparent;color:var(--color-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition);text-align:left;white-space:nowrap}.app-sidebar__item:hover{background:var(--color-primary-tint-hover);color:var(--color-primary)}.app-sidebar__item.is-active{background:var(--color-primary-tint-light);color:var(--color-primary)}.app-sidebar__icon{width:1.25rem;height:1.25rem;flex-shrink:0}.app-sidebar.is-collapsed .app-sidebar__item{justify-content:center;padding:.625rem}.app-sidebar__divider{height:1px;background:var(--color-border);margin:.5rem 0}.app-sidebar__footer{margin-top:auto}.app-sidebar__user{display:flex;align-items:center;gap:.625rem;padding:.5rem .25rem}.app-sidebar__avatar{width:2.05rem;height:2.05rem;min-width:2.05rem;min-height:2.05rem;padding:0;border:none;border-radius:50%;background:var(--color-primary);color:var(--color-on-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:var(--transition);flex-shrink:0}.app-sidebar__avatar:hover{opacity:.85}.app-sidebar__avatar .user-avatar-inner{font-size:.9rem;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.app-sidebar__avatar img{width:100%;height:100%;object-fit:cover}.app-sidebar__user-info{display:flex;flex-direction:column;min-width:0}.app-sidebar__user-email{font-size:.75rem;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-sidebar__logout{padding:0;border:none;background:transparent;color:var(--color-text-muted);font-size:.7rem;cursor:pointer;text-align:left;transition:var(--transition)}.app-sidebar__logout:hover{color:var(--color-danger)}.app-sidebar.is-collapsed .app-sidebar__user{justify-content:center}body:has(.app-layout){padding:0}.app-layout{display:flex;height:100dvh;min-height:100dvh;overflow:hidden}.app-layout__main{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto}.app-tab-bar{display:none}@media(max-width:1200px){.app-sidebar{display:none}.app-tab-bar{display:flex;align-items:center;justify-content:space-around;position:fixed;bottom:0;left:0;right:0;height:56px;background:var(--color-card);border-top:1px solid var(--color-border);z-index:var(--z-topbar);padding-bottom:env(safe-area-inset-bottom,0)}.app-tab-bar__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;flex:1;padding:.35rem 0;border:none;background:transparent;color:var(--color-text-muted);font-size:.65rem;font-weight:500;cursor:pointer;transition:var(--transition)}.app-tab-bar__item:hover,.app-tab-bar__item.is-active{color:var(--color-primary)}.app-tab-bar__icon{width:1.375rem;height:1.375rem}.app-layout__main:after{content:"";display:block;flex-shrink:0;height:calc(56px + env(safe-area-inset-bottom,0))}}[data-theme=dawn] .app-sidebar__icon path,[data-theme=dawn] .app-sidebar__icon circle,[data-theme=dawn] .app-tab-bar__icon path,[data-theme=dawn] .app-tab-bar__icon circle{stroke:url(#dawnNavGrad)}.app-sidebar__icon-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}.changelog-unread-dot{position:absolute;top:-2px;right:-3px;width:8px;height:8px;border-radius:50%;background:var(--color-primary);border:1.5px solid var(--color-card)}@keyframes slideUpFromBottom{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:600px){.stats-section-header{justify-content:center}.analytics-section h2,.transaction-history-section h2{text-align:center}.transaction-history-section thead th:nth-child(4),.transaction-history-section thead th:nth-child(6){display:none!important}.transaction-history-section table{display:block}.transaction-history-section colgroup{display:none}.transaction-history-section thead,.transaction-history-section tbody{display:block}.transaction-history-section thead tr,.transaction-history-section tbody tr{display:flex;width:100%;box-sizing:border-box}.transaction-history-section thead th,.transaction-history-section td{box-sizing:border-box}.transaction-history-section thead tr{align-items:center;padding:0 .5rem}.transaction-history-section thead th{padding:.625rem .375rem;display:flex;font-size:.885rem;align-items:center;justify-content:flex-start}.transaction-history-section thead th:nth-child(5){justify-content:flex-end}.transaction-history-section thead th:nth-child(1){flex:0 0 74px;min-width:74px}.transaction-history-section thead th:nth-child(2){flex:0 0 78px;min-width:78px}.transaction-history-section thead th:nth-child(3){flex:1;min-width:0}.transaction-history-section thead th:nth-child(5){flex:0 0 85px;min-width:85px;text-align:right}.cell-slider-wrap{padding:0!important;width:100%;flex:1;min-width:0}.row-slider-container{position:relative;overflow:hidden;border-bottom:1px solid var(--color-border)}.row-slider{display:flex;align-items:center;width:100%;min-height:3.25rem;gap:.375rem;position:relative;z-index:2}.row-slider .slider-cell{padding:.625rem .5rem;box-sizing:border-box}.row-slider .slider-cell.cell-date{flex:0 0 74px;min-width:74px;font-size:.8rem;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-left:.675rem}.row-slider .slider-cell.cell-category{flex:0 0 78px;min-width:78px;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-slider .slider-cell.cell-item{flex:1 1 0;min-width:0;font-size:.875rem;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-slider .slider-cell.cell-amount{flex:0 0 85px;min-width:85px;font-size:.875rem;text-align:right!important;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:.75rem}.transaction-row--semantic:nth-child(2n) .row-slider{background:var(--color-row-alt)}.transaction-row--semantic .row-slider{background:var(--color-card)}.transaction-row--semantic:hover .row-slider{background:var(--color-row-hover)}.row-slider-container .swipe-action{position:absolute;top:0;bottom:0;width:90px;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.row-slider-container .swipe-action--edit{left:0;background:var(--color-primary)}.row-slider-container .swipe-action--delete{right:0;background:var(--color-danger)}.transaction-history-section tbody tr:not(.transaction-row--semantic) td{flex:1}}@media(max-width:570px){.transaction-row--semantic td.cell-date{flex:0 0 60px}.transaction-row--semantic td.cell-category{flex:0 0 65px}.transaction-row--semantic td.cell-item{flex:1;min-width:0}.transaction-row--semantic td.cell-amount{flex:0 0 85px}.transaction-history-section thead th:nth-child(1){flex:0 0 68px;min-width:68px}.transaction-history-section thead th:nth-child(2){flex:0 0 72px;min-width:72px}.transaction-history-section thead th:nth-child(5){flex:0 0 85px;min-width:85px}.row-slider .slider-cell.cell-date{flex:0 0 68px;min-width:68px}.row-slider .slider-cell.cell-category{flex:0 0 72px;min-width:72px}.row-slider .slider-cell.cell-amount{flex:0 0 85px;min-width:85px}}@media(max-width:470px){.transaction-row--semantic td.cell-date{flex:0 0 55px;font-size:.75rem}.transaction-row--semantic td.cell-category{flex:0 0 58px}.transaction-row--semantic td.cell-item{flex:1;min-width:0;font-size:.8125rem}.transaction-row--semantic td.cell-amount{flex:0 0 85px;font-size:.8125rem}.transaction-history-section thead th:nth-child(1){flex:0 0 62px;min-width:62px}.transaction-history-section thead th:nth-child(2){flex:0 0 66px;min-width:66px}.transaction-history-section thead th:nth-child(5){flex:0 0 85px;min-width:85px}.row-slider .slider-cell.cell-date{flex:0 0 62px;min-width:62px;font-size:.75rem}.row-slider .slider-cell.cell-category{flex:0 0 66px;min-width:66px}.row-slider .slider-cell.cell-amount{flex:0 0 85px;min-width:85px;font-size:.8125rem}}@media(max-width:768px){.settings-manage-grid{grid-template-columns:1fr;grid-template-rows:auto auto}}@media(max-width:1440px){.app-container{gap:1.5rem;padding:1.5rem max(1.5rem,6vw)}.transaction-form-section{padding:1.5rem}.form-group{margin-bottom:1rem}.stat-card{padding:1.25rem}.stat-card:nth-child(1):after{width:4.5rem;height:4.5rem}.stat-card:nth-child(2):after{width:6.7rem;height:6.7rem}.stat-card:nth-child(3):after{width:5rem;height:5rem}.stat-value{font-size:1.75rem}.analytics-col{padding:1.25rem}:root{--chart-max-width: 240px}.transaction-history-section th,.transaction-history-section td{padding:.625rem;font-size:.875rem}}@media(max-width:1200px){.app-top-bar{display:flex;align-items:center;justify-content:space-between;padding:.75rem .5rem .5rem .75rem;margin-bottom:0;grid-column:1 / -1;background:transparent;border-bottom:none;box-shadow:none;position:relative}.app-top-bar__left{display:flex;align-items:center}.app-top-bar__right{display:flex;align-items:center;gap:.5rem}.user-avatar-wrapper--desktop{display:none!important}.user-avatar-wrapper--mobile{display:flex!important}.app-top-bar .user-avatar-wrapper--mobile,.app-top-bar .streak-badge{display:inline-flex;align-items:center;justify-content:center;min-height:2.25rem}.stats-section-header .streak-badge{display:none!important}body{min-height:auto}.app-container{grid-template-columns:1fr;grid-template-rows:auto;height:auto;min-height:0;max-height:none;overflow:visible;gap:1.5rem;padding:1.25rem max(1.25rem,6vw);flex:1 0 auto}.form-column{display:block;min-height:auto;overflow-y:visible}.dashboard-column{min-height:auto;overflow-y:visible}.transaction-form-section{padding:1.5rem}}@media(max-width:870px){.app-container{padding:1rem max(1.5rem,5vw)}.transaction-form-section{padding:1.25rem}.analytics-grid{grid-template-columns:1fr}.stats-cards{flex-wrap:wrap}.stat-card{flex:1 1 140px;min-width:0}:root{--chart-max-width: 220px}.streak-summary__card:first-child:after{width:5rem;height:5rem}.streak-summary__card:nth-child(3):after{width:3.2rem;height:3.2rem}}.app-container>*{max-width:100%}.table-wrapper{overflow-x:auto}@media(max-width:600px){body{padding:.75rem}.app-top-bar{background:transparent;border-bottom:none;box-shadow:none;padding:.75rem .5rem .5rem .75rem;margin:0;display:flex;justify-content:space-between;align-items:center}.app-top-bar__right{display:flex;align-items:center}.user-avatar-wrapper--mobile .user-avatar-btn{width:2.25rem;height:2.25rem;min-width:2.25rem;min-height:2.25rem}.app-container{padding:.75rem;gap:1rem}.form-column,.dashboard-column{width:100%;max-width:100%;margin-left:auto;margin-right:auto;padding-left:.5rem;padding-right:.5rem;padding-top:0;padding-bottom:0}.transaction-form-section,.stats-section,.analytics-section,.transaction-history-section{width:100%;max-width:100%;margin-left:auto;margin-right:auto}.transaction-form-section{padding:1rem;border-radius:10px}.transaction-form-header h2{font-size:1.25rem}.form-group input[type=text],.form-group input[type=number],.form-group input[type=date],.form-group select,.form-group textarea{padding:.875rem;font-size:16px;min-height:44px;max-width:100%;box-sizing:border-box}.transaction-form-section button[type=submit],.btn-cancel{padding:1rem;font-size:1rem;min-height:44px}.btn-checkin{padding:.5rem .75rem;font-size:.8125rem}.stats-cards{flex-direction:column;gap:.75rem}.stat-card{flex:1 1 auto;padding:1rem}.stat-card:nth-child(1):after{width:3.5rem;height:3.5rem;right:.5rem}.stat-card:nth-child(2):after{width:3.5rem;height:3.5rem;right:1.5rem}.stat-card:nth-child(3):after{width:3.5rem;height:3.5rem;right:1.7rem}.stat-value{font-size:1.5rem}.stat-label{font-size:.7rem}.stats-section-header{flex-wrap:wrap;gap:.5rem}.stats-section-header h2{font-size:1.25rem}.streak-badge{padding:.4rem .75rem;font-size:.8125rem}.month-picker-trigger{padding:.5rem .75rem;font-size:15px}.month-picker-popover{max-width:calc(100vw - 2rem);padding:.5rem}.month-picker-grid{grid-template-columns:repeat(3,1fr);gap:.3rem}.month-picker-item{padding:.4rem;font-size:.8rem}.analytics-col{padding:1rem}.analytics-col h3{font-size:1.125rem}:root{--chart-max-width: 200px}.transaction-history-section th,.transaction-history-section td{padding:.5rem .375rem;font-size:.8125rem}.transaction-history-section th{font-size:.75rem;white-space:nowrap}.row-actions{display:none}.swipe-action{width:90px}.swipe-action-btn{font-size:.8125rem}.swipe-action-btn svg{width:1.5rem;height:1.5rem}.swipe-action-btn span{font-size:.75rem}.transaction-history-section h2{font-size:1.25rem}.reaction-modal__dialog{width:calc(100% - 1.5rem);margin:5vh auto 0;padding:1rem;border-radius:12px}.reaction-modal__close{width:36px;height:36px;top:.5rem;right:.5rem;font-size:1.25rem}.reaction-modal__title{font-size:1.25rem;margin-bottom:.5rem}.streak-calendar{padding:.5rem}.streak-calendar__day-inner{width:32px;height:32px;font-size:.875rem}.streak-calendar__nav-btn{width:32px;height:32px}.streak-summary{grid-template-columns:1fr;gap:.5rem}.streak-summary__card:first-child:after{width:3rem;height:3rem;right:.4rem}.streak-summary__card:nth-child(3):after{width:3rem;height:3rem;right:.4rem}.form-actions{flex-direction:column}.form-actions button{width:100%}.form-group--currency-amount .form-group__currency-amount-row{flex-direction:row;gap:var(--space-sm)}.form-group--currency-amount .form-group__currency{width:30%}h2{font-size:1.25rem}h3{font-size:1.125rem}.transaction-detail-modal{padding:0;align-items:flex-end}.transaction-detail-content{max-width:100%;margin:0;border-radius:16px 16px 0 0;max-height:90vh;align-self:flex-end}.transaction-detail-header{padding:.875rem 1rem}.transaction-detail-title{font-size:1.0625rem}.transaction-detail-close{padding:.375rem}.transaction-detail-close svg{width:20px;height:20px}.transaction-detail-body{padding:.75rem 1rem 1rem}.transaction-detail-item{flex-direction:column;align-items:flex-start;padding:.5rem 0;gap:.125rem}.transaction-detail-item:first-child{padding-top:0}.transaction-detail-label{flex:none;width:100%;margin-bottom:0;font-size:.75rem;font-weight:500}.transaction-detail-value{width:100%;font-size:.875rem}.transaction-detail-amount{font-size:.9375rem}.transaction-detail-note{font-size:.8125rem;line-height:1.5}.transaction-detail-value .badge{padding:.25rem .5rem;font-size:.75rem}@media(prefers-reduced-motion:no-preference){.transaction-detail-content{animation:slideUpFromBottom .3s ease}}}@media(max-width:400px){body{padding:.5rem}.app-top-bar{padding:.75rem .5rem 0}.app-container{padding:.5rem;gap:.75rem}.transaction-form-section{padding:.875rem}.stat-value{font-size:1.25rem}.stat-card{padding:.875rem}.stat-card:nth-child(1):after{width:4.9rem;height:4.9rem;right:0rem}.stat-card:nth-child(2):after{width:6.2rem;height:6.2rem;right:0rem}.stat-card:nth-child(3):after{width:5.1rem;height:5.1rem;right:.75rem}:root{--chart-max-width: 180px}.transaction-history-section th,.transaction-history-section td{padding:.4rem .25rem;font-size:.75rem}.transaction-history-section th{font-size:.7rem}.streak-summary__card:first-child:after{width:5rem;height:5rem;right:.3rem}.streak-summary__card:nth-child(3):after{width:3.3rem;height:3.3rem;right:1.1rem}.transaction-detail-header{padding:.75rem .875rem}.transaction-detail-title{font-size:1rem}.transaction-detail-body{padding:.625rem .875rem .875rem}.transaction-detail-item{padding:.375rem 0;gap:.0625rem}.transaction-detail-label{font-size:.6875rem}.transaction-detail-value{font-size:.8125rem}.transaction-detail-amount{font-size:.875rem}.transaction-detail-note{font-size:.75rem}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}button,a{-webkit-tap-highlight-color:transparent}body.modal-open{overflow:hidden}html{scroll-behavior:smooth}h1,h2,h3,h4,h5,h6{line-height:1.3;color:var(--color-text)}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-hover)}button{font-family:inherit}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--scrollbar-track);border-radius:10px}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:10px;border:2px solid var(--scrollbar-track)}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}.scrollbar-on-scroll{scrollbar-width:thin;scrollbar-color:transparent transparent}.scrollbar-on-scroll:hover,.scrollbar-on-scroll.is-scrolling{scrollbar-color:var(--scrollbar-thumb) transparent}.scrollbar-on-scroll::-webkit-scrollbar{width:8px}.scrollbar-on-scroll::-webkit-scrollbar-track{background:transparent}.scrollbar-on-scroll::-webkit-scrollbar-thumb{background:transparent;border-radius:4px;transition:background .2s ease}.scrollbar-on-scroll:hover::-webkit-scrollbar-thumb,.scrollbar-on-scroll.is-scrolling::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb)}.scrollbar-on-scroll::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}.toast-container{position:fixed;top:1rem;right:1rem;z-index:var(--z-modal-high);display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast{pointer-events:auto;padding:.75rem 1.25rem;border-radius:8px;background:var(--color-card);box-shadow:var(--shadow-toast);color:var(--color-text);font-size:.9rem;max-width:360px}@media(prefers-reduced-motion:no-preference){.toast{animation:toastSlideIn .3s ease}}.toast--success{border-left:4px solid var(--color-success)}.toast--error{border-left:4px solid var(--color-danger)}.toast--info{border-left:4px solid var(--color-primary)}@media(prefers-reduced-motion:no-preference){.toast--exit{animation:toastSlideOut .3s ease forwards}}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toastSlideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);display:block;opacity:0;transition:opacity 50ms ease;pointer-events:none}.modal-overlay.is-open{opacity:1;pointer-events:auto}.modal-overlay.is-closing{opacity:0;pointer-events:none}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-backdrop-light);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-top)}.confirm-dialog{background:var(--color-card);border-radius:12px;padding:1.5rem;max-width:380px;width:calc(100% - 2rem);box-shadow:var(--shadow-modal-sm)}.confirm-dialog__message{font-size:.95rem;color:var(--color-text);margin-bottom:1.25rem;line-height:1.5}.confirm-dialog__actions{display:flex;gap:.75rem;justify-content:flex-end}.confirm-dialog__btn{padding:.5rem 1.25rem;border-radius:6px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);cursor:pointer;font-size:.875rem;transition:var(--transition)}.confirm-dialog__btn:hover{background:var(--color-row-hover)}.confirm-dialog__btn--confirm{background:var(--color-primary);color:var(--color-on-primary);border-color:var(--color-primary)}.confirm-dialog__btn--confirm:hover{background:var(--color-primary-hover)}.confirm-dialog__btn--danger{background:var(--color-danger);color:var(--color-on-primary);border-color:var(--color-danger)}.confirm-dialog__btn--danger:hover{opacity:.9}.account-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;padding:1rem}.account-item__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.account-item__name{font-size:1rem;font-weight:600;color:var(--color-text)}.account-item__actions{display:flex;gap:.5rem;flex-shrink:0}.account-item__btn{padding:.35rem .7rem;font-size:.8rem;font-weight:400;border:1px solid var(--color-border);border-radius:6px;background:var(--color-card);color:var(--color-text);cursor:pointer;transition:var(--transition);white-space:nowrap}.account-item__btn:hover{background:var(--color-row-hover);border-color:var(--color-primary);color:var(--color-primary)}.account-item__btn:disabled{opacity:.5;cursor:default}.account-item__btn--delete:hover{background:var(--color-danger-hover-bg);border-color:var(--color-danger-hover-border);color:var(--color-danger-hover-border)}.account-item__details{display:flex;flex-direction:column;gap:.05rem}.account-item__detail{margin:.1rem 0;font-size:.85rem;font-weight:400;color:var(--color-text-secondary)}
