:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: #1e293b;--bg-card-hover: #334155;--bg-input: #0f172a;--border-color: #334155;--border-light: #475569;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--accent-blue: #3b82f6;--accent-blue-hover: #2563eb;--accent-coral: #f97316;--accent-emerald: #10b981;--accent-emerald-hover: #059669;--accent-purple: #8b5cf6;--expense-red: #ef4444;--income-green: #22c55e;--chart-blue: #60a5fa;--chart-coral: #fb923c;--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 24px rgba(0,0,0,.5);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 16px;--font-heading: "DM Sans", sans-serif;--font-body: "Inter", sans-serif;--transition-fast: .15s ease;--transition-normal: .25s ease;--content-max-width: 1200px;--date-header-text: var(--text-secondary);--date-header-line: var(--accent-blue)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.5;overflow-x:hidden}input,select,textarea{font-size:16px}.expense-card,.kpi-card,.app-nav-item,.clickable-card,.clickable-row{touch-action:manipulation}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--accent-emerald);color:#fff;padding:12px 24px;border:none;border-radius:var(--radius-sm);text-decoration:none;font-family:var(--font-heading);font-weight:600;font-size:.95rem;letter-spacing:.01em;line-height:1.2;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 8px #10b9814d}.btn-primary:hover,.btn-primary:focus{background:var(--accent-emerald-hover);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #10b98166;text-decoration:none}.btn-primary:active{transform:translateY(0);box-shadow:0 2px 8px #10b9814d}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary svg{flex-shrink:0}.app-layout{display:flex;flex-direction:column;min-height:100vh}:root{--nav-height: 62px;--nav-offset: 16px;--safe-area-bottom: env(safe-area-inset-bottom, 0px);--bottom-spacing: calc(var(--nav-height) + var(--nav-offset) + var(--safe-area-bottom))}.app-nav{display:flex;position:sticky;bottom:16px;align-self:center;max-width:calc(100vw - 32px);width:fit-content;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:999px;padding:8px 12px;padding-bottom:max(8px,env(safe-area-inset-bottom,0px));z-index:1050;justify-content:center;align-items:center;gap:0px;box-shadow:0 4px 24px #00000040;margin-bottom:env(safe-area-inset-bottom,0px)}.app-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px clamp(10px,3vw,20px);min-height:44px;color:var(--text-muted);text-decoration:none;font-size:clamp(.55rem,1.8vw,.7rem);font-weight:500;background:none;border:none;border-radius:999px;cursor:pointer;white-space:nowrap;transition:color var(--transition-fast),background var(--transition-fast)}.app-nav-item:hover,.app-nav-item:focus{color:var(--text-primary)}.app-nav-item.active{background:var(--bg-card-hover)}.app-nav-item svg{width:clamp(18px,5vw,22px);height:clamp(18px,5vw,22px);stroke-width:1.75;flex-shrink:0}.app-nav-avatar{width:clamp(20px,5vw,24px);height:clamp(20px,5vw,24px);border-radius:50%;object-fit:cover}.main-content{flex:1;padding:32px;padding-bottom:var(--bottom-spacing);overflow-x:clip}.sticky-bottom-cta{position:sticky;bottom:var(--bottom-spacing);background:var(--bg-card);margin:16px -24px 0;padding:16px 24px;border-top:1px solid var(--border-color);z-index:50}.login-page{overflow-x:hidden}.hero-section{padding:60px 20px;position:relative}.hero-split{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:center;max-width:1100px;margin:0 auto}.hero-section:before{display:none}.hero-left{position:relative;z-index:1}.hero-right{position:relative;z-index:1;display:flex;justify-content:center}.hero-logo{display:flex;flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:24px}.hero-emoji{width:4.5rem;height:4.5rem;object-fit:contain;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 4px 12px rgba(0,0,0,.1))}.hero-emoji .logo-image{width:100%!important;height:100%!important}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.hero-title{font-family:var(--font-heading);font-size:2.5rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.15}.hero-subtitle{font-size:1.1rem;color:var(--text-secondary);margin:20px 0 0;line-height:1.6;max-width:460px}.language-section{padding:20px;background:#ffffff03;border-top:1px solid rgba(255,255,255,.05)}.language-container{max-width:400px;margin:0 auto;text-align:center}.language-selector{display:flex;align-items:center;justify-content:center;gap:12px}.language-label{font-size:.875rem;color:var(--text-secondary)}.language-select{padding:6px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-card);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:border-color .2s ease}.language-select:hover{border-color:var(--accent-color)}.language-select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #3b82f633}.hero-cta{margin-top:32px;scroll-margin-top:100px}.hero-google-btn{font-size:1.1rem;padding:16px 32px;box-shadow:0 4px 12px #3b82f64d}.hero-google-btn:hover{box-shadow:0 6px 16px #3b82f666}.auth-google-btn{margin:24px 0;width:100%;max-width:320px;justify-content:center}.features-section{padding:32px 20px 60px}.features-container{max-width:1200px;margin:0 auto}.features-title{font-family:var(--font-heading);font-size:2rem;text-align:center;color:var(--text-primary);margin-bottom:60px}.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:1200px;margin:0 auto}.features-view-all-link{display:block;text-align:center;margin-top:24px;color:var(--accent-emerald);text-decoration:none;font-weight:600;font-size:.95rem;padding:10px;transition:opacity var(--transition-fast)}.features-view-all-link:hover{opacity:.8}.feature-card{background:var(--bg-card);padding:32px 24px;border-radius:var(--radius-lg);border:1px solid var(--border-color);text-align:center;transition:all var(--transition-normal);box-shadow:var(--shadow-sm)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent-blue)}.feature-icon{font-size:3rem;margin-bottom:16px;display:block}.feature-title{font-family:var(--font-heading);font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:12px}.feature-description{color:var(--text-secondary);line-height:1.6;margin:0}.auth-section{padding:60px 20px 80px}.auth-container{max-width:400px;margin:0 auto}.auth-card{background:var(--bg-card);padding:40px 32px;border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);text-align:center}.auth-title{font-family:var(--font-heading);font-size:1.75rem;color:var(--text-primary);margin-bottom:8px}.auth-subtitle{color:var(--text-secondary);margin-bottom:32px;line-height:1.6}.auth-error{display:flex;align-items:center;justify-content:center;gap:8px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--expense-red);padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:24px;font-size:.875rem}.error-icon{font-size:1rem;flex-shrink:0}.auth-footer{font-size:.75rem;color:var(--text-muted);margin-top:24px;line-height:1.5}.auth-form-container{max-width:320px;margin:0 auto;text-align:center}.auth-form-header{margin-bottom:24px}.auth-icon{font-size:3rem;display:block;margin-bottom:16px}.auth-form-title{font-family:var(--font-heading);font-size:1.5rem;color:var(--text-primary);margin:0 0 8px}.auth-form-subtitle{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.auth-input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-primary);font-size:.95rem;transition:all var(--transition-fast)}.auth-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #3b82f633}.auth-input::placeholder{color:var(--text-muted)}.auth-btn{width:100%;margin-top:12px}.auth-divider{display:flex;align-items:center;margin:20px 0;color:var(--text-muted);font-size:.85rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.auth-divider span{padding:0 16px}.email-display{display:flex;align-items:center;justify-content:space-between;background:var(--bg-tertiary);padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:.9rem;color:var(--text-secondary)}.btn-link{background:none;border:none;color:var(--accent-color);font-size:.9rem;cursor:pointer;padding:8px 0;margin-top:16px;transition:color var(--transition-fast)}.btn-link:hover{color:var(--accent-blue);text-decoration:underline}.btn-link-small{background:none;border:none;color:var(--accent-color);font-size:.8rem;cursor:pointer;padding:0;transition:color var(--transition-fast)}.btn-link-small:hover{text-decoration:underline}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);padding:12px 24px;border-radius:var(--radius-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--accent-color)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.auth-form-container .form-group{margin-bottom:12px;text-align:left}.auth-form-container .auth-error{margin:12px 0}.login-footer{padding:24px;text-align:center;border-top:1px solid var(--border-color);margin-top:48px}.login-footer-swiss{display:inline-flex;align-items:center;gap:8px;color:var(--text-muted);font-size:.9rem}.login-footer-swiss .swiss-flag{font-size:1.1rem}.login-loading{min-height:100vh;display:flex;align-items:center;justify-content:center}@media(max-width:900px){.hero-split{grid-template-columns:1fr;gap:40px;text-align:center}.hero-logo{align-items:center}.hero-subtitle{margin-left:auto;margin-right:auto}.hero-right{order:-1}}@media(max-width:768px){.hero-section{padding:32px 20px}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.features-section{padding:40px 20px}.features-title{font-size:1.5rem;margin-bottom:40px}.features-grid{grid-template-columns:repeat(2,1fr);gap:16px}.feature-card{padding:24px 20px}.feature-icon{font-size:2.5rem}.auth-section{padding:40px 20px 60px}.auth-card{padding:32px 24px}.auth-title{font-size:1.5rem}}@media(max-width:480px){.hero-section{padding:24px 16px}.hero-logo{gap:12px}.hero-emoji{width:3.5rem;height:3.5rem}.hero-title{font-size:1.75rem}.hero-subtitle{font-size:.95rem;margin:16px 0 0}.features-grid{grid-template-columns:1fr;gap:16px}.features-section{padding:30px 16px}.features-title{font-size:1.25rem;margin-bottom:30px}.feature-card{padding:20px 16px}.feature-icon{font-size:2rem;margin-bottom:12px}.feature-title{font-size:1.1rem}.auth-section{padding:30px 16px 50px}.auth-card{padding:24px 20px}.auth-title{font-size:1.25rem}}.google-btn{display:inline-flex;align-items:center;gap:12px;background:var(--accent-blue);color:#fff;border:none;padding:14px 28px;border-radius:var(--radius-sm);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.google-btn:hover{background:var(--accent-blue-hover);transform:translateY(-2px)}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:1rem}h1{font-family:var(--font-heading);font-size:1.75rem;font-weight:700;margin-bottom:24px;color:var(--text-primary)}.group-card{display:block;background:var(--bg-card);padding:20px;border-radius:var(--radius-md);border:1px solid var(--border-color);text-decoration:none;color:var(--text-primary);transition:all var(--transition-fast)}.group-card:hover{border-color:var(--accent-blue);transform:translateY(-2px)}.group-card h3{font-family:var(--font-heading);font-size:1.125rem;margin-bottom:8px}.group-card p{color:var(--text-muted);font-size:.875rem}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:24px}.create-group-form,.add-member-form{display:flex;gap:8px;margin-bottom:24px;align-items:center}.add-member-form button{padding:8px 12px;min-width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}input[type=text],input[type=email],input[type=number],input[type=date],input[type=password],textarea,select{padding:12px 16px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-primary);font-size:.875rem;font-family:var(--font-body);transition:border-color var(--transition-fast)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-blue)}input::placeholder,textarea::placeholder{color:var(--text-muted)}button{padding:12px 20px;background:var(--accent-blue);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}button:hover:not(:disabled){background:var(--accent-blue-hover)}button:disabled{opacity:.5;cursor:not-allowed}.group-detail{max-width:800px;margin:0 auto;width:100%;box-sizing:border-box}.group-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.group-header h1{margin:0}.rename-group-btn{background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:6px 10px;font-size:1rem;cursor:pointer;transition:all var(--transition-fast);color:var(--text-muted);line-height:1}.rename-group-btn:hover{background:var(--bg-card-hover);border-color:var(--accent-blue)}.add-expense-btn{margin-bottom:32px}.members-section{background:var(--bg-card);padding:24px;border-radius:var(--radius-md);border:1px solid var(--border-color);box-sizing:border-box;max-width:100%;margin-top:24px}.members-section h2{font-family:var(--font-heading);font-size:1.125rem;margin-bottom:16px}.members-list{list-style:none}.members-list li{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-color)}.members-list li:last-child{border-bottom:none}.members-list button{background:transparent;color:var(--text-muted);padding:6px 12px;font-size:.75rem;border:1px solid var(--border-color)}.members-list button:hover{background:var(--expense-red);border-color:var(--expense-red);color:#fff}.members-list .member-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.members-list .badge{font-size:.65rem;padding:2px 8px;border-radius:12px;font-weight:500;text-transform:uppercase;letter-spacing:.03em}.members-list .badge.you{background:#3b82f626;color:var(--accent-blue)}.members-list .badge.owner{background:#f59e0b26;color:#f59e0b}.members-list li.owner{background:#f59e0b0d;margin:0 -16px;padding:12px 16px;border-radius:var(--radius-sm)}.add-expense-page{max-width:600px;margin:0 auto;width:100%;box-sizing:border-box}.expense-form{background:var(--bg-card);padding:32px;border-radius:var(--radius-md);border:1px solid var(--border-color)}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px;font-weight:500}.form-group input,.form-group textarea,.form-group select{width:100%}.form-group textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-actions{display:flex;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid var(--border-color)}.form-actions button:first-child{background:transparent;color:var(--text-muted);border:1px solid var(--border-color)}.form-actions button:first-child:hover{background:var(--bg-card-hover);color:var(--text-primary)}.expense-form-compact{padding:24px}.expense-form-compact .form-group{margin-bottom:16px}.form-group-grow{flex:1.5;min-width:0}.form-group-shrink{flex:1;min-width:90px;max-width:140px}.form-group-shrink .custom-select-trigger{padding:12px 16px;font-size:.875rem}.expense-form-compact .form-row{display:flex;gap:12px}@media(max-width:480px){.expense-form-compact .form-row{flex-direction:row}.expense-form-compact .form-group-grow{flex:1.3}.expense-form-compact .form-group-shrink{flex:1;min-width:90px;max-width:130px}}.form-group-collapsible{margin-bottom:80px}.collapsible-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px;font-weight:500}.collapsed-field{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);text-align:left}.collapsed-field:hover{background:var(--bg-card-hover);border-color:var(--accent-blue)}.collapsed-field.read-only{cursor:default;background:var(--bg-card)}.collapsed-field.read-only:hover{border-color:var(--border-color)}.collapsed-field-label{color:var(--text-muted);font-size:.875rem}.collapsed-field-value{flex:1;color:var(--text-primary);font-weight:500}.collapsed-field-edit{color:var(--accent-blue);font-size:.8rem}.split-section-expanded{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:16px}.split-section-expanded .form-group{margin-bottom:0}.split-section-expanded .form-group label{margin-bottom:4px}.split-section-expanded .form-group+.form-group{margin-top:20px}.collapse-btn{display:block;width:100%;margin-top:12px;padding:8px;background:transparent;border:1px dashed var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.8rem;cursor:pointer}.collapse-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.add-notes-btn{display:block;width:100%;padding:12px 16px;background:transparent;border:1px dashed var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.875rem;cursor:pointer;text-align:left}.add-notes-btn:hover{background:var(--bg-card-hover);border-color:var(--accent-blue);color:var(--text-primary)}.btn-secondary{background:transparent;color:var(--text-muted);border:1px solid var(--border-color);padding:12px 24px;border-radius:var(--radius-sm);cursor:pointer}.btn-secondary:hover{background:var(--bg-card-hover);color:var(--text-primary)}.dashboard-page{max-width:var(--content-max-width);margin:0 auto;width:100%;box-sizing:border-box}.view-all-expenses{margin-top:24px;text-align:center}.view-all-expenses-link{display:inline-flex;align-items:center;gap:8px;color:var(--accent-blue);text-decoration:none;font-weight:500;padding:12px 24px;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:#3b82f61a}.view-all-expenses-link:hover{background:#3b82f633;color:var(--text-primary)}.expenses-page{max-width:var(--content-max-width);margin:0 auto;width:100%;box-sizing:border-box}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.kpi-card{background:var(--bg-card);border-radius:var(--radius-md);padding:20px;border:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px}.kpi-value{font-family:var(--font-heading);font-size:1.75rem;font-weight:700;order:-1}.kpi-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:500}.kpi-value.coral{color:var(--accent-coral)}.kpi-value.blue{color:var(--accent-blue)}.kpi-value.income-green{color:var(--income-green)}.kpi-value.expense-red{color:var(--expense-red)}.kpi-value.emerald{color:var(--accent-emerald)}.kpi-value.purple{color:var(--accent-purple)}.kpi-sub{font-size:.8rem;color:var(--text-muted)}.kpi-balance-card{display:flex;flex-direction:column}.kpi-balance-content{flex:1;display:flex;flex-direction:column;gap:8px;margin-top:4px;min-height:60px}.balance-line{display:flex;flex-direction:column;gap:2px}.balance-line .balance-amount{font-family:var(--font-heading);font-size:1.25rem;font-weight:700}.balance-line.debit .balance-amount{color:var(--expense-red)}.balance-line.credit .balance-amount{color:var(--income-green)}.balance-line.neutral .balance-amount{color:var(--text-muted)}.balance-line .balance-detail{font-size:.75rem;color:var(--text-muted)}.charts-container{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:24px;max-width:100%;overflow:hidden}.chart-box{background:var(--bg-card);border-radius:var(--radius-md);padding:20px;border:1px solid var(--border-color);overflow:hidden;max-width:100%;box-sizing:border-box}.chart-title{font-family:var(--font-heading);font-size:1rem;margin-bottom:16px;font-weight:600}.monthly-trends-section{margin-bottom:24px}.monthly-trends-subtitle{font-size:.75rem;color:var(--text-muted);font-weight:400;margin-top:-12px;margin-bottom:12px}.monthly-trends-loading{display:flex;justify-content:center;padding:24px 0}.monthly-trends-list{display:flex;flex-direction:column}.monthly-trends-row{display:flex;align-items:center;gap:12px;padding:10px 4px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background var(--transition-normal);flex-wrap:nowrap;overflow:hidden;min-height:40px}.monthly-trends-row:hover{background:var(--bg-hover)}.monthly-trends-item:last-child .monthly-trends-row{border-bottom:none}.monthly-trends-row .chevron-icon{color:var(--text-muted);transition:transform var(--transition-normal);flex-shrink:0}.monthly-trends-row .chevron-icon.rotated{transform:rotate(180deg)}.monthly-trends-month{font-weight:600;min-width:130px;text-transform:capitalize;font-size:.95rem;flex-shrink:0}.monthly-trends-total{font-weight:500;white-space:nowrap;flex-shrink:0}.monthly-trends-categories{display:flex;align-items:center;gap:16px;margin-left:auto;flex-wrap:nowrap;overflow:hidden;min-width:0}.monthly-trends-cat-group{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;flex-shrink:0}.monthly-trends-categories .cat-3{display:none}.monthly-trends-no-data{font-size:.8rem;color:var(--text-muted);margin-left:auto;flex-shrink:0}.variation-badge{display:inline-flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;white-space:nowrap;padding:1px 4px;border-radius:3px;line-height:1.3;width:fit-content}.variation-positive{color:#f87171;background:#f871711f}.variation-negative{color:#34d399;background:#34d3991f}.variation-neutral{color:var(--text-muted);background:#94a3b81a}.category-chip{display:inline-flex;align-items:center;gap:3px;font-size:.85rem;white-space:nowrap}.category-chip-icon{font-size:.9rem}.category-chip-name{color:var(--text-secondary)}.monthly-trends-expanded{padding:8px 0 8px 32px;display:grid;grid-template-columns:28px 1fr auto auto;gap:0 8px;align-items:center;border-bottom:1px solid var(--border-color);max-width:600px}.monthly-trends-item:last-child .monthly-trends-expanded{border-bottom:none}.monthly-trends-cat-row{display:contents;font-size:.9rem}.monthly-trends-cat-row>*{padding:5px 4px;border-radius:4px;transition:background .12s ease}.monthly-trends-cat-row:hover>*{background:#ffffff0a}.monthly-trends-cat-icon{font-size:1rem;text-align:center}.monthly-trends-cat-name{color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.monthly-trends-cat-amount{font-weight:500;text-align:right;white-space:nowrap}.monthly-trends-cat-row .variation-badge{justify-self:end}.filters-section{background:var(--bg-card);border-radius:var(--radius-md);padding:20px;border:1px solid var(--border-color);margin-bottom:24px;box-sizing:border-box;max-width:100%;position:sticky;top:0;z-index:100}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:500}.filter-group select,.filter-group input{min-width:180px}.reset-filters-btn{background:var(--bg-card-hover);padding:8px 16px;font-size:.85rem;white-space:nowrap}.filter-actions-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.multiselect-dropdown{position:relative;min-width:180px}.dropdown-trigger{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.dropdown-trigger:hover{border-color:var(--border-light)}.dropdown-trigger.open{border-color:var(--accent-blue)}.dropdown-trigger.has-selection .trigger-value{color:var(--accent-blue);font-weight:500}.trigger-label{color:var(--text-muted);font-size:.85rem}.trigger-value{flex:1;text-align:left}.trigger-arrow{flex-shrink:0;transition:transform var(--transition-fast)}.dropdown-trigger.open .trigger-arrow{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:220px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:1000;max-height:320px;display:flex;flex-direction:column}.dropdown-search{padding:8px;border-bottom:1px solid var(--border-color)}.dropdown-search input{width:100%;padding:8px 12px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem}.dropdown-search input:focus{outline:none;border-color:var(--accent-blue)}.dropdown-actions{display:flex;gap:8px;padding:8px;border-bottom:1px solid var(--border-color)}.dropdown-actions button{flex:1;padding:6px 12px;background:var(--bg-card-hover);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.dropdown-actions button:hover{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.dropdown-options{overflow-y:auto;max-height:220px;padding:4px 0}.dropdown-option{display:flex;align-items:center;gap:10px;padding:10px 12px;min-height:44px;cursor:pointer;transition:background var(--transition-fast)}.dropdown-option:hover{background:var(--bg-card-hover)}.dropdown-option input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-blue);cursor:pointer}.option-label{display:flex;align-items:center;gap:8px;color:var(--text-primary);font-size:.9rem}.option-icon{font-size:1rem}.dropdown-empty{padding:16px;text-align:center;color:var(--text-muted);font-size:.85rem}.filter-dropdowns-row{display:flex;gap:12px;flex-wrap:wrap}@media(max-width:768px){.filter-dropdowns-row{flex-direction:column}.multiselect-dropdown{width:100%}.multiselect-dropdown.mobile .dropdown-trigger{min-height:48px;font-size:1rem}.dropdown-menu{position:fixed;top:auto;bottom:var(--bottom-spacing);left:0;right:0;border-radius:var(--radius-md) var(--radius-md) 0 0;max-height:50vh;z-index:1060}.multiselect-dropdown.mobile .dropdown-option{min-height:48px;padding:12px 16px}.multiselect-dropdown.mobile .dropdown-option input[type=checkbox]{width:20px;height:20px}.multiselect-dropdown.mobile .dropdown-actions button{min-height:44px;padding:10px 16px}}.empty-state{text-align:center;padding:48px;color:var(--text-muted)}.expense-table-section{background:var(--bg-card);border-radius:var(--radius-md);padding:24px;border:1px solid var(--border-color);margin-top:24px;box-sizing:border-box;max-width:100%}.table-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:16px}.table-header.compact{margin-bottom:12px;flex-wrap:nowrap}.table-header-content{display:flex;align-items:center;gap:8px;width:100%;justify-content:flex-start;flex-wrap:nowrap;min-width:0}.table-header-left{display:flex;flex-direction:column;gap:4px}.table-header-right{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.section-title{font-family:var(--font-heading);font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0;line-height:1.2}.stats{color:var(--text-muted);font-size:.875rem}.expense-pagination{display:flex;align-items:center;gap:8px;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:6px 12px;background:var(--bg-card)}.expense-pagination.inline{border:none;padding:0;background:transparent;margin-left:8px}.expense-pagination.bottom{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color);justify-content:center;margin-bottom:0;padding-bottom:0}.pagination-nav-btn{background:transparent;color:var(--text-secondary);border:none;padding:4px 8px;font-size:.9rem;font-weight:500;cursor:pointer;border-radius:var(--radius-xs);min-width:28px;display:flex;align-items:center;justify-content:center}.pagination-nav-btn:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text-primary)}.pagination-nav-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-page-info{color:var(--text-primary);font-size:.875rem;font-weight:500;white-space:nowrap}.pagination-page-info-full{display:none}.pagination-page-info-short{display:inline}@media(min-width:720px){.pagination-page-info-full{display:inline}.pagination-page-info-short{display:none}}.pagination-nav-btn.compact{padding:4px 6px;font-size:.9rem;min-width:24px;height:24px}.pagination-page-info.compact{font-size:.8rem;margin:0 4px}.page-size-menu-container{position:relative;margin-left:auto}.page-size-menu-trigger{background:transparent;border:none;color:var(--text-muted);font-size:1.2rem;padding:4px 8px;border-radius:var(--radius-xs);cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:24px;height:24px}.page-size-menu-trigger:hover{background:var(--bg-card-hover);color:var(--text-primary)}.page-size-menu{position:absolute;top:100%;right:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:0 4px 12px #00000026;z-index:100;min-width:120px;padding:4px 0;margin-top:4px}.page-size-option{display:block;width:100%;padding:8px 16px;background:none;border:none;text-align:left;font-size:.875rem;color:var(--text-primary);cursor:pointer}.page-size-option:hover{background:var(--bg-card-hover)}.page-size-option.active{background:var(--accent-blue-light);color:var(--accent-blue);font-weight:500}.download-btn{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);padding:8px 16px;font-size:.875rem}.download-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.table-scroll{overflow-x:auto;display:none}table{width:100%;border-collapse:collapse;table-layout:fixed}th,td{padding:14px 12px;text-align:left;border-bottom:1px solid var(--border-color);font-size:.875rem;vertical-align:middle;overflow:hidden;text-overflow:ellipsis}.expense-table-section table th:nth-child(1),.expense-table-section table td:nth-child(1){width:110px;white-space:nowrap}.expense-table-section table th:nth-child(2),.expense-table-section table td:nth-child(2){width:auto;min-width:150px}.expense-table-section table th:nth-child(3),.expense-table-section table td:nth-child(3){width:150px;text-align:right}.expense-table-section table th:nth-child(4),.expense-table-section table td:nth-child(4){width:140px}.expense-table-section table th:nth-child(5),.expense-table-section table td:nth-child(5){width:70px;text-align:center}th{color:var(--text-muted);font-weight:500;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}td{color:var(--text-secondary)}td.cost{color:var(--expense-red);font-weight:600;font-family:var(--font-heading)}.cost-cell{text-align:right;white-space:nowrap;vertical-align:top}.cost-cell .cost{color:var(--text-primary);font-weight:600;font-family:var(--font-heading);line-height:1.3;text-align:right}.user-balance{font-size:.75rem;font-weight:500;margin-top:2px;display:flex;justify-content:flex-end;align-items:baseline;gap:4px}.user-balance .balance-label{opacity:.85}.user-balance .balance-amount{font-weight:500}.user-balance.credit{color:var(--income-green)}.user-balance.debit{color:var(--expense-red)}.mobile-cards{display:block}.date-group-header{display:flex;align-items:center;margin:16px 0 8px;gap:12px;font-size:.7rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.date-group-header:before,.date-group-header:after{content:"";flex:1;height:1px;background:var(--border-color)}.date-group-header span{white-space:nowrap}.mobile-cards>.date-group-header:first-child{margin-top:0}.expense-card{display:flex;gap:10px;align-items:center;background:transparent;padding:8px 4px;margin:0;border:none}.expense-card-category{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;width:58px}.expense-card-icon{font-size:2.5rem;line-height:1;display:flex;align-items:center;justify-content:center;width:58px;height:58px;background:var(--border-color);border-radius:var(--radius-sm)}.expense-card-category-name{display:none;font-size:.7rem;color:var(--text-muted);text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(min-width:480px){.expense-card-category-name{display:block}}.expense-card-desc{font-weight:500;font-size:.9rem;color:var(--text-primary);flex:1;min-width:0;word-break:break-word;line-height:1.3}.expense-card-amounts{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.expense-card-cost{font-weight:600;font-size:.9rem;color:var(--text-primary);white-space:nowrap}.expense-card-balance{font-size:.75rem}.expense-card-balance.user-balance{flex-direction:column;align-items:flex-end;gap:0}.expense-card-balance .balance-label{font-size:.65rem;line-height:1.1}.expense-card-balance .balance-amount{font-size:.65rem;font-weight:600;line-height:1.1;margin-top:-0px}.expense-card-actions{display:flex;flex-direction:column;gap:0;flex-shrink:0}.edit-btn-mobile,.delete-btn-mobile{background:transparent;border:none;padding:4px;font-size:.9rem;cursor:pointer;min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7;transition:opacity .15s}.edit-btn-mobile:hover,.delete-btn-mobile:hover{opacity:1}.expense-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:6px}.expense-card-amounts{display:flex;flex-direction:column;align-items:flex-end;text-align:right;flex-shrink:0}.expense-card-meta{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--text-muted);min-height:28px}.expense-card-meta>span:first-child{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.expense-pagination.bottom{gap:12px;margin-top:16px;padding-top:16px}@media(max-width:768px){.expense-pagination.bottom{position:sticky;bottom:var(--bottom-spacing);background:var(--bg-card);margin:0 -24px -24px;padding:16px 24px;z-index:50;border-top:1px solid var(--border-color)}}.pagination-btn{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);padding:8px 16px;font-size:.875rem}.pagination-btn.compact{padding:6px 12px;font-size:.8rem}.pagination-btn:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text-primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{color:var(--text-muted);font-size:.875rem}.clickable-row:hover{background:var(--bg-card-hover)}.clickable-card{cursor:pointer;border-radius:var(--radius-sm);-webkit-tap-highlight-color:transparent}@media(hover:hover)and (pointer:fine){.clickable-card{transition:background var(--transition-fast)}.clickable-card:hover{background:#ffffff0a}}.expense-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;padding-bottom:calc(20px + var(--bottom-spacing));-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.expense-modal{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;border:1px solid var(--border-color);box-shadow:var(--shadow-lg)}.expense-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color);position:sticky;top:0;background:var(--bg-card);z-index:1}.expense-modal-header h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.modal-close-btn{background:transparent;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.expense-modal-body{padding:24px}.expense-detail-section{margin-bottom:24px}.expense-detail-section:last-child{margin-bottom:0}.expense-detail-section h4{font-family:var(--font-heading);font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.expense-detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-color)}.expense-detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-muted);font-size:.9rem}.detail-value{color:var(--text-primary);font-weight:500;font-size:.9rem}.detail-value.expense-amount{font-size:1.1rem;font-weight:700;color:var(--accent-blue)}.payer-info{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.payer-name{font-weight:500;color:var(--text-primary)}.payer-amount{font-weight:700;font-size:1rem}.payer-amount.positive{color:var(--accent-emerald)}.payer-amount.neutral{color:var(--text-secondary)}.participants-list{display:flex;flex-direction:column;gap:8px}.participant-row-stacked{flex-direction:row;align-items:center;gap:12px;flex-wrap:wrap}.participant-payments{display:inline-flex;gap:10px;flex-wrap:wrap}.participant-row{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.participant-name{color:var(--text-primary);font-size:.9rem}.participant-amount{font-weight:600;font-size:.9rem}.participant-amount.negative{color:var(--expense-red)}.participant-amount.positive{color:var(--income-green)}.participant-amount.neutral{color:var(--text-secondary)}.balance-summary{display:flex;flex-direction:column;gap:8px}.balance-row{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-radius:var(--radius-sm);font-size:.8rem}.balance-row.positive{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--accent-emerald)}.balance-row.negative{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--expense-red)}.participant-card{padding:12px 16px;background:var(--bg-primary);border-radius:var(--radius-sm);border-left:3px solid var(--border-color)}.participant-card.positive{border-left-color:var(--accent-emerald);background:#10b9810d}.participant-card.negative{border-left-color:var(--expense-red);background:#ef44440d}.participant-card.neutral{border-left-color:var(--text-muted)}.participant-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;gap:12px}.participant-card-header .participant-name{font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.participant-card-header .participant-balance{flex-shrink:0}.participant-balance{font-weight:600;font-size:.9rem}.participant-balance.positive{color:var(--accent-emerald)}.participant-balance.negative{color:var(--expense-red)}.participant-balance.neutral{color:var(--text-muted)}.participant-card-details{display:flex;gap:6px;font-size:.8rem;color:var(--text-muted)}.participant-card-details .detail-separator{opacity:.5}.expense-notes{color:var(--text-secondary);font-size:.9rem;line-height:1.6;background:var(--bg-primary);padding:12px 16px;border-radius:var(--radius-sm);border:1px solid var(--border-color)}.expense-meta{display:flex;gap:16px;font-size:.8rem;color:var(--text-muted);padding-top:16px;border-top:1px solid var(--border-color)}@media(max-width:768px){.expense-modal-overlay{padding:16px;padding-top:max(16px,env(safe-area-inset-top,16px));padding-bottom:calc(16px + var(--bottom-spacing))}.expense-modal{max-width:100%;max-height:calc(100% - 32px);width:100%}.expense-modal-header{padding:16px 20px}.expense-modal-body{padding:20px}}.split-editor-wrapper{margin-top:20px}.split-editor-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px;font-weight:500}.split-editor{max-width:100%;box-sizing:border-box}.split-editor.empty{text-align:center;padding:24px}.split-empty-message{color:var(--text-muted)}.split-list{display:flex;flex-direction:column;gap:8px}.split-row{display:flex;flex-direction:row;align-items:stretch;gap:12px;padding:4px 0;max-width:100%;box-sizing:border-box}.split-row.excluded{opacity:.5}.split-participant{display:flex;flex-direction:column;justify-content:center;gap:4px;flex:0 0 40%;min-width:0;padding:7px 12px;background:var(--border-color);border-radius:var(--radius-sm)}.split-participant-top{display:flex;align-items:center;gap:8px;min-width:0}.split-participant.split-participant-full{flex:1 1 100%;flex-direction:row;align-items:center;justify-content:space-between;gap:12px}.split-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-blue)}.split-name{font-size:.9rem;color:var(--text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.split-input-group{display:flex;align-items:stretch;flex:1;min-width:0}.split-input-wrapper{display:flex;align-items:center;justify-content:center;gap:6px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:0 12px;min-width:0;box-sizing:border-box}.split-input-wrapper.split-input-wide,.split-input-wrapper.split-input-narrow{flex:1}@media(min-width:481px){.split-input{padding:12px 6px;font-size:1rem}.split-currency,.split-suffix{font-size:.95rem}}.split-input-wrapper:focus-within{border-color:var(--accent-blue)}.split-currency,.split-suffix{font-size:.85rem;color:var(--text-muted);flex-shrink:0}.split-input{flex:1;padding:10px 4px;border:none!important;background:transparent!important;text-align:right;font-size:.9rem;min-width:0}.split-input:focus{outline:none}.split-calculated{font-family:var(--font-heading);font-size:.7rem;font-weight:600;color:var(--text-muted)}.split-validation{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-top:12px;padding-top:10px;border-top:1px solid var(--border-color);font-size:.75rem;color:var(--text-muted)}.split-validation.valid{color:var(--accent-emerald)}.split-validation.invalid .split-validation-amount{color:var(--expense-red)}.split-validation-amount{font-family:var(--font-heading);font-weight:600}.split-validation-percent{color:var(--text-muted)}.split-validation-warning{margin-left:auto;color:var(--accent-coral);font-weight:500;font-size:.7rem}@media(max-width:480px){.split-validation-warning{width:100%;margin-left:0;margin-top:4px}}.payer-editor-wrapper{margin-top:0}.payer-editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.payer-editor-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:500}.payer-mode-toggle{background:transparent;border:1px solid var(--accent-blue);color:var(--accent-blue);font-size:.75rem;padding:4px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.payer-mode-toggle:hover{background:var(--accent-blue);color:#fff}.payer-editor-header-simple{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.payer-more-menu-container{position:relative}.payer-more-menu-trigger{background:transparent;border:none;color:var(--text-muted);font-size:1.2rem;padding:4px 8px;border-radius:var(--radius-xs);cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:24px;height:24px}.payer-more-menu-trigger:hover{background:var(--bg-card-hover);color:var(--text-primary)}.payer-more-menu{position:absolute;top:100%;right:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:0 4px 12px #00000026;z-index:100;min-width:160px;padding:4px 0;margin-top:4px}.payer-more-menu button{display:block;width:100%;padding:8px 16px;background:none;border:none;text-align:left;font-size:.875rem;color:var(--text-primary);cursor:pointer}.payer-more-menu button:hover{background:var(--bg-card-hover)}.payer-select{width:100%;padding:12px 14px;font-size:1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-primary)}.payer-select:focus{border-color:var(--accent-blue);outline:none}.payer-editor{background:var(--bg-primary);border-radius:var(--radius-sm);padding:12px;border:1px solid var(--border-color);overflow:hidden;max-width:100%;box-sizing:border-box}.payer-list{display:flex;flex-direction:column;gap:8px}.payer-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-color);transition:all var(--transition-fast)}.payer-row.zero-amount{opacity:.6;background:var(--bg-primary)}.payer-participant{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.payer-name{font-size:.9rem;color:var(--text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.payer-input-group{display:flex;align-items:center;gap:10px;flex-shrink:0}.payer-input-wrapper{display:flex;align-items:center;gap:6px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:0 12px;min-width:100px}.payer-input-wrapper:focus-within{border-color:var(--accent-blue)}.payer-currency{font-size:.85rem;color:var(--text-muted);flex-shrink:0}.payer-input{flex:1;padding:10px 4px;border:none!important;background:transparent!important;text-align:right;font-size:.9rem;min-width:60px;color:var(--text-primary)}.payer-input:focus{outline:none}.payer-split-equally-btn{display:block;width:100%;margin-top:8px;padding:8px 12px;background:transparent;border:1px dashed var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.payer-split-equally-btn:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.payer-validation{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-top:12px;padding-top:10px;border-top:1px solid var(--border-color);font-size:.75rem;color:var(--text-muted)}.payer-validation.valid{color:var(--accent-emerald)}.payer-validation.invalid .payer-validation-amount{color:var(--expense-red)}.payer-validation-amount{font-family:var(--font-heading);font-weight:600}.payer-validation-warning{margin-left:auto;color:var(--accent-coral);font-weight:500;font-size:.7rem}@media(max-width:480px){.payer-row{flex-direction:column;align-items:stretch;gap:8px}.payer-input-wrapper{flex:1;max-width:100%}.payer-validation-warning{width:100%;margin-left:0;margin-top:4px}}.group-name-label{color:var(--text-muted);font-size:.875rem;margin-bottom:20px}.group-name-label strong{color:var(--text-primary)}.group-selector{background:var(--bg-card);padding:24px;border-radius:var(--radius-md);border:1px solid var(--border-color);margin-bottom:24px}.group-selector label{display:block;font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:12px}.group-selector .group-select{width:100%;padding:14px 16px;font-size:1rem;border:2px solid var(--accent-blue);background:var(--bg-input)}.group-selector .group-select:focus{border-color:var(--accent-emerald);outline:none}.settings-page{max-width:700px;margin:0 auto;width:100%;box-sizing:border-box}.settings-section{background:var(--bg-card);padding:32px;border-radius:var(--radius-md);border:1px solid var(--border-color);margin-bottom:24px;box-sizing:border-box;max-width:100%}.settings-section h2{font-family:var(--font-heading);font-size:1.25rem;margin-bottom:12px;color:var(--text-primary)}.settings-desc{color:var(--text-muted);font-size:.875rem;margin-bottom:24px;line-height:1.6}.settings-form{display:flex;flex-direction:column;gap:20px}.settings-form .form-group{margin-bottom:0}.account-readonly{padding:12px 16px;border:1px dashed var(--border-color);border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:.875rem;font-family:var(--font-body);min-height:44px;display:flex;align-items:center;gap:8px;cursor:default;-webkit-user-select:text;user-select:text;position:relative}.account-readonly:before{content:"🔒";font-size:.75rem;opacity:.6;flex-shrink:0}.form-help{display:block;font-size:.75rem;color:var(--text-muted);margin-top:8px}.form-help a{color:var(--accent-blue);text-decoration:none}.form-help a:hover{text-decoration:underline}.settings-message{padding:12px 16px;border-radius:var(--radius-sm);font-size:.875rem;margin-top:8px}.settings-message.success{background:#10b98126;color:var(--accent-emerald);border:1px solid var(--accent-emerald)}.settings-message.error{background:#ef444426;color:var(--expense-red);border:1px solid var(--expense-red)}.group-settings-section,.expense-defaults-section,.splitwise-mapping-section,.integrations-section,.danger-zone-section{background:var(--bg-card);padding:24px;border-radius:var(--radius-md);border:1px solid var(--border-color);margin-top:24px;box-sizing:border-box;max-width:100%}.group-settings-section h2,.expense-defaults-section h2,.splitwise-mapping-section h2,.integrations-section h2,.danger-zone-section h2{font-family:var(--font-heading);font-size:1.125rem;margin-bottom:16px}.section-desc{font-size:.875rem;color:var(--text-muted);margin-bottom:16px}.defaults-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.defaults-grid .settings-row{border-bottom:none;padding:0;flex-direction:column;align-items:flex-start;gap:6px}.defaults-grid .settings-row select{width:100%}.settings-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-color)}.settings-row:last-child{border-bottom:none;padding-bottom:0}.settings-row label{flex:1;font-size:.875rem;color:var(--text-secondary)}.settings-row select{min-width:200px}.integration-block{padding:16px 0;border-bottom:1px solid var(--border-color)}.integration-block:last-child{border-bottom:none;padding-bottom:0}.integration-block h3{font-size:.95rem;font-weight:500;margin-bottom:8px;color:var(--text-primary)}.integration-desc{color:var(--text-muted);font-size:.875rem;margin-bottom:16px;line-height:1.5}.danger-zone-section{background:#ef444414;border:1px solid rgba(239,68,68,.3)}.danger-zone-section h2{color:var(--expense-red)}.danger-zone-section p{font-size:.875rem;color:var(--text-muted);margin-bottom:16px;line-height:1.5}.danger-zone{margin-top:24px;padding:20px;background:#ef444414;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm)}.danger-zone h3{font-family:var(--font-heading);font-size:.9rem;color:var(--expense-red);margin-bottom:8px}.danger-zone p{font-size:.8rem;color:var(--text-muted);margin-bottom:16px;line-height:1.5}.delete-group-btn{background:var(--expense-red);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-sm);font-weight:500;cursor:pointer;transition:background var(--transition-fast),opacity var(--transition-fast)}.delete-group-btn:hover:not(:disabled){background:#dc2626}.delete-group-btn:disabled{opacity:.6;cursor:not-allowed}.delete-confirm-panel{background:#ef444414;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);padding:20px}.delete-confirm-panel .delete-warning{color:var(--text-primary);font-size:.9rem;line-height:1.6;margin-bottom:20px}.delete-confirm-actions{display:flex;gap:12px;flex-wrap:wrap}.delete-confirm-actions .btn-secondary,.delete-confirm-actions .delete-group-btn{flex:1;min-width:120px}@media(max-width:480px){.delete-confirm-actions{flex-direction:column}.delete-confirm-actions button{width:100%}}.filters-section{transition:box-shadow var(--transition-normal),border-radius var(--transition-normal)}.filters-section.is-stuck{box-shadow:0 4px 20px #00000080;border-radius:0 0 var(--radius-md) var(--radius-md)}.filters-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;cursor:pointer;transition:background var(--transition-fast)}.filters-header:hover{background:var(--bg-card-hover)}.filters-toggle{display:flex;align-items:center;gap:8px;font-family:var(--font-heading);font-weight:600;color:var(--text-primary)}.filters-toggle svg{transition:transform var(--transition-normal);flex-shrink:0}.filters-section.collapsed .filters-toggle svg{transform:rotate(-90deg)}.filter-summary{font-size:.8rem;color:var(--text-muted)}.filters-content{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end;max-height:500px;transition:max-height var(--transition-normal),padding var(--transition-normal),opacity var(--transition-normal);overflow:visible;box-sizing:border-box}.filters-section.collapsed .filters-content{max-height:0;padding-top:0;padding-bottom:0;overflow:hidden;opacity:0}@media(max-width:1200px){.monthly-trends-categories .monthly-trends-cat-group.saved-on{display:none}}@media(max-width:1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.expense-table-section table th:nth-child(1),.expense-table-section table td:nth-child(1){width:90px}.expense-table-section table th:nth-child(3),.expense-table-section table td:nth-child(3){width:140px}.expense-table-section table th:nth-child(4),.expense-table-section table td:nth-child(4){width:120px}.charts-container{grid-template-columns:1fr}.monthly-trends-categories .cat-2,.monthly-trends-categories .monthly-trends-cat-group.saved-on{display:none}.monthly-trends-month{min-width:110px;font-size:.9rem}}@media(max-width:768px){.main-content{padding:16px;padding-bottom:var(--bottom-spacing);overflow-x:hidden}.expenses-page,.group-detail,.settings-page,.dashboard-page,.add-expense-page{padding-left:0;padding-right:0;margin:0 auto}.form-row{grid-template-columns:1fr}.add-member-form{gap:6px}.add-member-form input[type=email]{flex:1;min-width:0}.add-member-form button{min-width:32px;height:32px;padding:6px 8px;font-size:16px}.kpi-grid{grid-template-columns:1fr 1fr}.filters-header{display:flex}.filters-section{padding:0}.filters-content{padding:0 20px 20px;flex-direction:column;align-items:stretch}.filter-group{width:100%}.filter-group select,.filter-group input{width:100%;min-width:unset;min-height:44px}.reset-filters-btn{width:100%;min-height:44px;justify-content:center}.table-header.compact{flex-direction:row;align-items:center;flex-wrap:nowrap}.table-header-content{flex-wrap:nowrap;gap:6px;min-width:0}.expense-pagination.inline{order:2;flex-shrink:0}.page-size-menu-container{order:3;flex-shrink:0}.stats{text-align:left}@media(max-width:640px){.table-header.compact{flex-direction:row;align-items:center;flex-wrap:nowrap}.table-header-content{flex-direction:row;align-items:center;gap:6px;flex-wrap:nowrap;min-width:0}.expense-pagination.inline{order:2;margin-left:6px;flex-shrink:0}.page-size-menu-container{order:3;align-self:center;flex-shrink:0}}.monthly-trends-categories .monthly-trends-cat-group.spent-more{display:none}}@media(max-width:480px){.main-content{padding:12px;padding-bottom:var(--bottom-spacing)}.kpi-grid{grid-template-columns:1fr 1fr;gap:12px}.kpi-card{padding:16px}.kpi-value{font-size:1.4rem}.kpi-label{font-size:.7rem}.monthly-trends-row{gap:8px;padding:8px 2px}.monthly-trends-month{min-width:unset;font-size:.85rem}.monthly-trends-total{font-size:.9rem}.monthly-trends-categories{display:none}.monthly-trends-expanded{padding-left:20px}.monthly-trends-cat-row{font-size:.85rem}.filters-section.mobile-default-collapsed .filters-content{max-height:0;padding-top:0;padding-bottom:0;overflow:hidden;opacity:0}.filters-section.mobile-default-collapsed .filters-toggle svg{transform:rotate(-90deg)}.download-btn{width:100%;justify-content:center}.pagination-nav-btn{min-height:44px;padding:12px 16px}.expense-card{padding:2px 3px}.expense-card{gap:8px}.date-cell{text-align:center;white-space:nowrap;width:90px}.date-compact{display:flex;flex-direction:column;align-items:center;line-height:1.2}.date-year{font-size:.8rem;color:var(--text-muted)}@media(min-width:769px){.date-cell{text-align:left;width:110px}.date-compact{flex-direction:row;gap:4px;align-items:baseline}.date-year{font-size:.85rem}}.cost-cell{display:flex;flex-direction:column;align-items:flex-end}}.sync-button{display:inline-flex;align-items:center;gap:10px;background:var(--accent-emerald);color:#fff;padding:14px 28px;font-family:var(--font-heading);font-size:1rem;font-weight:600;letter-spacing:.01em;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);margin-top:16px}.sync-button:hover:not(:disabled){background:var(--accent-emerald-hover);transform:translateY(-2px)}.sync-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.sync-button.loading{background:var(--bg-card-hover);color:var(--text-secondary);width:100%;justify-content:center}.import-mode-selector{display:flex;flex-direction:column;gap:12px;margin-top:8px}.mode-option{display:flex;align-items:flex-start;gap:16px;padding:16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);overflow:hidden}.mode-option:hover{border-color:var(--accent-emerald);background:var(--bg-card-hover)}.mode-option.selected{border-color:var(--accent-emerald);background:#10b9811a}.mode-option input[type=radio]{margin:3px 0 0;flex-shrink:0;width:18px;height:18px;accent-color:var(--accent-emerald)}.mode-content{flex:1;min-width:0;line-height:1.5;color:var(--text-muted)}.mode-title{font-weight:600;color:var(--text-primary)}.mode-title:after{content:" – ";font-weight:400;color:var(--text-muted)}.import-mode-tabs{display:flex;gap:0;margin-top:8px;border-bottom:2px solid var(--border-color)}.mode-tab{padding:12px 20px;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--text-muted);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.mode-tab:hover{color:var(--text-primary);background:var(--bg-card-hover)}.mode-tab.active{color:var(--accent-emerald);border-bottom-color:var(--accent-emerald)}.target-group-selector{margin-top:12px;max-width:300px}.target-group-selector .custom-select{width:100%}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--bg-primary);border-radius:var(--radius-md);max-width:600px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.25rem}.close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:0;line-height:1}.close-btn:hover{color:var(--text-primary)}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border-color)}.preview-summary{margin-bottom:20px;padding:16px;background:var(--bg-card);border-radius:var(--radius-sm)}.preview-summary p{margin:0;color:var(--text-primary)}.single-destination-selector{padding:20px;background:var(--bg-card);border-radius:var(--radius-sm);margin-bottom:16px}.single-destination-selector .form-group{margin-bottom:16px}.single-destination-selector .form-group:last-child{margin-bottom:0}.single-destination-selector label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary)}.single-destination-selector select,.single-destination-selector input{width:100%;padding:10px 12px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem}.single-destination-selector select:focus,.single-destination-selector input:focus{outline:none;border-color:var(--accent-emerald)}.preview-table-container{overflow-x:auto}.preview-table{width:100%;border-collapse:collapse}.preview-table th,.preview-table td{padding:12px;text-align:left;border-bottom:1px solid var(--border-color)}.preview-table th{font-weight:500;color:var(--text-muted);font-size:.875rem}.sw-group-info{display:flex;flex-direction:column;gap:4px}.sw-group-name{font-weight:500;color:var(--text-primary)}.sw-group-dates{font-size:.75rem;color:var(--text-muted)}.expense-count{text-align:center;font-weight:500}.destination-selector{display:flex;flex-direction:column;gap:8px}.destination-selector select,.destination-selector .new-group-name{width:100%}.warning-badge{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;color:var(--accent-amber);padding:4px 8px;background:#f59e0b1a;border-radius:var(--radius-xs)}.validation-warning{margin-top:16px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);color:var(--accent-rose);font-size:.875rem}.preview-table .checkbox-column{width:40px;text-align:center}.preview-table .checkbox-column input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-emerald)}.preview-table tr.row-disabled{opacity:.5}.preview-table tr.row-disabled td{color:var(--text-muted)}.preview-table tr.row-error{background:#ef44440d}.preview-table tr.row-error td{border-bottom-color:#ef44444d}.destination-selector .input-error{border-color:var(--accent-rose)!important;background:#ef44440d}.destination-selector .input-error:focus{border-color:var(--accent-rose)!important;box-shadow:0 0 0 2px #ef444433}.error-badge{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;color:var(--accent-rose);padding:4px 8px;background:#ef44441a;border-radius:var(--radius-xs)}.single-mode-container{display:flex;flex-direction:column;gap:24px}.single-mode-container .preview-table-container{margin-top:8px}.single-mode-container .groups-label{font-weight:500;margin-bottom:8px;display:block;color:var(--text-primary)}.mapping-status-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;background:var(--bg-card);border-radius:var(--radius-sm)}.mapping-status{font-size:.875rem}.mapping-status.unmapped{color:var(--accent-amber)}.configure-mapping-btn{background:var(--bg-card-hover);border:1px solid var(--border-color);color:var(--text-primary);padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem}.configure-mapping-btn:hover{background:var(--bg-tertiary)}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sync-error{display:flex;align-items:center;gap:10px;margin-top:16px;padding:14px 18px;background:#ef44441a;border:1px solid var(--expense-red);border-radius:var(--radius-sm);color:var(--expense-red);font-size:.875rem}.sync-result{margin-top:24px;padding:24px;background:#10b98114;border:1px solid var(--accent-emerald);border-radius:var(--radius-md)}.sync-result h3{font-family:var(--font-heading);font-size:1.125rem;color:var(--accent-emerald);margin-bottom:16px}.result-stats{display:flex;gap:32px;flex-wrap:wrap}.result-stats .stat{display:flex;flex-direction:column;gap:4px}.result-stats .stat-value{font-family:var(--font-heading);font-size:1.75rem;font-weight:700;color:var(--text-primary)}.result-stats .stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.post-import-guidance{margin-top:20px;padding:16px;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:var(--radius-sm)}.post-import-guidance p{color:var(--text-secondary);font-size:.9rem;margin-bottom:12px}.post-import-guidance strong{color:var(--accent-blue)}.go-to-group-btn{display:inline-block;background:var(--accent-blue);color:#fff;padding:10px 20px;border-radius:var(--radius-sm);text-decoration:none;font-family:var(--font-heading);font-weight:600;font-size:.9rem;letter-spacing:.01em;transition:background var(--transition-fast)}.go-to-group-btn:hover{background:var(--accent-blue-hover)}.map-users-btn{margin-top:20px;background:var(--accent-blue);color:#fff;border:none;padding:12px 20px;border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:.875rem;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:all var(--transition-fast)}.map-users-btn:hover{background:var(--accent-blue-hover)}.user-mapper{background:var(--bg-primary);border-radius:var(--radius-md);padding:24px;border:1px solid var(--border-color)}.user-mapper .mapper-header h3{font-family:var(--font-heading);font-size:1.125rem;color:var(--text-primary);margin-bottom:8px}.user-mapper .mapper-desc{font-size:.875rem;color:var(--text-muted);margin-bottom:20px;line-height:1.5}.mapper-stats{display:flex;gap:16px;margin-bottom:20px;padding:12px 16px;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.mapper-stats .stat{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--text-secondary)}.mapper-stats .stat.warning{color:var(--accent-coral)}.mapper-stats .stat.success{color:var(--accent-emerald)}.mapper-stats .auto-matched{color:var(--text-muted);font-size:.8rem}.mapper-grid{display:flex;flex-direction:column;gap:8px}.mapper-grid-header{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:8px 12px;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:500;border-bottom:1px solid var(--border-color);margin-bottom:8px}.mapper-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:14px;background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-color);transition:all var(--transition-fast)}.mapper-row.mapped{border-color:var(--accent-emerald);background:#10b9810d}.mapper-row.unmapped{border-color:var(--accent-coral)}.sw-user{display:flex;flex-direction:column;gap:2px;position:relative}.sw-user-name{font-weight:500;color:var(--text-primary);font-size:.9rem}.sw-user-email{font-size:.8rem;color:var(--text-muted)}.sw-user-id{font-size:.7rem;color:var(--text-muted);font-family:monospace}.sw-category{display:flex;flex-direction:column;gap:2px;position:relative}.sw-category-name{display:flex;align-items:center;gap:8px;font-weight:500;color:var(--text-primary);font-size:.9rem}.sw-category-name .category-icon{font-size:1.1rem}.sw-category-count{font-size:.8rem;color:var(--text-muted)}.category-picker-cell{display:flex;align-items:center;min-width:0}.category-picker-cell .category-picker-trigger{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.category-picker-cell .category-picker-trigger:hover{border-color:var(--accent-blue);background:var(--bg-card-hover)}.category-picker-cell .category-picker-trigger.mapped{color:var(--text-primary);border-color:var(--accent-emerald)}.category-picker-cell .category-picker-icon{font-size:1.2rem;flex-shrink:0}.category-picker-cell .category-picker-label{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auto-match-badge{position:absolute;top:0;right:0;background:var(--accent-blue);color:#fff;font-size:.65rem;padding:2px 6px;border-radius:4px;text-transform:uppercase;font-weight:600}.member-select{display:flex;align-items:center;gap:8px;min-width:0}.member-select select{flex:1;min-width:0;padding:10px 14px}.mapped-indicator{color:var(--accent-emerald);font-weight:600;font-size:1rem}.mapper-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color)}.mapper-actions .cancel-btn{background:transparent;color:var(--text-muted);border:1px solid var(--border-color);padding:12px 20px}.mapper-actions .cancel-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.mapper-actions .save-btn{background:var(--accent-emerald);color:#fff;padding:12px 24px}.mapper-actions .save-btn:hover:not(:disabled){background:var(--accent-emerald-hover)}.mapper-help{margin-top:16px;padding:14px 16px;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:var(--radius-sm);font-size:.8rem;color:var(--text-secondary);line-height:1.5}.mapper-help strong{color:var(--accent-blue)}.splitwise-mapper-section{margin-top:24px}.splitwise-import-section{background:var(--bg-card);padding:24px;border-radius:var(--radius-md);border:1px solid var(--border-color);margin-top:24px}.splitwise-import-section h2{font-family:var(--font-heading);font-size:1.125rem;margin-bottom:12px}.splitwise-import-desc{color:var(--text-muted);font-size:.875rem;margin-bottom:16px;line-height:1.5}.mapper-info-box{margin-top:16px;padding:12px;background:#3b82f61a;border-radius:6px;font-size:.8rem;color:var(--text-muted)}.mapper-info-link{background:none;border:none;color:var(--accent-blue);cursor:pointer;text-decoration:underline;font-size:inherit;padding:0}.mapper-info-link:hover{color:var(--accent-blue-hover)}.empty-balances-state{padding:24px;text-align:center;color:var(--text-muted)}.empty-state-link{color:var(--accent-blue);text-decoration:none}.empty-state-link:hover{text-decoration:underline}.splitwise-link-value{color:var(--accent-emerald)}.settings-row-vertical{display:flex;flex-direction:column;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-color)}.settings-row-vertical:last-child{border-bottom:none;padding-bottom:0}.settings-row-header{display:flex;justify-content:space-between;width:100%;align-items:center}.mapping-status{font-weight:500}.mapping-status.mapped{color:var(--accent-emerald)}.mapping-status.unmapped{color:var(--accent-coral)}.configure-mapping-btn{background:var(--accent-blue);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;font-weight:500;transition:background var(--transition-fast)}.configure-mapping-btn:hover:not(:disabled){background:var(--accent-blue-hover)}.balances-section{background:var(--bg-card);padding:24px;border-radius:var(--radius-md);border:1px solid var(--border-color);margin-top:24px;box-sizing:border-box;max-width:100%}.balances-section h2{font-family:var(--font-heading);font-size:1.125rem;margin-bottom:16px}.balances-list{list-style:none}.balances-list li{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--border-color)}.balances-list li:last-child{border-bottom:none}.balance-amount{font-family:var(--font-heading);font-weight:600;font-size:1rem}.balances-list li.positive .balance-amount{color:var(--accent-emerald)}.balances-list li.negative .balance-amount{color:var(--expense-red)}.balances-list li.zero .balance-amount{color:var(--text-muted)}.debts-section{margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color)}.debts-section h3{font-family:var(--font-heading);font-size:1rem;margin-bottom:12px;color:var(--text-secondary)}.debts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.debt-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:20px 16px;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.debt-transfer-flow{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;font-size:.875rem}.debt-item .debt-from{color:var(--expense-red);font-weight:500}.debt-item .debt-arrow{color:var(--text-muted)}.debt-item .debt-to{color:var(--accent-emerald);font-weight:500}.debt-item .debt-amount{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--text-primary)}.debt-item .settle-payment-btn{width:100%;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);padding:10px 16px;border-radius:var(--radius-sm);font-size:.85rem;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.debt-item .settle-payment-btn:hover{background:var(--bg-card-hover);border-color:var(--accent-blue)}@media(max-width:600px){.debts-grid{grid-template-columns:1fr}}@media(max-width:768px){.user-mapper{padding:16px;overflow:hidden}.mapper-grid-header{display:none}.mapper-row{grid-template-columns:1fr;gap:12px;overflow:hidden}.sw-user-email{word-break:break-all;overflow-wrap:break-word}.member-select{width:100%;min-width:0}.member-select select{width:100%;min-width:0;max-width:100%;box-sizing:border-box}.result-stats{gap:20px}.result-stats .stat-value{font-size:1.5rem}}.page-center-loader{display:flex;justify-content:center;align-items:center;min-height:280px;padding:24px}.spinner{display:inline-block;border-radius:50%;border-style:solid;border-color:var(--border-color);border-top-color:var(--accent-blue);animation:spinner-spin .9s linear infinite}.spinner-xs{width:16px;height:16px;border-width:2px}.spinner-sm{width:20px;height:20px;border-width:2px}.spinner-md{width:26px;height:26px;border-width:3px}.spinner-lg{width:40px;height:40px;border-width:4px}@keyframes spinner-spin{to{transform:rotate(360deg)}}.loader{display:inline-flex;align-items:center;gap:10px;font-weight:500;color:var(--text-primary)}.loader-label{font-size:.95rem}.delete-btn{background:transparent;border:none;padding:6px 8px;font-size:1rem;cursor:pointer;opacity:.5;transition:opacity var(--transition-fast),transform var(--transition-fast)}.delete-btn:hover:not(:disabled){opacity:1;transform:scale(1.1)}.delete-btn:disabled{cursor:not-allowed}.delete-btn-mobile{background:transparent;border:none;color:var(--text-muted);padding:4px;font-size:1rem;min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.delete-btn-mobile:hover:not(:disabled){color:var(--expense-red)}.card-actions{display:flex;gap:2px;align-items:center;flex-shrink:0;margin-left:8px}.edit-btn,.edit-btn-mobile{background:transparent;border:none;color:var(--text-muted);padding:4px;font-size:1rem;min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.edit-btn:hover:not(:disabled),.edit-btn-mobile:hover:not(:disabled){color:var(--accent-blue)}.category-cell{display:flex;align-items:center;gap:6px;overflow:hidden}.category-cell .category-icon{flex-shrink:0}.category-cell .category-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-icon{font-size:1rem;display:inline-flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;background:#ffffff1a;border-radius:4px}.category-name{color:var(--text-secondary)}th.actions-col,td.actions-col{width:70px;text-align:right}td.actions-col{padding:8px 4px;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:2px}.group-mapping-list{display:flex;flex-direction:column;gap:12px}.group-mapping-card{display:flex;justify-content:space-between;align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px;transition:border-color var(--transition-fast)}.group-mapping-card:hover{border-color:var(--accent-blue)}.group-mapping-info h3{font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.group-mapping-stats{display:flex;align-items:center;gap:16px;font-size:.8rem}.mapping-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-weight:500;font-size:.75rem}.mapping-badge.complete{background:#10b98126;color:var(--accent-emerald)}.mapping-badge.incomplete{background:#f9731626;color:var(--accent-coral)}.user-count{color:var(--text-muted)}@media(max-width:768px){.group-mapping-card{flex-direction:column;align-items:stretch;gap:16px}.group-mapping-card .map-users-btn{width:100%;text-align:center}}.category-picker{position:relative;flex-shrink:0}.category-picker-trigger{display:flex;align-items:center;justify-content:center;width:48px;height:48px;min-width:48px;min-height:48px;max-width:48px;max-height:48px;box-sizing:border-box;flex-shrink:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.category-picker-trigger:hover:not(.disabled){border-color:var(--accent-blue);background:var(--bg-card-hover)}.category-picker-trigger.disabled{opacity:.5;cursor:not-allowed}.category-picker-trigger.loading{pointer-events:none;cursor:default;min-height:inherit;max-height:inherit}.category-picker-icon{font-size:1.5rem}.category-picker-backdrop{position:fixed;inset:0;background:#0009;z-index:2000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px;padding-top:max(24px,env(safe-area-inset-top,24px));padding-bottom:max(24px,env(safe-area-inset-bottom,24px));box-sizing:border-box}.category-picker-panel{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;max-height:100%;display:flex;flex-direction:column}.category-picker-panel .category-grid{flex:1;overflow-y:auto;min-height:0;-webkit-overflow-scrolling:touch}.category-picker-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color);flex-shrink:0}.category-picker-title{font-family:var(--font-heading);font-weight:600;font-size:1.1rem;color:var(--text-primary)}.category-picker-close{background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-fast);line-height:1}.category-picker-close:hover{background:var(--bg-card-hover);color:var(--text-primary)}.category-picker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:16px;overflow-y:auto;flex:1}.category-picker-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 8px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);min-height:80px}.category-picker-option:hover{border-color:var(--accent-blue);background:var(--bg-card-hover);transform:translateY(-2px)}.category-picker-option.selected{border-color:var(--accent-blue);background:#3b82f626}.category-option-icon{font-size:1.75rem}.category-option-name{font-size:.75rem;color:var(--text-secondary);text-align:center;line-height:1.3;word-break:break-word}.category-picker-option.selected .category-option-name{color:var(--accent-blue);font-weight:600}@media(min-width:600px){.category-picker-panel{max-width:480px}.category-picker-grid{grid-template-columns:repeat(4,1fr);gap:12px;padding:20px}}@media(max-width:480px){.category-picker-backdrop{padding:16px;padding-top:max(16px,env(safe-area-inset-top,16px));padding-bottom:max(16px,env(safe-area-inset-bottom,16px))}.category-picker-grid{gap:8px;padding:12px}.category-picker-option{padding:12px 6px;min-height:70px}.category-option-icon{font-size:1.5rem}.category-option-name{font-size:.7rem}}.expense-primary-row{display:flex;gap:12px;align-items:flex-end;margin-bottom:16px}.expense-primary-row .form-group{flex:1;margin-bottom:0}.expense-primary-row .category-picker{margin-bottom:0;padding-bottom:0}.expense-secondary-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);margin-bottom:16px;overflow:hidden}.secondary-field{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background var(--transition-fast);min-height:56px;box-sizing:border-box}.secondary-field:last-child{border-bottom:none}.secondary-field:hover{background:var(--bg-card-hover)}.secondary-field-icon{font-size:1.1rem;color:var(--text-muted);width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.secondary-field-content{flex:1;min-width:0}.secondary-field-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:2px;line-height:1.2}.secondary-field-value{font-size:.875rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.secondary-field-chevron{color:var(--text-muted);font-size:1rem;flex-shrink:0;width:16px;text-align:center}.secondary-field-expanded{padding:14px 16px;background:var(--bg-card-hover);border-bottom:1px solid var(--border-color)}.secondary-field-expanded:last-child{border-bottom:none}.secondary-field-expanded .form-group{margin-bottom:0}.secondary-field-expanded .form-group label{margin-bottom:6px}.group-icon-svg{stroke:currentColor;stroke-width:2;fill:none}.split-summary-text{font-size:.875rem;color:var(--text-primary)}.split-summary-text .payer-highlight{font-weight:500}.expense-pills-row{display:flex;gap:12px;margin-bottom:12px}.expense-pill{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;flex:1;min-width:0;font-family:inherit;font-size:.9rem;color:var(--text-primary);transition:border-color var(--transition-fast),background var(--transition-fast);text-align:left}.expense-pill:hover{border-color:var(--accent-blue);background:var(--bg-card-hover)}.expense-pill-icon{font-size:1rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--text-muted)}.expense-pill-value{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.expense-pill-chevron{color:var(--text-muted);font-size:1rem;flex-shrink:0;margin-left:auto}.expense-pill-full{width:100%;flex:none;margin-bottom:12px}.expense-pill-readonly{cursor:default}.expense-pill-readonly:hover{border-color:var(--border-color);background:var(--bg-primary)}.expense-pill-dropdown{padding:0;overflow:visible;cursor:default}.expense-pill-dropdown:hover{border-color:var(--border-color);background:var(--bg-primary)}.expense-pill-dropdown .expense-pill-icon{padding-left:12px}.expense-pill-dropdown .expense-pill-select{flex:1}.expense-pill-dropdown .custom-select-trigger{border:none;background:transparent;padding:12px 12px 12px 8px;min-height:auto}.expense-pill-dropdown .custom-select-trigger:hover{background:transparent}.expense-pill-dropdown .custom-select-dropdown{left:-1px;right:-1px;top:calc(100% + 1px)}.expense-split-expanded{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:16px;margin-bottom:12px}@media(max-width:480px){.expense-pills-row{flex-direction:column}.expense-pill{padding:10px 14px}}.date-picker-modal{width:320px;max-width:95vw}.date-picker-quick{display:flex;justify-content:center;gap:12px;margin-bottom:20px;padding:4px 0}.date-picker-quick button{padding:8px 20px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:20px;color:var(--text-primary);font-family:var(--font-heading);font-size:.85rem;font-weight:500;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast)}.date-picker-quick button:hover{border-color:var(--accent-blue);background:var(--bg-card-hover)}.date-picker-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.date-picker-nav button{padding:8px 12px;background:transparent;border:none;color:var(--text-primary);font-size:1.25rem;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.date-picker-nav button:hover{background:var(--bg-card-hover)}.date-picker-month-year{font-weight:600;font-size:1rem;color:var(--text-primary)}.date-picker-calendar{-webkit-user-select:none;user-select:none;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}.date-picker-weekdays{display:contents}.date-picker-weekday{display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--text-muted);padding:8px 0;text-transform:uppercase}.date-picker-days{display:contents}.date-picker-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-primary);font-family:inherit;font-size:.875rem;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.date-picker-day:hover:not(.empty):not(:disabled){background:var(--bg-card-hover)}.date-picker-day.empty{cursor:default}.date-picker-day.today{font-weight:600;color:var(--accent-blue)}.date-picker-day.selected{background:var(--accent-blue);color:#fff}.date-picker-day.selected.today{color:#fff}@media(max-width:480px){.category-picker-trigger{width:44px;height:44px;min-width:44px;min-height:44px;max-width:44px;max-height:44px}.category-picker-icon{font-size:1.25rem}.category-picker-grid{grid-template-columns:repeat(3,1fr);gap:6px;padding:12px}.category-picker-option{padding:12px 6px;min-height:64px}.category-option-icon{font-size:1.25rem}.category-option-name{font-size:.65rem}.secondary-field{padding:12px 14px;min-height:52px}.secondary-field-icon{font-size:1rem;width:22px;height:22px}.secondary-field-expanded{padding:12px 14px}}.invite-row{display:flex;align-items:center;gap:16px;margin-bottom:24px}.invite-row .add-member-form{flex:1;min-width:0;margin-bottom:0}.invite-separator{width:1px;height:36px;background:var(--border-color);flex-shrink:0}.invite-link-compact{display:flex;align-items:center;gap:10px;flex-shrink:0}.invite-link-label{font-size:.875rem;font-weight:500;color:var(--text-muted);white-space:nowrap}.copy-link-btn,.generate-link-btn{padding:8px 14px;min-width:110px;height:36px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.generate-link-btn{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.generate-link-btn:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--accent-blue)}.generate-link-btn:disabled{opacity:.6;cursor:not-allowed}.copy-link-btn{background:var(--accent-blue);color:#fff;border:none}.copy-link-btn:hover{background:var(--accent-blue-hover)}.copy-link-btn.copied{background:var(--accent-emerald)}.join-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg-primary)}.join-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:40px;max-width:400px;width:100%;text-align:center;box-shadow:var(--shadow-lg)}.join-card h1{font-family:var(--font-heading);font-size:1.5rem;margin-bottom:16px;color:var(--text-primary)}.join-card p{color:var(--text-secondary);margin-bottom:24px;line-height:1.6}.join-card .login-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;background:var(--accent-blue);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:1rem;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:all var(--transition-fast)}.join-card .login-btn:hover{background:var(--accent-blue-hover);transform:translateY(-2px)}.join-card .home-btn{display:inline-block;padding:12px 24px;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.join-card .home-btn:hover{border-color:var(--accent-blue)}.join-card.error h1{color:var(--expense-red)}@media(max-width:600px){.invite-row{flex-direction:column;align-items:stretch;gap:12px}.invite-separator{width:100%;height:1px}.invite-row .add-member-form{width:100%}.invite-link-compact{width:100%;justify-content:space-between}}@media(max-width:480px){.join-card{padding:24px}}.category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:16px}.category-grid-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 8px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);min-height:80px;position:relative}.category-grid-option:hover{border-color:var(--accent-blue);background:var(--bg-card-hover);transform:translateY(-2px)}.category-grid-option.selected{border-color:var(--accent-blue);background:#3b82f626}.category-grid-icon{font-size:1.75rem}.category-grid-name{font-size:.75rem;color:var(--text-secondary);text-align:center;line-height:1.3;word-break:break-word}.category-grid-option.selected .category-grid-name{color:var(--accent-blue);font-weight:600}.category-grid-check{position:absolute;top:4px;right:4px;background:var(--accent-blue);color:#fff;border-radius:50%;width:18px;height:18px;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:700}@media(min-width:600px){.category-grid{grid-template-columns:repeat(4,1fr);gap:12px;padding:20px}}@media(max-width:480px){.category-grid{gap:8px;padding:12px}.category-grid-option{padding:12px 6px;min-height:70px}.category-grid-icon{font-size:1.5rem}.category-grid-name{font-size:.7rem}}.filters-section-new{margin-bottom:24px}.filter-badges-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;align-items:center}.filter-badge{display:flex;align-items:center;justify-content:center;gap:6px;min-width:0;height:42px;padding:0 14px;box-sizing:border-box;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;color:var(--text-secondary);transition:all var(--transition-fast);overflow:hidden}.filter-badge:hover{border-color:var(--accent-blue);color:var(--text-primary)}.filter-badge.active{color:var(--text-primary);font-weight:600;background:#60a5fa14;border-color:#60a5fa40}.filter-badge.active:hover{border-color:#60a5fa73}.filter-badge-label{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-badge-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#60a5fa26;border-radius:10px;font-size:.75rem;font-weight:600;color:var(--accent-blue)}.filter-reset-btn{display:inline-flex;align-items:center;gap:4px;padding:8px 12px;background:transparent;border:1px dashed var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.filter-reset-btn:hover{border-color:var(--text-muted);color:var(--text-secondary);background:#94a3b81a}.filter-search-row{display:flex;gap:8px;margin-bottom:8px}.filter-search-input{flex:1;height:42px;padding:0 16px;box-sizing:border-box;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;color:var(--text-primary);transition:border-color var(--transition-fast)}.filter-search-input:focus{outline:none;border-color:var(--accent-blue)}.filter-search-input::placeholder{color:var(--text-muted)}.filter-modal-backdrop{position:fixed;inset:0;background:#0009;z-index:2000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px;padding-top:max(24px,env(safe-area-inset-top,24px));padding-bottom:max(24px,env(safe-area-inset-bottom,24px));box-sizing:border-box}.filter-modal{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;max-height:calc(100% - 48px);display:flex;flex-direction:column;overflow:hidden}.filter-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color);flex-shrink:0}.filter-modal-header h3{margin:0;font-family:var(--font-heading);font-weight:600;font-size:1.1rem;color:var(--text-primary)}.filter-modal-close{background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-fast);line-height:1}.filter-modal-close:hover{background:var(--bg-card-hover);color:var(--text-primary)}.filter-modal-actions{display:flex;gap:8px;padding:12px 20px;border-bottom:1px solid var(--border-color);flex-shrink:0}.filter-modal-actions button{flex:1;padding:8px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.85rem;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.filter-modal-actions button:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.filter-modal-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:0;min-height:0}.filter-modal-footer{display:flex;gap:12px;padding:16px 20px;border-top:1px solid var(--border-color);background:var(--bg-card);flex-shrink:0}.filter-modal-footer button{flex:1;padding:12px 20px;border-radius:var(--radius-sm);font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.filter-modal-footer .btn-secondary{background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-secondary)}.filter-modal-footer .btn-secondary:hover{border-color:var(--text-muted);color:var(--text-primary)}.filter-modal-footer .btn-primary{background:var(--accent-blue);border:1px solid var(--accent-blue);color:#fff}.filter-modal-footer .btn-primary:hover{background:var(--accent-blue-hover)}.rename-group-modal{max-width:400px;width:100%}.rename-group-content{padding:20px}.rename-group-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.rename-group-input{width:100%;padding:12px 16px;font-size:1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);transition:border-color var(--transition-fast);box-sizing:border-box}.rename-group-input:focus{outline:none;border-color:var(--accent-blue)}.rename-group-input::placeholder{color:var(--text-muted)}.rename-group-input:disabled{opacity:.6;cursor:not-allowed}.group-tiles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:16px 20px}.group-tile{display:flex;flex-direction:column;gap:4px;padding:16px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);position:relative;text-align:left}.group-tile:hover{border-color:var(--accent-blue);background:var(--bg-card-hover)}.group-tile.selected{border-color:var(--accent-blue);background:#3b82f626}.group-tile-name{font-weight:500;color:var(--text-primary);font-size:.95rem}.group-tile.selected .group-tile-name{color:var(--accent-blue)}.group-tile-members{font-size:.8rem;color:var(--text-muted)}.group-tile-check{position:absolute;top:8px;right:8px;background:var(--accent-blue);color:#fff;border-radius:50%;width:20px;height:20px;font-size:12px;display:flex;align-items:center;justify-content:center;font-weight:700}.filter-modal-date .filter-modal-content{padding:16px 20px}.date-range-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.date-range-row label{font-size:.9rem;color:var(--text-secondary);width:40px;flex-shrink:0}.custom-select{position:relative;flex:1}.custom-select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast);text-align:left}.custom-select-trigger:hover,.custom-select-trigger.open{border-color:var(--accent-blue)}.custom-select-value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-select-chevron{flex-shrink:0;opacity:.6;transition:transform var(--transition-fast)}.custom-select-trigger.open .custom-select-chevron{transform:rotate(180deg)}.custom-select-dropdown{overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:9999}.custom-select-option{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;background:transparent;border:none;font-size:.9rem;color:var(--text-primary);cursor:pointer;text-align:left;transition:background var(--transition-fast)}.custom-select-option:hover{background:var(--bg-card-hover)}.custom-select-option.selected{background:#3b82f61a;color:var(--accent-blue)}.custom-select-check{flex-shrink:0;color:var(--accent-blue)}.custom-select-disabled{opacity:.5;pointer-events:none}.custom-select-group-label{padding:8px 12px 4px;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.custom-select-separator{height:1px;margin:4px 0;background:var(--border-color)}@media(max-width:480px){.custom-select-trigger,.custom-select-option{padding:12px 14px;font-size:1rem}.custom-select-dropdown{max-height:200px}}.pill-toggle{display:flex;flex-wrap:wrap;gap:8px}.pill-toggle-option{padding:8px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.pill-toggle-option:hover{border-color:var(--accent-blue);color:var(--text-primary)}.pill-toggle-option.selected{background:#3b82f626;border-color:var(--accent-blue);color:var(--accent-blue);font-weight:500}.time-window-pills{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.time-window-pills .pill-toggle-option{text-align:center;justify-content:center}@media(max-width:480px){.pill-toggle{gap:6px}.pill-toggle-option{padding:10px 14px;font-size:.85rem}.time-window-pills{grid-template-columns:1fr}}.date-quick-selectors{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.date-quick-label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:10px}.date-quick-buttons{display:flex;gap:8px;flex-wrap:wrap}.date-quick-buttons button{padding:8px 14px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.date-quick-buttons button:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.filter-modal-category .filter-modal-content{padding:0}.filter-modal-category .category-grid{padding:16px 20px}@media(max-width:480px){.filter-modal-backdrop{padding:16px;padding-top:max(16px,env(safe-area-inset-top,16px));padding-bottom:max(16px,env(safe-area-inset-bottom,16px))}.group-tiles-grid{grid-template-columns:1fr}}@media(max-width:480px){.filter-badges-row{gap:6px}.filter-badge{height:38px;padding:0 10px;font-size:.75rem;gap:4px}.filter-search-input{height:38px}.filter-badge-count{min-width:18px;height:18px;font-size:.7rem;padding:0 4px}.filter-reset-btn{height:38px;font-size:.75rem;padding:0 10px}.filter-reset-label{display:none}.date-range-row{gap:8px}.date-range-row label{width:32px;font-size:.85rem}}.activity-log-section{background:var(--bg-card);padding:24px;border-radius:var(--radius-md);border:1px solid var(--border-color);margin-top:24px}.activity-log-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}.activity-log-toggle h2{margin:0;font-size:1.1rem;font-weight:600}.activity-log-toggle .chevron-icon{color:var(--text-muted);transition:transform var(--transition-normal)}.activity-log-toggle .chevron-icon.rotated{transform:rotate(180deg)}.activity-log-content{margin-top:16px}.activity-log-empty,.activity-log-error{color:var(--text-muted);font-size:.9rem;padding:16px 0;text-align:center}.activity-log-error{color:var(--expense-red)}.activity-log-loading{display:flex;justify-content:center;padding:16px 0}.activity-log-list{display:flex;flex-direction:column;gap:16px}.activity-log-entry{padding:16px;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.activity-log-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.activity-log-time{font-size:.8rem;color:var(--text-muted)}.activity-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.activity-badge-created{background:#10b98133;color:var(--accent-emerald)}.activity-badge-updated{background:#3b82f633;color:var(--accent-blue)}.activity-badge-deleted{background:#ef444433;color:var(--expense-red)}.activity-badge-imported{background:#8b5cf633;color:#8b5cf6}.activity-log-body{display:flex;flex-wrap:wrap;gap:8px;align-items:baseline}.activity-log-user{font-weight:600;color:var(--text-primary)}.activity-log-description{color:var(--text-secondary);font-style:italic}.activity-log-view-link{background:none;border:none;padding:0;color:var(--accent-blue);font-size:.85rem;cursor:pointer;text-decoration:none;white-space:nowrap}.activity-log-view-link:hover{text-decoration:underline}.activity-log-changes{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:6px}.activity-log-change{display:flex;flex-wrap:wrap;gap:6px;font-size:.85rem;align-items:center}.change-field{color:var(--text-muted);font-weight:500}.change-old{color:var(--expense-red);text-decoration:line-through}.change-arrow{color:var(--text-muted)}.change-new{color:var(--accent-emerald)}.activity-log-load-more{display:block;width:100%;margin-top:16px;padding:12px;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.activity-log-load-more:hover{background:var(--bg-card-hover);border-color:var(--accent-blue);color:var(--text-primary)}.confirm-modal{max-width:400px}.confirm-modal-content{padding:16px 20px}.confirm-modal-content p{color:var(--text-secondary);line-height:1.6}.confirm-modal-error{margin-top:12px;padding:12px;background:#ef44441a;border:1px solid var(--expense-red);border-radius:var(--radius-sm);color:var(--expense-red);font-size:.9rem}.btn-danger{background:var(--expense-red);color:#fff;padding:12px 24px;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-danger:hover{background:#dc2626}.btn-danger:disabled{opacity:.6;cursor:not-allowed}@media(max-width:480px){.activity-log-section{padding:16px}.activity-log-entry{padding:12px}.activity-log-header{flex-wrap:wrap}.activity-log-change{font-size:.8rem}}.tasks-page{padding:16px 16px 100px;max-width:900px;margin:0 auto;position:relative}.tasks-suggested-banner{display:block;width:100%;padding:12px 16px;margin-bottom:16px;background:var(--bg-card-hover);color:var(--accent-blue);border:1px solid var(--accent-blue);border-radius:var(--radius-md);font-size:.9rem;font-weight:500;cursor:pointer;text-align:left;transition:background var(--transition-fast)}.tasks-suggested-banner:hover{background:#3b82f626}.task-suggestions-btn{display:flex;align-items:center;gap:6px;margin-top:8px;padding:8px 14px;background:transparent;color:var(--text-secondary);border:1px dashed var(--border-color);border-radius:var(--radius-sm);font-size:.85rem;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.task-suggestions-btn:hover,.task-suggestions-btn:focus-visible{color:var(--text-primary);border-color:var(--accent-blue)}.tasks-fab{position:fixed;bottom:90px;right:24px;width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);z-index:50;padding:0}.task-list-section{margin-top:8px}.task-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.task-list-title{font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.task-list-page-size{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-muted)}.task-list-page-size select{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color, rgba(255,255,255,.1));border-radius:var(--radius-sm);padding:4px 8px;font-size:.8rem}.task-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.task-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-secondary);border-radius:var(--radius-md);transition:background var(--transition-fast)}.task-row:hover{background:var(--bg-card-hover)}.task-row--done{opacity:.65}.task-row--expired{border-left:3px solid var(--expense-red)}.task-row--suggested{border-left:3px solid var(--accent-blue)}.task-check{flex-shrink:0;width:24px;height:24px;border-radius:50%;border:2px solid var(--text-muted);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;color:var(--text-primary);transition:all var(--transition-fast)}.task-check:hover{border-color:var(--accent-emerald)}.task-check--done{border-color:var(--accent-emerald);background:var(--accent-emerald);color:#fff}.task-row-body{flex:1;display:flex;flex-direction:column;gap:2px;background:none;border:none;color:inherit;text-align:left;cursor:pointer;padding:0;font:inherit;min-width:0}.task-row-title{font-weight:500;font-size:.95rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-row-title--done{text-decoration:line-through;color:var(--text-muted)}.task-row-due{font-size:.8rem;color:var(--text-secondary)}.task-row-due--expired{color:var(--expense-red);font-weight:600}.task-row-category{font-size:.75rem;color:var(--text-muted)}.task-status-pill{flex-shrink:0;font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.task-status-pill--suggested{background:#3b82f626;color:var(--accent-blue)}.task-status-pill--expired{background:#ef444426;color:var(--expense-red)}.task-list-pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:16px}.task-list-pagination-info{font-size:.85rem;color:var(--text-secondary)}.task-modal{background:var(--bg-secondary);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden}.task-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.06)}.task-modal-header h2{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.task-modal-save-indicator{padding:0 20px;min-height:24px;display:flex;align-items:center}.save-state{font-size:.75rem}.save-state--saving{color:var(--text-muted)}.save-state--saved{color:var(--accent-emerald)}.save-state--error{color:var(--expense-red)}.task-modal-body{padding:12px 20px 20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.task-detail-field label{display:block;font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:4px}.task-input{width:100%;padding:10px 12px;background:var(--bg-primary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.95rem;font-family:var(--font-body);transition:border-color var(--transition-fast)}.task-input:focus{outline:none;border-color:var(--accent-blue)}textarea.task-input{resize:vertical;min-height:60px}.task-detail-status-row{padding-top:4px}.task-done-toggle{width:100%}.task-done-toggle--active{background:var(--accent-emerald)}.task-modal-footer{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-top:1px solid rgba(255,255,255,.06);gap:8px}.task-modal-nav,.task-modal-actions{display:flex;gap:8px}.task-detail-row{display:flex;gap:12px;align-items:flex-end}.task-detail-field--grow{flex:1;min-width:0}.task-detail-field--grow .expense-pill{width:100%}.task-recurrence-section{border-top:1px solid rgba(255,255,255,.06);padding-top:12px}.task-recurrence-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:var(--bg-primary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.9rem;font-family:var(--font-body);cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast)}.task-recurrence-toggle:hover{border-color:var(--accent-blue)}.task-recurrence-toggle.active{border-color:var(--accent-blue);color:var(--text-primary)}.task-recurrence-toggle svg{flex-shrink:0;color:var(--text-muted)}.task-recurrence-toggle.active svg{color:var(--accent-blue)}.task-recurrence-badge{margin-left:auto;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:999px;background:#ffffff0f;color:var(--text-muted)}.task-recurrence-toggle.active .task-recurrence-badge{background:#3b82f626;color:var(--accent-blue)}.task-recurrence-options{display:flex;flex-direction:column;gap:12px;margin-top:12px;padding:12px;background:#ffffff05;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.06)}.task-recurrence-frequency{display:flex;align-items:center;gap:10px}.task-recurrence-frequency label{font-size:.8rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.task-recurrence-every-input{width:64px!important;text-align:center}.task-recurrence-interval-toggle{width:100%}.task-recurrence-interval-toggle .pill-toggle-option{flex:1;text-align:center;font-size:.8rem;padding:6px 4px}.task-recurrence-clear-end{font-size:.75rem;margin-top:4px}@media(max-width:768px){.task-modal{max-width:100%;max-height:calc(100% - 32px);width:100%}.task-modal-header{padding:16px 20px}}.task-onboarding-modal{max-width:420px}.task-onboarding-body{color:var(--text-secondary);font-size:.9rem;margin:0 0 16px}.task-onboarding-countries{display:flex;gap:10px;flex-wrap:wrap}.task-country-chip{padding:10px 20px;border-radius:var(--radius-md);border:2px solid rgba(255,255,255,.12);background:var(--bg-primary);color:var(--text-primary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.task-country-chip:hover{border-color:var(--accent-blue)}.task-country-chip--selected{border-color:var(--accent-emerald);background:#10b9811f;color:var(--accent-emerald)}@media(max-width:768px){.tasks-page{padding:12px 12px 100px}.tasks-fab{bottom:80px;right:16px;width:48px;height:48px}}.global-message-host{position:fixed;bottom:calc(var(--bottom-spacing, 70px) + 16px);left:50%;transform:translate(-50%);z-index:1100;display:flex;flex-direction:column;gap:8px;width:calc(100% - 32px);max-width:420px;pointer-events:none}.global-message{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);pointer-events:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.global-message-content{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}.global-message-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.85rem;font-weight:700}.global-message-text{display:flex;flex-direction:column;gap:2px;min-width:0}.global-message-title{font-weight:600;font-size:.9rem;line-height:1.3}.global-message-body{font-size:.8rem;opacity:.85;line-height:1.4}.global-message-dismiss{flex-shrink:0;background:transparent;border:none;padding:4px 8px;font-size:1.25rem;cursor:pointer;opacity:.6;transition:opacity var(--transition-fast);line-height:1}.global-message-dismiss:hover{opacity:1}.global-message-success{background:linear-gradient(135deg,#065f46,#047857);color:#d1fae5;border:1px solid #10b981}.global-message-success .global-message-icon{background:#10b9814d;color:#34d399}.global-message-success .global-message-dismiss{color:#d1fae5}.global-message-error{background:linear-gradient(135deg,#7f1d1d,#991b1b);color:#fecaca;border:1px solid #ef4444}.global-message-error .global-message-icon{background:#ef44444d;color:#f87171}.global-message-error .global-message-dismiss{color:#fecaca}.global-message-warning{background:linear-gradient(135deg,#78350f,#92400e);color:#fef3c7;border:1px solid #f59e0b}.global-message-warning .global-message-icon{background:#f59e0b4d;color:#fbbf24}.global-message-warning .global-message-dismiss{color:#fef3c7}.global-message-info{background:linear-gradient(135deg,#1e3a5f,#1e40af);color:#dbeafe;border:1px solid #3b82f6}.global-message-info .global-message-icon{background:#3b82f64d;color:#60a5fa}.global-message-info .global-message-dismiss{color:#dbeafe}.public-layout{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(ellipse at 20% 0%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(16,185,129,.06) 0%,transparent 50%),var(--bg-primary)}.public-header{position:sticky;top:0;z-index:100;background:#0f172ad9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color)}.public-nav{max-width:1200px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:32px}.public-logo,.footer-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text-primary)}.logo-image{object-fit:contain;flex-shrink:0}.logo-text{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--accent-emerald)}.public-nav-links{display:flex;align-items:center;gap:8px;list-style:none;margin:0;padding:0}.public-nav-links a{padding:10px 18px;color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:.95rem;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.public-nav-links a:hover{color:var(--text-primary);background:var(--bg-card-hover)}.public-nav-links a.active{color:var(--accent-emerald);background:#10b9811a}.public-nav-cta{display:flex;align-items:center;gap:12px}.public-lang-custom-select{flex:0 0 auto;min-width:64px}.public-lang-custom-select .custom-select-trigger{padding:7px 10px;font-size:.85rem;font-weight:500;background:var(--bg-card);color:var(--text-secondary);gap:4px}.public-lang-custom-select .custom-select-trigger:hover{border-color:var(--border-light);color:var(--text-primary)}.public-lang-custom-select .custom-select-trigger.open{border-color:var(--accent-blue)}.public-lang-custom-select .custom-select-chevron{width:12px;height:12px}.public-lang-custom-select .custom-select-dropdown{min-width:80px;right:0;left:auto}.public-lang-custom-select .custom-select-option{padding:8px 12px;font-size:.85rem}.btn-login{padding:10px 20px;color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:.95rem;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.btn-login:hover{color:var(--text-primary);background:var(--bg-card-hover)}.btn-get-started{padding:10px 24px;background:linear-gradient(135deg,var(--accent-emerald) 0%,#059669 100%);color:#fff;text-decoration:none;font-family:var(--font-heading);font-weight:600;font-size:.95rem;letter-spacing:.01em;border-radius:var(--radius-sm);transition:all var(--transition-fast);box-shadow:0 2px 12px #10b9814d}.btn-get-started:hover{transform:translateY(-2px);box-shadow:0 4px 20px #10b98166}.public-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:48px 24px}.public-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;padding:64px 24px 48px;display:grid;grid-template-columns:1.5fr 2fr;gap:64px}.footer-brand{display:flex;flex-direction:column;gap:16px}.footer-logo{width:fit-content}.footer-tagline{color:var(--text-muted);font-size:.95rem;line-height:1.6;max-width:300px}.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}.footer-column h4{font-family:var(--font-heading);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-primary);margin-bottom:16px}.footer-column ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.footer-column a{color:var(--text-muted);text-decoration:none;font-size:.9rem;transition:all var(--transition-fast)}.footer-column a:hover{color:var(--accent-emerald)}.footer-bottom{max-width:1200px;margin:0 auto;padding:24px;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;gap:16px}.footer-bottom p{color:var(--text-muted);font-size:.85rem}.footer-swiss{display:flex;align-items:center;gap:6px}.swiss-flag{font-size:1rem}@media(max-width:900px){.footer-content{grid-template-columns:1fr;gap:48px}.footer-links{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.public-nav{padding:12px 16px;gap:12px}.public-nav-links{display:none}.public-nav-cta{gap:8px;flex-shrink:0}.public-lang-custom-select .custom-select-trigger{padding:6px 8px;font-size:.8rem}.btn-login{display:none}.btn-get-started{padding:8px 14px;font-size:.85rem;white-space:nowrap}.public-main{padding:32px 16px}.footer-content{padding:48px 16px 32px}.footer-links{grid-template-columns:1fr 1fr;gap:24px}.footer-bottom{flex-direction:column;text-align:center;padding:20px 16px}}@media(max-width:480px){.public-nav{padding:10px 12px;gap:8px}.logo--sm .logo-image{width:24px!important;height:24px!important}.logo-text{font-size:1.25rem}.public-lang-custom-select .custom-select-trigger{padding:5px 6px;font-size:.75rem}.public-lang-custom-select .custom-select-chevron{width:10px;height:10px}.btn-get-started{padding:7px 12px;font-size:.8rem}.footer-links{grid-template-columns:1fr}.footer-column{text-align:center}.footer-brand{align-items:center;text-align:center}.footer-tagline{max-width:100%}}@media(max-width:360px){.logo-text{font-size:1.1rem}.btn-get-started{padding:6px 10px;font-size:.75rem}.public-lang-custom-select .custom-select-trigger{padding:4px 5px}}.dp-window{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, rgba(255, 255, 255, .08));border-radius:12px;overflow:hidden;box-shadow:0 20px 60px #0006,0 0 0 1px #ffffff0d;font-size:.7rem;width:100%;max-width:520px}.dp-window--compact{max-width:460px}.dp-toolbar{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#00000040;border-bottom:1px solid rgba(255,255,255,.06)}.dp-dots{display:flex;gap:5px}.dp-dots span{width:8px;height:8px;border-radius:50%}.dp-dots span:nth-child(1){background:#ef4444}.dp-dots span:nth-child(2){background:#f59e0b}.dp-dots span:nth-child(3){background:#22c55e}.dp-toolbar-title{font-weight:600;color:var(--text-primary, #e2e8f0);font-size:.75rem;letter-spacing:.02em}.dp-toolbar-pills{display:flex;gap:6px;margin-left:auto}.dp-pill{padding:3px 8px;border-radius:4px;font-size:.6rem;font-weight:500;color:var(--text-muted, #94a3b8);background:#ffffff0a;border:1px solid rgba(255,255,255,.06)}.dp-pill.active{color:var(--accent-emerald, #10b981);background:#10b9811a;border-color:#10b98133}.dp-content{padding:14px;display:flex;flex-direction:column;gap:14px}.dp-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.dp-window--compact .dp-kpi-row{grid-template-columns:repeat(3,1fr)}.dp-kpi{background:var(--bg-card, rgba(255, 255, 255, .03));border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:10px 8px;display:flex;flex-direction:column;gap:4px;text-align:center}.dp-kpi-value{font-weight:700;font-size:.85rem;letter-spacing:-.01em}.dp-kpi-value.coral{color:#f87171}.dp-kpi-value.blue{color:#60a5fa}.dp-kpi-value.green{color:#34d399}.dp-kpi-value.purple{color:#a78bfa}.dp-kpi-label{font-size:.55rem;color:var(--text-muted, #94a3b8);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.dp-trends{background:var(--bg-card, rgba(255, 255, 255, .03));border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:12px}.dp-section-title{font-weight:600;color:var(--text-primary, #e2e8f0);font-size:.72rem;margin-bottom:2px}.dp-trends-subtitle{font-size:.55rem;color:var(--text-muted, #94a3b8);margin-bottom:10px}.dp-trend-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04)}.dp-trend-row:last-child{border-bottom:none;padding-bottom:0}.dp-trend-month{font-weight:500;color:var(--text-secondary, #cbd5e1);min-width:60px;font-size:.65rem}.dp-trend-amount{font-weight:600;color:var(--text-primary, #e2e8f0);min-width:52px;font-size:.7rem}.dp-badge{padding:1px 6px;border-radius:4px;font-size:.55rem;font-weight:600;flex-shrink:0}.dp-badge.up{color:#f87171;background:#f871711f}.dp-badge.down{color:#34d399;background:#34d3991f}.dp-trend-cats{display:flex;gap:4px;margin-left:auto;flex-wrap:wrap;justify-content:flex-end}.dp-cat-chip{font-size:.52rem;padding:1px 5px;border-radius:3px;font-weight:500;white-space:nowrap}.dp-cat-chip.up{color:#fca5a5;background:#f8717114}.dp-cat-chip.down{color:#6ee7b7;background:#34d39914}.dp-charts-row{display:grid;grid-template-columns:1fr 1.2fr;gap:10px}.dp-chart-box{background:var(--bg-card, rgba(255, 255, 255, .03));border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:12px;display:flex;flex-direction:column;align-items:center;gap:8px}.dp-chart-title{font-weight:600;color:var(--text-primary, #e2e8f0);font-size:.62rem;align-self:flex-start}.dp-doughnut{width:80px;height:80px;border-radius:50%;background:conic-gradient(#fb923c 0deg 100deg,#60a5fa 100deg 185deg,#10b981 185deg 260deg,#8b5cf6 260deg 315deg,#f97316 315deg 360deg);-webkit-mask:radial-gradient(circle at center,transparent 16px,black 17px);mask:radial-gradient(circle at center,transparent 16px,black 17px);flex-shrink:0}.dp-doughnut-legend{display:flex;flex-wrap:wrap;gap:6px 10px;justify-content:center}.dp-doughnut-legend span{display:flex;align-items:center;gap:4px;font-size:.55rem;color:var(--text-muted, #94a3b8)}.dp-doughnut-legend i{width:6px;height:6px;border-radius:2px;display:inline-block;font-style:normal}.dp-bars{display:flex;align-items:flex-end;gap:6px;height:80px;width:100%;padding-top:4px}.dp-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.dp-bar-col>span{font-size:.5rem;color:var(--text-muted, #94a3b8);font-weight:500}.dp-bar{width:100%;border-radius:3px 3px 0 0;display:flex;flex-direction:column;overflow:hidden;margin-top:auto}.dp-bar-fill{width:100%}.dp-bar-fill.yours{background:#60a5fa}.dp-bar-fill.others{background:#475569}.dp-currency-list{display:flex;flex-direction:column;gap:2px}.dp-currency-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;transition:background .15s}.dp-currency-row:hover{background:#ffffff08}.dp-currency-icon{font-size:1rem;line-height:1}.dp-currency-desc{flex:1;color:var(--text-secondary, #cbd5e1);font-size:.72rem;font-weight:500}.dp-currency-amount{font-weight:700;color:var(--text-primary, #e2e8f0);font-size:.75rem;font-variant-numeric:tabular-nums}.dp-currency-total{display:flex;justify-content:space-between;align-items:center;padding:10px 10px 4px;margin-top:4px;border-top:1px solid rgba(255,255,255,.08)}.dp-currency-total span:first-child{font-size:.62rem;color:var(--text-muted, #94a3b8);text-transform:uppercase;letter-spacing:.04em;font-weight:500}.dp-currency-total-value{font-weight:700;font-size:.85rem;color:var(--accent-emerald, #10b981)}.hero-right .dp-window{transform:perspective(1200px) rotateY(-8deg) rotateX(2deg);transition:transform .4s ease}.hero-right:hover .dp-window{transform:perspective(1200px) rotateY(-3deg) rotateX(1deg)}@media(max-width:768px){.dp-window{font-size:.65rem;max-width:100%}.dp-kpi-row,.dp-window--compact .dp-kpi-row{grid-template-columns:repeat(2,1fr)}.dp-charts-row{grid-template-columns:1fr}.dp-trend-cats,.dp-toolbar-pills{display:none}.hero-right .dp-window,.hero-right:hover .dp-window{transform:none}}@media(max-width:480px){.dp-content{padding:10px;gap:10px}.dp-kpi-value{font-size:.75rem}.dp-doughnut{width:64px;height:64px;-webkit-mask:radial-gradient(circle at center,transparent 13px,black 14px);mask:radial-gradient(circle at center,transparent 13px,black 14px)}.dp-bars{height:60px}}.in-app-browser-warning{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.in-app-browser-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);padding:40px 32px;max-width:400px;width:100%;text-align:center}.in-app-browser-icon{font-size:3rem;margin-bottom:16px}.in-app-browser-title{font-family:var(--font-heading);font-size:1.5rem;color:var(--text-primary);margin-bottom:12px}.in-app-browser-message{color:var(--text-secondary);line-height:1.6;margin-bottom:24px}.in-app-browser-instructions{background:var(--bg-secondary);border-radius:var(--radius-md);padding:16px;margin-bottom:24px;border-left:3px solid var(--accent-blue)}.in-app-browser-instructions p{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.in-app-browser-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;width:100%;max-width:280px}.in-app-browser-btn.primary{background:var(--accent-blue);color:#fff}.in-app-browser-btn.primary:hover{background:var(--accent-blue-hover);transform:translateY(-2px)}.in-app-browser-btn.primary:active{transform:translateY(0)}.in-app-browser-btn .btn-icon{font-size:1.1rem}.in-app-browser-hint{font-size:.8rem;color:var(--text-muted);margin-top:20px;line-height:1.5}@media(max-width:480px){.in-app-browser-card{padding:32px 24px}.in-app-browser-title{font-size:1.25rem}.in-app-browser-icon{font-size:2.5rem}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 24px}.empty-state-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:24px}.empty-state-plain{background:transparent;border:none}.empty-state-icon{font-size:3rem;margin-bottom:16px;opacity:.6}.empty-state-title{font-family:var(--font-heading);font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.empty-state-body{font-size:.9rem;color:var(--text-muted);max-width:320px;line-height:1.5;margin-bottom:24px}.empty-state-actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:280px}.empty-state-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:.9rem;font-weight:600;letter-spacing:.01em;text-decoration:none;cursor:pointer;transition:all var(--transition-fast);border:none;width:100%}.empty-state-btn.primary{background:var(--accent-emerald);color:#fff;box-shadow:0 2px 8px #10b9814d}.empty-state-btn.primary:hover{background:var(--accent-emerald-hover);transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.empty-state-btn.secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.empty-state-btn.secondary:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--accent-blue)}@media(max-width:480px){.empty-state{padding:32px 16px}.empty-state-title{font-size:1.1rem}.empty-state-btn{min-height:48px}}.hint-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:20px;animation:hintSlideIn .3s ease-out}@keyframes hintSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.hint-banner-content{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}.hint-banner-icon{flex-shrink:0;font-size:1.1rem;line-height:1}.hint-banner-text{display:flex;flex-direction:column;gap:2px;min-width:0}.hint-banner-title{font-weight:600;font-size:.875rem;line-height:1.3}.hint-banner-body{font-size:.8rem;opacity:.85;line-height:1.4}.hint-banner-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.hint-banner-cta{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:var(--radius-sm);font-family:var(--font-heading);font-size:.8rem;font-weight:600;letter-spacing:.01em;text-decoration:none;cursor:pointer;transition:all var(--transition-fast);border:none;white-space:nowrap}.hint-banner-arrow{transition:transform var(--transition-fast)}.hint-banner-cta:hover .hint-banner-arrow{transform:translate(2px)}.hint-banner-dismiss{background:transparent;border:none;padding:4px 8px;font-size:1.25rem;cursor:pointer;opacity:.5;transition:opacity var(--transition-fast);line-height:1}.hint-banner-dismiss:hover{opacity:1}.hint-banner-dismiss-actions{display:flex;align-items:center;gap:8px}.hint-banner-dismiss-secondary{background:transparent;border:1px solid rgba(255,255,255,.3);padding:6px 12px;font-size:.8rem;font-weight:500;cursor:pointer;opacity:.7;transition:all var(--transition-fast);border-radius:var(--radius-sm);white-space:nowrap}.hint-banner-dismiss-secondary:hover{opacity:1;background:#ffffff1a}.hint-banner-info{background:#3b82f61a;border:1px solid rgba(59,130,246,.3);color:var(--text-primary)}.hint-banner-info .hint-banner-cta{background:var(--accent-blue);color:#fff}.hint-banner-info .hint-banner-cta:hover{background:var(--accent-blue-hover)}.hint-banner-info .hint-banner-dismiss{color:var(--text-secondary)}.hint-banner-success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--text-primary)}.hint-banner-success .hint-banner-cta{background:var(--accent-emerald);color:#fff}.hint-banner-success .hint-banner-cta:hover{background:var(--accent-emerald-hover)}.hint-banner-warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:var(--text-primary)}.hint-banner-warning .hint-banner-cta{background:var(--accent-coral);color:#fff}.hint-banner-warning .hint-banner-cta:hover{background:#ea580c}@media(max-width:640px){.hint-banner{flex-direction:column;align-items:stretch;gap:12px}.hint-banner-actions{justify-content:space-between}.hint-banner-dismiss-actions{gap:6px}.hint-banner-cta{flex:1;justify-content:center;min-height:40px}.hint-banner-dismiss-secondary{font-size:.75rem;padding:6px 12px;min-height:40px}}.features-hero{text-align:center;padding:48px 0 64px}.features-hero-content{max-width:700px;margin:0 auto}.features-hero-title{font-family:var(--font-heading);font-size:clamp(2rem,5vw,3rem);font-weight:700;color:var(--text-primary);margin-bottom:16px;line-height:1.2}.features-hero-subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:32px;line-height:1.6}.features-hero-cta{display:flex;justify-content:center}.btn-primary-large{display:inline-flex;align-items:center;gap:12px;padding:16px 32px;background:linear-gradient(135deg,var(--accent-emerald) 0%,#059669 100%);color:#fff;text-decoration:none;font-family:var(--font-heading);font-weight:600;font-size:1.1rem;letter-spacing:.01em;border-radius:var(--radius-md);transition:all var(--transition-fast);box-shadow:0 4px 20px #10b98159;border:none;cursor:pointer}.btn-primary-large:hover{transform:translateY(-3px);box-shadow:0 8px 30px #10b98173}.feature-showcase{padding:48px 0;border-top:1px solid var(--border-color)}.showcase-item{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;max-width:1000px;margin:0 auto}.showcase-item--reverse{direction:rtl}.showcase-item--reverse>*{direction:ltr}.showcase-text{display:flex;flex-direction:column;gap:12px}.showcase-badge{font-size:2.5rem;line-height:1}.showcase-text h2{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.3}.showcase-text p{font-size:1rem;color:var(--text-secondary);line-height:1.7}.showcase-visual{display:flex;justify-content:center}.feature-free-banner{padding:64px 0;border-top:1px solid var(--border-color)}.free-banner-content{max-width:600px;margin:0 auto;text-align:center;background:linear-gradient(135deg,#10b9810f,#3b82f60f);border:1px solid rgba(16,185,129,.15);border-radius:var(--radius-lg);padding:48px 40px}.free-banner-icon{font-size:3rem;line-height:1;display:block;margin-bottom:16px}.free-banner-content h2{font-family:var(--font-heading);font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:12px}.free-banner-content p{font-size:1.05rem;color:var(--text-secondary);line-height:1.7}.features-additional{padding:64px 0;border-top:1px solid var(--border-color)}.features-section-title{font-family:var(--font-heading);font-size:1.75rem;font-weight:600;color:var(--text-primary);text-align:center;margin-bottom:40px}.features-list{display:flex;flex-direction:column;gap:24px;max-width:800px;margin:0 auto}.features-list-item{display:flex;gap:20px;align-items:flex-start;padding:24px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.features-list-item:hover{border-color:var(--border-light);background:var(--bg-card-hover)}.features-list-icon{font-size:1.75rem;line-height:1;flex-shrink:0}.features-list-item h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.features-list-item p{font-size:.95rem;color:var(--text-muted);line-height:1.6}.features-cta-section{padding:64px 0}.features-cta-card{max-width:500px;margin:0 auto;text-align:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:48px 32px}.features-cta-card h2{font-family:var(--font-heading);font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:12px}.features-cta-card>p{color:var(--text-secondary);margin-bottom:24px}@media(max-width:768px){.features-hero{padding:32px 0 48px}.feature-showcase{padding:40px 0}.showcase-item,.showcase-item--reverse{grid-template-columns:1fr;gap:32px;direction:ltr}.showcase-visual{order:-1}.showcase-text h2{font-size:1.3rem}.features-additional,.features-cta-section,.feature-free-banner{padding:40px 0}.features-list-item{flex-direction:column;text-align:center;gap:12px;align-items:center}.free-banner-content,.features-cta-card{padding:32px 20px}}
