@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.chatbot-fab{bottom:calc(var(--nav-height,72px) + 16px);background:linear-gradient(135deg, var(--primary,#4a90d9), var(--primary-dark,#3a7bc8));color:#fff;cursor:pointer;z-index:1000;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;right:16px;box-shadow:0 4px 20px #4a90d966}.chatbot-fab:hover{transform:scale(1.08);box-shadow:0 6px 24px #4a90d980}.chatbot-fab:active{transform:scale(.95)}.chatbot-fab--open{background:var(--text-secondary,#5a6b7f);box-shadow:0 4px 12px #0003}.chatbot-fab__pulse{background:var(--primary,#4a90d9);opacity:0;pointer-events:none;border-radius:50%;width:100%;height:100%;animation:2.5s ease-out infinite chatbot-pulse;position:absolute}@keyframes chatbot-pulse{0%{opacity:.4;transform:scale(1)}to{opacity:0;transform:scale(1.6)}}.chatbot-panel{bottom:calc(var(--nav-height,72px) + 80px);background:var(--card,#fff);z-index:999;opacity:0;pointer-events:none;border-radius:20px;flex-direction:column;width:350px;max-height:500px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;right:16px;overflow:hidden;transform:translateY(20px)scale(.95);box-shadow:0 8px 40px #00000026}.chatbot-panel--open{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.chatbot-header{background:linear-gradient(135deg, var(--primary,#4a90d9), var(--primary-dark,#3a7bc8));color:#fff;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.chatbot-header__info{align-items:center;gap:8px;font-size:.95rem;font-weight:600;display:flex}.chatbot-header__sparkle{color:gold;animation:2s ease-in-out infinite chatbot-sparkle}@keyframes chatbot-sparkle{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.chatbot-header__close{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:background .2s;display:flex}.chatbot-header__close:hover{background:#ffffff59}.chatbot-messages{background:var(--bg,#f5f7fa);flex-direction:column;flex:1;gap:12px;min-height:200px;max-height:340px;padding:16px;display:flex;overflow-y:auto}.chatbot-messages::-webkit-scrollbar{width:4px}.chatbot-messages::-webkit-scrollbar-thumb{background:var(--border,#e8edf2);border-radius:4px}.chatbot-msg{flex-direction:column;display:flex}.chatbot-msg--user{align-items:flex-end}.chatbot-msg--bot{align-items:flex-start}.chatbot-bubble{word-break:break-word;border-radius:16px;max-width:85%;padding:10px 14px;font-size:.875rem;line-height:1.5}.chatbot-bubble--user{background:var(--primary,#4a90d9);color:#fff;border-bottom-right-radius:4px}.chatbot-bubble--bot{background:var(--card,#fff);color:var(--text,#1a2332);border-bottom-left-radius:4px;box-shadow:0 1px 4px #0000000f}.chatbot-quick-replies{flex-wrap:wrap;gap:6px;margin-top:8px;padding-left:4px;display:flex}.chatbot-chip{border:1.5px solid var(--primary,#4a90d9);color:var(--primary,#4a90d9);cursor:pointer;white-space:nowrap;background:0 0;border-radius:20px;padding:6px 12px;font-size:.78rem;font-weight:500;transition:all .2s}.chatbot-chip:hover{background:var(--primary,#4a90d9);color:#fff}.chatbot-chip:active{transform:scale(.95)}.chatbot-typing{align-items:center;gap:4px;padding:12px 18px;display:flex}.chatbot-dot{background:var(--text-light,#94a3b8);border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite chatbot-bounce}.chatbot-dot:nth-child(2){animation-delay:.15s}.chatbot-dot:nth-child(3){animation-delay:.3s}@keyframes chatbot-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.chatbot-input{border-top:1px solid var(--border,#e8edf2);background:var(--card,#fff);align-items:center;gap:8px;padding:12px;display:flex}.chatbot-input__field{border:1.5px solid var(--border,#e8edf2);background:var(--bg,#f5f7fa);color:var(--text,#1a2332);border-radius:24px;outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:.875rem;transition:border-color .2s}.chatbot-input__field:focus{border-color:var(--primary,#4a90d9)}.chatbot-input__field::placeholder{color:var(--text-light,#94a3b8)}.chatbot-input__send{background:var(--primary,#4a90d9);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex}.chatbot-input__send:hover:not(:disabled){background:var(--primary-dark,#3a7bc8);transform:scale(1.05)}.chatbot-input__send:disabled{opacity:.4;cursor:not-allowed}@media (width<=480px){.chatbot-panel{right:0;bottom:calc(var(--nav-height,72px) + 4px);width:100%;max-height:calc(100vh - var(--nav-height,72px) - var(--header-height,60px) - 20px);border-radius:20px 20px 0 0}.chatbot-fab{bottom:calc(var(--nav-height,72px) + 12px);width:52px;height:52px;right:12px}.chatbot-messages{max-height:calc(100vh - var(--nav-height,72px) - var(--header-height,60px) - 160px)}}@media (width>=769px){.chatbot-fab{bottom:24px;right:24px}.chatbot-panel{bottom:96px;right:24px}}:root{--primary:#4a90d9;--primary-light:#6ba3e0;--primary-dark:#3a7bc8;--primary-bg:#ebf3fb;--accent:#ff6b6b;--accent-light:#ff8e8e;--accent-bg:#fff0f0;--success:#2ecc71;--success-bg:#e8f8ef;--warning:#f1c40f;--warning-bg:#fdf6d8;--danger:#e74c3c;--danger-bg:#fde8e7;--bg:#f5f7fa;--card:#fff;--text:#1a2332;--text-secondary:#5a6b7f;--text-light:#94a3b8;--border:#e8edf2;--shadow:0 2px 12px #0000000d;--shadow-md:0 4px 16px #00000012;--shadow-lg:0 8px 30px #0000001a;--radius:18px;--radius-sm:12px;--radius-xs:8px;--nav-height:72px;--header-height:60px;--cat-cleaning:#56ccf2;--cat-laundry:#9b59b6;--cat-kitchen:#f39c12;--cat-deep:#1abc9c;--cat-maintenance:#34495e;--cat-seasonal:#27ae60}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;font-size:16px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}#root{min-height:100vh;padding-bottom:calc(var(--nav-height) + 24px)}.header{z-index:100;-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);height:var(--header-height);background:#ffffffeb;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.header-title{align-items:center;gap:10px;display:flex}.header-title .header-logo-icon{background:linear-gradient(135deg, var(--primary), var(--primary-light));color:#fff;border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.header-title h1{background:linear-gradient(135deg, var(--primary), #6c63ff);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.2rem;font-weight:700}.header-actions{align-items:center;gap:8px;display:flex}.lang-toggle{border:1.5px solid var(--border);cursor:pointer;color:var(--text-secondary);background:#fff;border-radius:20px;padding:6px 12px;font-size:.8rem;font-weight:600;transition:all .2s}.lang-toggle:hover{border-color:var(--primary);color:var(--primary)}.bottom-nav{z-index:200;-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);height:var(--nav-height);padding-bottom:env(safe-area-inset-bottom,8px);background:#fffffff2;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000000a}.nav-item{color:var(--text-light);letter-spacing:.02em;flex-direction:column;align-items:center;gap:3px;min-width:52px;padding:8px 12px;font-size:.6rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex;position:relative}.nav-item.active{color:var(--primary)}.nav-item.active:before{content:"";background:linear-gradient(90deg, var(--primary), var(--primary-light));border-radius:0 0 4px 4px;width:28px;height:3px;position:absolute;top:-1px;left:50%;transform:translate(-50%)}.nav-item .nav-icon-wrapper{border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;transition:all .2s;display:flex}.nav-item.active .nav-icon-wrapper{background:var(--primary-bg)}.nav-item svg{width:20px;height:20px}.page{max-width:800px;margin:0 auto;padding:20px 16px}.page-title{color:var(--text);align-items:center;gap:10px;margin-bottom:20px;font-size:1.5rem;font-weight:700;line-height:1.3;display:flex}.page-subtitle{color:var(--text-secondary);margin-bottom:24px;font-size:.9rem;line-height:1.5}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid #00000008;margin-bottom:14px;padding:18px;transition:all .2s}.card:hover{box-shadow:var(--shadow-md)}.card-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.card-title{color:var(--text);font-size:.95rem;font-weight:600}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;display:grid}.stat-card{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow);text-align:center;border:1px solid #00000008;padding:16px;transition:all .2s}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card .stat-icon{border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;margin:0 auto 10px;display:flex}.stat-card .stat-value{color:var(--text);font-size:1.6rem;font-weight:700;line-height:1.2}.stat-card .stat-label{color:var(--text-secondary);margin-top:4px;font-size:.72rem;font-weight:500}.progress-bar{background:var(--border);border-radius:5px;width:100%;height:10px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--primary), var(--primary-light));border-radius:5px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.progress-fill.high{background:linear-gradient(90deg,#2ecc71,#58d68d)}.progress-fill.medium{background:linear-gradient(90deg,#f39c12,#f7c948)}.progress-fill.low{background:linear-gradient(90deg,#e74c3c,#f1948a)}.progress-label{justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.8rem;display:flex}.progress-label .label{color:var(--text-secondary);font-weight:500}.progress-label .value{color:var(--text);font-weight:700}.task-item{border-radius:var(--radius-sm);border:1px solid #0000;align-items:center;gap:12px;padding:12px 14px;transition:all .2s;display:flex}.task-item:hover{background:var(--bg);border-color:var(--border)}.task-item.completed{opacity:.55}.task-item.completed .task-name{color:var(--text-light);text-decoration:line-through}.task-checkbox{border:2.5px solid var(--border);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:26px;min-width:26px;height:26px;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.task-checkbox:hover{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.task-checkbox.checked{background:linear-gradient(135deg, var(--primary), var(--primary-light));border-color:var(--primary);color:#fff;animation:.3s cubic-bezier(.4,0,.2,1) checkPop;transform:scale(1)}@keyframes checkPop{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.task-info{flex:1;min-width:0}.task-name{color:var(--text);font-size:.88rem;font-weight:500;line-height:1.4}.task-meta{color:var(--text-light);align-items:center;gap:8px;margin-top:3px;font-size:.7rem;display:flex}.task-badge{border-radius:12px;align-items:center;gap:4px;padding:2px 8px;font-size:.65rem;font-weight:600;display:inline-flex}.task-actions{gap:4px;display:flex}.task-actions button{cursor:pointer;color:var(--text-light);background:0 0;border:none;border-radius:8px;padding:6px;transition:all .2s}.task-actions button:hover{background:var(--bg);color:var(--text)}.task-done-icon{color:var(--success);justify-content:center;align-items:center;animation:.3s fadeScaleIn;display:flex}@keyframes fadeScaleIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.task-item-stripe{border-radius:2px;flex-shrink:0;width:4px;min-width:4px;height:32px}.category-tag{border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:.7rem;font-weight:600;display:inline-flex}.category-dot{border-radius:50%;width:8px;min-width:8px;height:8px;display:inline-block}.filter-pills{-webkit-overflow-scrolling:touch;gap:8px;margin-bottom:16px;padding-bottom:10px;display:flex;overflow-x:auto}.filter-pills::-webkit-scrollbar{display:none}.filter-pill{border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:#fff;border-radius:24px;padding:8px 16px;font-size:.75rem;font-weight:600;transition:all .2s}.filter-pill:hover{border-color:var(--primary-light);color:var(--primary)}.filter-pill.active{background:linear-gradient(135deg, var(--primary), var(--primary-light));color:#fff;border-color:#0000;box-shadow:0 2px 8px #4a90d94d}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:6px;padding:10px 20px;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-light));color:#fff;box-shadow:0 2px 8px #4a90d940}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #4a90d959}.btn-accent{background:linear-gradient(135deg, var(--accent), var(--accent-light));color:#fff;box-shadow:0 2px 8px #ff6b6b40}.btn-accent:hover{transform:translateY(-1px);box-shadow:0 4px 16px #ff6b6b59}.btn-outline{border:1.5px solid var(--border);color:var(--text-secondary);background:0 0}.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-bg)}.btn-sm{padding:6px 14px;font-size:.75rem}.btn-full{justify-content:center;width:100%}.btn-icon{background:var(--bg);cursor:pointer;color:var(--text-secondary);border:none;border-radius:10px;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.btn-icon:hover{background:var(--primary-bg);color:var(--primary)}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.form-input{border:1.5px solid var(--border);border-radius:var(--radius-xs);width:100%;color:var(--text);background:#fff;padding:11px 14px;font-family:inherit;font-size:.9rem;transition:all .2s}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg);outline:none}.form-select{border:1.5px solid var(--border);border-radius:var(--radius-xs);width:100%;color:var(--text);appearance:none;cursor:pointer;background:#fff 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='%23718096' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") right 12px center no-repeat;padding:11px 14px;font-family:inherit;font-size:.9rem;transition:all .2s}.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg);outline:none}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;background:#00000073;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius) var(--radius) 0 0;background:#fff;width:100%;max-width:500px;max-height:80vh;padding:24px;animation:.3s cubic-bezier(.4,0,.2,1) slideUp;overflow-y:auto}.modal-title{margin-bottom:18px;font-size:1.15rem;font-weight:700}.modal-actions{gap:10px;margin-top:18px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.week-grid{grid-template-columns:1fr;gap:10px;display:grid}.day-card{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow);border:1px solid #00000008;transition:all .2s;overflow:hidden}.day-card:hover{box-shadow:var(--shadow-md)}.day-card-header{background:var(--bg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.day-card-header.today{background:linear-gradient(135deg, var(--primary-bg), #d6e8fa);border-bottom-color:#4a90d926}.day-name{font-size:.85rem;font-weight:700}.day-date{color:var(--text-secondary);font-size:.75rem}.day-card-body{padding:8px}.year-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.month-card{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow);cursor:pointer;border:2px solid #0000;padding:16px;transition:all .2s}.month-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.month-card.green{border-color:var(--success);background:linear-gradient(135deg, white, var(--success-bg))}.month-card.yellow{border-color:var(--warning);background:linear-gradient(135deg, white, var(--warning-bg))}.month-card.red{border-color:var(--danger);background:linear-gradient(135deg, white, var(--danger-bg))}.month-name{margin-bottom:6px;font-size:.9rem;font-weight:700}.month-stats{color:var(--text-secondary);font-size:.75rem}.shopping-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 14px;transition:all .2s;display:flex}.shopping-item:last-child{border-bottom:none}.shopping-item:hover{background:var(--bg)}.shopping-item.bought .shopping-name{color:var(--text-light);text-decoration:line-through}.shopping-name{flex:1;font-size:.9rem;font-weight:500}.shopping-price{color:var(--primary);font-size:.85rem;font-weight:600}.shopping-category{color:var(--text-light);font-size:.7rem}.budget-bar{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow);border:1px solid #00000008;justify-content:space-between;align-items:center;margin-bottom:14px;padding:16px;display:flex}.budget-total{background:linear-gradient(135deg, var(--primary), #6c63ff);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.4rem;font-weight:700}.celebration{text-align:center;padding:28px;animation:.5s bounceIn;background:linear-gradient(135deg,#e8f8ef,#ebf3fb)!important}.celebration .celebration-icon{background:linear-gradient(135deg, var(--success), #58d68d);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 14px;animation:1.5s infinite celebPulse;display:flex}@keyframes celebPulse{0%,to{box-shadow:0 0 #2ecc7166}50%{box-shadow:0 0 0 12px #2ecc7100}}.celebration .message{color:var(--primary);font-size:1rem;font-weight:600}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.95)}to{opacity:1;transform:scale(1)}}.confetti-container{pointer-events:none;z-index:999;position:fixed;inset:0;overflow:hidden}.confetti{border-radius:2px;width:10px;height:10px;animation:3s ease-out forwards confettiFall;position:absolute}@keyframes confettiFall{0%{opacity:1;top:-10px}to{opacity:0;top:100vh;transform:rotate(720deg)}}.streak-badge{color:#fff;background:linear-gradient(135deg,#ff6b6b,#ff8e8e);border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:.8rem;font-weight:700;display:inline-flex}.motivational-card{background:linear-gradient(135deg, var(--primary), #6c63ff);color:#fff;border-radius:var(--radius);text-align:center;margin-bottom:20px;padding:24px;box-shadow:0 4px 20px #4a90d94d}.motivational-card .motivational-icon{color:#fff;background:#fff3;border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 10px;display:flex}.motivational-card .text{opacity:.95;font-size:1rem;font-weight:600}.history-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 4px;transition:all .2s;display:flex}.history-item:last-child{border-bottom:none}.history-item:hover{background:var(--bg);border-radius:var(--radius-xs)}.history-date{color:var(--text-light);min-width:80px;font-size:.7rem}.history-task{font-size:.85rem;font-weight:500}.history-by{color:var(--text-secondary);margin-left:auto;font-size:.7rem}.empty-state{text-align:center;color:var(--text-light);padding:48px 20px}.empty-state .empty-icon{background:var(--bg);width:64px;height:64px;color:var(--text-light);border-radius:20px;justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.empty-state .text{font-size:.95rem;font-weight:500}.empty-state .subtext{color:var(--text-light);margin-top:4px;font-size:.8rem}.fab{bottom:calc(var(--nav-height) + 16px);background:linear-gradient(135deg, var(--accent), var(--accent-light));color:#fff;cursor:pointer;z-index:150;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:all .2s;display:flex;position:fixed;right:16px;box-shadow:0 4px 20px #ff6b6b66}.fab:hover{transform:scale(1.1)translateY(-2px);box-shadow:0 6px 24px #ff6b6b80}.search-bar{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#fff;align-items:center;gap:10px;margin-bottom:14px;padding:10px 14px;transition:all .2s;display:flex}.search-bar:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.search-bar input{border:none;outline:none;flex:1;font-family:inherit;font-size:.9rem}.search-bar svg{color:var(--text-light)}@media (width>=640px){.year-grid{grid-template-columns:repeat(3,1fr)}.stats-grid{grid-template-columns:repeat(4,1fr)}.week-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=768px){.year-grid{grid-template-columns:repeat(4,1fr)}.week-grid{grid-template-columns:repeat(3,1fr)}.modal-overlay{align-items:center}.modal{border-radius:var(--radius);max-height:70vh}}.section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--text-light);align-items:center;gap:6px;margin-top:20px;margin-bottom:12px;font-size:.78rem;font-weight:700;display:flex}.scroll-x{-webkit-overflow-scrolling:touch;overflow-x:auto}.scroll-x::-webkit-scrollbar{display:none}.inline-form{gap:8px;margin-bottom:14px;display:flex}.inline-form input{flex:1}.setting-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 0;display:flex}.setting-label{font-size:.9rem;font-weight:500}.member-chip{background:var(--primary-bg);color:var(--primary);border-radius:20px;align-items:center;gap:6px;margin:4px;padding:6px 12px;font-size:.8rem;font-weight:600;display:inline-flex}.member-chip button{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:1rem;line-height:1}.fade-in{animation:.3s fadeIn}.divider{background:var(--border);height:1px;margin:14px 0}.auth-page{background:linear-gradient(135deg,#ebf3fb 0%,#f5f7fa 40%,#e5f7f4 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{border-radius:var(--radius);width:100%;max-width:420px;box-shadow:var(--shadow-lg);background:#fff;border:1px solid #0000000a;padding:36px 28px}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{background:linear-gradient(135deg, var(--primary), #6c63ff);color:#fff;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 14px;display:flex}.auth-header h1{color:var(--text);margin-bottom:4px;font-size:1.5rem;font-weight:700}.auth-header p{color:var(--text-secondary);font-size:.9rem}.auth-error{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-xs);border:1px solid #e74c3c33;margin-bottom:16px;padding:10px 14px;font-size:.85rem}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:24px;font-size:.85rem}.auth-footer a{color:var(--primary);margin-left:6px;font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.family-option-btn{border-radius:var(--radius-sm);border:1.5px solid var(--border);cursor:pointer;text-align:left;background:#fff;align-items:center;gap:16px;width:100%;padding:18px;transition:all .2s;display:flex}.family-option-btn:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.family-option-icon{border-radius:14px;justify-content:center;align-items:center;width:48px;min-width:48px;height:48px;display:flex}.family-option-title{color:var(--text);margin-bottom:2px;font-size:.95rem;font-weight:600}.family-option-desc{color:var(--text-secondary);font-size:.8rem}.invite-code-display{text-align:center;background:linear-gradient(135deg, var(--primary-bg), #d6e8fa);border-radius:var(--radius-sm);margin-bottom:16px;padding:28px}.invite-code{letter-spacing:.3em;color:var(--primary);margin-bottom:16px;font-family:Courier New,monospace;font-size:2.5rem;font-weight:700;display:block}.header-family-link{background:var(--primary-bg);color:var(--primary);border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:.75rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.header-family-link:hover{background:var(--primary);color:#fff}.header-avatar{color:#fff;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:.85rem;font-weight:700;display:flex;box-shadow:0 2px 6px #00000026}.member-row{border-radius:var(--radius-xs);align-items:center;gap:14px;padding:14px 12px;transition:all .2s;display:flex}.member-row:hover{background:var(--bg)}.member-row:not(:last-child){border-bottom:1px solid var(--border)}.member-avatar{color:#fff;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:44px;min-width:44px;height:44px;font-size:1rem;font-weight:700;display:flex;box-shadow:0 2px 8px #0000001f}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.season-icon{border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}
