*,:before,:after{box-sizing:border-box}html{max-width:100%;overflow-x:hidden}:root{--bg:#060c1f;--surface:#0a1434c7;--card-item:#ffffff0f;--input-bg:#ffffff0d;--green-dark:#d4785a;--green-light:#e8a48c;--yellow:#ffd166;--purple:#c77dff;--cream:#f5f0e8;--brown:#f0f4ff;--border:#ffffff1f;--white:#fff}body{background-color:var(--bg);max-width:100%;min-height:100vh;margin:0;font-family:Nunito,sans-serif;overflow-x:hidden}body:before{content:"";pointer-events:none;background-image:radial-gradient(circle at 2% 4%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 8% 11%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 14% 3%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 21% 8%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 28% 13%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 35% 5%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 42% 10%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 49% 3%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 56% 8%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 63% 13%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 70% 5%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 77% 10%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 84% 4%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 91% 9%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 97% 13%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 5% 14%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 12% 7%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 19% 12%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 26% 4%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 33% 9%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 40% 14%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 47% 6%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 54% 11%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 61% 4%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 68% 9%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 75% 14%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 82% 6%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 89% 11%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 95% 4%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 3% 20%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 9% 26%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 16% 21%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 23% 28%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 30% 19%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 37% 25%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 44% 30%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 51% 22%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 58% 28%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 65% 20%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 72% 26%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 79% 21%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 86% 29%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 93% 19%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 6% 32%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 13% 25%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 20% 32%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 27% 18%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 34% 25%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 41% 32%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 48% 19%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 55% 26%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 62% 32%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 69% 19%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 76% 25%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 83% 32%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 90% 19%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 97% 26%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 1% 42%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 7% 48%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 14% 40%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 21% 46%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 28% 52%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 35% 41%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 42% 47%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 49% 42%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 56% 48%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 63% 40%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 70% 46%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 77% 52%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 84% 42%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 91% 48%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 98% 40%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 4% 60%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 11% 67%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 18% 62%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 25% 69%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 32% 61%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 39% 68%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 46% 62%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 53% 69%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 60% 62%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 67% 68%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 74% 62%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 81% 69%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 88% 62%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 95% 68%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 2% 76%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 9% 73%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 16% 79%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 23% 74%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 30% 79%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 37% 73%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 44% 79%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 51% 74%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 58% 79%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 65% 73%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 72% 79%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 79% 73%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 86% 79%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 93% 74%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 5% 86%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 12% 91%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 19% 85%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 26% 92%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 33% 87%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 40% 93%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 47% 86%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 54% 92%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 61% 86%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 68% 93%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 75% 87%,#fff9 0 1px,#0000 1.5px),radial-gradient(circle at 82% 93%,#ffffff73 0 1px,#0000 1.5px),radial-gradient(circle at 89% 87%,#ffffffbf 0 1px,#0000 1.5px),radial-gradient(circle at 96% 92%,#ffffff73 0 1px,#0000 1.5px);background-repeat:no-repeat;background-size:100% 100%;animation:6s ease-in-out infinite alternate twinkle1;position:fixed;inset:0}body:after{content:"";pointer-events:none;background-image:radial-gradient(circle at 11% 6%,#fffffff2 0,#ffffffb3 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 33% 18%,#ffffffe6 0,#ffffffa6 1.5px,#ffffff1a 4px,#0000 7px),radial-gradient(circle at 67% 3%,#fffffff2 0,#ffffffb3 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 89% 12%,#ffffffd9 0,#fff9 1.5px,#ffffff1a 4px,#0000 7px),radial-gradient(circle at 22% 35%,#ffffffe6 0,#ffffffa6 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 78% 29%,#fffffff2 0,#ffffffb3 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 45% 49%,#ffffffd9 0,#fff9 1.5px,#ffffff1a 4px,#0000 7px),radial-gradient(circle at 11% 63%,#ffffffe6 0,#ffffffa6 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 67% 57%,#fffffff2 0,#ffffffb3 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 89% 71%,#ffffffd9 0,#fff9 1.5px,#ffffff1a 4px,#0000 7px),radial-gradient(circle at 33% 82%,#ffffffe6 0,#ffffffa6 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 55% 91%,#fffffff2 0,#ffffffb3 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 78% 77%,#ffffffd9 0,#fff9 1.5px,#ffffff1a 4px,#0000 7px),radial-gradient(circle at 22% 89%,#ffffffe6 0,#ffffffa6 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 4% 45%,#fffffff2 0,#ffffffb3 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 96% 39%,#ffffffd9 0,#fff9 1.5px,#ffffff1a 4px,#0000 7px),radial-gradient(circle at 56% 21%,#ffffffe6 0,#ffffffa6 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 44% 74%,#fffffff2 0,#ffffffb3 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 8% 83%,#ffffffd9 0,#fff9 1.5px,#ffffff1a 4px,#0000 7px),radial-gradient(circle at 91% 59%,#ffffffe6 0,#ffffffa6 1.5px,#ffffff1f 4px,#0000 7px),radial-gradient(circle at 28% 59%,#fffffff2 0,#ffffffb3 1.5px,#ffffff1f 4px,#0000 7px);background-repeat:no-repeat;background-size:100% 100%;animation:4s ease-in-out 1s infinite alternate twinkle2;position:fixed;inset:0}@keyframes twinkle1{0%{opacity:.65}to{opacity:1}}@keyframes twinkle2{0%{opacity:1}to{opacity:.3}}.page-bg{background:0 0;width:100%;min-height:calc(100vh - 60px);overflow-x:hidden}.grocery-title,.recipe-title,.meal-title,.feedback-title,.todo-title,.home-title{letter-spacing:-.01em;font-family:DM Serif Display,serif;font-weight:400}.page-bg>*,.home-container>*{animation:.45s cubic-bezier(.22,1,.36,1) both pageEnter}.home-container>:nth-child(2){animation-delay:50ms}.home-container>:nth-child(3){animation-delay:.1s}.home-container>:nth-child(4){animation-delay:.15s}@keyframes pageEnter{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.grocery-title,.recipe-title,.meal-title,.feedback-title,.todo-title,.notes-heading,.day-name,.cuisine-count,.recipe-category,.detail-label,.form-title{color:var(--brown)!important}.grocery-container,.recipe-container,.meal-container,.feedback-container,.todo-container,.home-card,.music-bar{-webkit-backdrop-filter:blur(24px);border:1px solid #ffffff1a!important;box-shadow:0 8px 48px #00000073,inset 0 1px #ffffff14!important}.add-button,.todo-add-btn,.submit-button,.add-recipe-button,.post-button,.picker-freetext-btn{letter-spacing:.01em;font-weight:800;border-radius:100px!important}.add-input,.todo-input,.form-input,.note-input,.picker-freetext-input,.edit-input{border:1px solid #ffffff1f!important;border-radius:14px!important}.category-tab,.todo-filter-btn,.assignee-btn,.back-button{border-radius:100px!important}.cuisine-tile{border-radius:20px!important}.navbar{-webkit-backdrop-filter:blur(24px);z-index:10;background:#060c1fd1;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex;position:sticky;top:0}.navbar-brand{color:var(--cream);font-size:1.8rem;line-height:1;text-decoration:none}.hamburger{cursor:pointer;background:0 0;border:none;border-radius:8px;flex-direction:column;justify-content:center;gap:5px;padding:6px;transition:background .2s;display:flex}.hamburger:hover{background:#ffffff26}.hamburger span{background:var(--cream);border-radius:2px;width:24px;height:2px;display:block}.sidebar-overlay{z-index:100;background:#00000059;position:fixed;inset:0}.sidebar{-webkit-backdrop-filter:blur(32px);z-index:101;background:#060c1fe6;border-right:1px solid #ffffff14;flex-direction:column;width:280px;max-width:85vw;height:100vh;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-100%);box-shadow:8px 0 48px #00000080}.sidebar.sidebar-open{transform:translate(0)}.sidebar-header{background:0 0;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:20px 20px 16px;display:flex}.sidebar-title{color:var(--brown);letter-spacing:.02em;font-size:1.1rem;font-weight:800}.sidebar-close{color:var(--cream);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-family:inherit;font-size:1.1rem;transition:background .2s}.sidebar-close:hover{background:#fff3}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex}.sidebar-link{color:var(--brown);border-radius:12px;align-items:center;gap:12px;padding:14px 16px;font-size:1rem;font-weight:600;text-decoration:none;transition:background .2s,color .2s;display:flex}.sidebar-link:hover{background:#ffffff14}.sidebar-link.active{background:var(--green-dark);color:var(--white)}.sidebar-logout{border:2px solid var(--border);color:var(--brown);cursor:pointer;background:0 0;border-radius:12px;margin:16px;padding:12px;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .2s}.sidebar-logout:hover{color:#c87070;border-color:#c87070}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.home-container{flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:calc(100vh - 60px);padding:24px 20px;display:flex}.home-container>*{opacity:0;animation:.8s cubic-bezier(.22,1,.36,1) forwards fadeUp}.home-card{animation-delay:.3s!important}.days-widget{animation-delay:.85s!important}.music-bar{animation-delay:1.3s!important}.couple-icon{border:3px solid var(--border);background:var(--card-item);border-radius:50%;width:110px;height:110px;margin:0 auto 16px;overflow:hidden}.couple-img{width:200%;height:auto;margin-top:-10px;margin-left:-100%}.home-card{background:var(--surface);text-align:center;border:1px solid #ffffff1a;border-radius:28px;width:100%;max-width:420px;padding:36px 28px;box-shadow:0 8px 64px #00000080,0 0 120px #ff7b540f}.home-title{color:var(--brown);letter-spacing:.01em;margin:0 0 8px;font-family:Caveat,cursive;font-size:3.2rem;font-weight:700;line-height:1.1}.home-subtitle{color:#f0f4ff80;margin:0;font-size:1rem;font-weight:500}.music-bar{background:var(--surface);border:1px solid var(--border);border-radius:12px;align-items:center;gap:10px;width:100%;min-width:0;max-width:420px;padding:10px 16px;display:flex}.music-note{color:var(--green-dark);font-size:1.1rem;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.music-title{color:var(--brown);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.9rem;font-weight:600;overflow:hidden}.music-toggle{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 6px;font-size:1.1rem;transition:background .2s}.music-toggle:hover{background:#ffffff14}.youtube-hidden{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.days-widget{background:var(--purple);border-radius:12px;flex-direction:row;align-items:center;gap:10px;padding:10px 20px;display:flex}.days-number{color:var(--yellow);font-size:1.6rem;font-weight:800;line-height:1}.days-label{color:var(--cream);font-size:.85rem;font-weight:700}.grocery-container{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:500px;margin:24px auto;padding:20px 16px;box-shadow:0 8px 32px #0006}.grocery-title{color:var(--brown);margin-bottom:28px;font-size:2.6rem;font-weight:400;line-height:1.1}.add-form{flex-wrap:wrap;gap:8px;margin-bottom:24px;display:flex}.add-input{border:2px solid var(--border);background:var(--input-bg);color:var(--brown);border-radius:12px;outline:none;flex:1;padding:12px 16px;font-family:inherit;font-size:1rem;transition:border-color .2s}.add-input:focus{border-color:var(--green-dark)}.priority-toggle{gap:4px;display:flex}.priority-btn{border:2px solid var(--border);background:var(--card-item);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.1rem;transition:all .2s;display:flex}.priority-btn:hover{border-color:var(--green-dark)}.priority-btn.selected{border-color:var(--green-dark);background:var(--green-dark)}.item-priority{cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:2px 4px;font-family:inherit;font-size:.95rem;transition:background .15s}.item-priority:hover{background:#0000000f}.edit-input{border:2px solid var(--green-dark);background:var(--input-bg);color:var(--brown);border-radius:8px;outline:none;flex:1;padding:4px 8px;font-family:inherit;font-size:1rem}.add-button{background:var(--green-dark);color:var(--white);cursor:pointer;border:none;border-radius:12px;padding:12px 20px;font-family:inherit;font-size:1rem;font-weight:700;transition:background .2s}.add-button:hover{background:var(--green-light)}.item-list{margin:0;padding:0;list-style:none}.item{background:var(--card-item);border:1px solid var(--border);border-radius:12px;align-items:center;gap:12px;margin-bottom:6px;padding:12px 16px;display:flex}.checkbox{border:2px solid var(--border);background:var(--input-bg);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-family:inherit;font-size:.8rem;transition:background .2s,border-color .2s;display:flex}.checkbox.checked{background:var(--green-dark);border-color:var(--green-dark);color:#fff}.item-name{color:var(--brown);flex:1;font-size:1rem;font-weight:500}.item.checked .item-name{color:#a0a0a0;text-decoration:line-through}.delete-button{color:#c8b8a8;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 6px;font-family:inherit;font-size:.9rem;transition:color .2s}.delete-button:hover{color:var(--purple)}.got-label{text-transform:uppercase;letter-spacing:.08em;color:#a0a0a0;margin:20px 0 8px;font-size:.8rem;font-weight:700}.recipe-container{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:600px;margin:24px auto;padding:20px 16px;box-shadow:0 8px 32px #0006}.recipe-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.recipe-title{color:var(--brown);margin:0;font-size:2.6rem;font-weight:400;line-height:1.1}.add-recipe-button{background:var(--green-dark);color:var(--white);cursor:pointer;border:none;border-radius:20px;padding:10px 18px;font-family:inherit;font-size:.95rem;font-weight:700;transition:background .2s}.add-recipe-button:hover{background:var(--green-light)}.recipe-form{background:var(--card-item);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:12px;margin-bottom:24px;padding:20px;display:flex}.form-input{border:2px solid var(--border);color:var(--brown);background:var(--input-bg);resize:vertical;border-radius:10px;outline:none;padding:10px 14px;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-input:focus{border-color:var(--green-dark);background:var(--input-bg)}.submit-button{background:var(--green-dark);color:var(--white);cursor:pointer;border:none;border-radius:12px;padding:12px;font-family:inherit;font-size:1rem;font-weight:700;transition:background .2s}.submit-button:hover{background:var(--green-light)}.category-tabs{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.category-tab{border:2px solid var(--border);background:var(--card-item);color:var(--brown);cursor:pointer;border-radius:20px;padding:6px 16px;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s}.category-tab:hover{border-color:var(--green-dark);color:var(--green-dark)}.category-tab.active{background:var(--green-dark);border-color:var(--green-dark);color:var(--white)}.recipe-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.recipe-item{background:var(--card-item);border:1px solid var(--border);border-radius:16px;overflow:hidden}.recipe-row{cursor:pointer;justify-content:space-between;align-items:center;padding:16px;transition:background .2s;display:flex}.recipe-row:hover{background:#ffffff0d}.recipe-name{color:var(--brown);margin-right:10px;font-size:1rem;font-weight:700}.recipe-category{text-transform:uppercase;letter-spacing:.06em;color:var(--green-light);font-size:.75rem;font-weight:700}.recipe-chevron{color:var(--green-light);font-size:.75rem}.recipe-detail{border-top:1px solid var(--border);flex-direction:column;gap:12px;padding:0 16px 16px;display:flex}.recipe-link{color:var(--purple);margin-top:12px;font-weight:600;text-decoration:none;display:inline-block}.recipe-link:hover{text-decoration:underline}.detail-section{flex-direction:column;gap:4px;display:flex}.detail-label{text-transform:uppercase;letter-spacing:.08em;color:var(--green-light);margin:0;font-size:.75rem;font-weight:700}.detail-text{color:var(--brown);white-space:pre-wrap;margin:0;font-family:inherit;font-size:.95rem}.grocery-button{background:var(--purple);color:var(--white);cursor:pointer;border:none;border-radius:10px;align-self:flex-start;padding:8px 16px;font-family:inherit;font-size:.9rem;font-weight:700;transition:background .2s}.grocery-button:hover{background:#6a3a6a}.grocery-button:disabled{opacity:.5;cursor:not-allowed}.link-row{align-items:stretch;gap:8px;display:flex}.link-input{flex:1;min-width:0}.fetch-btn{background:var(--green-dark);color:var(--white);cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:10px 14px;font-family:inherit;font-size:.85rem;font-weight:700;transition:background .2s}.fetch-btn:hover{background:var(--green-light)}.fetch-btn:disabled{opacity:.6;cursor:not-allowed}.fetch-message{color:var(--green-dark);margin:0;font-size:.85rem;font-weight:600}.form-title{color:var(--green-dark);margin:0 0 4px;font-size:1rem;font-weight:700}.recipe-actions{gap:8px;display:flex}.edit-recipe-button{border:1px solid var(--border);color:var(--green-dark);cursor:pointer;background:0 0;border-radius:8px;padding:6px 12px;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s}.edit-recipe-button:hover{background:var(--green-dark);border-color:var(--green-dark);color:var(--white)}.delete-recipe-button{color:#c87070;cursor:pointer;background:0 0;border:1px solid #e8c8c8;border-radius:8px;align-self:flex-start;padding:6px 12px;font-family:inherit;font-size:.85rem;transition:all .2s}.delete-recipe-button:hover{color:#ff8070;background:#e83a2a1f}.empty-message{color:#a0a0a0;text-align:center;padding:40px 0}.cuisine-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.cuisine-tile{background:var(--card-item);border:2px solid var(--border);cursor:pointer;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:20px 12px;font-family:inherit;transition:all .2s;display:flex}.cuisine-tile:hover:not(:disabled){border-color:var(--green-dark);background:#ffffff12;transform:translateY(-2px)}.cuisine-tile:disabled{opacity:.4;cursor:not-allowed}.cuisine-emoji{font-size:2rem;line-height:1}.cuisine-name{color:var(--brown);font-size:.95rem;font-weight:700}.cuisine-count{color:var(--green-dark);font-size:.75rem;font-weight:600}.cuisine-back-header{align-items:center;gap:12px;display:flex}.back-button{border:2px solid var(--border);color:var(--green-dark);cursor:pointer;white-space:nowrap;background:0 0;border-radius:20px;padding:6px 12px;font-family:inherit;font-size:.85rem;font-weight:700;transition:all .2s}.back-button:hover{background:var(--green-dark);border-color:var(--green-dark);color:var(--white)}.form-row{gap:8px;display:flex}.form-row .form-input{flex:1;min-width:0}.ingredient-list{flex-direction:column;gap:4px;margin:0 0 12px;padding:0;list-style:none;display:flex}.ingredient-item{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:8px 4px;transition:background .15s;display:flex}.ingredient-item:hover{background:#ffffff0d}.ingredient-checkbox{border:2px solid var(--border);background:var(--input-bg);border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;transition:background .15s,border-color .15s;display:flex}.ingredient-checkbox.checked{background:var(--green-dark);border-color:var(--green-dark);color:#fff}.ingredient-name{color:var(--brown);font-size:.95rem;font-weight:500;transition:color .15s}.ingredient-name.deselected{color:#a0a0a0;text-decoration:line-through}.meal-container{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:600px;margin:24px auto;padding:20px 16px;box-shadow:0 8px 32px #0006}.meal-title{color:var(--brown);margin-bottom:24px;font-size:2.6rem;font-weight:400;line-height:1.1}.days-list{flex-direction:column;gap:8px;display:flex}.day-card{background:var(--card-item);border:1px solid var(--border);border-radius:14px;align-items:center;gap:12px;padding:14px 16px;display:flex}.day-name{color:var(--green-dark);flex-shrink:0;width:80px;font-size:.9rem;font-weight:800}.day-card.today{border-color:var(--green-dark);background:#e83a2a1a}.day-meal{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.day-meal-name{color:var(--brown);word-break:break-word;flex:1;font-size:.95rem;font-weight:600}.day-change{border:1px solid var(--border);color:var(--green-dark);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;padding:4px 10px;font-family:inherit;font-size:.8rem;font-weight:600;transition:all .2s}.day-change:hover{background:var(--green-dark);color:var(--white);border-color:var(--green-dark)}.day-clear{color:#c8b8a8;cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px 6px;font-size:.9rem;transition:color .2s}.day-clear:hover{color:var(--purple)}.day-add{border:2px dashed var(--border);color:#a0a0a0;cursor:pointer;text-align:left;background:0 0;border-radius:10px;flex:1;padding:8px 12px;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s}.day-add:hover{border-color:var(--green-dark);color:var(--green-dark)}.picker-overlay{z-index:200;background:#0006;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.picker-modal{background:var(--surface);border-radius:24px 24px 0 0;flex-direction:column;width:100%;max-width:600px;max-height:70vh;display:flex;overflow:hidden}.picker-header{background:0 0;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:20px 20px 12px;display:flex}.picker-title{color:var(--brown);font-size:1rem;font-weight:800}.picker-close{color:var(--brown);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-family:inherit;font-size:1.1rem;transition:background .2s}.picker-close:hover{background:#fff3}.picker-list{flex-direction:column;gap:6px;margin:0;padding:12px;list-style:none;display:flex;overflow-y:auto}.picker-item{background:var(--card-item);border:1px solid var(--border);cursor:pointer;border-radius:12px;justify-content:space-between;align-items:center;padding:14px 16px;transition:all .2s;display:flex}.picker-item:hover{background:var(--green-dark);border-color:var(--green-dark)}.picker-item:hover .picker-recipe-name,.picker-item:hover .picker-recipe-category{color:var(--white)}.picker-recipe-name{color:var(--brown);font-size:.95rem;font-weight:700}.picker-recipe-category{text-transform:uppercase;letter-spacing:.05em;color:var(--green-light);font-size:.75rem;font-weight:700}.picker-empty{text-align:center;color:#a0a0a0;padding:24px}.day-cooked{cursor:pointer;filter:grayscale()opacity(.35);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:1.2rem;transition:transform .2s,filter .2s;display:flex}.day-cooked:hover{filter:grayscale(.3)opacity(.7);transform:scale(1.15)}.day-cooked.cooked{filter:grayscale(0)opacity();transform:scale(1.2)}.day-meal-name.cooked{color:#b0b0b0;text-decoration:line-through}.picker-extras{flex-direction:column;gap:8px;padding:12px 12px 0;display:flex}.picker-eating-out{background:var(--card-item);border:2px dashed var(--yellow);color:var(--brown);cursor:pointer;text-align:left;border-radius:12px;padding:12px 16px;font-family:inherit;font-size:.95rem;font-weight:700;transition:all .2s}.picker-eating-out:hover{background:var(--yellow);border-style:solid}.picker-freetext-row{gap:8px;display:flex}.picker-freetext-input{border:2px solid var(--border);color:var(--brown);background:var(--input-bg);border-radius:10px;outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:.95rem}.picker-freetext-input:focus{border-color:var(--green-dark)}.picker-freetext-btn{background:var(--green-dark);color:var(--white);cursor:pointer;border:none;border-radius:10px;padding:10px 16px;font-family:inherit;font-size:.9rem;font-weight:700;transition:background .2s}.picker-freetext-btn:hover{background:var(--green-light)}.picker-freetext-btn:disabled{opacity:.4;cursor:not-allowed}.ribbon-wrapper{background:var(--purple);white-space:nowrap;border-bottom:3px solid var(--yellow);width:100%;padding:10px 0;overflow:hidden}.ribbon-track{animation:60s linear infinite ribbon-scroll;display:inline-flex}.ribbon-wrapper:hover .ribbon-track{animation-play-state:paused}@keyframes ribbon-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.ribbon-item{color:var(--cream);white-space:nowrap;align-items:center;gap:6px;padding:0 32px;font-size:.88rem;font-weight:600;display:inline-flex}.ribbon-author{color:var(--yellow);font-weight:800}.ribbon-dot{color:var(--yellow);margin-left:20px;font-size:.6rem}.feedback-container{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:500px;margin:24px auto;padding:20px 16px;box-shadow:0 8px 32px #0006}.feedback-title{color:var(--brown);margin-bottom:4px;font-size:2.6rem;font-weight:400;line-height:1.1}.feedback-subtitle{color:#a0a0a0;margin:0 0 24px;font-size:.9rem}.letterbox{flex-direction:column;align-items:center;width:120px;margin:0 auto 28px;display:flex}.letterbox-top{background:#c20;border:3px solid #991a00;border-bottom:none;border-radius:50% 50% 0 0;flex-direction:column;align-items:center;gap:4px;width:100px;padding:10px 0 6px;display:flex}.letterbox-crown{clip-path:polygon(0% 100%,20% 0%,40% 60%,60% 0%,80% 60%,100% 0%,100% 100%);background:gold;width:32px;height:18px}.letterbox-label{color:gold;letter-spacing:.15em;font-size:.65rem;font-weight:800}.letterbox-body{background:#c20;border-left:3px solid #991a00;border-right:3px solid #991a00;flex-direction:column;justify-content:center;align-items:center;width:100px;height:80px;display:flex;position:relative}.letterbox-slot{background:#1a1a1a;border-radius:5px;justify-content:center;align-items:center;width:60px;height:10px;transition:transform .15s;display:flex;box-shadow:inset 0 2px 4px #00000080}.letterbox-slot.posting{transform:scaleY(1.4)}.slot-line{background:#ffffff26;width:40px;height:1px}.posted-message{color:gold;font-size:.75rem;font-weight:700;animation:.3s fadeIn;position:absolute;bottom:8px}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.letterbox-base{background:#991a00;border-radius:0 0 8px 8px;width:110px;height:14px}.note-form{background:var(--card-item);border:2px solid var(--border);border-radius:16px;flex-direction:column;gap:12px;margin-bottom:28px;padding:20px;display:flex;position:relative}.note-form:before{content:"";background:repeating-linear-gradient(90deg, var(--yellow) 0px, var(--yellow) 8px, transparent 8px, transparent 14px);border-radius:2px;height:3px;position:absolute;top:0;left:40px;right:40px}.author-toggle{gap:8px;display:flex}.author-btn{border:2px solid var(--border);background:var(--card-item);color:var(--brown);cursor:pointer;border-radius:20px;padding:6px 18px;font-family:inherit;font-size:.9rem;font-weight:700;transition:all .2s}.author-btn.selected{background:var(--purple);border-color:var(--purple);color:var(--white)}.note-input{border:2px solid var(--border);color:var(--brown);background:var(--input-bg);resize:vertical;border-radius:12px;outline:none;padding:12px 14px;font-family:inherit;font-size:1rem;line-height:1.6;transition:border-color .2s}.note-input:focus{border-color:var(--green-dark)}.post-button{color:var(--white);cursor:pointer;background:#c20;border:none;border-radius:12px;padding:12px;font-family:inherit;font-size:1rem;font-weight:700;transition:background .2s}.post-button:hover{background:#991a00}.post-button:disabled{opacity:.5;cursor:not-allowed}.notes-heading{color:var(--green-dark);margin:0 0 12px;font-size:1.1rem;font-weight:800}.notes-list{flex-direction:column;gap:10px;display:flex}.note-card{background:var(--card-item);border:1px solid var(--border);border-left:4px solid var(--purple);border-radius:14px;padding:14px 16px}.note-card-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.note-author{color:var(--purple);font-size:.85rem;font-weight:800}.note-date{color:#a0a0a0;flex:1;font-size:.8rem}.note-delete{color:#c8b8a8;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:.85rem;transition:color .2s}.note-delete:hover{color:var(--purple)}.note-message{color:var(--brown);white-space:pre-wrap;margin:0;font-size:.95rem;line-height:1.6}.todo-container{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:500px;margin:24px auto;padding:20px 16px;box-shadow:0 8px 32px #0006}.todo-title{color:var(--brown);margin-bottom:28px;font-size:2.6rem;font-weight:400;line-height:1.1}.todo-form{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.todo-input{box-sizing:border-box;border:2px solid var(--border);background:var(--input-bg);width:100%;color:var(--brown);border-radius:12px;outline:none;padding:12px 16px;font-family:inherit;font-size:1rem;transition:border-color .2s}.todo-input:focus{border-color:var(--green-dark)}.todo-form-row{align-items:center;gap:8px;display:flex}.assignee-toggle{flex:1;gap:4px;display:flex}.assignee-btn{border:2px solid var(--border);background:var(--card-item);cursor:pointer;height:42px;color:var(--brown);border-radius:10px;padding:0 14px;font-family:inherit;font-size:.9rem;font-weight:700;transition:all .2s}.assignee-btn.selected.assignee-ozzy{background:var(--purple);border-color:var(--purple);color:var(--white)}.assignee-btn.selected.assignee-tommy{background:var(--green-dark);border-color:var(--green-dark);color:var(--white)}.assignee-btn.selected.assignee-both{background:var(--yellow);border-color:var(--yellow);color:#1a1a1a}.todo-add-btn{background:var(--green-dark);color:var(--white);cursor:pointer;border:none;border-radius:12px;padding:12px 20px;font-family:inherit;font-size:1rem;font-weight:700;transition:background .2s}.todo-add-btn:hover{background:var(--green-light)}.todo-filters{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.todo-filter-btn{border:2px solid var(--border);background:var(--card-item);cursor:pointer;color:var(--brown);border-radius:20px;padding:6px 14px;font-family:inherit;font-size:.85rem;font-weight:700;transition:all .2s}.todo-filter-btn.active{background:var(--green-dark);border-color:var(--green-dark);color:var(--white)}.todo-list{margin:0;padding:0;list-style:none}.todo-item{background:var(--card-item);border:1px solid var(--border);border-radius:12px;align-items:center;gap:10px;margin-bottom:6px;padding:12px 14px;display:flex}.todo-checkbox{border:2px solid var(--border);background:var(--input-bg);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-family:inherit;font-size:.8rem;transition:background .2s,border-color .2s;display:flex}.todo-checkbox-done{background:var(--green-dark);border-color:var(--green-dark);color:var(--white)}.todo-task{color:var(--brown);flex:1;font-size:1rem;font-weight:500}.todo-task-done{color:#dce4ff59;text-decoration:line-through}.todo-badge{border-radius:20px;flex-shrink:0;padding:3px 10px;font-size:.75rem;font-weight:700}.badge-ozzy{color:var(--purple);background:#c77dff26}.badge-tommy{color:var(--green-light);background:#e83a2a26}.badge-both{color:var(--yellow);background:#ffd16626}.todo-delete{color:#dce4ff4d;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 6px;font-family:inherit;font-size:.9rem;transition:color .2s}.todo-delete:hover{color:var(--green-dark)}.todo-done-label{text-transform:uppercase;letter-spacing:.08em;color:#dce4ff59;margin:20px 0 8px;font-size:.8rem;font-weight:700}.todo-empty{text-align:center;color:#dce4ff59;padding:20px 0;font-size:.95rem}.login-container{justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--white);border:2px solid var(--border);border-radius:20px;width:100%;max-width:380px;padding:40px;box-shadow:0 4px 24px #4a7c3f1a}.login-title{color:var(--green-dark);text-align:center;letter-spacing:.05em;margin:0 0 4px;font-size:2.2rem;font-weight:800}.login-subtitle{color:#a0a0a0;text-align:center;margin:0 0 28px;font-size:.95rem}.login-form{flex-direction:column;gap:12px;display:flex}.login-input{border:2px solid var(--border);background:var(--cream);color:var(--brown);border-radius:12px;outline:none;padding:12px 16px;font-family:inherit;font-size:1rem;transition:border-color .2s}.login-input:focus{border-color:var(--green-dark);background:var(--white)}.login-button{background:var(--green-dark);color:var(--white);cursor:pointer;border:none;border-radius:12px;margin-top:4px;padding:12px;font-family:inherit;font-size:1rem;font-weight:700;transition:background .2s}.login-button:hover{background:var(--green-light)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#c87070;text-align:center;margin:0;font-size:.9rem}
