@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800&display=swap";:root{--color-bg-primary: #FDF8F3;--color-bg-secondary: #FFF9F5;--color-bg-card: rgba(255, 255, 255, .85);--color-sage: #8FAE8B;--color-sage-light: #B5D2B0;--color-sage-dark: #6B8A67;--color-terracotta: #D4896A;--color-terracotta-light: #E8A88C;--color-terracotta-dark: #B86B4E;--color-cream: #FAF0E6;--color-peach: #FFD9C4;--color-lavender: #C5B4E3;--color-sky: #A8D5E5;--color-text-primary: #3D3D3D;--color-text-secondary: #6B6B6B;--color-text-muted: #9A9A9A;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--shadow-glow: 0 0 20px rgba(143, 174, 139, .3);--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Nunito,sans-serif;background:var(--color-bg-primary);color:var(--color-text-primary);min-height:100vh;line-height:1.6}#root{min-height:100vh;display:flex;flex-direction:column}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-header{background:var(--color-bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.05);padding:var(--space-md) var(--space-lg);position:sticky;top:0;z-index:100}.header-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.app-logo{display:flex;align-items:center;gap:var(--space-sm);font-weight:800;font-size:1.5rem;color:var(--color-sage-dark);text-decoration:none}.app-logo .logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--color-sage),var(--color-sage-light));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem}.main-content{flex:1;padding:var(--space-lg);max-width:1200px;margin:0 auto;width:100%}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--color-bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid rgba(0,0,0,.05);padding:var(--space-sm) var(--space-md);padding-bottom:calc(var(--space-sm) + env(safe-area-inset-bottom,0px));z-index:100}.nav-list{display:flex;justify-content:space-around;list-style:none;max-width:500px;margin:0 auto}.nav-item a{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-sm) var(--space-md);text-decoration:none;color:var(--color-text-muted);font-size:.75rem;font-weight:600;border-radius:var(--radius-md);transition:var(--transition-fast)}.nav-item a:hover{color:var(--color-sage-dark);background:#8fae8b1a}.nav-item a.active{color:var(--color-sage-dark);background:#8fae8b26}.nav-item a.active .nav-icon{transform:scale(1.1)}.nav-icon{width:24px;height:24px;transition:var(--transition-fast)}.card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md);border:1px solid rgba(255,255,255,.8);transition:var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.card-title{font-size:1.125rem;font-weight:700;color:var(--color-text-primary);display:flex;align-items:center;gap:var(--space-sm)}.card-icon{width:28px;height:28px;padding:4px;border-radius:var(--radius-sm)}.card-icon.sage{background:#8fae8b33;color:var(--color-sage-dark)}.card-icon.terracotta{background:#d4896a33;color:var(--color-terracotta-dark)}.card-icon.lavender{background:#c5b4e333;color:#8b7ab8}.card-icon.sky{background:#a8d5e533;color:#5ba3ba}.page-title{font-size:1.75rem;font-weight:800;margin-bottom:var(--space-lg);color:var(--color-text-primary)}.page-subtitle{font-size:1rem;color:var(--color-text-secondary);margin-top:calc(-1 * var(--space-sm));margin-bottom:var(--space-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-md);font-family:inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition-fast)}.btn-primary{background:linear-gradient(135deg,var(--color-sage),var(--color-sage-dark));color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-secondary{background:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid rgba(0,0,0,.08)}.btn-secondary:hover{background:var(--color-cream)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-full)}.dashboard-grid{display:grid;gap:var(--space-md);grid-template-columns:1fr;padding-bottom:100px}@media(min-width:768px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.dashboard-grid{grid-template-columns:repeat(3,1fr)}}.welcome-banner{grid-column:1 / -1;background:linear-gradient(135deg,var(--color-sage-light) 0%,var(--color-sage) 100%);border-radius:var(--radius-lg);padding:var(--space-xl);color:#fff;position:relative;overflow:hidden}.welcome-banner:before{content:"";position:absolute;top:-50%;right:-20%;width:300px;height:300px;background:#ffffff1a;border-radius:50%}.welcome-banner h1{font-size:1.5rem;font-weight:800;margin-bottom:var(--space-xs);position:relative}.welcome-banner p{font-size:.9rem;opacity:.9;position:relative}.item-list{display:flex;flex-direction:column;gap:var(--space-sm)}.item-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm);border-radius:var(--radius-md);transition:var(--transition-fast)}.item-row:hover{background:#00000005}.item-time{font-size:.75rem;font-weight:700;color:var(--color-sage-dark);min-width:50px}.item-content{flex:1}.item-title{font-weight:600;font-size:.9rem}.item-meta{font-size:.75rem;color:var(--color-text-muted)}.avatar-stack{display:flex}.avatar{width:32px;height:32px;border-radius:var(--radius-full);border:2px solid white;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;margin-left:-8px}.avatar:first-child{margin-left:0}.avatar.pink{background:linear-gradient(135deg,#f8b4d9,#f472b6)}.avatar.blue{background:linear-gradient(135deg,#93c5fd,#3b82f6)}.avatar.green{background:linear-gradient(135deg,#86efac,#22c55e)}.avatar.orange{background:linear-gradient(135deg,#fed7aa,#f97316)}.fridge-board{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-md);padding-bottom:100px}.sticky-note{padding:var(--space-md);border-radius:var(--radius-md);min-height:120px;box-shadow:var(--shadow-sm);transition:var(--transition-normal);position:relative;transform:rotate(-1deg)}.sticky-note:nth-child(2n){transform:rotate(1deg)}.sticky-note:hover{transform:rotate(0) scale(1.02);box-shadow:var(--shadow-md)}.sticky-note.yellow{background:#fff9c4}.sticky-note.pink{background:#ffcdd2}.sticky-note.blue{background:#bbdefb}.sticky-note.green{background:#c8e6c9}.sticky-note .note-content{font-size:.875rem;line-height:1.5}.sticky-note .note-author{position:absolute;bottom:var(--space-sm);right:var(--space-sm);font-size:.7rem;color:var(--color-text-muted)}.shopping-list{display:flex;flex-direction:column;gap:var(--space-sm);padding-bottom:100px}.shopping-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:var(--transition-fast)}.shopping-item.checked{opacity:.6}.shopping-item.checked .shopping-item-name{text-decoration:line-through;color:var(--color-text-muted)}.shopping-checkbox{width:24px;height:24px;border:2px solid var(--color-sage);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);flex-shrink:0}.shopping-checkbox.checked{background:var(--color-sage);color:#fff}.shopping-item-name{flex:1;font-weight:600}.shopping-item-quantity{font-size:.875rem;color:var(--color-text-secondary);background:var(--color-cream);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full)}.calendar-container{padding-bottom:100px}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.calendar-nav{display:flex;align-items:center;gap:var(--space-sm)}.calendar-title{font-size:1.25rem;font-weight:700}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;background:#0000000d;border-radius:var(--radius-md);overflow:hidden}.calendar-day-header{background:var(--color-sage-light);color:var(--color-sage-dark);padding:var(--space-sm);text-align:center;font-size:.75rem;font-weight:700}.calendar-day{background:var(--color-bg-card);padding:var(--space-sm);min-height:80px;font-size:.875rem}.calendar-day.other-month{opacity:.4}.calendar-day.today{background:#8fae8b26}.calendar-day .day-number{font-weight:700;margin-bottom:var(--space-xs)}.calendar-day.today .day-number{background:var(--color-sage);color:#fff;width:24px;height:24px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.calendar-event{font-size:.7rem;padding:2px 4px;border-radius:4px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-event.sage{background:#8fae8b4d;color:var(--color-sage-dark)}.calendar-event.terracotta{background:#d4896a4d;color:var(--color-terracotta-dark)}.calendar-event.lavender{background:#c5b4e34d;color:#6b5b95}@media(max-width:480px){.calendar-day{min-height:50px;padding:4px}.calendar-day .day-number{font-size:.75rem}.calendar-event{font-size:.6rem;padding:1px 3px;margin-bottom:1px}.calendar-day.today .day-number{width:20px;height:20px;font-size:.7rem}.calendar-title{font-size:1rem}.calendar-header{flex-direction:column;gap:var(--space-sm)}}.input-field{width:100%;padding:var(--space-md);border:2px solid rgba(0,0,0,.08);border-radius:var(--radius-md);font-family:inherit;font-size:1rem;background:var(--color-bg-secondary);transition:var(--transition-fast)}.input-field:focus{outline:none;border-color:var(--color-sage);box-shadow:0 0 0 3px #8fae8b33}.input-field::placeholder{color:var(--color-text-muted)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.mt-md{margin-top:var(--space-md)}.mb-md{margin-bottom:var(--space-md)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeIn .4s ease forwards}.stagger-children>*{opacity:0;animation:fadeIn .4s ease forwards}.stagger-children>*:nth-child(1){animation-delay:.05s}.stagger-children>*:nth-child(2){animation-delay:.1s}.stagger-children>*:nth-child(3){animation-delay:.15s}.stagger-children>*:nth-child(4){animation-delay:.2s}.stagger-children>*:nth-child(5){animation-delay:.25s}.stagger-children>*:nth-child(6){animation-delay:.3s}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-primary) 0%,var(--color-cream) 100%);padding:var(--space-lg);position:relative;overflow:hidden}.login-container{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-lg);width:100%;max-width:400px;position:relative;z-index:10;animation:fadeIn .6s ease}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-logo{width:70px;height:70px;background:linear-gradient(135deg,var(--color-sage),var(--color-sage-dark));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto var(--space-md);box-shadow:var(--shadow-md),var(--shadow-glow)}.login-header h1{font-size:1.75rem;font-weight:800;color:var(--color-sage-dark);margin-bottom:var(--space-xs)}.login-header p{color:var(--color-text-secondary);font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:var(--space-md)}.input-group{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:var(--space-md);color:var(--color-text-muted);pointer-events:none}.login-input{width:100%;padding:var(--space-md);padding-left:calc(var(--space-md) * 2 + 20px);padding-right:calc(var(--space-md) * 2 + 20px);border:2px solid rgba(0,0,0,.08);border-radius:var(--radius-md);font-family:inherit;font-size:1rem;background:var(--color-bg-secondary);transition:var(--transition-fast)}.login-input:focus{outline:none;border-color:var(--color-sage);box-shadow:0 0 0 3px #8fae8b33}.password-toggle{position:absolute;right:var(--space-md);background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.password-toggle:hover{color:var(--color-sage-dark)}.login-error{background:#ef44441a;color:#dc2626;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:.875rem;text-align:center;animation:fadeIn .3s ease}.login-button{width:100%;padding:var(--space-md);background:linear-gradient(135deg,var(--color-sage),var(--color-sage-dark));color:#fff;border:none;border-radius:var(--radius-md);font-family:inherit;font-size:1rem;font-weight:700;cursor:pointer;transition:var(--transition-normal);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;min-height:50px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md),var(--shadow-glow)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-hint{margin-top:var(--space-lg);text-align:center;font-size:.8rem;color:var(--color-text-muted)}.loading-spinner{width:20px;height:20px;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)}}.login-decoration{position:absolute;inset:0;pointer-events:none;overflow:hidden}.decoration-circle{position:absolute;border-radius:50%;opacity:.4}.circle-1{width:400px;height:400px;background:var(--color-sage-light);top:-200px;right:-100px}.circle-2{width:300px;height:300px;background:var(--color-peach);bottom:-150px;left:-100px}.circle-3{width:200px;height:200px;background:var(--color-lavender);bottom:20%;right:10%}.header-right{display:flex;align-items:center;gap:var(--space-md)}.logout-btn{width:36px;height:36px;border-radius:var(--radius-full);border:none;background:var(--color-bg-secondary);color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.logout-btn:hover{background:#ef44441a;color:#dc2626}.status-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}@media(min-width:768px){.status-grid{grid-template-columns:repeat(4,1fr)}}.status-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--color-bg-secondary);border-radius:var(--radius-md);position:relative;transition:var(--transition-fast)}.status-card:hover{background:var(--color-cream)}.status-info{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);width:100%}.status-name{font-weight:700;font-size:.9rem}.status-button{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--color-bg-card);border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-sm);font-family:inherit;font-size:.75rem;color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-fast);white-space:nowrap}.status-button:hover{border-color:var(--color-sage);color:var(--color-sage-dark)}.status-dropdown{position:absolute;top:100%;left:50%;transform:translate(-50%);background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--space-xs);z-index:50;min-width:160px;margin-top:var(--space-xs);animation:fadeIn .2s ease}.status-option{display:block;width:100%;padding:var(--space-sm) var(--space-md);background:none;border:none;border-radius:var(--radius-sm);font-family:inherit;font-size:.8rem;text-align:left;cursor:pointer;transition:var(--transition-fast);color:var(--color-text-primary)}.status-option:hover{background:var(--color-cream)}.status-option.active{background:#8fae8b33;color:var(--color-sage-dark);font-weight:600}.empty-state{padding:var(--space-lg);text-align:center;color:var(--color-text-muted);font-size:.875rem}.status-edit-container{width:100%;display:flex;flex-direction:column;gap:var(--space-xs)}.emoji-row{display:flex;gap:2px;flex-wrap:wrap;justify-content:center}.emoji-btn{width:28px;height:28px;border:none;background:var(--color-bg-card);border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem;transition:var(--transition-fast);display:flex;align-items:center;justify-content:center}.emoji-btn:hover{background:var(--color-cream);transform:scale(1.1)}.status-input-row{display:flex;gap:var(--space-xs)}.status-input{flex:1;padding:var(--space-xs) var(--space-sm);border:2px solid var(--color-sage-light);border-radius:var(--radius-sm);font-family:inherit;font-size:.8rem;background:#fff;min-width:0}.status-input:focus{outline:none;border-color:var(--color-sage)}.save-btn{width:32px;height:32px;border:none;background:var(--color-sage);color:#fff;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);flex-shrink:0}.save-btn:hover{background:var(--color-sage-dark)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--space-md);animation:fadeIn .2s ease}.modal{background:var(--color-bg-card);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid rgba(0,0,0,.08)}.modal-header h3{font-size:1.125rem;font-weight:700}.modal-body{padding:var(--space-lg);max-height:60vh;overflow-y:auto}.modal-footer{display:flex;gap:var(--space-sm);justify-content:flex-end;padding:var(--space-md) var(--space-lg);border-top:1px solid rgba(0,0,0,.08)}.form-group label{display:block;font-size:.875rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.color-picker{display:flex;gap:var(--space-sm)}.color-option{padding:var(--space-xs) var(--space-md);border:2px solid transparent;border-radius:var(--radius-sm);font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer;transition:var(--transition-fast)}.color-option.sage{background:#8fae8b4d;color:var(--color-sage-dark)}.color-option.terracotta{background:#d4896a4d;color:var(--color-terracotta-dark)}.color-option.lavender{background:#c5b4e34d;color:#6b5b95}.color-option.selected{border-color:var(--color-text-primary)}.calendar-day.clickable{cursor:pointer}.calendar-day.clickable:hover{background:#8fae8b1a}.calendar-event{cursor:pointer}.calendar-event:hover{opacity:.7}.add-member-card{border:2px dashed rgba(0,0,0,.15);background:transparent!important;cursor:pointer;color:var(--color-text-muted);min-height:140px;justify-content:center}.add-member-card:hover{border-color:var(--color-sage);color:var(--color-sage-dark);background:#8fae8b0d!important}.add-member-card span{font-size:.8rem;font-weight:600}.delete-member-btn{position:absolute;top:var(--space-xs);right:var(--space-xs);width:24px;height:24px;border:none;background:#0000001a;color:var(--color-text-muted);border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition-fast)}.status-card:hover .delete-member-btn{opacity:1}@media(max-width:768px){.delete-member-btn{opacity:.6}.shopping-item .btn-icon{opacity:.8!important}}.delete-member-btn:hover{background:#ef444433;color:#dc2626}.color-circle{width:32px;height:32px;border-radius:var(--radius-full);border:3px solid transparent;cursor:pointer;transition:var(--transition-fast)}.color-circle.selected{border-color:var(--color-text-primary);transform:scale(1.1)}.color-circle.pink{background:linear-gradient(135deg,#f8b4d9,#f472b6)}.color-circle.blue{background:linear-gradient(135deg,#93c5fd,#3b82f6)}.color-circle.green{background:linear-gradient(135deg,#86efac,#22c55e)}.color-circle.orange{background:linear-gradient(135deg,#fed7aa,#f97316)}.color-circle.purple,.avatar.purple{background:linear-gradient(135deg,#c5b4e3,#8b5cf6)}.link-button{background:none;border:none;color:var(--color-sage-dark);font-family:inherit;font-size:inherit;font-weight:700;cursor:pointer;text-decoration:underline;padding:0}.link-button:hover{color:var(--color-sage)}.user-info{display:flex;align-items:center;gap:var(--space-sm)}.user-name{font-weight:600;font-size:.875rem;color:var(--color-text-primary)}@media(max-width:480px){.user-name{display:none}}.messages-container{display:flex;flex-direction:column;height:calc(100vh - 180px);padding-bottom:0}.messages-wrapper{display:flex;flex-direction:column;flex:1;background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.messages-list{flex:1;overflow-y:auto;padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}.date-divider{display:flex;align-items:center;justify-content:center;margin:var(--space-md) 0}.date-divider span{background:var(--color-bg-secondary);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:.75rem;color:var(--color-text-muted);font-weight:600}.message-bubble{max-width:75%;animation:fadeIn .2s ease}.message-bubble.mine{align-self:flex-end}.message-bubble.other{align-self:flex-start}.message-author{font-size:.7rem;font-weight:600;color:var(--color-text-muted);margin-bottom:2px;margin-left:var(--space-sm)}.message-content{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);position:relative}.message-bubble.mine .message-content{background:linear-gradient(135deg,var(--color-sage),var(--color-sage-dark));color:#fff;border-bottom-right-radius:4px}.message-content p{margin:0;word-break:break-word;line-height:1.4}.message-time{font-size:.65rem;opacity:.7;margin-top:4px;display:block;text-align:right}.message-input-form{display:flex;gap:var(--space-sm);padding:var(--space-md);border-top:1px solid rgba(0,0,0,.08);background:var(--color-bg-card)}.message-input{flex:1;display:block!important;visibility:visible!important;opacity:1!important;padding:var(--space-sm) var(--space-md);border:2px solid rgba(0,0,0,.08);border-radius:var(--radius-full);font-family:inherit;font-size:.9rem;background:var(--color-bg-secondary);transition:var(--transition-fast);min-height:44px}.send-button{width:44px;height:44px;border:none;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-sage),var(--color-sage-dark));color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);flex-shrink:0}.send-button:hover:not(:disabled){transform:scale(1.05);box-shadow:var(--shadow-md),var(--shadow-glow)}@media(max-width:480px){.messages-container{height:calc(100vh - 200px);padding-bottom:120px}.message-bubble{max-width:85%}.messages-wrapper{position:relative}.message-input-form{position:fixed;bottom:70px;left:0;right:0;padding:var(--space-sm) var(--space-md);background:var(--color-bg-card);border-top:1px solid rgba(0,0,0,.1);z-index:500;box-shadow:0 -2px 10px #0000001a}.message-input{font-size:16px;padding:var(--space-md)}.send-button{width:48px;height:48px}.messages-list{padding-bottom:80px}}.notification-bell{position:relative}.bell-button{width:40px;height:40px;border:none;border-radius:var(--radius-full);background:transparent;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);position:relative}.bell-button:hover{background:#0000000d;color:var(--color-text-primary)}.notification-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;background:#e91e63;color:#fff;font-size:.65rem;font-weight:700;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 4px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:400px;background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;z-index:1000;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);border-bottom:1px solid rgba(0,0,0,.08)}.notification-header h3{font-size:.95rem;font-weight:700;color:var(--color-text-primary);margin:0}.clear-all-btn{background:none;border:none;color:var(--color-sage);font-size:.75rem;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:var(--transition-fast)}.clear-all-btn:hover{background:#6d8c701a}.notification-list{max-height:320px;overflow-y:auto}.no-notifications{padding:var(--space-xl);text-align:center;color:var(--color-text-muted)}.no-notifications svg{margin-bottom:var(--space-sm);opacity:.5}.no-notifications p{font-size:.85rem}.notification-item{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);border-bottom:1px solid rgba(0,0,0,.05);cursor:pointer;transition:var(--transition-fast);position:relative}.notification-item:hover{background:#00000005}.notification-item.unread{background:#6d8c700d}.notification-item.unread:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color-sage)}.notification-icon{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-message{font-size:.85rem;color:var(--color-text-primary);margin:0 0 4px;line-height:1.4}.notification-time{font-size:.7rem;color:var(--color-text-muted)}.delete-notification-btn{width:24px;height:24px;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition-fast);flex-shrink:0}.notification-item:hover .delete-notification-btn{opacity:1}.delete-notification-btn:hover{background:#0000001a;color:var(--color-text-primary)}@media(max-width:480px){.notification-dropdown{position:fixed;top:60px;left:8px;right:8px;width:auto;max-height:70vh}.notification-item:hover .delete-notification-btn,.delete-notification-btn{opacity:1}}.password-gate-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-sage-light) 0%,var(--color-bg-secondary) 100%);padding:var(--space-lg)}.password-gate-card{background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-xxl);width:100%;max-width:400px;text-align:center}.password-gate-icon{width:80px;height:80px;margin:0 auto var(--space-lg);background:linear-gradient(135deg,var(--color-sage-light),rgba(109,140,112,.2));border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--color-sage)}.password-gate-title{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0 0 var(--space-sm)}.password-gate-subtitle{color:var(--color-text-muted);font-size:.9rem;line-height:1.6;margin:0 0 var(--space-xl)}.password-gate-form{display:flex;flex-direction:column;gap:var(--space-md)}.password-input-wrapper{position:relative}.password-gate-input{width:100%;padding:var(--space-md) var(--space-lg);padding-right:48px;border:2px solid rgba(0,0,0,.08);border-radius:var(--radius-full);font-family:inherit;font-size:1rem;text-align:center;transition:var(--transition-fast);background:var(--color-bg-secondary)}.password-gate-input:focus{outline:none;border-color:var(--color-sage);box-shadow:0 0 0 4px #6d8c7026}.password-toggle-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.password-toggle-btn:hover{color:var(--color-text-primary)}.password-gate-error{color:#e91e63;font-size:.85rem;margin:0;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.password-gate-button{width:100%;padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,var(--color-sage),var(--color-sage-dark));color:#fff;border:none;border-radius:var(--radius-full);font-family:inherit;font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition-fast)}.password-gate-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md),var(--shadow-glow)}.password-gate-hint{margin-top:var(--space-lg);font-size:.75rem;color:var(--color-text-muted)}@media(max-width:480px){.password-gate-card{padding:var(--space-xl)}.password-gate-title{font-size:1.3rem}}.push-notification-banner{display:flex;align-items:center;gap:var(--space-md);background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);box-shadow:var(--shadow-md)}.push-banner-icon{width:48px;height:48px;background:#fff3;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.push-banner-content{flex:1;min-width:0}.push-banner-content h4{margin:0 0 4px;font-size:.95rem;font-weight:600}.push-banner-content p{margin:0;font-size:.8rem;opacity:.9}.push-banner-actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.push-btn-enable{display:flex;align-items:center;gap:6px;padding:var(--space-sm) var(--space-md);background:#fff;color:#4caf50;border:none;border-radius:var(--radius-full);font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--transition-fast)}.push-btn-enable:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #00000026}.push-btn-enable:disabled{opacity:.7;cursor:not-allowed}.push-btn-dismiss{width:32px;height:32px;background:#fff3;border:none;border-radius:var(--radius-full);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.push-btn-dismiss:hover{background:#ffffff4d}.loading-spinner.small{width:16px;height:16px;border-width:2px}@media(max-width:480px){.push-notification-banner{flex-direction:column;text-align:center;padding:var(--space-md)}.push-banner-actions{width:100%;justify-content:center;margin-top:var(--space-sm)}.push-btn-enable{flex:1;justify-content:center}}.shopping-add-form{background:linear-gradient(135deg,var(--color-bg-card),rgba(109,140,112,.05))}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;font-size:.85rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.assignee-options{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.assignee-chip{padding:var(--space-sm) var(--space-md);background:var(--color-bg-secondary);border:2px solid transparent;border-radius:var(--radius-full);font-family:inherit;font-size:.85rem;color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-fast)}.assignee-chip:hover{background:#6d8c701a}.assignee-chip.active{background:var(--color-sage);color:#fff;border-color:var(--color-sage)}.form-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;margin-top:var(--space-lg)}.shopping-group{margin-bottom:var(--space-lg)}.shopping-group-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:linear-gradient(135deg,var(--color-sage-light),rgba(109,140,112,.2));border-radius:var(--radius-md);font-size:.9rem;font-weight:600;color:var(--color-sage-dark);margin-bottom:var(--space-sm)}.shopping-group-header.completed{background:linear-gradient(135deg,#9e9e9e33,#9e9e9e1a);color:var(--color-text-muted)}.shopping-group-count{margin-left:auto;font-size:.75rem;background:#ffffff80;padding:2px 8px;border-radius:var(--radius-full)}.shopping-item-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.shopping-item-requester{font-size:.7rem;color:var(--color-text-muted)}.shopping-item.checked .shopping-item-requester{color:var(--color-sage)}@media(max-width:480px){.assignee-options{gap:var(--space-xs)}.assignee-chip{padding:var(--space-xs) var(--space-sm);font-size:.8rem}.form-actions{flex-direction:column}.form-actions button{width:100%;justify-content:center}}.image-upload-button{width:44px;height:44px;border:none;border-radius:var(--radius-full);background:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);flex-shrink:0}.image-upload-button:hover:not(:disabled){background:#6d8c7033;color:var(--color-sage)}.image-upload-button:disabled{opacity:.5;cursor:not-allowed}.image-preview-bar{padding:var(--space-sm) var(--space-md);background:var(--color-bg-secondary);border-top:1px solid rgba(0,0,0,.05)}.image-preview-container{position:relative;display:inline-block}.image-preview-container img{max-width:120px;max-height:80px;border-radius:var(--radius-md);object-fit:cover}.image-preview-remove{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border:none;border-radius:var(--radius-full);background:#e91e63;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.image-preview-remove:hover{transform:scale(1.1)}.message-image{margin-bottom:var(--space-sm)}.message-image img{max-width:200px;max-height:200px;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast)}.message-image img:hover{transform:scale(1.02);box-shadow:var(--shadow-md)}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:480px){.image-upload-button{width:40px;height:40px}.message-image img{max-width:150px;max-height:150px}}.image-zoom-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999;padding:var(--space-md);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.image-zoom-close{position:absolute;top:var(--space-md);right:var(--space-md);width:44px;height:44px;background:#fff3;border:none;border-radius:var(--radius-full);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.image-zoom-close:hover{background:#ffffff4d;transform:scale(1.1)}.image-zoom-content{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-md);box-shadow:0 10px 40px #00000080}.weight-records{display:flex;flex-direction:column;gap:var(--space-sm)}.weight-record-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-bg-secondary);border-radius:var(--radius-md)}.weight-record-date{font-size:.85rem;color:var(--color-text-muted);min-width:50px}.weight-record-value{font-weight:600;flex:1}.weight-record-change{font-size:.8rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);background:var(--color-bg-secondary)}.weight-record-change.up{color:#4caf50;background:#4caf501a}.weight-record-change.down{color:#f44336;background:#f443361a}.allowance-records{display:flex;flex-direction:column;gap:var(--space-sm)}.allowance-record-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-bg-secondary);border-radius:var(--radius-md)}.allowance-record-icon{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.allowance-record-icon.income{background:#4caf5033;color:#4caf50}.allowance-record-icon.expense{background:#f4433633;color:#f44336}.allowance-record-info{flex:1;min-width:0}.allowance-record-note{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.allowance-record-date{font-size:.75rem;color:var(--color-text-muted)}.allowance-record-amount{font-weight:600;flex-shrink:0}.allowance-record-amount.income{color:#4caf50}.allowance-record-amount.expense{color:#f44336}.quick-link-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-lg);border-radius:var(--radius-lg);transition:var(--transition-fast);cursor:pointer;text-align:center}.quick-link-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.messages-container{display:flex;flex-direction:column;height:calc(100vh - 200px);max-height:calc(100vh - 200px);padding-bottom:80px}.messages-wrapper{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.messages-list{flex:1;overflow-y:auto;padding:var(--space-md);padding-bottom:var(--space-lg)}.date-divider{text-align:center;margin:var(--space-md) 0}.date-divider span{background:var(--color-bg-secondary);color:var(--color-text-muted);font-size:.75rem;padding:4px 12px;border-radius:var(--radius-full)}.message-bubble{max-width:80%;margin-bottom:var(--space-sm)}.message-bubble.mine{margin-left:auto}.message-bubble.other{margin-right:auto}.message-author{font-size:.75rem;color:var(--color-text-muted);margin-bottom:4px;padding-left:4px}.message-content{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md)}.message-bubble.mine .message-content{background:var(--color-sage);color:#fff;border-bottom-right-radius:4px}.message-bubble.other .message-content{background:var(--color-bg-secondary);color:var(--color-text-primary);border-bottom-left-radius:4px}.message-content p{margin:0;word-wrap:break-word}.message-time{display:block;font-size:.65rem;opacity:.7;margin-top:4px;text-align:right}.message-input-form{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);border-top:1px solid rgba(0,0,0,.08);background:var(--color-bg-card)}.message-input{flex:1;padding:12px 16px;border:2px solid rgba(0,0,0,.08);border-radius:var(--radius-full);font-family:inherit;font-size:.95rem;background:var(--color-bg-secondary);transition:var(--transition-fast)}.message-input:focus{outline:none;border-color:var(--color-sage)}.message-input:disabled{opacity:.6}.send-button{width:44px;height:44px;border:none;border-radius:var(--radius-full);background:var(--color-sage);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);flex-shrink:0}.send-button:hover:not(:disabled){background:var(--color-sage-dark);transform:scale(1.05)}.send-button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.messages-container{height:calc(100vh - 220px);max-height:calc(100vh - 220px);padding-bottom:100px}.nav-item a{padding:var(--space-xs) var(--space-sm);font-size:.65rem}.nav-icon{width:20px;height:20px}}
