*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #ebedf0;--bg-card: #ffffff;--bg-subtle: #f4f5f7;--bg-input: #f4f5f7;--border: #e4e6ea;--text: #1d2230;--text-muted: #8c92a0;--charcoal: #383d47;--charcoal-2: #2b2f38;--accent: #2f80ed;--accent-hover: #1f6fd6;--accent-dim: rgba(47, 128, 237, .1);--danger: #c75c6a;--success: #2e9e7b;--color-neli-bg: #f9d7e5;--color-neli-accent: #d6588a;--color-alex-bg: #d7e6fb;--color-alex-accent: #2f80ed;--warning: #f59e0b;--radius: 18px;--radius-sm: 12px;--shadow-card: 0 1px 2px rgba(16, 24, 40, .04), 0 1px 3px rgba(16, 24, 40, .06);--tab-h: 64px;--header-h: 56px;--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}.app-shell{display:flex;flex-direction:column;height:100%;padding-top:var(--safe-top)}.app-header{height:var(--header-h);background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0;box-shadow:var(--shadow-card)}.app-header h1{font-size:18px;font-weight:700;color:var(--charcoal);letter-spacing:-.3px}.app-header-right{display:flex;align-items:center;gap:10px}.app-header-user{font-size:14px;color:var(--text-muted)}.app-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--tab-h) + var(--safe-bottom) + 8px)}.tab-bar{position:fixed;bottom:0;left:0;right:0;height:calc(var(--tab-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--bg-card);border-top:1px solid var(--border);display:flex;z-index:100}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-decoration:none;color:var(--text-muted);font-size:11px;font-weight:500;transition:color .15s;-webkit-tap-highlight-color:transparent}.tab-item.active{color:var(--accent)}.tab-icon{font-size:22px;line-height:1}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit;color:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;transition:background .15s,opacity .15s;-webkit-tap-highlight-color:transparent}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:active{opacity:.85}.btn-ghost{background:transparent;color:var(--text-muted);padding:8px 12px}.btn-ghost:hover{color:var(--text);background:var(--bg-subtle)}.btn-danger{background:#ef444414;color:var(--danger)}.btn-danger:hover{background:#ef444426}.btn-sm{padding:6px 12px;font-size:13px}.btn:disabled{opacity:.5;cursor:not-allowed}input,textarea,select{width:100%;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:16px;font-family:inherit;padding:11px 14px;outline:none;transition:border-color .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}input:focus,textarea:focus,select:focus{border-color:var(--accent);background:var(--bg-card)}textarea{resize:vertical;min-height:80px}label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:6px;font-weight:500}.form-group{margin-bottom:14px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-card)}.login-page{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 20px;padding-top:calc(var(--safe-top) + 24px);padding-bottom:calc(var(--safe-bottom) + 24px);background:var(--bg)}.login-logo{width:56px;height:56px;border-radius:16px;background:var(--charcoal);display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:14px}.login-title{font-size:28px;font-weight:700;color:var(--text);margin-bottom:4px;letter-spacing:-.5px}.login-subtitle{font-size:14px;color:var(--text-muted);margin-bottom:32px}.login-form{width:100%;max-width:360px;display:flex;flex-direction:column;gap:0}.login-form .form-group{margin-bottom:16px}.login-submit{width:100%;padding:14px;font-size:16px;border-radius:var(--radius);margin-top:8px}.login-error{color:var(--danger);font-size:13px;margin-top:8px;text-align:center}.login-quick{display:flex;gap:8px;margin-top:20px;width:100%;max-width:360px}.login-quick-btn{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 8px;font-size:13px;color:var(--text-muted);box-shadow:var(--shadow-card);transition:border-color .15s,color .15s}.login-quick-btn:hover{border-color:var(--charcoal);color:var(--text)}.tasks-page{padding:16px}.tasks-toolbar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.filter-chip{padding:6px 14px;border-radius:999px;font-size:13px;font-weight:500;background:var(--bg-subtle);border:1px solid transparent;color:var(--text-muted);transition:all .15s;-webkit-tap-highlight-color:transparent}.filter-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.tasks-add-btn{margin-bottom:16px;width:100%}.task-group{margin-bottom:20px}.task-group-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.task-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px;box-shadow:var(--shadow-card);transition:border-color .15s}.task-card:last-child{margin-bottom:0}.task-card-header{display:flex;align-items:flex-start;gap:10px}.task-status-btn{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s;-webkit-tap-highlight-color:transparent}.task-status-btn.status-todo{border-color:var(--text-muted)}.task-status-btn.status-doing{border-color:var(--warning);background:#f59e0b1a;color:var(--warning)}.task-status-btn.status-done{border-color:var(--success);background:#2e9e7b1a;color:var(--success)}.task-info{flex:1;min-width:0}.task-title{font-size:15px;font-weight:600;color:var(--text);line-height:1.3}.task-title.done{text-decoration:line-through;color:var(--text-muted)}.task-desc{font-size:13px;color:var(--text-muted);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-meta{display:flex;align-items:center;gap:8px;margin-top:8px;flex-wrap:wrap}.task-badge{font-size:11px;font-weight:500;padding:2px 8px;border-radius:999px}.task-badge.shared{background:var(--accent-dim);color:var(--charcoal)}.task-badge.personal{background:var(--bg-subtle);color:var(--text-muted)}.task-due{font-size:11px;color:var(--text-muted)}.task-due.overdue{color:var(--danger)}.task-actions{display:flex;gap:4px;margin-left:4px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:flex-end;justify-content:center;z-index:200;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-sheet{background:var(--bg-card);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:600px;padding:20px 20px calc(var(--tab-h) + var(--safe-bottom) + 28px);max-height:90vh;max-height:90dvh;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-size:17px;font-weight:700;color:var(--text)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-subtle);font-size:16px;color:var(--text-muted)}.status-chips{display:flex;gap:8px}.status-chip{flex:1;padding:8px 6px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text-muted);text-align:center;background:var(--bg-subtle);transition:all .15s}.status-chip.active.todo{background:var(--bg-subtle);border-color:var(--text-muted);color:var(--text)}.status-chip.active.doing{background:#f59e0b1a;border-color:var(--warning);color:var(--warning)}.status-chip.active.done{background:#2e9e7b1a;border-color:var(--success);color:var(--success)}.placeholder-page{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center;color:var(--text-muted)}.placeholder-icon{font-size:56px;margin-bottom:16px;opacity:.5}.placeholder-title{font-size:20px;font-weight:600;color:var(--text);margin-bottom:8px}.placeholder-text{font-size:14px;line-height:1.6;max-width:260px}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:14px}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--charcoal);border-radius:50%;animation:spin .7s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}.offline-banner{background:#f59e0b1f;border-bottom:1px solid rgba(245,158,11,.25);color:var(--warning);font-size:12px;font-weight:500;text-align:center;padding:6px}.finance-page{display:flex;flex-direction:column;height:100%}.finance-tabs{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;border-bottom:1px solid var(--border);background:var(--bg-card);flex-shrink:0;scrollbar-width:none}.finance-tabs::-webkit-scrollbar{display:none}.finance-tab{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 14px;font-size:11px;font-weight:500;color:var(--text-muted);transition:color .15s,border-bottom .15s;border-bottom:2px solid transparent;-webkit-tap-highlight-color:transparent}.finance-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.finance-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.finance-section{padding:16px}.month-switcher{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:16px}.month-nav{width:36px;height:36px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);color:var(--text);font-size:20px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-card)}.month-label{font-size:16px;font-weight:600;text-transform:capitalize;text-align:center;color:var(--text)}.month-label-wrap{display:flex;flex-direction:column;align-items:center;min-width:160px}.period-sub-label{font-size:11px;color:var(--text-muted);font-weight:400;margin-top:1px}.period-settings-btn{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--accent);background:none;border:none;cursor:pointer;padding:4px 0;opacity:.8}.period-settings-btn:hover{opacity:1}.balance-hero{text-align:center;margin-bottom:16px;padding:20px;background:var(--bg-card);border:1px solid var(--accent-dim);border-top:2px solid var(--accent);border-radius:var(--radius);box-shadow:var(--shadow-card)}.balance-label{font-size:13px;color:var(--text-muted);margin-bottom:6px}.balance-amount{font-size:32px;font-weight:700;color:var(--success);letter-spacing:-1px}.balance-amount.negative{color:var(--danger)}.overview-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.overview-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-card)}.overview-card-icon{width:36px;height:36px;border-radius:50%;background:var(--bg-subtle);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.overview-card-label{font-size:12px;color:var(--text-muted)}.overview-card-amount{font-size:16px;font-weight:700;margin-top:2px;color:var(--text)}.income-card .overview-card-amount{color:var(--success)}.expense-card .overview-card-amount{color:var(--danger)}.goals-mini{margin-bottom:12px}.goals-mini-title{font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:4px}.goals-mini-amount{font-size:15px;font-weight:600;margin-bottom:10px;color:var(--text)}.goal-mini-item{display:flex;align-items:center;gap:10px;margin-bottom:8px}.goal-mini-icon{width:36px;height:36px;border-radius:50%;background:var(--charcoal);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.goal-mini-info{flex:1;min-width:0}.goal-mini-name{font-size:13px;display:block;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.goal-mini-pct{font-size:12px;color:var(--text-muted);flex-shrink:0}.progress-bar-wrap{width:100%;height:6px;background:var(--bg-subtle);border-radius:999px;overflow:hidden}.progress-bar{height:100%;border-radius:999px;transition:width .3s ease;background:var(--charcoal)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-title{font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.category-card{margin-bottom:10px}.category-card-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.category-icon{width:38px;height:38px;border-radius:50%;background:var(--charcoal);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.category-name{flex:1;font-size:14px;font-weight:500;color:var(--text)}.category-actions{display:flex;gap:4px}.category-amounts{display:flex;gap:12px;font-size:13px;color:var(--text-muted);margin-bottom:4px}.category-spent{color:var(--text)}.category-remaining{font-size:12px;color:var(--success);margin-top:4px}.category-remaining.overbudget{color:var(--danger);font-weight:600}.limit-edit-row{display:flex;gap:6px;align-items:center;margin-bottom:8px}.goal-card{margin-bottom:12px}.goal-card-header{display:flex;align-items:center;gap:10px}.goal-icon{width:44px;height:44px;border-radius:50%;background:var(--charcoal);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.goal-info{flex:1;min-width:0}.goal-title{font-size:15px;font-weight:600;margin-bottom:2px;color:var(--text)}.goal-amounts{font-size:13px;color:var(--text-muted)}.goal-pct{font-size:18px;font-weight:700;color:var(--charcoal);flex-shrink:0}.goal-card-actions{display:flex;gap:8px;margin-top:10px}.fund-row{display:flex;gap:6px;align-items:center;margin-top:10px}.archived-goal{opacity:.6}.goal-archived-badge{font-size:11px;background:#2e9e7b1a;color:var(--success);padding:2px 8px;border-radius:999px}.analytics-summary .analytics-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--text)}.analytics-summary .analytics-row:last-child{border-bottom:none}.analytics-balance-row{font-weight:600;font-size:15px!important}.analytics-section-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px}.text-income{color:var(--success);font-weight:600}.text-expense{color:var(--danger);font-weight:600}.trend-chart{display:flex;align-items:flex-end;gap:8px;height:100px;padding-bottom:20px;position:relative}.trend-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;position:relative}.trend-bars{display:flex;align-items:flex-end;gap:2px;flex:1;width:100%}.trend-bar{flex:1;border-radius:3px 3px 0 0;min-height:3px;transition:height .3s}.income-bar{background:var(--success);opacity:.75}.expense-bar{background:var(--danger);opacity:.75}.trend-label{font-size:10px;color:var(--text-muted);position:absolute;bottom:0;text-transform:capitalize}.trend-legend{display:flex;gap:16px;font-size:11px;color:var(--text-muted);margin-top:4px}.legend-income{color:var(--success)}.legend-expense{color:var(--danger)}.top-cat-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--text)}.top-cat-row:last-child{border-bottom:none}.top-cat-rank{color:var(--text-muted);width:24px;flex-shrink:0}.top-cat-icon{width:28px;height:28px;border-radius:50%;background:var(--charcoal);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.top-cat-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-cat-amount{font-weight:600;flex-shrink:0}.top-cat-share{color:var(--text-muted);width:36px;text-align:right;flex-shrink:0}.hints-card{margin-bottom:16px}.hints-disclaimer{font-size:10px;font-weight:400;color:var(--text-muted);text-transform:none;letter-spacing:0}.hint{padding:8px 10px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:8px;line-height:1.5;color:var(--text)}.hint:last-child{margin-bottom:0}.hint-ok{background:#2e9e7b14;color:#166044;border-left:3px solid var(--success)}.hint-warn{background:#f59e0b12;color:#92400e;border-left:3px solid var(--warning)}.hint-info{background:var(--bg-subtle);color:var(--charcoal);border-left:3px solid var(--charcoal)}.hint-danger{background:#c75c6a14;color:#8b2535;border-left:3px solid var(--danger)}.checkbox-label{display:flex;align-items:center;font-size:14px;color:var(--text);cursor:pointer;margin-bottom:0}.tip-of-day{margin-bottom:12px}.tip-header{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px;color:var(--charcoal)}.tip-text{font-size:14px;line-height:1.5}.tip-disclaimer{font-size:10px;opacity:.6;margin-top:4px;font-style:italic}.event-card{margin-bottom:10px;transition:border-color .15s;cursor:pointer}.event-card:hover{border-color:var(--charcoal)}.event-card-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}.event-icon{width:44px;height:44px;border-radius:50%;background:var(--charcoal);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.event-info{flex:1;min-width:0}.event-title{font-size:15px;font-weight:600;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.event-type{font-size:12px;color:var(--text-muted)}.event-arrow{font-size:20px;color:var(--text-muted);flex-shrink:0}.event-amounts{display:flex;gap:12px;font-size:13px;color:var(--text-muted)}.event-spent{color:var(--text)}.event-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.event-type-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:12px;font-weight:500;color:var(--text-muted);background:var(--bg-subtle);transition:all .15s}.event-type-btn span:first-child{font-size:20px}.event-type-btn.active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.event-detail-header{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0;box-shadow:var(--shadow-card)}.event-detail-title{flex:1;font-size:16px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.event-dashboard{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.event-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 8px;text-align:center;box-shadow:var(--shadow-card)}.event-stat-label{font-size:11px;color:var(--text-muted);margin-bottom:4px}.event-stat-value{font-size:15px;font-weight:700;letter-spacing:-.3px;color:var(--text)}.dashboard-period-switcher{display:flex;gap:6px;margin-bottom:16px}.period-btn{flex:1;padding:8px 6px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text-muted);text-align:center;background:var(--bg-subtle);transition:all .15s}.period-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.cat-bar-row{margin-bottom:10px}.cat-bar-label{display:flex;align-items:center;gap:6px;font-size:13px;margin-bottom:2px;color:var(--text)}.cat-bar-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cat-bar-amount{font-weight:600;flex-shrink:0}.cat-bar-share{color:var(--text-muted);flex-shrink:0;width:32px;text-align:right}.donut-wrap{display:flex;gap:16px;align-items:center}.donut{width:80px;height:80px;border-radius:50%;flex-shrink:0;mask:radial-gradient(circle at center,transparent 30px,black 30px);-webkit-mask:radial-gradient(circle at center,transparent 30px,black 30px)}.donut-legend{flex:1;display:flex;flex-direction:column;gap:4px}.donut-legend-item{display:flex;align-items:center;gap:6px;font-size:12px}.donut-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.donut-legend-icon{flex-shrink:0}.donut-legend-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted)}.donut-legend-pct{flex-shrink:0;font-weight:600;color:var(--text)}.calendar-page{display:flex;flex-direction:column;padding:0 0 12px}.cal-week-nav{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 6px;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0}.cal-nav-btn{width:36px;height:36px;border-radius:50%;background:var(--bg-subtle);color:var(--text);font-size:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:background .15s}.cal-nav-btn:hover{background:var(--accent-dim);color:var(--charcoal)}.cal-week-label{flex:1;text-align:center}.cal-week-range{font-size:15px;font-weight:600;color:var(--text);text-transform:capitalize}.cal-today-row{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:8px 14px;background:var(--bg-card);border-bottom:1px solid var(--border)}.cal-today-btn{font-size:13px;font-weight:500;color:var(--charcoal);padding:6px 12px;border-radius:var(--radius-sm);background:var(--accent-dim);border:1px solid transparent;-webkit-tap-highlight-color:transparent;transition:opacity .15s}.cal-today-btn:hover{opacity:.8}.cal-add-btn{font-size:13px;padding:7px 14px!important}.cal-week-grid{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px 12px;display:flex;flex-direction:column;gap:8px}.cal-day{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card)}.cal-day-today{border-color:var(--charcoal)}.cal-day-header{display:flex;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .12s}.cal-day-header:hover{background:var(--bg-subtle)}.cal-day-name{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;width:22px;flex-shrink:0}.cal-day-num{font-size:17px;font-weight:700;color:var(--text);line-height:1}.cal-day-num.today{color:var(--charcoal)}.cal-day-items{padding:6px 10px 10px;display:flex;flex-direction:column;gap:4px}.cal-empty{font-size:12px;color:var(--text-muted);padding:4px;font-style:italic}.cal-item{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:var(--radius-sm);font-size:13px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .12s;min-width:0;color:var(--text)}.cal-item-event{background:var(--accent-dim);border:1px solid rgba(47,128,237,.2)}.cal-item-event:hover{background:#2f80ed29}.cal-item-task{background:#2e9e7b12;border:1px solid rgba(46,158,123,.18);cursor:default}.cal-item-task.cal-item-done .cal-item-title{text-decoration:line-through;color:var(--text-muted)}.cal-item-time{font-size:11px;color:var(--text-muted);flex-shrink:0;min-width:36px;font-variant-numeric:tabular-nums}.cal-item-allday{font-style:italic;min-width:auto}.cal-item-icon{font-size:13px;flex-shrink:0;line-height:1}.cal-item-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.cal-item-bell{flex-shrink:0;color:var(--accent);opacity:.7}.assistant-header{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:4px;box-shadow:var(--shadow-card)}.assistant-icon{width:48px;height:48px;border-radius:14px;background:var(--charcoal);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.assistant-title{font-size:16px;font-weight:700;color:var(--text)}.assistant-subtitle{font-size:12px;color:var(--text-muted);margin-top:2px}.assistant-input-row{display:flex;gap:8px}.assistant-input-row input{flex:1}.assistant-answer{margin-top:12px;padding:14px 16px}.assistant-examples{display:flex;flex-direction:column;gap:6px}.assistant-example-btn{text-align:left;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;color:var(--text-muted);box-shadow:var(--shadow-card);transition:border-color .15s,color .15s;-webkit-tap-highlight-color:transparent}.assistant-example-btn:hover{border-color:var(--charcoal);color:var(--text)}.finance-tab-icon{display:flex;align-items:center;justify-content:center;color:inherit}.task-assignee-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;color:var(--charcoal);background:var(--bg-subtle);border:1px solid var(--border);border-radius:999px;padding:2px 8px 2px 3px}.task-assignee-avatar{width:16px;height:16px;border-radius:50%;background:var(--charcoal);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.shopping-page{padding:16px}.shopping-input-row{display:flex;gap:8px;margin-bottom:20px;align-items:flex-end}.shopping-input-title{flex:1;min-width:0}.shopping-input-qty{width:90px;flex-shrink:0}.shopping-add-btn{flex-shrink:0;padding:11px 18px;font-size:20px;line-height:1}.shopping-section{margin-bottom:20px}.shopping-section-checked{opacity:.75}.shopping-section-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;display:block}.shopping-section-toggle{background:none;border:none;cursor:pointer;padding:0;font-family:inherit;-webkit-tap-highlight-color:transparent;transition:color .15s;text-align:left;width:100%}.shopping-section-toggle:hover{color:var(--text)}.shopping-item{display:flex;align-items:center;gap:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:11px 12px 11px 14px;margin-bottom:8px;box-shadow:var(--shadow-card)}.shopping-item:last-child{margin-bottom:0}.shopping-item-done{opacity:.7}.shopping-check-btn{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;background:none;transition:all .15s;-webkit-tap-highlight-color:transparent;cursor:pointer}.shopping-check-btn:hover{border-color:var(--accent)}.shopping-check-btn-done{border-color:var(--success);background:#2e9e7b1f;position:relative}.shopping-check-btn-done:after{content:"✓";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--success);font-weight:700}.shopping-item-body{flex:1;min-width:0;display:flex;align-items:baseline;gap:8px}.shopping-item-title{font-size:15px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shopping-item-title-done{text-decoration:line-through;color:var(--text-muted)}.shopping-item-qty{font-size:12px;color:var(--text-muted);flex-shrink:0}.shopping-remove-btn{flex-shrink:0;color:var(--text-muted);font-size:12px;padding:4px 8px}.shopping-segment{display:flex;gap:0;margin-bottom:20px;background:var(--bg-subtle);border-radius:var(--radius);padding:3px}.shopping-segment-btn{flex:1;padding:8px 0;border:none;background:none;border-radius:calc(var(--radius) - 2px);font-size:14px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;font-family:inherit}.shopping-segment-btn.active{background:var(--accent);color:#fff}.wish-input-block{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.wish-input-title{width:100%}.wish-input-comment{width:100%;resize:none;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-input, var(--bg-card));color:var(--text);font-family:inherit;font-size:16px;padding:10px 12px;line-height:1.4;outline:none;transition:border-color .15s;box-sizing:border-box}.wish-input-comment::placeholder{color:var(--text-muted)}.wish-input-comment:focus{border-color:var(--accent)}.wish-add-btn{align-self:flex-end;min-width:120px}.wish-card{display:flex;align-items:flex-start;gap:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:11px 12px 11px 14px;margin-bottom:8px;box-shadow:var(--shadow-card)}.wish-card:last-child{margin-bottom:0}.wish-card-done{opacity:.7}.wish-card-left{padding-top:1px;flex-shrink:0}.wish-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.wish-card-title{font-size:15px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wish-card-title-done{text-decoration:line-through;color:var(--text-muted)}.wish-card-comment{font-size:13px;color:var(--text-muted);word-break:break-word;white-space:pre-wrap;overflow-wrap:break-word}.wish-card-owner{font-size:11px;color:var(--accent);font-weight:500;margin-top:2px}.person-neli .cal-item,.cal-item-task-neli{background:#f9d7e580;border-color:#d6588a40}.cal-item-task-alex{background:#d7e6fb80;border-color:#2f80ed38}.task-person-bar{width:3px;border-radius:2px;align-self:stretch;flex-shrink:0;margin-right:2px}.task-person-bar-neli{background:var(--color-neli-accent)}.task-person-bar-alex{background:var(--color-alex-accent)}.task-assignee-badge-neli{background:var(--color-neli-bg);border-color:#d6588a4d;color:var(--color-neli-accent)}.task-assignee-badge-alex{background:var(--color-alex-bg);border-color:#2f80ed4d;color:var(--color-alex-accent)}.fab-chat{position:fixed;bottom:calc(var(--tab-h) + var(--safe-bottom) + 16px);right:16px;width:52px;height:52px;border-radius:50%;background:var(--charcoal);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0000002e;z-index:50;-webkit-tap-highlight-color:transparent;transition:background .15s,transform .15s}.fab-chat:hover{background:var(--charcoal-2);transform:scale(1.05)}.fab-chat:active{transform:scale(.95)}.chat-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:flex-end;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.chat-modal-sheet{background:var(--bg-card);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:600px;padding:0;max-height:80vh;max-height:80dvh;display:flex;flex-direction:column;overflow:hidden}.chat-modal-header{display:flex;align-items:center;gap:10px;padding:16px 20px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.chat-modal-title{flex:1;font-size:16px;font-weight:700;color:var(--text)}.chat-modal-subtitle{font-size:11px;color:var(--text-muted);margin-top:1px}.chat-messages{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:12px 16px;display:flex;flex-direction:column;gap:8px}.chat-bubble{max-width:85%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.5}.chat-bubble-user{align-self:flex-end;background:var(--charcoal);color:#fff;border-bottom-right-radius:4px}.chat-bubble-bot{align-self:flex-start;background:var(--bg-subtle);color:var(--text);border-bottom-left-radius:4px;white-space:pre-wrap}.chat-quick-btns{display:flex;flex-direction:column;gap:6px;margin-top:4px}.chat-quick-btn{text-align:left;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;color:var(--accent);font-weight:500;box-shadow:var(--shadow-card);transition:border-color .15s,background .15s;-webkit-tap-highlight-color:transparent}.chat-quick-btn:hover{border-color:var(--accent);background:var(--accent-dim)}.chat-input-row{display:flex;gap:8px;padding:10px 16px calc(var(--safe-bottom) + 12px);border-top:1px solid var(--border);flex-shrink:0;background:var(--bg-card)}.chat-input-row input{flex:1;font-size:16px}.nearest-event-card{margin:12px 12px 0;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);box-shadow:var(--shadow-card);flex-shrink:0}.nearest-event-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:4px}.nearest-event-title{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nearest-event-date{font-size:12px;color:var(--text-muted);margin-top:2px}:root[data-theme=dark]{--bg: #0f141b;--bg-card: #1a212b;--bg-subtle: #222b37;--bg-input: #222b37;--border: #2c3744;--text: #e7ebf0;--text-muted: #8c96a5;--charcoal: #e7ebf0;--charcoal-2: #d0d8e4;--accent: #3d8ef5;--accent-hover: #2f80ed;--accent-dim: rgba(61, 142, 245, .13);--shadow-card: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 6px rgba(0, 0, 0, .2);--badge-bg: #2c3744;--color-neli-bg: rgba(214, 88, 138, .15);--color-alex-bg: rgba(47, 128, 237, .15)}:root[data-theme=dark] .category-icon,:root[data-theme=dark] .goal-icon,:root[data-theme=dark] .goal-mini-icon,:root[data-theme=dark] .top-cat-icon,:root[data-theme=dark] .event-icon,:root[data-theme=dark] .assistant-icon,:root[data-theme=dark] .fab-chat,:root[data-theme=dark] .chat-bubble-user{background:#3a4560;color:#e7ebf0}:root[data-theme=dark] .progress-bar{background:var(--accent)}:root[data-theme=dark] .hint-ok{color:#6ee7b7}:root[data-theme=dark] .hint-warn{color:#fcd34d}:root[data-theme=dark] .hint-info{color:var(--text)}:root[data-theme=dark] .hint-danger{color:#fca5a5}:root[data-theme=dark] .spinner{border-color:var(--border);border-top-color:var(--accent)}.app-header-user-btn{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:var(--radius-sm);-webkit-tap-highlight-color:transparent;transition:background .15s}.app-header-user-btn:hover{background:var(--bg-subtle)}.app-header-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1.5px solid var(--border);flex-shrink:0}.app-header-avatar-placeholder{width:28px;height:28px;border-radius:50%;background:var(--bg-subtle);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0}.profile-page{padding:20px 16px calc(var(--tab-h) + var(--safe-bottom) + 28px);max-width:480px;margin:0 auto;display:flex;flex-direction:column;gap:0}.profile-hero{display:flex;flex-direction:column;align-items:center;padding:28px 20px 24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);margin-bottom:16px}.profile-avatar-wrap{position:relative;width:88px;height:88px;border-radius:50%;cursor:pointer;margin-bottom:14px;-webkit-tap-highlight-color:transparent}.profile-avatar-img{width:88px;height:88px;border-radius:50%;object-fit:cover;border:2.5px solid var(--border);display:block}.profile-avatar-placeholder{width:88px;height:88px;border-radius:50%;background:var(--bg-subtle);border:2.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.profile-avatar-badge{position:absolute;bottom:2px;right:2px;width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-card)}.profile-avatar-spinner{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:3px solid transparent;border-top-color:var(--accent);animation:spin .7s linear infinite}.profile-name{font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.3px;margin-bottom:3px;text-align:center}.profile-username{font-size:14px;color:var(--text-muted);margin-bottom:12px}.profile-remove-photo{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--danger);background:#c75c6a12;border:none;border-radius:var(--radius-sm);padding:5px 12px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s}.profile-remove-photo:hover{background:#c75c6a24}.profile-remove-photo:disabled{opacity:.5;cursor:not-allowed}.profile-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);overflow:hidden;margin-bottom:20px}.profile-row{display:flex;align-items:center;gap:14px;padding:14px 16px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .12s;border-bottom:1px solid var(--border)}.profile-row:last-child{border-bottom:none}.profile-row:hover,.profile-row:active{background:var(--bg-subtle)}.profile-row-badge{width:36px;height:36px;border-radius:10px;background:var(--bg-subtle);display:flex;align-items:center;justify-content:center;color:var(--text);flex-shrink:0}:root[data-theme=dark] .profile-row-badge{background:#2c3744;color:var(--text)}.profile-row-badge-danger{background:#c75c6a17;color:var(--danger)}:root[data-theme=dark] .profile-row-badge-danger{background:#c75c6a26}.profile-row-label{flex:1;font-size:15px;font-weight:500;color:var(--text)}.profile-row-danger .profile-row-label{color:var(--danger)}.profile-row-chevron{color:var(--text-muted);flex-shrink:0}.profile-toggle{width:44px;height:26px;border-radius:999px;background:var(--border);position:relative;flex-shrink:0;transition:background .2s}.profile-toggle.on{background:var(--accent)}.profile-toggle-knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 4px #0003}.profile-toggle.on .profile-toggle-knob{transform:translate(18px)}.profile-toast{position:fixed;bottom:calc(var(--tab-h) + var(--safe-bottom) + 20px);left:50%;transform:translate(-50%);background:var(--charcoal-2);color:#fff;font-size:13px;font-weight:500;padding:10px 20px;border-radius:999px;box-shadow:0 4px 16px #0003;z-index:300;white-space:nowrap;pointer-events:none}:root[data-theme=dark] .profile-toast{background:#3a4560;color:#fff}.profile-back-btn{align-self:flex-start;margin-bottom:8px;font-size:14px;padding:8px 4px;color:var(--accent)}.profile-version{text-align:center;font-size:11px;color:var(--text-muted);opacity:.5;margin-top:4px}.task-status-select{width:auto;display:inline-block;padding:3px 28px 3px 11px;font-size:13px;font-weight:600;line-height:1.3;border-radius:999px;background-color:var(--bg-subtle);color:var(--text-muted);border:1px solid var(--border);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238c92a0' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center}.task-status-select.status-doing{color:var(--accent);border-color:var(--accent)}.task-status-select.status-done{color:var(--success);border-color:var(--success)}.status-filter-select{width:auto;min-width:170px;display:inline-block;padding:9px 38px 9px 16px;font-size:14px;font-weight:600;border-radius:999px;background-color:var(--bg-subtle);color:var(--text);border:1px solid var(--border);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238c92a0' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.shopping-edit-btn{color:var(--text-muted)}.shopping-item-edit{align-items:center;gap:8px}.shopping-edit-fields{display:flex;gap:8px;flex:1;min-width:0}.shopping-edit-fields input:first-child{flex:1;min-width:0}.shopping-edit-fields input:last-child{width:90px;flex-shrink:0}.shopping-edit-actions{display:flex;gap:6px;flex-shrink:0}.wish-card-edit{display:block}.wish-edit-fields{display:flex;flex-direction:column;gap:8px;width:100%}.wish-edit-actions{display:flex;gap:8px}.wish-edit-actions .btn{flex:1}.ops-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px;padding:10px 12px}.ops-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ops-info{flex:1;min-width:0}.ops-amount{font-size:15px;font-weight:700}.ops-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.ops-note{font-size:12px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ops-actions{display:flex;gap:4px;flex-shrink:0;align-items:center}
