:root{--t-p:#6d4fc2;--t-p-rgb:109,79,194;--t-pd:#4e3594;--t-pb:#9b7de0;--t-pl:#eee9fa;--t-pm:#f6f3fd;--t-bg-from:#c0b0e8;--t-bg-to:#d8ccf4}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#c0b0e8,#d8ccf4);background:linear-gradient(135deg,var(--t-bg-from) 0,var(--t-bg-to) 100%);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@keyframes loading-spin{to{transform:rotate(1turn)}}@keyframes loading-pulse{0%,to{opacity:1}50%{opacity:.35}}@keyframes skeleton-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.loading-wrap{align-items:center;display:flex;flex-direction:column;gap:14px;justify-content:center;padding:40px 20px}.loading-ring{animation:loading-spin .65s linear infinite;border:3px solid #6d4fc226;border-top-color:#6d4fc2;border:3px solid rgba(var(--t-p-rgb),.15);border-radius:50%;border-top-color:var(--t-p);flex-shrink:0;height:36px;width:36px}.loading-ring.sm{border-width:2.5px;height:22px;width:22px}.loading-text{animation:loading-pulse 1.5s ease-in-out infinite;color:#9ca3af;font-size:.83rem;font-weight:500}.skeleton-line{animation:skeleton-shimmer 1.4s ease-in-out infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 50%,#f0f0f0 75%);background-size:800px 100%;border-radius:6px;height:14px}.app-nav{backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:#fff9;border-bottom:1px solid #0000000f;gap:16px;height:52px;padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.app-nav,.app-nav-logo{align-items:center;display:flex}.app-nav-logo{font-family:Raleway,sans-serif;font-size:1.1rem;font-weight:800;gap:5px;letter-spacing:.06em;line-height:1;text-transform:uppercase;white-space:nowrap}.logo-icon{color:#fff;flex-shrink:0}.logo-text{display:inline;letter-spacing:.06em}.logo-fin{color:#a78bca;margin-right:-.2em}.logo-track{color:#2d1b69}.header-logo{font-family:Raleway,sans-serif!important;font-size:1.8rem!important;font-weight:800!important;letter-spacing:.12em;text-transform:uppercase}.app-nav-links{align-items:center;display:flex;flex:1 1;gap:4px;overflow:hidden}.app-nav-actions{flex-shrink:0;gap:8px}.app-nav-actions,.app-nav-user{align-items:center;display:flex}.app-nav-user{gap:4px;position:relative}.app-nav-avatar-btn{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;padding:0;transition:opacity .15s}.app-nav-avatar-btn:hover{opacity:.82}.app-nav-avatar-dropdown{animation:avatar-dropdown-in .15s cubic-bezier(.4,0,.2,1);background:#fff;border:1px solid #2d1b6914;border-radius:14px;box-shadow:0 8px 32px #2d1b6929,0 2px 8px #00000014;min-width:220px;overflow:hidden;position:absolute;right:0;top:calc(100% + 10px);z-index:200}@keyframes avatar-dropdown-in{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.app-nav-avatar-info{display:flex;flex-direction:column;gap:3px;padding:14px 16px 12px}.app-nav-avatar-name{color:#2d1b69;font-size:.88rem;font-weight:700}.app-nav-avatar-email,.app-nav-avatar-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-nav-avatar-email{color:#9ca3af;font-size:.8rem;font-weight:500}.app-nav-avatar-divider{background:#2d1b6912;height:1px;margin:0}.app-nav-avatar-menu-item{align-items:center;background:none;border:none;color:#4b5563;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:8px;padding:11px 16px;text-align:left;transition:background .15s,color .15s;width:100%}.app-nav-avatar-menu-item:hover{background:#f5f3ff;color:#7c3aed}.app-nav-avatar-signout{align-items:center;background:none;border:none;color:#dc2626;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:8px;padding:11px 16px;text-align:left;transition:background .15s;width:100%}.app-nav-avatar-signout:hover{background:#fff1f1}.app-nav-avatar{border:2px solid #2d1b6940;border-radius:50%;flex-shrink:0;height:30px;object-fit:cover;width:30px}.app-nav-avatar-fallback{align-items:center;background:#2d1b691f;color:#2d1b69;display:flex;font-size:.78rem;font-weight:700;justify-content:center}.app-nav-link{background:none;border:none;border-radius:20px;color:#2d1b69a6;cursor:pointer;font-size:.82rem;font-weight:600;padding:6px 13px;transition:background .15s,color .15s;white-space:nowrap}.app-nav-link:hover{background:#2d1b6914;color:#2d1b69}.app-nav-hamburger{align-items:center;background:#2d1b6914;border:1px solid #2d1b6926;border-radius:10px;cursor:pointer;display:none;flex-direction:column;flex-shrink:0;gap:5px;height:36px;justify-content:center;padding:0;transition:background .15s;width:36px}.app-nav-hamburger:hover{background:#2d1b6924}.app-nav-hamburger span{background:#2d1b69;border-radius:2px;display:block;height:2px;transform-origin:center;transition:transform .22s ease,opacity .18s ease,width .18s ease;width:18px}.app-nav-hamburger.open span:first-child{transform:translateY(7px) rotate(45deg)}.app-nav-hamburger.open span:nth-child(2){opacity:0;width:0}.app-nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.app-mobile-menu{animation:mobileMenuIn .2s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);background:rgba(var(--t-p-rgb),.55);border-bottom:1px solid #ffffff24;box-shadow:0 8px 32px #0003;left:0;padding:12px 16px 16px;position:fixed;right:0;top:52px;z-index:98}@keyframes mobileMenuIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.app-mobile-links-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:1fr 1fr;margin-bottom:10px}.app-mobile-link{background:#ffffff14;border:1px solid #ffffff1a;border-radius:11px;color:#ffffffe6;cursor:pointer;font-size:.88rem;font-weight:600;padding:11px 14px;text-align:left;transition:background .15s,color .15s}.app-mobile-link:active,.app-mobile-link:hover{background:#ffffff2e;color:#fff}@media (max-width:768px){.app-nav{gap:10px;padding:0 14px}.app-nav-links{display:none}.app-nav-hamburger{display:flex}.app-nav-actions{margin-left:auto}.edit-mode-banner{display:none}.app-nav-avatar-dropdown{left:auto;right:0}}@media (min-width:769px){.app-mobile-menu,.app-nav-hamburger{display:none!important}}#sec-chart,#sec-form,#sec-goals,#sec-investments,#sec-methods,#sec-projections,#sec-reminders,#sec-transactions{scroll-margin-top:64px}.sections-grid{grid-column-gap:20px;grid-row-gap:16px;align-items:stretch;column-gap:20px;display:grid;grid-template-columns:1fr 1fr;row-gap:16px}.sections-grid-edit{background:rgba(var(--t-p-rgb),.03);border-radius:20px;gap:12px;padding:8px}.edit-mode-banner{align-items:center;background:linear-gradient(135deg,var(--t-p),var(--t-pb));box-shadow:0 2px 12px rgba(var(--t-p-rgb),.4);color:#fff;display:flex;gap:16px;justify-content:space-between;padding:10px 24px;position:-webkit-sticky;position:sticky;top:52px;z-index:90}.edit-mode-banner-text{font-size:.82rem;font-weight:600}.edit-mode-banner-btn{background:#fff3;border:1px solid #ffffff59;border-radius:8px;color:#fff;cursor:pointer;font-size:.8rem;font-weight:700;padding:5px 14px;transition:background .15s;white-space:nowrap}.edit-mode-banner-btn:hover{background:#ffffff4d}.app-nav-edit-btn{align-items:center;background:#2d1b6914;border:1px solid #2d1b692e;border-radius:20px;color:#2d1b69bf;cursor:pointer;display:flex;font-size:.78rem;font-weight:700;gap:6px;padding:5px 13px;transition:background .15s,color .15s;white-space:nowrap}.app-nav-edit-icon{flex-shrink:0}.app-nav-edit-btn:hover{background:#2d1b6924;color:#2d1b69}.app-nav-edit-btn.active{background:#2d1b69;border-color:#2d1b69;color:#fff}@media (max-width:768px){.app-nav-edit-btn{border-radius:10px;padding:7px 9px}.app-nav-edit-label{display:none}}@media (max-width:1024px){.sections-grid{grid-template-columns:1fr;row-gap:14px}}.App{min-height:100vh;padding-top:0}.container{margin:0 auto;max-width:1200px;padding:28px 20px 40px}.header{color:#fff;margin-bottom:36px;padding:10px 0;text-align:center}.app-nav-eye-btn{align-items:center;background:none;border:none;border-radius:8px;color:#2d1b698c;cursor:pointer;display:flex;flex-shrink:0;padding:5px;transition:background .15s,color .15s}.app-nav-eye-btn:hover{background:#2d1b6914;color:#2d1b69}.header h1{color:#fff;font-size:2.8rem;font-weight:800;letter-spacing:-.02em;margin-bottom:2px;text-shadow:1px 1px 8px #ffffff40}.subtitle{color:#ffffffbf;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;letter-spacing:.04em;text-shadow:0 1px 3px #00000026}.summary-cards-header{align-items:center;display:flex;margin-bottom:10px}.summary-month-nav{align-items:center;display:flex;gap:6px}.summary-month-arrow{align-items:center;background:none;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;line-height:1;padding:3px 6px;transition:background .15s,color .15s,border-color .15s}.summary-month-arrow:hover{background:#f3f4f6;border-color:#d1d5db;color:#374151}.summary-cards-period{align-items:center;color:#6b7280;display:inline-flex;font-size:.75rem;font-weight:700;gap:5px;justify-content:center;letter-spacing:.07em;min-width:140px;text-transform:uppercase}.summary-period-clear{background:none;border:1px solid #e5e7eb;border-radius:5px;color:#6b7280;cursor:pointer;font-size:.68rem;font-weight:700;letter-spacing:.04em;padding:2px 8px;transition:color .15s,background .15s}.summary-period-clear:hover{background:#f3f4f6;color:#374151}.summary-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:30px}.summary-card{align-items:center;background:#fff;border-radius:16px;box-shadow:0 2px 12px rgba(var(--t-p-rgb),.1);display:flex;gap:18px;overflow:hidden;padding:20px 24px;position:relative;transition:transform .2s,box-shadow .2s}.summary-card:hover{box-shadow:0 6px 20px rgba(var(--t-p-rgb),.15);transform:translateY(-2px)}.summary-card:after{bottom:0;content:"";height:4px;left:0;position:absolute;right:0}.summary-card.income:after{background:#6ee7b7}.summary-card.expense:after{background:#fca5a5}.summary-card.balance.positive:after{background:#6ee7b7}.summary-card.balance.negative:after{background:#fca5a5}.summary-card.invested:after{background:#6ee7b7}.summary-card-icon{align-items:center;border-radius:14px;display:flex;flex-shrink:0;font-size:1.3rem;font-weight:800;height:48px;justify-content:center;width:48px}.summary-card.income .summary-card-icon{background:#d1fae5;color:#059669}.summary-card.expense .summary-card-icon{background:#fee2e2;color:#dc2626}.summary-card.balance .summary-card-icon{background:var(--t-pl);color:var(--t-p)}.summary-card.invested{cursor:pointer}.summary-card.invested .summary-card-icon{background:#d1fae5;color:#059669}.summary-card-content{display:flex;flex-direction:column;gap:2px}.summary-card h3{color:#9ca3af;font-size:.75rem;font-weight:600;letter-spacing:.08em;margin:0;text-transform:uppercase}.summary-card .amount{color:#111;font-size:1.45rem;font-weight:700;margin:0}.summary-card.income .amount{color:#059669}.summary-card.expense .amount{color:#dc2626}.summary-card.balance.positive .amount{color:#059669}.summary-card.balance.negative .amount{color:#dc2626}.summary-card.invested .amount{color:#059669}.summary-card-sub{color:#10b981;font-size:.75rem;font-weight:600;margin:2px 0 0}.filter-buttons{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:30px}.filter-buttons button{background:#0000;border:2px solid #fff;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:10px 20px;transition:all .3s}.filter-buttons button:hover{background:#ffffff1a}.filter-buttons button.active{background:#fff;color:#667eea}@media (max-width:900px){.summary-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.header h1{font-size:2rem}.summary-card .amount{font-size:1.2rem}.container{padding:20px 14px 32px}}@media (max-width:480px){.summary-cards{gap:10px;grid-template-columns:repeat(2,1fr)}.summary-card{border-radius:12px;gap:10px;padding:14px 12px}.summary-card-icon{display:none}.summary-card h3{font-size:.65rem}.summary-card .amount{font-size:1rem}.summary-card-sub{font-size:.65rem}.container{padding:16px 10px 24px}}.app-loading-overlay{align-items:center;animation:overlay-fade-in .3s ease;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:linear-gradient(135deg,rgba(var(--t-p-rgb),.97) 0,rgba(var(--t-p-rgb),.85) 100%);display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.app-loading-box{align-items:center;display:flex;flex-direction:column;gap:28px;padding:0 24px;text-align:center}.app-loading-logo{animation:logo-pulse 2s ease-in-out infinite;font-family:Raleway,sans-serif;font-size:2.2rem;font-weight:800;letter-spacing:.1em;line-height:1;text-transform:uppercase}@keyframes logo-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.03)}}.app-loading-ring,.app-loading-spinner{height:64px;width:64px}.app-loading-ring{animation:spin 1.2s linear infinite}.app-loading-track{stroke:#fff3;stroke-linecap:round}.app-loading-arc{stroke:#fff;stroke-linecap:round;stroke-dasharray:80 125;stroke-dashoffset:0}.app-loading-msg{animation:msg-slide-in .4s ease;color:#ffffffe6;font-size:.95rem;font-weight:500;letter-spacing:.02em;margin:0;min-height:1.4em}@keyframes msg-slide-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.empty-preview-wrap{position:relative}.empty-preview-ghost{filter:blur(.4px);opacity:.38;pointer-events:none;-webkit-user-select:none;user-select:none}.empty-preview-badge{background:#a78bca1f;border:1px solid #a78bca47;border-radius:20px;color:#a78bca;display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.06em;margin-bottom:10px;padding:2px 9px;text-transform:uppercase}.empty-cta{background:#a78bca0f;border:1.5px dashed #a78bca59;border-radius:10px;margin-top:14px;padding:14px 16px;text-align:center}.empty-cta-title{color:#2d1b69;font-size:.88rem;font-weight:600;margin:0 0 3px}.empty-cta-sub{color:#9ca3af;font-size:.78rem;margin:0}.login-page{align-items:center;background:linear-gradient(135deg,#2d1b69,#1a0f3e);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:24px;box-shadow:0 20px 60px #2d1b6959;max-width:400px;padding:48px 40px 40px;text-align:center;width:100%}.login-brand{align-items:center;display:flex;flex-wrap:nowrap;gap:10px;justify-content:center;margin-bottom:16px}.login-brand-icon{color:var(--t-p);flex-shrink:0}.login-title{font-family:Raleway,sans-serif;font-size:2.4rem;font-weight:800;letter-spacing:.06em;line-height:1;margin:0;text-transform:uppercase;white-space:nowrap}.logo-text-login{display:inline;letter-spacing:.06em}.logo-fin-login{color:#a78bca;margin-right:-.2em}.logo-track-login{color:#2d1b69}.login-subtitle{color:#9ca3af;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;letter-spacing:.04em;margin:0 0 36px;text-shadow:0 1px 3px #0000001a}.login-google-btn{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:14px;color:#374151;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:12px;justify-content:center;margin-bottom:20px;padding:14px 20px;transition:all .2s;width:100%}.login-google-btn:hover{background:#f9f7ff;border-color:#a78bca;box-shadow:0 4px 12px #2d1b691f;transform:translateY(-1px)}.login-google-btn:active{transform:translateY(0)}.login-google-icon{flex-shrink:0}.login-disclaimer{color:#d1d5db;font-size:.78rem;line-height:1.5;margin:0}@media (max-width:480px){.login-card{padding:36px 24px 32px}}.wm-overlay{align-items:center;animation:wm-fade-in .25s ease;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:#0a051ea6;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}@keyframes wm-fade-in{0%{opacity:0}to{opacity:1}}.wm-card{animation:wm-slide-up .3s cubic-bezier(.34,1.56,.64,1);background:#fff;border-radius:24px;box-shadow:0 24px 80px #2d1b6940;max-width:460px;overflow:hidden;width:100%}@keyframes wm-slide-up{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}.wm-header{background:linear-gradient(135deg,#2d1b69,#1a0f3e);padding:36px 40px 28px;text-align:center}.wm-logo{font-family:Raleway,sans-serif;font-size:1.8rem;font-weight:800;letter-spacing:.06em;margin-bottom:16px;text-transform:uppercase}.wm-fin{color:#a78bca}.wm-title,.wm-track{color:#fff}.wm-title{font-family:Inter,sans-serif;font-size:1.2rem;font-weight:700;margin:0 0 6px}.wm-subtitle{color:#ffffff8c;font-size:.82rem;letter-spacing:.03em;margin:0}.wm-features{display:flex;flex-direction:column;gap:4px;padding:20px 28px}.wm-feature{align-items:flex-start;border:1.5px solid #0000;border-radius:12px;cursor:pointer;display:flex;gap:14px;padding:12px 14px;transition:background .15s}.wm-feature:hover{background:#f9f7ff}.wm-feature-active{background:#f4f0ff;border-color:#ddd6fe}.wm-feature-icon{flex-shrink:0;font-size:1.3rem;margin-top:1px}.wm-feature-text{display:flex;flex-direction:column;gap:4px}.wm-feature-title{color:#2d1b69;font-size:.9rem;font-weight:600}.wm-feature-desc{animation:wm-desc-in .2s ease;color:#6b7280;font-size:.82rem;line-height:1.55}@keyframes wm-desc-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.wm-tip-container{display:flex;flex-direction:column;gap:10px;padding:20px 28px}.wm-tip-card{align-items:flex-start;animation:wm-desc-in .25s ease;background:#f4f0ff;border:1.5px solid #ddd6fe;border-radius:14px;display:flex;gap:12px;padding:14px 16px}.wm-tip-card--highlight{background:linear-gradient(135deg,#ede9ff,#f0fdf4);border-color:#a78bca}.wm-tip-icon{flex-shrink:0;font-size:1.25rem;margin-top:1px}.wm-tip-text{color:#374151;font-size:.85rem;line-height:1.6;margin:0}.wm-tip-text strong{color:#2d1b69}.wm-footer{gap:16px;justify-content:space-between;padding:16px 28px 28px}.wm-footer,.wm-footer-actions{align-items:center;display:flex}.wm-footer-actions{gap:8px}.wm-btn-skip{background:none;border:none;border-radius:8px;color:#9ca3af;cursor:pointer;font-size:.85rem;font-weight:600;padding:6px 8px;transition:color .15s,background .15s}.wm-btn-skip:hover{background:#f3f4f6;color:#6b7280}.wm-dots{display:flex;gap:6px}.wm-dot{background:#e5e7eb;border:none;border-radius:50%;cursor:pointer;height:7px;padding:0;transition:background .2s,transform .2s;width:7px}.wm-dot-active{background:#2d1b69;transform:scale(1.25)}.wm-btn{background:linear-gradient(135deg,#2d1b69,#4a2d8f);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:700;letter-spacing:.02em;padding:11px 28px;transition:opacity .2s,transform .15s}.wm-btn:hover{opacity:.9;transform:translateY(-1px)}.wm-btn:active{transform:translateY(0)}@media (max-width:480px){.wm-header{padding:28px 24px 22px}.wm-features{padding:16px}.wm-footer{padding:12px 16px 22px}}.tm-overlay{background:#0000;cursor:pointer;inset:0;position:fixed;z-index:500}.tm-spotlight{animation:tm-spotlight-in .3s ease-out forwards;border:2.5px solid;border-radius:18px;pointer-events:none;position:fixed;transition:top .35s cubic-bezier(.4,0,.2,1),left .35s cubic-bezier(.4,0,.2,1),width .35s cubic-bezier(.4,0,.2,1),height .35s cubic-bezier(.4,0,.2,1),box-shadow .35s ease;z-index:501}@keyframes tm-spotlight-in{0%{opacity:0;transform:scale(1.04)}to{opacity:1;transform:scale(1)}}.tm-spotlight-pulse{animation:tm-pulse 1.8s ease-out infinite;border:2px solid;border-radius:20px;opacity:0;pointer-events:none;position:fixed;z-index:500}@keyframes tm-pulse{0%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(1.06)}}.tm-card{animation:tm-card-in .22s cubic-bezier(.34,1.56,.64,1);background:#fff;border-radius:18px;box-shadow:0 12px 48px #00000038,0 2px 8px #0000001a;max-height:calc(100vh - 16px);max-width:calc(100vw - 16px);overflow:hidden;overflow-y:auto;position:fixed;z-index:502}@keyframes tm-card-in{0%{opacity:0;transform:scale(.92) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.tm-arrow{display:none}.tm-card-right .tm-arrow{left:-7px}.tm-card-left .tm-arrow,.tm-card-right .tm-arrow{border-radius:3px;display:block;height:14px;position:absolute;top:24px;transform:rotate(45deg);width:14px}.tm-card-left .tm-arrow{right:-7px}.tm-card-bottom .tm-arrow{border-radius:3px;display:block;height:14px;left:28px;position:absolute;top:-7px;transform:rotate(45deg);width:14px}.tm-card-header{align-items:flex-start;border-bottom:1px solid;display:flex;gap:12px;padding:14px 16px 12px}.tm-card-icon{flex-shrink:0;font-size:1.4rem;margin-top:2px}.tm-card-title{font-size:.95rem;font-weight:800;margin:0 0 3px}.tm-card-desc{color:#6b7280;font-size:.78rem;line-height:1.45;margin:0}.tm-tips{display:flex;flex-direction:column;gap:7px;list-style:none;padding:10px 16px}.tm-tip{align-items:flex-start;color:#374151;display:flex;font-size:.8rem;gap:9px;line-height:1.45}.tm-tip-dot{border-radius:50%;flex-shrink:0;height:5px;margin-top:5px;width:5px}.tm-card-footer{align-items:center;border-top:1px solid #f3f4f6;display:flex;gap:6px;justify-content:space-between;padding:8px 16px 6px}.tm-counter{font-size:.72rem;font-weight:700;white-space:nowrap}.tm-actions{align-items:center;display:flex;gap:4px}.tm-btn-prev{background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;font-size:.8rem;font-weight:700;padding:6px 10px;transition:background .12s}.tm-btn-prev:hover{background:#e5e7eb}.tm-btn-skip{background:none;border:none;border-radius:7px;color:#9ca3af;cursor:pointer;font-size:.78rem;font-weight:600;padding:6px 8px;transition:color .12s,background .12s;white-space:nowrap}.tm-btn-skip:hover{background:#f3f4f6;color:#6b7280}.tm-btn-next{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.8rem;font-weight:700;padding:7px 12px;transition:opacity .12s,transform .12s;white-space:nowrap}.tm-btn-next:hover{opacity:.9;transform:translateY(-1px)}.tm-dots{display:flex;gap:5px;justify-content:center;padding:6px 16px 12px}.tm-dot{background:#e5e7eb;border:none;border-radius:50%;cursor:pointer;height:6px;padding:0;transition:background .2s,transform .2s;width:6px}.tm-dot-active{transform:scale(1.3)}.tm-intro-overlay{align-items:center;animation:tm-fade-in .25s ease;background:#000000a6;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:600}@keyframes tm-fade-in{0%{opacity:0}to{opacity:1}}.tm-intro-card{animation:tm-intro-in .35s cubic-bezier(.34,1.56,.64,1);background:#fff;border-radius:24px;box-shadow:0 24px 64px #00000038;max-width:440px;padding:32px 28px 28px;text-align:center;width:100%}@keyframes tm-intro-in{0%{opacity:0;transform:scale(.88) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.tm-intro-badge{background:linear-gradient(135deg,#7c3aed,#a855f7);border-radius:20px;color:#fff;display:inline-block;font-size:11px;font-weight:700;letter-spacing:.08em;margin-bottom:16px;padding:3px 12px;text-transform:uppercase}.tm-intro-icon{font-size:48px;line-height:1;margin-bottom:12px}.tm-intro-title{color:#1e1b4b;font-size:20px;font-weight:800;line-height:1.25;margin:0 0 10px}.tm-intro-desc{color:#6b7280;font-size:14px;line-height:1.55;margin:0 0 20px}.tm-intro-highlights{background:#f9f7ff;border-radius:14px;display:flex;flex-direction:column;gap:10px;list-style:none;margin:0 0 24px;padding:14px 16px;text-align:left}.tm-intro-highlights li{align-items:center;color:#374151;display:flex;font-size:13.5px;gap:10px}.tm-intro-highlights li span{flex-shrink:0;font-size:18px}.tm-intro-actions{display:flex;gap:10px;justify-content:center}.tm-intro-btn-skip{background:none;border:1.5px solid #e5e7eb;border-radius:10px;color:#6b7280;cursor:pointer;font-size:14px;padding:10px 18px;transition:background .15s}.tm-intro-btn-skip:hover{background:#f3f4f6}.tm-intro-btn-start{background:linear-gradient(135deg,#7c3aed,#a855f7);border:none;border-radius:10px;color:#fff;cursor:pointer;flex:1 1;font-size:14px;font-weight:700;padding:10px 22px;transition:opacity .15s,transform .1s}.tm-intro-btn-start:hover{opacity:.9;transform:translateY(-1px)}.tm-intro-btn-start:active{transform:translateY(0)}@media (max-width:480px){.tm-intro-card{border-radius:20px;padding:24px 18px 22px}.tm-intro-title{font-size:18px}.tm-intro-actions{flex-direction:column}.tm-intro-btn-skip{order:2}.tm-intro-btn-start{order:1}}@media (max-width:640px){.tm-card{animation:tm-sheet-in .25s cubic-bezier(.32,.72,0,1);border-radius:20px 20px 0 0;bottom:0!important;left:0!important;position:fixed!important;right:0!important;top:auto!important;width:100%!important}@keyframes tm-sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.tm-arrow{display:none!important}.tm-spotlight{box-shadow:0 0 0 9999px #00000073,0 0 0 3px #7c3aed!important;box-shadow:0 0 0 9999px #00000073,0 0 0 3px var(--spot-color,#7c3aed)!important}}.transaction-form-container{background:#fff;border-radius:16px;border-top:4px solid #e0e0e0;box-shadow:0 2px 12px rgba(var(--t-p-rgb),.1);padding:28px 30px 24px;position:relative;transition:border-color .3s}.transaction-form-container.accent-expense{border-top-color:#fca5a5}.transaction-form-container.accent-income{border-top-color:#6ee7b7}.tf-header{align-items:center;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;margin-bottom:24px}.tf-header h2{color:#1f2937;font-size:1.25rem;font-weight:700;margin:0}.tf-type-toggle{background:#f3f4f6;border-radius:10px;display:flex;gap:4px;padding:4px}.tf-toggle-btn{background:#0000;border:none;border-radius:7px;color:#6b7280;cursor:pointer;font-size:.85rem;font-weight:600;padding:7px 16px;transition:all .2s;white-space:nowrap}.tf-toggle-btn:hover{background:#ffffffb3;color:#374151}.tf-toggle-btn.expense.active{background:#fff;box-shadow:0 1px 4px #0000001a;color:#dc2626}.tf-toggle-btn.income.active{background:#fff;box-shadow:0 1px 4px #0000001a;color:#059669}.transaction-form{display:flex;flex-direction:column;gap:16px}.form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{color:#6b7280;font-size:.78rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.form-group input,.form-group select{background:#fafafa;border:1.5px solid #e5e7eb;border-radius:10px;color:#1f2937;font-size:.95rem;padding:10px 14px;transition:border-color .2s,background .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus{background:#fff;border-color:var(--t-pb);box-shadow:0 0 0 3px #a78bfa26;outline:none}.form-group input::placeholder{color:#d1d5db}.tf-tooltip-wrap{margin-left:5px;position:relative;vertical-align:middle}.tf-tooltip-icon,.tf-tooltip-wrap{align-items:center;display:inline-flex}.tf-tooltip-icon{background:#e5e7eb;border-radius:50%;color:#6b7280;cursor:default;font-size:.65rem;font-weight:700;height:15px;justify-content:center;line-height:1;transition:background .15s;width:15px}.tf-tooltip-wrap:hover .tf-tooltip-icon{background:#ddd6fe;color:#6d28d9}.tf-tooltip-text{background:#1f2937;border-radius:8px;bottom:calc(100% + 8px);box-shadow:0 4px 16px #0000002e;color:#f9fafb;display:none;font-size:.75rem;font-weight:400;line-height:1.5;padding:8px 12px;pointer-events:none;text-align:center;white-space:normal;width:220px;z-index:100}.tf-tooltip-text,.tf-tooltip-text:after{left:50%;position:absolute;transform:translateX(-50%)}.tf-tooltip-text:after{border:5px solid #0000;border-top-color:#1f2937;content:"";top:100%}.tf-tooltip-wrap:hover .tf-tooltip-text{display:block}.tf-billing-day-hint{align-items:center;background:#f4f0ff;border:1px solid #ddd6fe;border-radius:8px;color:#6d28d9;cursor:pointer;display:inline-flex;font-size:.76rem;font-weight:500;gap:4px;margin-top:6px;padding:4px 10px;transition:background .15s,border-color .15s;white-space:nowrap}.tf-billing-day-hint:hover{background:#ede9fe;border-color:#a78bfa}.tf-checks-row{display:flex;flex-wrap:wrap;gap:20px}.tf-check-label{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;-webkit-user-select:none;user-select:none}.tf-check-label input[type=checkbox]{height:0;opacity:0;position:absolute;width:0}.tf-check-box{align-items:center;background:#fff;border:2px solid #d1d5db;border-radius:6px;display:flex;flex-shrink:0;height:20px;justify-content:center;transition:all .2s;width:20px}.tf-check-label input:checked+.tf-check-box{background:var(--t-p);border-color:var(--t-p)}.tf-check-label input:checked+.tf-check-box:after{border:2px solid #fff;border-left:none;border-top:none;content:"";display:block;height:9px;transform:rotate(45deg) translateY(-1px);width:5px}.form-actions{display:flex;gap:10px;justify-content:flex-end;padding-top:4px}.btn-cancel,.btn-submit{border:none;border-radius:10px;cursor:pointer;font-size:.95rem;font-weight:600;padding:10px 24px;transition:all .2s}.btn-submit{background:linear-gradient(135deg,var(--t-p) 0,var(--t-p) 100%);box-shadow:0 2px 8px rgba(var(--t-p-rgb),.3);color:#fff}.btn-submit:hover:not(:disabled){box-shadow:0 4px 14px rgba(var(--t-p-rgb),.4);transform:translateY(-1px)}.btn-cancel{background:#f3f4f6;color:#6b7280}.btn-cancel:hover:not(:disabled){background:#e5e7eb}.btn-cancel:disabled,.btn-submit:disabled{cursor:not-allowed;opacity:.55}.btn-loading{align-items:center;display:inline-flex;gap:8px}.btn-spinner{animation:spin .7s linear infinite;border:2px solid #fff6;border-radius:50%;border-top-color:#fff;display:inline-block;flex-shrink:0;height:14px;width:14px}.tf-category-row{align-items:center;display:flex;gap:8px}.tf-category-select{background:#fff;border:1.5px solid #e5e7eb;border-radius:9px;color:#1f2937;flex:1 1;font-size:.92rem;padding:10px 13px;transition:border-color .2s}.tf-category-select:focus{border-color:var(--t-pb);box-shadow:0 0 0 3px #a78bfa1f;outline:none}.tf-cat-new-btn{background:var(--t-pl);border:none;border-radius:9px;color:var(--t-p);cursor:pointer;font-size:.82rem;font-weight:600;padding:9px 14px;transition:background .15s;white-space:nowrap}.tf-cat-new-btn:hover{background:#ddd6fe}.tf-cat-icon-btn{align-items:center;background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:34px;justify-content:center;transition:background .15s,color .15s;width:34px}.tf-cat-icon-btn:hover{background:var(--t-pl);color:var(--t-p)}.tf-manage-cat-panel{background:#faf9ff;border:1.5px solid #e9d5ff;border-radius:10px;display:flex;flex-direction:column;gap:4px;margin-top:8px;padding:8px 10px}.tf-manage-cat-item{align-items:center;border-radius:7px;display:flex;gap:8px;padding:5px 6px;transition:background .12s}.tf-manage-cat-item:hover{background:var(--t-pl)}.tf-manage-cat-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.tf-manage-cat-name{color:#374151;flex:1 1;font-size:.88rem;font-weight:500}.tf-manage-cat-delete{background:none;border:none;border-radius:5px;color:#d1d5db;cursor:pointer;font-size:.7rem;font-weight:700;line-height:1;padding:3px 6px;transition:background .15s,color .15s}.tf-manage-cat-delete:hover{background:#fee2e2;color:#ef4444}.tf-manage-cat-edit{background:none;border:none;border-radius:5px;color:#d1d5db;cursor:pointer;font-size:.82rem;line-height:1;padding:3px 6px;transition:background .15s,color .15s}.tf-manage-cat-edit:hover{background:#ede9fe;color:#7c3aed}.tf-edit-cat-form{margin:4px 0;padding:12px 14px}.tf-edit-cat-form,.tf-new-cat-form{background:#faf9ff;border:1.5px solid #e9d5ff;border-radius:10px;display:flex;flex-direction:column;gap:10px}.tf-new-cat-form{margin-top:10px;padding:14px}.tf-new-cat-input{background:#fff;border:1.5px solid #e5e7eb;border-radius:9px;font-size:.9rem;padding:9px 13px;transition:border-color .2s}.tf-new-cat-input:focus{border-color:var(--t-pb);outline:none}.tf-color-picker{display:flex;flex-wrap:wrap;gap:8px}.tf-color-dot{border:2.5px solid #0000;border-radius:50%;cursor:pointer;height:22px;padding:0;transition:transform .15s,border-color .15s;width:22px}.tf-color-dot:hover{transform:scale(1.15)}.tf-color-dot.selected{border-color:#1f2937;transform:scale(1.15)}.tf-new-cat-actions{display:flex;gap:8px;justify-content:flex-end}.tf-new-cat-cancel{background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;font-size:.85rem;font-weight:600;padding:7px 14px}.tf-new-cat-cancel:hover{background:#e5e7eb}.tf-new-cat-save{background:linear-gradient(135deg,var(--t-p),var(--t-p));border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:7px 18px;transition:opacity .2s}.tf-new-cat-save:disabled{cursor:not-allowed;opacity:.5}.tf-new-cat-save:hover:not(:disabled){opacity:.9}.tf-monthly-modal-overlay{align-items:center;animation:tf-modal-fade-in .18s ease;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#00000073;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}@keyframes tf-modal-fade-in{0%{opacity:0}to{opacity:1}}.tf-monthly-modal{align-items:center;animation:tf-modal-slide-in .2s ease;background:#fff;border-radius:20px;box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column;max-width:400px;padding:32px 28px 24px;text-align:center;width:100%}@keyframes tf-modal-slide-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.tf-monthly-modal-icon{font-size:2.2rem;margin-bottom:10px}.tf-monthly-modal-title{color:#1f2937;font-size:1.15rem;font-weight:700;margin:0 0 8px}.tf-monthly-modal-desc{color:#6b7280;font-size:.9rem;line-height:1.5;margin:0 0 24px}.tf-monthly-modal-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:12px;width:100%}.tf-monthly-btn{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:14px;cursor:pointer;display:flex;gap:14px;padding:14px 18px;text-align:left;transition:all .18s;width:100%}.tf-monthly-btn:hover:not(:disabled){background:rgba(var(--t-p-rgb),.06);border-color:var(--t-p);transform:translateY(-1px)}.tf-monthly-btn:disabled{cursor:not-allowed;opacity:.55}.tf-monthly-btn-icon{flex-shrink:0;font-size:1.5rem}.tf-monthly-btn span:last-child{display:flex;flex-direction:column;gap:2px}.tf-monthly-btn strong{color:#1f2937;font-size:.95rem;font-weight:700}.tf-monthly-btn small{color:#9ca3af;font-size:.78rem;font-weight:400}.tf-monthly-btn-future{background:rgba(var(--t-p-rgb),.04);border-color:rgba(var(--t-p-rgb),.3)}.tf-monthly-btn-future:hover:not(:disabled){background:rgba(var(--t-p-rgb),.1);border-color:var(--t-p)}.tf-monthly-btn-future strong{color:var(--t-p)}.tf-monthly-modal-cancel{background:none;border:none;border-radius:8px;color:#9ca3af;cursor:pointer;font-size:.88rem;padding:6px 12px;transition:color .15s,background .15s}.tf-monthly-modal-cancel:hover:not(:disabled){background:#f3f4f6;color:#6b7280}@media (max-width:600px){.tf-monthly-modal{padding:24px 18px 20px}.tf-monthly-modal-actions{flex-direction:column}}.tf-checks-disabled .tf-check-label{cursor:not-allowed;opacity:.38;pointer-events:none}.tf-checks-debit-note{align-items:center;color:#6366f1;display:flex;font-size:.75rem;font-weight:500;gap:4px;margin-left:auto;white-space:nowrap}.tf-method-debit-badge{align-items:center;background:#6366f10f;border:1.5px solid #6366f159;border-radius:10px;color:#4f46e5;display:flex;font-size:.88rem;font-weight:600;gap:7px;min-height:42px;padding:9px 14px}.tf-debit-row{grid-template-columns:1fr;margin-bottom:2px}.tf-debit-group{display:flex;flex-direction:column;gap:4px}.tf-debit-label{align-items:center;color:#6b7280;display:flex;font-size:.82rem;font-weight:600}.tf-debit-select{background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;color:#374151;cursor:pointer;font-size:.88rem;outline:none;padding:9px 12px;transition:border-color .18s;width:100%}.tf-debit-select:focus{border-color:var(--t-p)}.tf-debit-select.tf-debit-over{background:#fff5f5;border-color:#f87171}.tf-debit-info{color:#059669;font-size:.78rem;font-weight:500;padding:4px 2px}.tf-debit-info.tf-debit-info-over{color:#dc2626}@media (max-width:600px){.tf-header{align-items:flex-start;flex-direction:column}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-cancel,.btn-submit{width:100%}}.tf-header-right{flex-wrap:wrap;gap:10px}.tf-header-right,.tf-scan-btn{align-items:center;display:flex}.tf-scan-btn{background:#0000;border:1.5px dashed #6d28d9;border:1.5px dashed var(--t-p,#6d28d9);border-radius:8px;color:#6d28d9;color:var(--t-p,#6d28d9);cursor:pointer;font-size:.8rem;font-weight:600;gap:6px;padding:7px 14px;transition:background .15s,color .15s;white-space:nowrap}.tf-scan-btn:hover:not(:disabled){background:#6d28d914;background:var(--t-pl,#6d28d914)}.tf-scan-btn:disabled{cursor:default;opacity:.7}.tf-scan-btn-loading{border-style:solid}.tf-scan-spinner{animation:tf-spin .7s linear infinite;border:2px solid;border-radius:50%;border-top:2px solid #0000;flex-shrink:0;height:12px;width:12px}@keyframes tf-spin{to{transform:rotate(1turn)}}.tf-scan-preview-wrap{align-items:center;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;display:flex;gap:12px;margin-bottom:4px;padding:10px 14px}.tf-scan-preview-img{border:1px solid #e5e7eb;border-radius:6px;flex-shrink:0;height:56px;object-fit:cover;width:56px}.tf-scan-preview-info{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:10px;min-width:0}.tf-scan-status-loading{color:#6b7280;font-size:.8rem;font-style:italic}.tf-scan-status-ok{align-items:center;color:#059669;display:flex;font-size:.8rem;font-weight:600;gap:5px}.tf-scan-status-err{color:#dc2626;font-size:.8rem;font-weight:500}.tf-scan-clear{background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;flex-shrink:0;font-size:.85rem;margin-left:auto;padding:2px 4px}.tf-scan-clear:hover{background:#f3f4f6;color:#6b7280}.tf-action-tooltip-wrap{align-items:center;display:flex;position:relative}.tf-action-tooltip-wrap:before{background:#1f2937;border-radius:6px;bottom:calc(100% + 8px);color:#fff;content:attr(data-tooltip);font-size:.72rem;font-weight:500;padding:5px 9px;transform:translateX(-50%);transform:translateX(-50%) translateY(4px);transition:opacity .15s,transform .15s;white-space:nowrap}.tf-action-tooltip-wrap:after,.tf-action-tooltip-wrap:before{left:50%;opacity:0;pointer-events:none;position:absolute;z-index:20}.tf-action-tooltip-wrap:after{border:5px solid #0000;border-top-color:#1f2937;bottom:calc(100% + 3px);content:"";transform:translateX(-50%);transition:opacity .15s}.tf-action-tooltip-wrap:hover:before{opacity:1;transform:translateX(-50%) translateY(0)}.tf-action-tooltip-wrap:hover:after{opacity:1}.tf-paste-wrap{position:relative}.tf-paste-btn,.tf-paste-wrap{align-items:center;display:flex}.tf-paste-btn{background:#0000;border:1.5px dashed #6d28d9;border:1.5px dashed var(--t-p,#6d28d9);border-radius:8px;color:#6d28d9;color:var(--t-p,#6d28d9);cursor:pointer;flex-shrink:0;height:34px;justify-content:center;transition:background .15s;width:34px}.tf-paste-btn:hover:not(:disabled){background:#6d28d914;background:var(--t-pl,#6d28d914)}.tf-paste-btn:disabled{cursor:default;opacity:.5}.tf-paste-hint{animation:tf-hint-in .15s ease-out;background:#1f2937;border-radius:6px;bottom:calc(100% + 6px);color:#fff;font-size:.72rem;font-weight:500;padding:5px 9px;pointer-events:none;position:absolute;right:0;white-space:nowrap;z-index:10}.tf-paste-hint:after{border:5px solid #0000;border-top-color:#1f2937;content:"";position:absolute;right:10px;top:100%}@keyframes tf-hint-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tf-crop-overlay{align-items:center;background:#000000b3;display:flex;inset:0;justify-content:center;padding:12px;position:fixed;z-index:1000}.tf-crop-modal{background:#fff;border-radius:14px;box-shadow:0 8px 32px #0000004d;display:flex;flex-direction:column;gap:14px;max-height:92vh;max-width:700px;padding:20px;width:100%}.tf-crop-modal-header h3{color:#1f2937;font-size:1rem;font-weight:700;margin:0 0 4px}.tf-crop-modal-header p{color:#6b7280;font-size:.8rem;margin:0}.tf-crop-hint-mobile{display:none}.tf-crop-canvas-wrap{align-items:center;background:#111;border:1.5px solid #e5e7eb;border-radius:8px;display:flex;flex:1 1;justify-content:center;min-height:0;overflow:auto}.tf-crop-container{cursor:crosshair;display:inline-block;line-height:0;position:relative;touch-action:none;-webkit-user-select:none;user-select:none}.tf-crop-img{display:block;max-height:60vh;max-width:100%;object-fit:contain}.tf-crop-dimmer{background:#00000080;left:0;pointer-events:none;position:absolute;right:0}.tf-crop-dimmer-top{top:0}.tf-crop-dimmer-bottom{bottom:0;top:auto}.tf-crop-dimmer-left,.tf-crop-dimmer-right{left:auto;right:auto}.tf-crop-dimmer-right{left:auto;right:0}.tf-crop-selection{border:2.5px solid #6d28d9;border:2.5px solid var(--t-p,#6d28d9);box-shadow:inset 0 0 0 1px #ffffffb3;pointer-events:none;position:absolute}.tf-crop-selection:after,.tf-crop-selection:before{background:#6d28d9;background:var(--t-p,#6d28d9);border-radius:2px;content:"";height:12px;position:absolute;width:12px}.tf-crop-selection:before{left:-5px;top:-5px}.tf-crop-selection:after{bottom:-5px;right:-5px}.tf-crop-actions{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:8px}.tf-crop-btn-full{background:none;border:1.5px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;font-size:.82rem;font-weight:600;padding:8px 14px;transition:border-color .15s,color .15s}.tf-crop-btn-full:hover{border-color:#9ca3af;color:#374151}.tf-crop-btn-confirm{align-items:center;background:#6d28d9;background:var(--t-p,#6d28d9);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.82rem;font-weight:700;gap:6px;justify-content:center;margin-left:auto;padding:8px 16px;transition:opacity .15s}.tf-crop-btn-confirm:hover:not(:disabled){opacity:.88}.tf-crop-btn-confirm.disabled,.tf-crop-btn-confirm:disabled{cursor:default;opacity:.4}.tf-crop-btn-cancel{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:.82rem;font-weight:600;padding:8px 6px}.tf-crop-btn-cancel:hover{color:#6b7280}@media (max-width:600px){.tf-crop-overlay{align-items:flex-end;padding:0}.tf-crop-modal{border-radius:18px 18px 0 0;gap:12px;max-height:95vh;max-width:100%;padding:16px 14px 24px}.tf-crop-img{max-height:50vh}.tf-crop-hint-desktop{display:none}.tf-crop-hint-mobile{display:block}.tf-crop-actions{flex-direction:column;gap:8px}.tf-crop-btn-confirm,.tf-crop-btn-full{font-size:.9rem;margin-left:0;padding:12px 16px;width:100%}.tf-crop-btn-cancel{text-align:center;width:100%}.tf-crop-selection:after,.tf-crop-selection:before{height:18px;width:18px}}.transaction-list-container{background:#fff;border-radius:16px;border-top:4px solid var(--t-pb);box-shadow:0 2px 12px rgba(var(--t-p-rgb),.1);padding:28px 30px 24px}.transaction-list-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}.tl-title-group{align-items:center;display:flex;flex:1 1;gap:10px}.transaction-list-container h2{color:#1f2937;font-size:1.25rem;font-weight:700;margin:0}.tl-count-badge{font-size:.75rem;font-weight:700;padding:3px 10px}.projection-filter-badge,.tl-count-badge{background:var(--t-pl);border-radius:20px;color:var(--t-p)}.projection-filter-badge{align-items:center;display:flex;font-size:.8rem;font-weight:600;gap:6px;padding:5px 10px 5px 14px}.btn-clear-filter{align-items:center;background:var(--t-p);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.65rem;font-weight:700;height:18px;justify-content:center;line-height:1;transition:background .2s;width:18px}.btn-clear-filter:hover{background:var(--t-pd)}.tl-header-right{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.tl-sort-group{background:#f3f4f6;border:1.5px solid #e5e7eb;border-radius:20px;gap:2px;padding:2px}.tl-sort-btn,.tl-sort-group{align-items:center;display:flex}.tl-sort-btn{background:#0000;border:none;border-radius:16px;color:#6b7280;cursor:pointer;font-size:.76rem;font-weight:600;gap:4px;padding:4px 10px;transition:all .15s;white-space:nowrap}.tl-sort-btn.active,.tl-sort-btn:hover{background:#fff;color:var(--t-p)}.tl-sort-btn.active{box-shadow:0 1px 4px #00000014}.tl-sort-arrow{font-size:.7rem;opacity:.7}.tl-filter-toggle{align-items:center;background:#f3f4f6;border:1.5px solid #e5e7eb;border-radius:20px;color:#6b7280;cursor:pointer;display:flex;font-size:.78rem;font-weight:600;gap:6px;padding:5px 12px;transition:all .15s;white-space:nowrap}.tl-filter-toggle.active,.tl-filter-toggle:hover{background:var(--t-pl);border-color:var(--t-p);color:var(--t-p)}.tl-filter-toggle.has-filters{border-color:var(--t-p);color:var(--t-p)}.tl-filter-count{background:var(--t-p);border-radius:50%;color:#fff;font-size:.62rem;font-weight:700;height:16px;justify-content:center;width:16px}.tl-filter-count,.tl-filters{align-items:center;display:flex}.tl-filters{flex-wrap:wrap;gap:10px;margin-bottom:20px}@media (max-width:768px){.tl-filters{align-items:stretch;background:#f9fafb;border:1px solid #f3f4f6;border-radius:12px;display:none;flex-direction:column;gap:8px;padding:12px}.tl-filters.tl-filters-open{display:flex}.tl-filter-group{justify-content:stretch;width:100%}.tl-filter-group .tl-pill{flex:1 1;text-align:center}.tl-filter-group-days{flex-wrap:wrap;overflow:visible}.tl-filter-group-days .tl-pill{flex-basis:calc(50% - 1px);flex-grow:1;flex-shrink:1;min-width:0}.tl-filter-group-days .tl-pill:nth-child(2){border-left:1.5px solid #e5e7eb}.tl-filter-group-days .tl-pill:nth-child(3){border-left:none;border-top:1.5px solid #e5e7eb}.tl-filter-group-days .tl-pill:nth-child(4){border-left:1.5px solid #e5e7eb;border-top:1.5px solid #e5e7eb}.tl-method-select{width:100%}}.tl-filter-group{border:1.5px solid #e5e7eb;border-radius:10px;display:flex;overflow:hidden}.tl-pill{background:#fff;border:none;color:#6b7280;cursor:pointer;font-size:.8rem;font-weight:600;padding:7px 14px;transition:background .15s,color .15s;white-space:nowrap}.tl-pill+.tl-pill{border-left:1.5px solid #e5e7eb}.tl-pill:hover{background:#f9fafb;color:#374151}.tl-pill.active{background:var(--t-pl);color:var(--t-p)}.tl-method-select{appearance:none;-webkit-appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23888' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:1.5px solid #e5e7eb;border-radius:10px;color:#6b7280;cursor:pointer;font-size:.8rem;font-weight:600;padding:7px 28px 7px 12px;transition:border-color .2s}.tl-method-select:focus{border-color:var(--t-pb);outline:none}.tl-method-select.active{background-color:var(--t-pl);border-color:var(--t-pb);color:var(--t-p)}.tl-btn-clear-filters{background:none;border:1.5px solid #e5e7eb;border-radius:10px;color:#9ca3af;cursor:pointer;font-size:.78rem;font-weight:600;padding:7px 13px;transition:border-color .2s,color .2s}.tl-btn-clear-filters:hover{border-color:#ef4444;color:#ef4444}.empty-state{color:#9ca3af;padding:50px 20px;text-align:center}.empty-state p{font-size:.95rem;margin:0}.empty-state-subtitle{color:#d1d5db!important;font-size:.82rem!important;margin-top:8px!important}.tl-table-wrapper{overflow-x:auto}.tl-table{border-collapse:collapse;font-size:.88rem;width:100%}.tl-table thead tr{background:#fafafa}.tl-table th{border-bottom:1.5px solid #f0f0f0;color:#9ca3af;font-size:.72rem;font-weight:600;letter-spacing:.05em;padding:10px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.tl-table td{border-bottom:1px solid #f5f5f5;color:#374151;padding:11px 14px;vertical-align:middle}.tl-table tbody tr:last-child td{border-bottom:none}.tl-table tbody tr{cursor:pointer;transition:background .12s}.tl-table tbody tr.row-income:hover{background:#f0fdf4}.tl-table tbody tr.row-expense:hover{background:#fff5f5}.tl-table tbody tr.row-income td:first-child{border-left:3px solid #6ee7b7}.tl-table tbody tr.row-expense td:first-child{border-left:3px solid #fca5a5}.tl-type-dot{border-radius:50%;display:inline-block;flex-shrink:0;height:7px;margin-right:8px;vertical-align:middle;width:7px}.tl-type-dot.income{background:#10b981}.tl-type-dot.expense{background:#ef4444}.tl-col-desc{font-weight:500}.tl-col-value{font-weight:700;white-space:nowrap}.tl-col-value.income{color:#059669}.tl-col-value.expense{color:#dc2626}.tl-col-center{text-align:center}.tl-col-method{color:#6b7280;font-size:.84rem}.tl-col-date{color:#9ca3af;font-size:.83rem;white-space:nowrap}.tl-col-actions{text-align:right}.tl-cat-badge,.tl-col-category{white-space:nowrap}.tl-cat-badge{border:1px solid;border-radius:10px;display:inline-block;font-size:.7rem;font-weight:600;padding:2px 9px}.tl-no-cat{color:#d1d5db;font-size:.85rem}.tl-nature-badge{border-radius:10px;font-size:.7rem;font-weight:600;padding:3px 9px;white-space:nowrap}.tl-nature-badge.fixed{background:#dbeafe;color:#1e40af}.tl-nature-badge.variable{background:#fef3c7;color:#92400e}.detail-badge{border-radius:10px;font-size:.7rem;font-weight:600;padding:3px 8px;white-space:nowrap}.detail-badge.monthly{background:#dbeafe;color:#1e40af}.detail-badge.installments{background:#fef3c7;color:#92400e}.btn-delete{background:none;border:none;border-radius:6px;color:#d1d5db;cursor:pointer;font-size:.72rem;font-weight:700;line-height:1;padding:4px 7px;transition:background .15s,color .15s}.btn-delete:hover{background:#fee2e2;color:#ef4444}.btn-delete:disabled{cursor:not-allowed;opacity:.6}.btn-delete:disabled:hover{background:none;color:#d1d5db}.tl-delete-spinner{animation:tl-spin .6s linear infinite;border:2px solid #d1d5db;border-radius:50%;border-top-color:#ef4444;display:inline-block;height:10px;width:10px}@keyframes tl-spin{to{transform:rotate(1turn)}}.tl-pagination{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:14px 4px 2px}.tl-page-info{color:#9ca3af;font-size:.8rem;font-weight:500}.tl-page-controls{gap:4px}.tl-page-btn,.tl-page-controls{align-items:center;display:flex}.tl-page-btn{background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;font-size:.82rem;font-weight:600;height:32px;justify-content:center;min-width:32px;padding:0 8px;transition:all .15s}.tl-page-btn:hover:not(:disabled){background:var(--t-pm);border-color:var(--t-pb);color:var(--t-p)}.tl-page-btn.active{background:var(--t-p);border-color:var(--t-p);color:#fff}.tl-page-btn:disabled{cursor:not-allowed;opacity:.35}.tl-mobile-only{display:none}.tl-desktop-only{display:block}@media (max-width:640px){.transaction-list-container{padding:18px 14px 16px}.tl-mobile-only{display:flex}.tl-desktop-only{display:none}.transaction-list-header{gap:8px;margin-bottom:14px}.transaction-list-container h2{font-size:1.05rem}.tl-count-badge{font-size:.7rem}.tl-sort-btn{font-size:.72rem;padding:4px 8px}.tl-filter-toggle{font-size:.72rem;padding:5px 10px}}.tl-mobile-list{flex-direction:column;gap:8px}.tl-card{background:#fff;border:1.5px solid #f0f0f0;border-radius:12px;cursor:pointer;overflow:hidden;padding:12px 14px;position:relative;transition:background .12s,box-shadow .12s}.tl-card:before{bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.tl-card-income:before{background:#6ee7b7}.tl-card-expense:before{background:#fca5a5}.tl-card-income:hover{background:#f0fdf4}.tl-card-expense:hover{background:#fff5f5}.tl-card-top{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-bottom:8px}.tl-card-desc-wrap{align-items:center;display:flex;flex:1 1;gap:7px;min-width:0}.tl-card-desc{color:#1f2937;font-size:.88rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tl-card-value{flex-shrink:0;font-size:.95rem;font-weight:700;white-space:nowrap}.tl-card-value.income{color:#059669}.tl-card-value.expense{color:#dc2626}.tl-card-bottom{gap:8px;justify-content:space-between}.tl-card-bottom,.tl-card-tags{align-items:center;display:flex;flex-wrap:wrap}.tl-card-tags{flex:1 1;gap:5px;min-width:0}.tl-card-meta{flex-shrink:0;gap:6px}.tl-card-meta,.tl-card-method{align-items:center;display:flex}.tl-card-method{color:#9ca3af;font-size:.72rem;gap:4px;white-space:nowrap}.tl-debit-badge{align-items:center;background:#6366f11f;border-radius:4px;color:#6366f1;display:inline-flex;flex-shrink:0;font-size:.68rem;font-weight:700;height:16px;justify-content:center;padding:0 4px}.tl-withdraw-badge{background:#10b9811f;color:#10b981}.tl-card-date{color:#9ca3af;font-size:.72rem;white-space:nowrap}.projections-container{background:#fff;border-radius:16px;border-top:4px solid var(--t-pb);box-shadow:0 2px 12px rgba(var(--t-p-rgb),.1);padding:28px 30px 24px}.projections-header{gap:12px;justify-content:space-between;margin-bottom:20px}.projections-controls,.projections-header{align-items:center;display:flex;flex-wrap:wrap}.projections-controls{gap:10px}.past-months-selector{align-items:center;background:#f3f4f6;border-radius:10px;display:flex;gap:4px;padding:4px}.past-months-label{color:#9ca3af;font-size:.72rem;font-weight:700;letter-spacing:.05em;padding:0 6px 0 4px;text-transform:uppercase;white-space:nowrap}.projections-header h2{color:#1f2937;font-size:1.25rem;font-weight:700;margin:0}.months-selector{background:#f3f4f6;border-radius:10px;display:flex;gap:4px;padding:4px}.months-btn{background:#0000;border:none;border-radius:7px;color:#6b7280;cursor:pointer;font-size:.82rem;font-weight:600;padding:6px 14px;transition:all .2s}.months-btn:hover{background:#ffffffb3;color:#374151}.months-btn.active{background:#fff;box-shadow:0 1px 4px #0000001a;color:var(--t-p)}.current-balance{align-items:center;border-radius:12px;display:flex;gap:12px;justify-content:space-between;margin-bottom:20px;padding:14px 20px}.current-balance.positive{background:#f0fdf4;border:1.5px solid #bbf7d0}.current-balance.negative{background:#fff5f5;border:1.5px solid #fecaca}.current-balance-label{color:#9ca3af;font-size:.75rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase}.balance-amount{font-size:1.3rem;font-weight:700;margin:0}.current-balance.positive .balance-amount{color:#059669}.current-balance.negative .balance-amount{color:#dc2626}.balance-display-wrap{align-items:center;display:flex;gap:8px}.balance-edit-btn{align-items:center;background:none;border:none;border-radius:6px;color:inherit;cursor:pointer;display:flex;opacity:.5;padding:4px;transition:opacity .2s,background .2s}.balance-edit-btn:hover{background:#0000000f;opacity:1}.balance-edit-wrap{align-items:center;display:flex;gap:6px}.balance-edit-input{background:#ffffffb3;border:1.5px solid;border-radius:8px;color:inherit;font-size:1.2rem;font-weight:700;outline:none;padding:4px 10px;width:160px}.balance-edit-cancel,.balance-edit-confirm{align-items:center;border:none;border-radius:7px;cursor:pointer;display:flex;font-size:.85rem;font-weight:700;height:32px;justify-content:center;min-width:32px;padding:5px 10px;transition:opacity .2s}.balance-edit-confirm{background:#059669;color:#fff}.balance-edit-confirm:hover{opacity:.85}.balance-edit-cancel{background:#00000014;color:#374151}.balance-edit-cancel:hover{opacity:.7}.balance-edit-cancel:disabled,.balance-edit-confirm:disabled{cursor:not-allowed;opacity:.5}.balance-edit-spinner{animation:spin .7s linear infinite;border:2px solid #fff6;border-radius:50%;border-top-color:#fff;display:inline-block;height:14px;width:14px}@keyframes spin{to{transform:rotate(1turn)}}.projections-table-container{-webkit-overflow-scrolling:touch;border:1.5px solid #f0f0f0;border-radius:12px;margin-bottom:20px;overflow-x:auto}.projections-table{border-collapse:collapse;border-radius:12px;font-size:.9rem;min-width:560px;overflow:hidden;width:100%}.projections-table thead{background:#f9fafb}.projections-table th{border-bottom:1.5px solid #f0f0f0;color:#9ca3af;font-size:.72rem;font-weight:700;letter-spacing:.07em;padding:11px 16px;text-align:left;text-transform:uppercase}.projections-table td{border-bottom:1px solid #f9f9f9;color:#374151;padding:11px 16px}.projections-table tbody tr:last-child td{border-bottom:none}.projections-table tbody tr.clickable{cursor:pointer}.projections-table tbody tr:hover{background:#fafafa}.projections-table tbody tr.selected{background:var(--t-pm)}.projections-table tbody tr.selected:hover{background:var(--t-pl)}.projections-table tbody tr.past-row{background:#fafafa;opacity:.82}.projections-table tbody tr.past-row td{color:#6b7280}.projections-table tbody tr.past-row:hover{background:#f3f4f6;opacity:1}.projections-table tbody tr.past-row-last td{border-bottom:2px dashed #e5e7eb}.past-badge{background:#e5e7eb;border-radius:4px;color:#9ca3af;display:inline-block;font-size:.6rem;font-weight:700;letter-spacing:.05em;margin-right:6px;padding:1px 5px;text-transform:uppercase;vertical-align:middle}.past-cumulative{color:#d1d5db;font-weight:500}.month-cell{align-items:center;color:#1f2937;display:flex;font-weight:600;gap:6px}.selected-indicator{color:var(--t-p);font-size:.55rem;vertical-align:middle}.income-cell{color:#059669;font-weight:500}.expense-cell{color:#dc2626;font-weight:500}.balance-cell.positive{color:#059669;font-weight:600}.balance-cell.negative{color:#dc2626;font-weight:600}.cumulative-cell{font-weight:700}.cumulative-cell.positive{color:#059669}.cumulative-cell.negative{color:#dc2626}.projections-summary{grid-gap:12px;border-top:1.5px solid #f0f0f0;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);padding-top:20px}.summary-item{background:#f9fafb;border-radius:12px;display:flex;flex-direction:column;gap:4px;padding:14px 16px}.summary-label{color:#9ca3af;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.summary-value{font-size:1.15rem;font-weight:700}.summary-value.income{color:#059669}.summary-value.expense{color:#dc2626}.summary-value.positive{color:#059669}.summary-value.negative{color:#dc2626}.empty-state,.loading{color:#9ca3af;font-size:.9rem;padding:40px;text-align:center}.empty-state .btn-retry{background:linear-gradient(135deg,var(--t-p) 0,var(--t-p) 100%);border:none;border-radius:9px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;margin-top:16px;padding:9px 20px;transition:opacity .2s}.empty-state .btn-retry:hover{opacity:.88}@media (max-width:768px){.projections-container{padding:18px 16px}.projections-header{align-items:flex-start;flex-direction:column;gap:8px}.projections-header h2{font-size:1.05rem}.projections-controls{flex-direction:column;gap:6px;width:100%}.months-selector,.past-months-selector{grid-gap:3px;display:grid;gap:3px;grid-template-columns:repeat(4,1fr);padding:3px;width:100%}.past-months-selector{grid-template-columns:auto repeat(4,1fr)}.past-months-label{font-size:.65rem;padding:0 4px}.months-btn{font-size:.78rem;padding:6px 4px;text-align:center}.current-balance{padding:10px 14px}.balance-amount{font-size:1.1rem}.projections-table{font-size:.82rem;min-width:0}.projections-table tbody td:nth-child(2),.projections-table tbody td:nth-child(3),.projections-table thead th:nth-child(2),.projections-table thead th:nth-child(3){display:none}.projections-table td,.projections-table th{padding:9px 10px}.month-cell{font-size:.8rem}.projections-summary{grid-template-columns:1fr 1fr}.projections-summary .summary-item:last-child{grid-column:span 2}.summary-item{padding:10px 12px}.summary-value{font-size:1rem}.summary-label{font-size:.67rem}}.pm-container{background:#fff;border-radius:16px;border-top:4px solid var(--t-pb);box-shadow:0 2px 12px rgba(var(--t-p-rgb),.1);padding:28px 30px 24px}.pm-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:20px}.pm-header h2{color:#1f2937;font-size:1.25rem;font-weight:700;margin:0}.pm-btn-add{background:linear-gradient(135deg,var(--t-p) 0,var(--t-p) 100%);border:none;border-radius:10px;box-shadow:0 2px 8px rgba(var(--t-p-rgb),.3);color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:9px 18px;transition:opacity .2s,box-shadow .2s}.pm-btn-add:hover{box-shadow:0 4px 14px rgba(var(--t-p-rgb),.4);opacity:.9}.pm-month-badge{align-items:center;background:var(--t-pl);border-radius:20px;color:var(--t-p);display:inline-flex;font-size:.82rem;font-weight:600;margin-bottom:18px;padding:5px 14px}.pm-form{background:#faf9ff;border:1.5px solid #e9d5ff;border-radius:12px;margin-bottom:24px;padding:20px}.pm-form h3{color:#1f2937;font-size:1rem;font-weight:700;margin:0 0 16px}.pm-form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}@media (max-width:600px){.pm-form-row{grid-template-columns:1fr}}@media (min-width:769px){button.pm-section-toggle{cursor:default;pointer-events:none}.pm-toggle-chevron{display:none}.pm-nolimit-grid{display:grid!important}}.pm-form-group{display:flex;flex-direction:column;gap:5px}.pm-form-group label{align-items:center;color:#6b7280;display:flex;flex-wrap:wrap;font-size:.75rem;font-weight:600;gap:5px;letter-spacing:.05em;text-transform:uppercase}.pm-tooltip-wrap{position:relative}.pm-tooltip-icon,.pm-tooltip-wrap{align-items:center;display:inline-flex}.pm-tooltip-icon{background:#e5e7eb;border-radius:50%;color:#6b7280;cursor:default;flex-shrink:0;font-size:.6rem;font-weight:700;height:14px;justify-content:center;width:14px}.pm-tooltip-text{background:#1f2937;border-radius:7px;bottom:calc(100% + 6px);color:#f9fafb;display:none;font-size:.72rem;font-weight:400;left:50%;letter-spacing:0;line-height:1.45;padding:7px 10px;pointer-events:none;position:absolute;text-transform:none;transform:translateX(-50%);white-space:normal;width:220px;z-index:100}.pm-tooltip-wrap:hover .pm-tooltip-text{display:block}.pm-form-group input{background:#fff;border:1.5px solid #e5e7eb;border-radius:9px;color:#1f2937;font-size:.92rem;padding:9px 13px;transition:border-color .2s,box-shadow .2s}.pm-form-group input:focus{border-color:var(--t-pb);box-shadow:0 0 0 3px #a78bfa26;outline:none}.pm-form-error{color:#ef4444;font-size:.82rem;margin:8px 0 0}.pm-optional{color:#9ca3af;font-size:.75rem;font-weight:400;margin-left:4px}.pm-billing-day{color:#6b7280;font-size:.78rem;margin-top:8px}.pm-form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.pm-btn-cancel{background:#f3f4f6;border:none;border-radius:9px;color:#6b7280;cursor:pointer;font-size:.88rem;font-weight:600;padding:8px 18px;transition:background .2s}.pm-btn-cancel:hover{background:#e5e7eb}.pm-btn-save{background:linear-gradient(135deg,var(--t-p) 0,var(--t-p) 100%);border:none;border-radius:9px;box-shadow:0 2px 8px rgba(var(--t-p-rgb),.25);color:#fff;cursor:pointer;font-size:.88rem;font-weight:600;padding:8px 22px;transition:opacity .2s}.pm-btn-save:disabled{cursor:not-allowed;opacity:.55}.pm-btn-save:hover:not(:disabled){opacity:.9}.pm-loading{color:#9ca3af;font-size:.9rem;padding:30px;text-align:center}.pm-section{margin-bottom:28px}.pm-section:last-child{margin-bottom:0}.pm-section-title{color:#9ca3af;font-size:.72rem;font-weight:700;letter-spacing:.08em;margin:0 0 14px;text-transform:uppercase}button.pm-section-toggle{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:7px;padding:0;text-align:left;width:100%}.pm-nolimit-count{background:var(--t-pl);border-radius:20px;color:var(--t-p);font-size:.65rem;font-weight:700;letter-spacing:0;padding:2px 8px;text-transform:none}.pm-toggle-chevron{color:#9ca3af;flex-shrink:0;margin-left:auto;transition:transform .2s}button.pm-section-toggle.open .pm-toggle-chevron{transform:rotate(180deg)}.pm-cards{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.pm-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;overflow:hidden;padding:18px 20px;position:relative;transition:box-shadow .2s,transform .2s}.pm-card:before{background:var(--t-pb);border-radius:14px 14px 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:0}.pm-card.over-limit{background:#fff8f8;border-color:#fca5a5}.pm-card.over-limit:before{background:#f87171}.pm-card:hover{box-shadow:0 6px 20px rgba(var(--t-p-rgb),.1);transform:translateY(-2px)}.pm-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:14px}.pm-card-name{align-items:center;color:#1f2937;display:flex;flex-wrap:wrap;font-size:.95rem;font-weight:700;gap:7px}.pm-badge-default{background:var(--t-pl);border-radius:8px;color:var(--t-p);font-size:.65rem;font-weight:700;letter-spacing:.06em;padding:2px 7px;text-transform:uppercase}.pm-card-actions{display:flex;flex-shrink:0;gap:4px}.pm-btn-delete{background:none;border:none;border-radius:6px;color:#d1d5db;cursor:pointer;flex-shrink:0;font-size:.8rem;font-weight:700;line-height:1;padding:3px 7px;transition:background .15s,color .15s}.pm-btn-delete:hover{background:#fee2e2;color:#ef4444}.pm-limit-info{align-items:baseline;display:flex;justify-content:space-between;margin-bottom:8px}.pm-used{color:#1f2937;font-size:1.1rem;font-weight:700}.pm-limit-total{color:#9ca3af;font-size:.8rem;font-weight:500}.pm-progress-bar-bg{background:#f3f4f6;border-radius:999px;height:8px;margin-bottom:10px;overflow:hidden}.pm-progress-bar-fill{border-radius:999px;height:100%;transition:width .5s ease}.pm-progress-bar-fill.ok{background:linear-gradient(90deg,#6ee7b7,#34d399)}.pm-progress-bar-fill.warning{background:linear-gradient(90deg,#fcd34d,#f59e0b)}.pm-progress-bar-fill.over{background:linear-gradient(90deg,#fca5a5,#ef4444)}.pm-remaining-info{font-size:.8rem}.pm-remaining-text{color:#6b7280}.pm-over-text{color:#dc2626;font-weight:600}.pm-nolimit-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-top:14px}@media (max-width:768px){.pm-container{padding:18px 16px 16px}.pm-cards{gap:10px;grid-template-columns:1fr}.pm-card{border-radius:12px;padding:14px}.pm-card-name{font-size:.88rem}.pm-used{font-size:.95rem}.pm-limit-total,.pm-remaining-info{font-size:.75rem}.pm-nolimit-grid{display:none}.pm-nolimit-grid.pm-nolimit-open{display:grid;grid-template-columns:1fr 1fr}}.pm-nolimit-card{background:var(--t-pm);border:1.5px solid var(--t-pl);border-radius:14px;display:flex;flex-direction:column;gap:10px;padding:16px;transition:box-shadow .2s,transform .2s}.pm-nolimit-card:hover{background:var(--t-pl);box-shadow:0 4px 14px rgba(var(--t-p-rgb),.12);transform:translateY(-1px)}.pm-nolimit-top{align-items:flex-start;display:flex;justify-content:space-between}.pm-nolimit-name-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.pm-nolimit-name{color:#1f2937;font-size:.92rem;font-weight:700}.pm-nolimit-spending{display:flex;flex-direction:column;gap:2px}.pm-nolimit-label{color:#9ca3af;font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.pm-nolimit-value{color:#ef4444;font-size:1.1rem;font-weight:700}.pm-nolimit-empty{color:#d1d5db;font-size:.8rem;font-style:italic}.pm-list-item-name{color:#1f2937;font-weight:600;margin-right:7px}.pm-list-item-spending{color:#ef4444;font-weight:700}.rem-container{background:#fff;border-radius:16px;border-top:4px solid var(--t-pb);box-shadow:0 2px 12px rgba(var(--t-p-rgb),.1);padding:28px 30px 24px}.rem-header{gap:12px;justify-content:space-between;margin-bottom:16px}.rem-header,.rem-title-group{align-items:center;display:flex;flex-wrap:wrap}.rem-title-group{gap:10px}.rem-title-group h2{color:#1f2937;font-size:1.25rem;font-weight:700;margin:0}.rem-month-badge{background:var(--t-pl);border-radius:20px;color:var(--t-p);font-size:.78rem;font-weight:600;padding:4px 12px}.rem-btn-add{background:linear-gradient(135deg,var(--t-p) 0,var(--t-p) 100%);border:none;border-radius:10px;box-shadow:0 2px 8px rgba(var(--t-p-rgb),.3);color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:9px 18px;transition:opacity .2s,box-shadow .2s}.rem-btn-add:hover{box-shadow:0 4px 14px #7c3aed66;opacity:.9}.rem-progress-wrap{margin-bottom:20px}.rem-progress-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.rem-progress-text{color:#6b7280;font-size:.8rem;font-weight:600}.rem-progress-pct{color:#9ca3af;font-size:.78rem;font-weight:700}.rem-progress-bg{background:#f3f4f6;border-radius:999px;height:6px;overflow:hidden}.rem-progress-fill{background:linear-gradient(90deg,var(--t-pb),var(--t-p));border-radius:999px;height:100%;transition:width .4s ease}.rem-progress-fill.all-done{background:linear-gradient(90deg,#6ee7b7,#10b981)}.rem-form{background:#faf9ff;border:1.5px solid #e9d5ff;border-radius:12px;margin-bottom:20px;padding:20px}.rem-form h3{color:#1f2937;font-size:1rem;font-weight:700;margin:0 0 16px}.rem-form-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.rem-col-span-2{grid-column:span 2}@media (max-width:560px){.rem-form-grid{grid-template-columns:1fr}.rem-col-span-2{grid-column:span 1}}.rem-form-group{display:flex;flex-direction:column;gap:5px}.rem-form-group label{color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.rem-form-group input,.rem-form-group select{background:#fff;border:1.5px solid #e5e7eb;border-radius:9px;color:#1f2937;font-size:.92rem;padding:9px 13px;transition:border-color .2s,box-shadow .2s}.rem-form-group input:focus,.rem-form-group select:focus{border-color:var(--t-pb);box-shadow:0 0 0 3px #a78bfa26;outline:none}.rem-form-error{color:#ef4444;font-size:.82rem;margin:8px 0 0}.rem-form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.rem-btn-cancel{background:#f3f4f6;border:none;border-radius:9px;color:#6b7280;cursor:pointer;font-size:.88rem;font-weight:600;padding:8px 18px;transition:background .2s}.rem-btn-cancel:hover{background:#e5e7eb}.rem-btn-save{background:linear-gradient(135deg,var(--t-p) 0,var(--t-p) 100%);border:none;border-radius:9px;box-shadow:0 2px 8px #7c3aed40;color:#fff;cursor:pointer;font-size:.88rem;font-weight:600;padding:8px 22px;transition:opacity .2s}.rem-btn-save:disabled{cursor:not-allowed;opacity:.55}.rem-btn-save:hover:not(:disabled){opacity:.9}.rem-loading{font-size:.9rem;padding:30px}.rem-empty,.rem-loading{color:#9ca3af;text-align:center}.rem-empty{padding:28px 20px}.rem-empty p{font-size:.95rem;margin:0}.rem-empty-sub{color:#d1d5db!important;font-size:.82rem!important;margin-top:6px!important}.rem-list{display:flex;flex-direction:column;gap:8px}.rem-item{align-items:center;background:#fafafa;border:1.5px solid #f0f0f0;border-radius:12px;display:flex;gap:12px;padding:12px 14px;transition:background .15s,border-color .15s}.rem-item:hover{background:#fff;border-color:#e5e7eb}.rem-item.rem-item-done{background:#f9fafb;border-color:#f0f0f0;opacity:.7}.rem-item.expense{border-left:3px solid #fca5a5}.rem-item.income{border-left:3px solid #6ee7b7}.rem-item.expense.rem-item-done,.rem-item.income.rem-item-done{border-left-color:#e5e7eb}.rem-check-label{align-items:center;cursor:pointer;display:flex;flex-shrink:0}.rem-check-label input[type=checkbox]{height:0;opacity:0;position:absolute;width:0}.rem-check-box{align-items:center;background:#fff;border:2px solid #d1d5db;border-radius:6px;display:flex;flex-shrink:0;height:20px;justify-content:center;transition:all .2s;width:20px}.rem-check-label input:checked+.rem-check-box{background:var(--t-p);border-color:var(--t-p)}.rem-check-label input:checked+.rem-check-box:after{border:2px solid #fff;border-left:none;border-top:none;content:"";display:block;height:9px;transform:rotate(45deg) translateY(-1px);width:5px}.rem-item-day{align-items:center;display:flex;flex-direction:column;flex-shrink:0;min-width:32px}.rem-day-num{color:#1f2937;font-size:1rem;font-weight:800;line-height:1}.rem-day-label{color:#9ca3af;font-size:.62rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.rem-item-body{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:8px;min-width:0}.rem-item-desc{color:#1f2937;font-size:.92rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rem-strikethrough{color:#9ca3af;text-decoration:line-through}.rem-type-badge{border-radius:10px;flex-shrink:0;font-size:.7rem;font-weight:600;padding:2px 8px;white-space:nowrap}.rem-type-badge.income{background:#d1fae5;color:#065f46}.rem-type-badge.expense{background:#fee2e2;color:#991b1b}.rem-item-value{flex-shrink:0;font-size:.92rem;font-weight:700;white-space:nowrap}.rem-item-value.income{color:#059669}.rem-item-value.expense{color:#dc2626}.rem-item-value.rem-muted{color:#9ca3af!important}.rem-no-value{color:#d1d5db;font-weight:400}.rem-item-actions{display:flex;flex-shrink:0;gap:4px}.rem-item{cursor:pointer}.rem-btn-delete{background:none;border:none;border-radius:6px;color:#d1d5db;cursor:pointer;font-size:.78rem;font-weight:700;line-height:1;padding:4px 6px;transition:background .15s,color .15s}.rem-btn-delete:hover{background:#fee2e2;color:#ef4444}.inv-container{background:#fff;border-radius:16px;border-top:4px solid #6ee7b7;box-shadow:0 2px 12px rgba(var(--t-p-rgb),.1);padding:28px 30px 24px}.inv-header{flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px}.inv-header,.inv-title-group{align-items:center;display:flex}.inv-title-group{gap:10px}.inv-title-group h2{color:#1f2937;font-size:1.25rem;font-weight:700;margin:0}.inv-count-badge{background:#d1fae5;border-radius:20px;color:#065f46;font-size:.75rem;font-weight:700;padding:3px 10px}.inv-btn-add{background:linear-gradient(135deg,#059669,#10b981);border:none;border-radius:10px;box-shadow:0 2px 8px #10b9814d;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:9px 18px;transition:opacity .2s,box-shadow .2s}.inv-btn-add:hover{box-shadow:0 4px 14px #10b98166;opacity:.9}.inv-summary-row{align-items:center;background:#f0fdf4;border:1.5px solid #d1fae5;border-radius:12px;display:flex;gap:0;margin-bottom:20px;padding:14px 20px}.inv-summary-item{display:flex;flex:1 1;flex-direction:column;gap:3px}.inv-summary-divider{background:#d1fae5;flex-shrink:0;height:36px;margin:0 20px;width:1.5px}.inv-summary-label{color:#6b7280;font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.inv-summary-value{font-size:1.2rem;font-weight:800}.inv-summary-value.total{color:#1f2937}.inv-summary-value.monthly{color:#059669}.inv-form{background:#f0fdf4;border:1.5px solid #d1fae5;border-radius:12px;margin-bottom:20px;padding:20px}.inv-form h3{color:#1f2937;font-size:1rem;font-weight:700;margin:0 0 16px}.inv-form-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.inv-col-span-2{grid-column:span 2}@media (max-width:560px){.inv-form-grid{grid-template-columns:1fr}.inv-col-span-2{grid-column:span 1}}.inv-form-group{display:flex;flex-direction:column;gap:5px}.inv-form-group label{color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.inv-form-group input,.inv-form-group select{background:#fff;border:1.5px solid #e5e7eb;border-radius:9px;color:#1f2937;font-size:.92rem;padding:9px 13px;transition:border-color .2s,box-shadow .2s}.inv-form-group input:focus,.inv-form-group select:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811f;outline:none}.inv-form-preview{align-items:center;background:#fff;border:1.5px solid #a7f3d0;border-radius:9px;flex-direction:row;justify-content:space-between;padding:10px 14px}.inv-preview-label{color:#6b7280;font-size:.8rem;font-weight:600}.inv-preview-value{color:#059669;font-size:1rem;font-weight:800}.inv-form-error{color:#ef4444;font-size:.82rem;margin:8px 0 0}.inv-form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.inv-btn-cancel{background:#f3f4f6;border:none;border-radius:9px;color:#6b7280;cursor:pointer;font-size:.88rem;font-weight:600;padding:8px 18px;transition:background .2s}.inv-btn-cancel:hover{background:#e5e7eb}.inv-btn-save{background:linear-gradient(135deg,#059669,#10b981);border:none;border-radius:9px;box-shadow:0 2px 8px #10b98140;color:#fff;cursor:pointer;font-size:.88rem;font-weight:600;padding:8px 22px;transition:opacity .2s}.inv-btn-save:disabled{cursor:not-allowed;opacity:.55}.inv-btn-save:hover:not(:disabled){opacity:.9}.inv-loading{font-size:.9rem;padding:30px}.inv-empty,.inv-loading{color:#9ca3af;text-align:center}.inv-empty{padding:28px 20px}.inv-empty p{font-size:.95rem;margin:0}.inv-empty-sub{color:#d1d5db!important;font-size:.82rem!important;margin-top:6px!important}.inv-list{display:flex;flex-direction:column;gap:8px}.inv-item{align-items:center;background:#fafafa;border:1.5px solid #f0fdf4;border-left:3px solid #6ee7b7;border-radius:12px;cursor:pointer;display:flex;gap:14px;padding:13px 16px;transition:background .15s,border-color .15s}.inv-item:hover{background:#fff;border-color:#a7f3d0}.inv-item-type-badge{background:#d1fae5;border-radius:10px;color:#065f46;flex-shrink:0;font-size:.7rem;font-weight:700;padding:4px 10px;white-space:nowrap}.inv-item-body{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.inv-item-name{color:#1f2937;font-size:.92rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inv-item-rate{color:#6b7280;font-size:.78rem;font-weight:500}.inv-item-amounts{display:flex;flex-shrink:0;gap:24px}.inv-item-invested,.inv-item-return{align-items:flex-end;display:flex;flex-direction:column;gap:1px}.inv-item-amt-label{color:#9ca3af;font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.inv-item-amt-value{color:#1f2937;font-size:.9rem;font-weight:700}.inv-item-amt-value.green{color:#059669}.inv-item-actions{flex-shrink:0}.inv-btn-delete{background:none;border:none;border-radius:6px;color:#d1d5db;cursor:pointer;font-size:.78rem;font-weight:700;line-height:1;padding:4px 6px;transition:background .15s,color .15s}.inv-btn-delete:hover{background:#fee2e2;color:#ef4444}.inv-btn-projection{background:none;border:1.5px solid #a7f3d0;border-radius:10px;color:#059669;cursor:pointer;flex-shrink:0;font-size:.8rem;font-weight:600;margin-left:auto;padding:7px 14px;transition:background .15s,color .15s;white-space:nowrap}.inv-btn-projection.active,.inv-btn-projection:hover{background:#d1fae5;border-color:#6ee7b7}.inv-projection{border:1.5px solid #d1fae5;border-radius:14px;margin-top:20px;overflow:hidden}.inv-proj-header{align-items:center;background:#f0fdf4;border-bottom:1.5px solid #d1fae5;display:flex;flex-wrap:wrap;gap:12px;padding:14px 18px}.inv-proj-title{color:#065f46;flex:1 1;font-size:.85rem;font-weight:700}.inv-proj-horizons{border:1.5px solid #a7f3d0;border-radius:9px;display:flex;overflow:hidden}.inv-proj-pill{background:#fff;border:none;color:#6b7280;cursor:pointer;font-size:.78rem;font-weight:600;padding:5px 13px;transition:background .15s,color .15s;white-space:nowrap}.inv-proj-pill+.inv-proj-pill{border-left:1.5px solid #a7f3d0}.inv-proj-pill:hover{background:#f0fdf4;color:#059669}.inv-proj-pill.active{background:#059669;color:#fff}.inv-proj-table-wrap{overflow-x:auto}.inv-proj-table{border-collapse:collapse;font-size:.85rem;width:100%}.inv-proj-table th{background:#fafafa;border-bottom:1px solid #f0fdf4;color:#9ca3af;font-size:.7rem;font-weight:600;letter-spacing:.05em;padding:9px 14px;text-align:left;text-transform:uppercase}.inv-proj-table td:last-child,.inv-proj-table th:last-child{width:110px}.inv-proj-table td{border-bottom:1px solid #f5f5f5;padding:9px 14px;vertical-align:middle}.inv-proj-table tbody tr:last-child td{border-bottom:none}.inv-proj-table tbody tr:hover{background:#f9fefb}.proj-row-year td{background:#f0fdf4;font-weight:600}.proj-col-period{color:#374151;font-weight:600}.proj-col-total{color:#1f2937;font-weight:700}.proj-col-earnings,.proj-col-pct{color:#059669;font-weight:600}.proj-col-pct{font-size:.82rem;white-space:nowrap}.inv-proj-breakdown{background:#fafffe;border-top:1.5px solid #d1fae5;padding:16px 18px}.inv-proj-breakdown-title{color:#6b7280;display:block;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:12px;text-transform:uppercase}.inv-proj-cards{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.inv-proj-card{background:#fff;border:1.5px solid #d1fae5;border-radius:12px;display:flex;flex-direction:column;gap:6px;padding:13px 14px}.inv-proj-card-top{align-items:flex-start;display:flex;gap:6px;justify-content:space-between;margin-bottom:2px}.inv-proj-card-name{color:#1f2937;font-size:.85rem;font-weight:700;line-height:1.2}.inv-proj-card-type{background:#d1fae5;border-radius:8px;color:#065f46;flex-shrink:0;font-size:.65rem;font-weight:700;padding:2px 7px;white-space:nowrap}.inv-proj-card-row{color:#6b7280;display:flex;font-size:.78rem;justify-content:space-between}.inv-proj-card-row span:last-child{color:#374151;font-weight:600}.inv-proj-card-row.green span:last-child{color:#059669;font-size:.88rem}.inv-proj-card-row.muted{opacity:.7}@media (max-width:640px){.inv-container{padding:20px 16px 18px}.inv-header{flex-wrap:nowrap;gap:8px}.inv-count-badge{display:none}.inv-btn-add{border-radius:8px;font-size:.75rem;padding:7px 10px;white-space:nowrap}.inv-summary-row{flex-direction:column;gap:0;padding:14px 16px}.inv-summary-item{align-items:center;flex-direction:row;justify-content:space-between;padding:6px 0}.inv-summary-label{font-size:.75rem}.inv-summary-value{font-size:1rem}.inv-summary-divider{height:1px;margin:4px 0;width:100%}.inv-btn-projection{justify-content:center;margin-left:0;margin-top:10px;width:100%}.inv-item{flex-wrap:wrap;gap:8px;padding:12px 14px}.inv-item-type-badge{order:1}.inv-item-body{flex:1 1;min-width:0;order:2}.inv-item-actions{order:3}.inv-item-amounts{background:#f0fdf4;border-radius:8px;gap:0;justify-content:flex-end;order:4;padding:8px 10px;width:100%}.inv-item-invested{display:none}.inv-item-return{align-items:flex-start}.inv-item-amt-label{font-size:.65rem}.inv-item-amt-value{font-size:.85rem}.inv-proj-header{align-items:flex-start;flex-direction:column;gap:10px}.inv-proj-title{font-size:.8rem}.inv-proj-horizons{border-radius:10px;display:grid;grid-template-columns:repeat(4,1fr);width:100%}.inv-proj-pill{flex:1 1;font-size:.8rem;padding:9px 4px;text-align:center}.inv-proj-pill+.inv-proj-pill{border-left:1.5px solid #a7f3d0}}.goals-container{background:#fff;border-radius:20px;border-top:4px solid var(--t-pb);box-shadow:0 2px 16px rgba(var(--t-p-rgb),.08);padding:22px 28px}.goals-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.goals-header h2{color:#1f2937;font-size:.97rem;font-weight:700;margin:0}.goals-add-btn{background:linear-gradient(135deg,var(--t-p),var(--t-pb));border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:.82rem;font-weight:600;padding:7px 16px;transition:opacity .15s;white-space:nowrap}.goals-add-btn:hover{opacity:.88}.goals-tabs{background:#f9fafb;border-radius:12px;display:flex;gap:4px;margin-bottom:18px;padding:4px;width:-webkit-fit-content;width:fit-content}.goals-tab{align-items:center;background:none;border:none;border-radius:9px;color:#6b7280;cursor:pointer;display:flex;font-size:.8rem;font-weight:600;gap:6px;padding:6px 14px;transition:all .15s;white-space:nowrap}.goals-tab.active{background:#fff;box-shadow:0 1px 5px #00000017;color:var(--t-p)}.goals-tab-badge{background:var(--t-pl);border-radius:20px;color:var(--t-p);font-size:.65rem;font-weight:700;padding:1px 6px}.goals-form{background:#f9fafb;border:1px solid #e5e7eb;border-radius:14px;display:flex;flex-direction:column;gap:12px;margin-bottom:20px;padding:18px}.goals-form-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:12px}.goals-form-group{display:flex;flex:1 1 140px;flex-direction:column;gap:5px;min-width:0}.goals-form-group label{color:#6b7280;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.goals-form-group input,.goals-form-group select{background:#fff;border:1.5px solid #e5e7eb;border-radius:9px;color:#1f2937;font-size:.85rem;outline:none;padding:8px 11px;transition:border-color .15s}.goals-form-group input:focus,.goals-form-group select:focus{border-color:var(--t-p)}.goals-type-toggle{background:#fff;border:1.5px solid #e5e7eb;border-radius:9px;display:flex;overflow:hidden;width:100%}.goals-type-toggle button{background:none;border:none;color:#6b7280;cursor:pointer;flex:1 1;font-size:.76rem;font-weight:600;min-width:0;padding:7px 6px;text-align:center;transition:all .15s;white-space:nowrap}.goals-type-toggle button.active{background:var(--t-pl);color:var(--t-p)}.goals-form-color{flex:0 0 auto!important;min-width:0!important;min-width:auto!important}.goals-color-picker{align-items:center;display:flex;flex-wrap:wrap;gap:6px;padding:6px 0}.goals-color-dot{border:2.5px solid #0000;border-radius:50%;cursor:pointer;height:22px;padding:0;transition:transform .12s,border-color .12s;width:22px}.goals-color-dot:hover{transform:scale(1.2)}.goals-color-dot.selected{border-color:#1f2937;transform:scale(1.2)}.goals-form-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.goals-btn-cancel{background:none;border:1.5px solid #e5e7eb;border-radius:9px;color:#6b7280;cursor:pointer;font-size:.82rem;font-weight:600;padding:7px 16px;transition:border-color .15s}.goals-btn-cancel:hover{border-color:#9ca3af}.goals-btn-save{background:linear-gradient(135deg,var(--t-p),var(--t-pb));border:none;border-radius:9px;color:#fff;cursor:pointer;font-size:.82rem;font-weight:600;padding:7px 18px;transition:opacity .15s}.goals-btn-save:hover{opacity:.88}.goals-btn-save:disabled{cursor:default;opacity:.6}.goals-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.goal-card{border:1px solid #f3f4f6;border-radius:14px;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .15s,transform .15s}.goal-card:hover{box-shadow:0 4px 18px #00000014;transform:translateY(-1px)}.goal-card-top{border-top:3px solid var(--t-p);display:flex;flex:1 1;flex-direction:column;gap:10px;padding:14px 16px}.goal-card-top.over-limit{background:#fff5f5}.goal-card-top.near-limit{background:#fffbeb}.goal-card-header{align-items:flex-start;display:flex;gap:6px;justify-content:space-between;min-width:0}.goal-name-row{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:6px;min-width:0}.goal-cat-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.goal-card-name{color:#1f2937;flex:1 1;font-size:.87rem;min-width:0;overflow:hidden;text-overflow:ellipsis}.goal-card-name,.goal-status-pill{font-weight:700;white-space:nowrap}.goal-status-pill{border-radius:20px;flex-shrink:0;font-size:.62rem;padding:2px 7px}.goal-status-pill.over{background:#fee2e2;color:#dc2626}.goal-status-pill.warn{background:#fef3c7;color:#d97706}.goal-card-actions{display:flex;flex-shrink:0;gap:3px}.goal-action-btn{align-items:center;background:#f3f4f6;border:none;border-radius:7px;color:#6b7280;cursor:pointer;display:flex;font-size:.72rem;height:26px;justify-content:center;transition:background .12s,color .12s;width:26px}.goal-action-btn:hover{background:#e5e7eb;color:#374151}.goal-action-btn.delete:hover{background:#fee2e2;color:#dc2626}.goal-month-tag{color:#9ca3af;font-size:.68rem;font-weight:600;margin-top:-4px;text-transform:capitalize}.goal-amounts{align-items:baseline;display:flex;gap:5px}.goal-saved{font-size:1.15rem;font-weight:800;line-height:1}.goal-sep{color:#d1d5db;font-size:.85rem}.goal-target{color:#9ca3af;font-size:.8rem;font-weight:600}.goal-bar-wrap{background:#f3f4f6;border-radius:3px;height:6px;overflow:hidden}.goal-bar-fill{border-radius:3px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.goal-bar-labels{align-items:center;display:flex;gap:6px;justify-content:space-between}.goal-pct{flex-shrink:0;font-size:.78rem;font-weight:700}.goal-remaining{color:#9ca3af;font-size:.7rem;font-weight:500;text-align:right}.goal-done-label{color:#10b981;font-size:.7rem;font-weight:700}.goal-over-label{color:#dc2626;font-size:.68rem;font-weight:600;text-align:right}.goal-deposit-row{align-items:center;background:#fafafa;border-top:1px solid #f3f4f6;display:flex;gap:6px;padding:10px 16px}.goal-deposit-row input{border:1.5px solid #e5e7eb;border-radius:8px;flex:1 1;font-size:.82rem;min-width:0;outline:none;padding:6px 10px}.goal-deposit-row input:focus{border-color:var(--t-p)}.goal-deposit-save{color:#fff;font-size:1rem;font-weight:700}.goal-deposit-cancel,.goal-deposit-save{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex-shrink:0;height:30px;justify-content:center;width:30px}.goal-deposit-cancel{background:#f3f4f6;color:#6b7280;font-size:.72rem}.goal-deposit-btn{background:none;border:none;border-radius:0 0 14px 14px;border-top:1px dashed;cursor:pointer;font-size:.76rem;font-weight:600;padding:8px 16px;text-align:center;transition:opacity .15s;width:100%}.goal-deposit-btn:hover{opacity:.7}.goals-empty{color:#9ca3af;font-size:.88rem;padding:32px 16px;text-align:center}@media (max-width:640px){.goals-container{padding:16px 14px}.goals-grid{grid-template-columns:1fr}.goals-tabs{width:100%}.goals-tab{flex:1 1;justify-content:center}.goals-form{padding:14px}.goals-form-row{gap:10px}.goals-form-group{flex:1 1 100%}.goals-form-color{flex:0 0 auto!important}.goals-btn-cancel,.goals-btn-save{flex:1 1;justify-content:center;text-align:center}.goals-header{gap:8px}}@keyframes cat-container-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.cat-chart-container{animation:cat-container-in .5s ease both;background:#fff;border-radius:20px;border-top:4px solid #fca5a5;box-shadow:0 2px 16px rgba(var(--t-p-rgb),.08);padding:22px 28px}.cat-chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.cat-chart-title-group{align-items:baseline;display:flex;gap:10px}.cat-chart-title-group h2{color:#1f2937;font-size:.97rem;font-weight:700;margin:0}.cat-chart-count{color:#9ca3af;font-size:.72rem;font-weight:600}.cat-chart-month{background:var(--t-pl);border-radius:20px;color:var(--t-p);font-size:.73rem;font-weight:600;padding:3px 11px;text-transform:capitalize}.cat-stats-strip{align-items:center;background:#f9fafb;border:1.5px solid #f0f0f0;border-radius:12px;display:flex;gap:0;margin-bottom:20px;padding:12px 20px}.cat-stat-item{display:flex;flex:1 1;flex-direction:column;gap:3px}.cat-stat-divider{background:#e5e7eb;flex-shrink:0;height:32px;margin:0 20px;width:1.5px}.cat-stat-label{color:#9ca3af;font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.cat-stat-value{font-size:.95rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cat-stat-value.expense{color:#dc2626}.cat-stat-value.neutral{color:#374151}.cat-chart-body{align-items:stretch;gap:24px}.cat-chart-body,.cat-chart-left{display:flex;flex-direction:column}.cat-chart-left{align-items:center;gap:12px}.cat-chart-donut-wrap{height:200px;position:relative;width:200px}.cat-chart-donut-wrap canvas{position:relative;z-index:2}.cat-chart-center{left:50%;pointer-events:none;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:1}.cat-chart-center-label{color:#9ca3af;display:block;font-size:.6rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.cat-chart-center-value{color:#dc2626;display:block;font-size:1.05rem;font-weight:800;margin-top:3px;white-space:nowrap}.cat-chart-top-badge{align-items:center;background:#f9fafb;border:1px solid #f3f4f6;border-radius:20px;display:flex;gap:6px;padding:4px 10px}.cat-chart-top-dot{border-radius:50%;flex-shrink:0;height:7px;width:7px}.cat-chart-top-text{color:#6b7280;font-size:.7rem;white-space:nowrap}.cat-chart-top-text strong{color:#374151;font-weight:700}.cat-chart-legend,.cat-chart-legend-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(2,1fr)}@keyframes cat-legend-in{0%{opacity:0;transform:translateX(12px)}to{opacity:1;transform:translateX(0)}}.cat-legend-item{align-items:center;animation:cat-legend-in .4s ease both;border:1.5px solid #0000;border-radius:10px;display:flex;gap:8px;padding:8px 10px;transition:background .15s}.cat-legend-item:first-child{animation-delay:.15s}.cat-legend-item:nth-child(2){animation-delay:.25s}.cat-legend-item:nth-child(3){animation-delay:.35s}.cat-legend-item:nth-child(4){animation-delay:.45s}.cat-legend-item:nth-child(5){animation-delay:.55s}.cat-legend-item:nth-child(6){animation-delay:.65s}.cat-legend-item:nth-child(7){animation-delay:.7s}.cat-legend-item:nth-child(8){animation-delay:.75s}.cat-legend-item:hover{background:#f9fafb}.cat-legend-item-clickable{cursor:pointer}.cat-legend-item-clickable:hover{background:#f3f4f6;border-color:#e5e7eb;box-shadow:0 2px 8px #0000000f;transform:translateY(-1px);transition:background .15s,transform .15s,box-shadow .15s}.cat-legend-item-clickable:hover .cat-legend-name{color:#111827}.cat-legend-rank{align-items:center;background:#f3f4f6;border-radius:50%;color:#6b7280;display:flex;flex-shrink:0;font-size:.65rem;font-weight:700;height:18px;justify-content:center;width:18px}.cat-legend-info{flex:1 1;min-width:0}.cat-legend-top-row{align-items:center;display:flex;gap:6px;margin-bottom:5px}.cat-legend-name{color:#374151;flex:1 1;font-size:.8rem;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cat-legend-pct-pill{border-radius:20px;flex-shrink:0;font-size:.65rem;font-weight:700;padding:1px 7px;white-space:nowrap}.cat-legend-bar-row{align-items:center;display:flex;gap:8px}.cat-legend-bar-wrap{background:#f3f4f6;border-radius:3px;flex:1 1;height:5px;overflow:hidden}@keyframes bar-grow{0%{width:0!important}}.cat-legend-bar{animation:bar-grow .8s cubic-bezier(.4,0,.2,1) both;border-radius:3px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.cat-legend-amount{color:#374151;flex-shrink:0;font-size:.78rem;font-weight:700;min-width:72px;text-align:right;white-space:nowrap}.cat-svg-donut{display:none;height:auto;overflow:visible;width:100%}.cat-chart-header-right{align-items:center;display:flex;gap:10px}.cat-legend-toggle{align-items:center;background:rgba(var(--t-p-rgb),.07);border:1.5px solid rgba(var(--t-p-rgb),.15);border-radius:8px;color:var(--t-p);cursor:pointer;display:flex;font-size:.75rem;font-weight:600;gap:5px;padding:5px 10px;transition:background .15s,border-color .15s;white-space:nowrap}.cat-legend-toggle:hover{background:rgba(var(--t-p-rgb),.13);border-color:rgba(var(--t-p-rgb),.25)}.cat-legend-toggle:active{background:rgba(var(--t-p-rgb),.2)}.cat-legend-hidden{display:none!important}@media (max-width:640px){.cat-chart-container{padding:16px 18px}.cat-chart-count,.cat-stats-strip{display:none}.cat-chart-body{gap:16px}.cat-chart-donut-wrap{height:150px;width:150px}.cat-chart-legend,.cat-chart-legend-grid{grid-template-columns:1fr}.cat-legend-amount{font-size:.75rem;min-width:60px}.cat-chart-center-value{font-size:.78rem}.cat-chart-body:has(.cat-legend-hidden){align-items:center;flex-direction:column}.cat-svg-donut-visible{display:block}.cat-chartjs-hidden{display:none!important}.cat-chart-left:has(.cat-svg-donut-visible){width:100%}}.ss-wrapper{min-width:0;position:relative}.ss-wrapper.ss-edit{border-radius:16px;outline:2px dashed rgba(var(--t-p-rgb),.35);outline-offset:2px;padding-top:38px;transition:outline-color .2s}.ss-wrapper.ss-edit:hover{outline-color:rgba(var(--t-p-rgb),.65)}.ss-wrapper.ss-dragging{cursor:grabbing!important;opacity:.75;outline-color:var(--t-p)}.ss-handle{align-items:center;background:linear-gradient(135deg,var(--t-p),var(--t-pb));border-radius:12px 12px 0 0;color:#fff;cursor:grab;display:flex;gap:8px;height:36px;left:2px;padding:0 14px;position:absolute;right:2px;top:0;touch-action:none;-webkit-user-select:none;user-select:none;z-index:4}.ss-handle:active{cursor:grabbing}.ss-handle-dots{flex-shrink:0;font-size:1.1rem;letter-spacing:-1px;opacity:.85}.ss-handle-label{font-size:.8rem;font-weight:700;white-space:nowrap}.ss-handle-hint{font-size:.67rem;margin-left:auto;opacity:.65;white-space:nowrap}.ss-icon-btn{align-items:center;background:#ffffff21;border:1px solid #ffffff40;border-radius:7px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:24px;justify-content:center;margin-left:4px;transition:background .15s;width:28px}.ss-icon-btn:hover{background:#ffffff42}.ss-icon-btn.ss-icon-btn-on{background:#ffffff47;border-color:#ffffff8c}.ss-content{display:contents}@media (min-width:1025px){.ss-wrapper:not(.ss-collapsed){display:flex;flex-direction:column}.ss-wrapper:not(.ss-collapsed) .ss-content{display:flex;flex:1 1;flex-direction:column}.ss-wrapper:not(.ss-collapsed) .ss-content>*{flex:1 1}}.ss-content-hidden{display:none!important}.ss-collapse-header{align-items:center;background:#fff;border:1px solid rgba(var(--t-p-rgb),.09);border-radius:14px;box-shadow:0 1px 6px rgba(var(--t-p-rgb),.07);cursor:pointer;display:flex;gap:10px;justify-content:space-between;padding:10px 14px 10px 16px;transition:background .15s,box-shadow .18s,border-color .15s;width:100%}.ss-collapse-header:hover{background:rgba(var(--t-p-rgb),.2);box-shadow:0 3px 12px rgba(var(--t-p-rgb),.13)}.ss-collapsed .ss-collapse-header{background:#fff;border:1px solid rgba(var(--t-p-rgb),.16);border-left:3.5px solid var(--t-p);border-radius:12px;box-shadow:0 2px 10px rgba(var(--t-p-rgb),.1);padding-left:14px}.ss-collapsed .ss-collapse-header:hover{background:rgba(var(--t-p-rgb),.11);border-color:rgba(var(--t-p-rgb),.28);box-shadow:0 4px 16px rgba(var(--t-p-rgb),.16)}.ss-collapse-label{color:#4b5563;flex:1 1;font-size:.82rem;font-weight:700;letter-spacing:.02em}.ss-collapsed .ss-collapse-label{color:var(--t-p);font-weight:800}.ss-collapsed .ss-collapse-header:after{color:var(--t-p);content:"oculto";font-size:.67rem;font-weight:600;letter-spacing:.06em;opacity:.5;text-transform:uppercase;white-space:nowrap}.ss-collapse-chevron{color:#9ca3af;flex-shrink:0;transition:transform .22s cubic-bezier(.4,0,.2,1),color .15s}.ss-collapsed .ss-collapse-chevron{color:var(--t-p);opacity:.7}.ss-collapse-chevron-closed{transform:rotate(-90deg)}.ss-wrapper:not(.ss-collapsed) .ss-collapse-header{border-bottom:1px solid rgba(var(--t-p-rgb),.07);border-radius:14px 14px 0 0;box-shadow:0 2px 10px rgba(var(--t-p-rgb),.07)}.ss-wrapper:not(.ss-collapsed) .ss-content>*{border-top:none!important;border-top-left-radius:0!important;border-top-right-radius:0!important}.ss-collapse-action{display:none}.ss-collapse-action-wrap{align-items:stretch;border-radius:14px;box-shadow:0 4px 18px rgba(var(--t-p-rgb),.32);display:flex;gap:8px;overflow:hidden;transition:box-shadow .18s,transform .15s}.ss-collapse-action-wrap:hover{box-shadow:0 6px 24px rgba(var(--t-p-rgb),.42)}.ss-collapse-action-wrap:active{transform:translateY(1px)}.ss-collapse-action-wrap .ss-collapse-action{align-items:center;background:linear-gradient(135deg,var(--t-p) 0,var(--t-pb) 100%);border:none;border-radius:0;cursor:pointer;display:flex;flex:1 1;gap:12px;padding:13px 20px;transition:opacity .15s}.ss-collapse-action-wrap:hover .ss-collapse-action{opacity:.95}.ss-collapse-action-icon{align-items:center;background:#ffffff2e;border-radius:9px;display:flex;flex-shrink:0;height:30px;justify-content:center;width:30px}.ss-collapse-action-label{color:#fff;font-size:.9rem;font-weight:700;letter-spacing:.02em}.ss-collapse-scan-btn{align-items:center;background:#ffffff2e;border:none;border-left:1px solid #fff3;color:#fff;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;min-width:52px;padding:0 14px;transition:background .15s}.ss-collapse-scan-btn:hover{background:#ffffff4d}.ss-collapse-scan-btn:active{background:#ffffff61}@media (max-width:768px){.ss-edit,.ss-handle{outline:none;padding-top:0}}@media (max-width:1024px){.ss-collapse-header{border:1px solid rgba(var(--t-p-rgb),.09);border-radius:16px;box-shadow:0 2px 12px rgba(var(--t-p-rgb),.08);padding:13px 18px}.ss-collapse-label{font-size:.9rem}.ss-wrapper:not(.ss-collapsed) .ss-collapse-header{border-radius:16px 16px 0 0}.ss-collapsed .ss-collapse-header{border-left-width:4px;border-radius:16px;box-shadow:0 2px 14px rgba(var(--t-p-rgb),.13);padding-left:15px}.ss-collapsed .ss-collapse-header:after{font-size:.64rem}.ss-collapse-action-wrap{border-radius:16px;box-shadow:0 4px 16px rgba(var(--t-p-rgb),.35)}.ss-collapse-action-wrap .ss-collapse-action{padding:15px 20px}.ss-collapse-action-icon{border-radius:10px;height:32px;width:32px}.ss-collapse-action-label{font-size:.95rem}.ss-collapse-scan-btn{min-width:58px}}.ss-wrapper.ss-edit .cat-chart-container,.ss-wrapper.ss-edit .goals-container,.ss-wrapper.ss-edit .inv-container,.ss-wrapper.ss-edit .pm-container,.ss-wrapper.ss-edit .projections-container,.ss-wrapper.ss-edit .rem-container,.ss-wrapper.ss-edit .tl-container,.ss-wrapper.ss-edit .transaction-form-container{border-top:none;border-top-left-radius:0;border-top-right-radius:0}.mlm-backdrop{animation:mlm-backdrop-in .2s ease;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);background:#0006;inset:0;position:fixed;z-index:300}@keyframes mlm-backdrop-in{0%{opacity:0}to{opacity:1}}.mlm-sheet{animation:mlm-sheet-in .28s cubic-bezier(.32,.72,0,1);background:#fff;border-radius:24px 24px 0 0;bottom:0;left:0;max-height:88vh;overflow-y:auto;padding:12px 20px 32px;position:absolute;right:0}@keyframes mlm-sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mlm-handle-bar{background:#e5e7eb;border-radius:2px;height:4px;margin:0 auto 16px;width:40px}.mlm-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.mlm-title{color:#2d1b69;font-size:1.05rem;font-weight:800;letter-spacing:.01em}.mlm-close{align-items:center;background:#f3f4f6;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;height:32px;justify-content:center;transition:background .15s;width:32px}.mlm-close:hover{background:#e5e7eb}.mlm-subtitle{color:#9ca3af;font-size:.82rem;margin-bottom:20px}.mlm-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin-bottom:24px}.mlm-item{background:#f9f7ff;border:1px solid #a78bca33;border-radius:12px;gap:12px;padding:12px 14px}.mlm-item,.mlm-item-index{align-items:center;display:flex}.mlm-item-index{background:#a78bca;border-radius:50%;color:#fff;flex-shrink:0;font-size:.72rem;font-weight:800;height:22px;justify-content:center;width:22px}.mlm-item-label{color:#2d1b69;flex:1 1;font-size:.9rem;font-weight:600}.mlm-item-arrows{display:flex;flex-direction:column;gap:2px}.mlm-arrow-btn{align-items:center;background:#fff;border:1px solid #a78bca4d;border-radius:7px;color:#a78bca;cursor:pointer;display:flex;height:24px;justify-content:center;transition:background .12s,color .12s,border-color .12s;width:28px}.mlm-arrow-btn:hover:not(:disabled){background:#a78bca;border-color:#a78bca;color:#fff}.mlm-arrow-btn:disabled{cursor:default;opacity:.3}.mlm-footer{display:flex;gap:10px}.mlm-btn-cancel{background:#f3f4f6;border:none;border-radius:14px;color:#6b7280;cursor:pointer;flex:1 1;font-size:.9rem;font-weight:700;padding:13px;transition:background .15s}.mlm-btn-cancel:hover{background:#e5e7eb}.mlm-btn-apply{background:linear-gradient(135deg,var(--t-p) 0,var(--t-pb) 100%);border:none;border-radius:14px;box-shadow:0 4px 14px rgba(var(--t-p-rgb),.35);color:#fff;cursor:pointer;flex:2 1;font-size:.9rem;font-weight:700;padding:13px;transition:opacity .15s,box-shadow .15s}.mlm-btn-apply:hover{box-shadow:0 6px 18px rgba(var(--t-p-rgb),.42);opacity:.92}.tp-root{flex-shrink:0;position:relative}.tp-trigger{border:2px solid #ffffff80;border-radius:50%;cursor:pointer;flex-shrink:0;height:24px;transition:transform .15s,border-color .15s;width:24px}.tp-trigger:hover{border-color:#fff;transform:scale(1.15)}.tp-backdrop{inset:0;position:fixed;z-index:150}.tp-popover{backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);background:#ffffffe6;border:1px solid #fff6;border-radius:14px;box-shadow:0 8px 32px #00000026;min-width:180px;padding:14px 16px;position:absolute;right:0;top:calc(100% + 10px);z-index:200}.tp-popover-label{color:#9ca3af;font-size:.7rem;font-weight:700;letter-spacing:.07em;margin-bottom:10px;text-transform:uppercase}.tp-swatches{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(5,1fr)}.tp-swatch{border:none;border-radius:50%;cursor:pointer;height:32px;transition:transform .12s,box-shadow .12s;width:32px}.tp-swatch:hover{transform:scale(1.12)}.tp-swatch.tp-swatch-active{box-shadow:0 0 0 3px #000000bf;transform:none}
/*# sourceMappingURL=main.c74ac8e7.css.map*/