:root{--color-terracotta:#2d5a30;--color-terracotta-dark:#1d4a20;--color-terracotta-light:#e8f2e9;--color-cream:#f8faf7;--color-cream-dark:#e8efe6;--color-olive:#2d5b30;--color-olive-dark:#1d4b20;--color-olive-light:#e5f0e7;--color-mustard:#6a5a12;--color-mustard-light:#faf6e8;--color-charcoal:#2a3a2e;--color-brown:#3a4a3e;--color-taupe:#4a5a4c;--color-sand:#4a5a4c;--color-background:#fafcfa;--color-surface:var(--color-cream);--color-border:#c8d8c8;--color-text:var(--color-charcoal);--color-text-muted:var(--color-taupe);--color-danger:#b91c1c;--color-danger-light:#fceaea;--font-display:"Fraunces", Georgia, serif;--font-body:"Outfit", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.625rem;--text-3xl:2.25rem;--text-4xl:3rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--container-max:1200px;--header-height:72px;--mobile-nav-height:66px;--mobile-nav-offset:calc(var(--mobile-nav-height) + env(safe-area-inset-bottom));--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--shadow-sm:0 2px 4px #2d29260a;--shadow-md:0 4px 12px #2d292614;--shadow-lg:0 8px 24px #2d29261a;--shadow-xl:0 16px 48px #2d29261f;--shadow-glow:0 0 40px #c4553d26;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--transition-bounce:.5s cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;scroll-behavior:smooth}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background:var(--color-background);background-image:radial-gradient(at 0 0,#c4553d08 0%,#0000 50%),radial-gradient(at 100% 100%,#6b7f5908 0%,#0000 50%);min-height:100vh;font-weight:400;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--color-charcoal);font-variation-settings:"opsz" 32;font-weight:500;line-height:1.2}button{font-family:var(--font-body);font-size:inherit;cursor:pointer;transition:all var(--transition-base);background:0 0;border:none}button:active{transform:scale(.97)}input,textarea{font-family:var(--font-body);font-size:var(--text-base)}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.app{flex-direction:column;min-height:100vh;display:flex}.container{width:100%;max-width:var(--container-max);padding:0 var(--space-6);margin:0 auto}@media (width<=640px){.container{padding:0 var(--space-4)}}.main{padding:var(--space-10) 0 var(--space-16);flex:1}@media (width<=640px){.main{padding:var(--space-6) 0 var(--space-10)}}.header{height:var(--header-height);-webkit-backdrop-filter:blur(20px);z-index:100;background:#fffcf8d9;border-bottom:1px solid #e8ddd099;position:sticky;top:0}.header-content{height:100%;max-width:var(--container-max);padding:0 var(--space-6);grid-template-columns:1fr auto 1fr;align-items:center;margin:0 auto;display:grid}@media (width<=640px){.header-content{padding:0 var(--space-4)}}@media (width<=900px){.header-content{grid-template-columns:1fr auto}}.logo-section{align-items:center;gap:var(--space-3);color:inherit;justify-self:start;text-decoration:none;display:flex}.logo-icon{color:var(--color-terracotta);filter:drop-shadow(0 2px 4px #c4553d33);transition:transform var(--transition-bounce)}.logo-section:hover .logo-icon{transform:rotate(-8deg)scale(1.05)}.logo-text h1{font-size:var(--text-xl);letter-spacing:-.02em;background:linear-gradient(135deg, var(--color-charcoal) 0%, var(--color-brown) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:600}@media (width<=480px){.logo-text h1{font-size:var(--text-lg)}}.header-nav{align-items:center;gap:var(--space-6);padding:0 var(--space-4);justify-self:center;display:flex}.nav-tab{align-items:center;gap:var(--space-2);padding:var(--space-2) 0;font-size:var(--text-sm);color:var(--color-taupe);transition:all var(--transition-fast);white-space:nowrap;font-weight:500;display:flex;position:relative}.nav-tab:after{content:"";background:var(--color-terracotta);height:2px;transition:transform var(--transition-fast);border-radius:1px;position:absolute;bottom:-2px;left:0;right:0;transform:scaleX(0)}.nav-tab:hover{color:var(--color-charcoal)}.nav-tab.active{color:var(--color-terracotta);font-weight:600}.nav-tab.active:after{transform:scaleX(1)}@media (width<=900px){.header-nav.desktop-only{display:none}}.mobile-nav{z-index:100;padding:var(--space-2) var(--space-4);padding-bottom:calc(var(--space-2) + env(safe-area-inset-bottom));min-height:var(--mobile-nav-offset);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--color-border);background:#fafcfaf2;display:none;position:fixed;bottom:0;left:0;right:0}.mobile-nav-container{justify-content:center;width:100%;max-width:360px;display:flex}@media (width<=900px){.mobile-nav{justify-content:center;display:flex}.main{padding-bottom:calc(var(--mobile-nav-offset) + var(--space-10))}}.mobile-nav-item{min-width:0;padding:var(--space-2) var(--space-2);color:var(--color-taupe);font-size:var(--text-xs);transition:color var(--transition-fast);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;font-weight:500;line-height:1.1;display:flex;position:relative}.mobile-nav-item span{white-space:nowrap}.mobile-nav-item:before{content:"";background:var(--color-terracotta);width:24px;height:2px;transition:transform var(--transition-fast);border-radius:0 0 2px 2px;position:absolute;top:0;left:50%;transform:translate(-50%)scaleX(0)}.mobile-nav-item svg{width:20px;height:20px}.mobile-nav-item.active{color:var(--color-terracotta)}.mobile-nav-item.active:before{transform:translate(-50%)scaleX(1)}.mobile-nav-item:hover:not(.active){color:var(--color-charcoal)}.header-actions{align-items:center;gap:var(--space-3);justify-self:end;display:flex}.create-menu-container{position:relative}.btn-create{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-terracotta);color:#fff;border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:500;display:flex}.btn-create:hover{background:var(--color-terracotta-dark)}.create-menu{top:calc(100% + var(--space-2));border-radius:var(--radius-md);min-width:160px;box-shadow:var(--shadow-lg);border:1px solid var(--color-border);z-index:100;background:#fff;animation:.15s ease-out dropdownFadeIn;position:absolute;right:0;overflow:hidden}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.create-menu-item{align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:background var(--transition-fast);text-align:left;background:0 0;border:none;display:flex}.create-menu-item:hover{background:var(--color-cream)}.create-menu-item svg{color:var(--color-taupe)}@media (width<=640px){.btn-create span.desktop-only{display:none}.btn-create{justify-content:center;width:40px;height:40px;padding:0}}.user-info{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4) var(--space-2) var(--space-2);background:var(--color-cream);border-radius:var(--radius-full);border:1px solid var(--color-border);display:flex}.user-avatar{background:linear-gradient(135deg, var(--color-terracotta) 0%, var(--color-terracotta-dark) 100%);color:#fff;border-radius:var(--radius-full);width:32px;height:32px;font-size:var(--text-sm);justify-content:center;align-items:center;display:flex}.user-name{font-size:var(--text-sm);color:var(--color-charcoal);text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-weight:500;overflow:hidden}.btn-icon{width:44px;height:44px;color:var(--color-taupe);border-radius:var(--radius-md);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.btn-icon:hover{background:var(--color-cream);color:var(--color-charcoal)}@media (width<=640px){.user-info{display:none}.header-actions{gap:var(--space-2)}}@media (width<=900px){.header-action-button{min-width:44px}.header-actions .btn-primary .btn-text{display:none}.header-actions .btn-primary{justify-content:center;width:44px;height:44px;padding:0}}.btn-primary{justify-content:center;align-items:center;gap:var(--space-2);height:44px;padding:0 var(--space-6);background:linear-gradient(135deg, var(--color-terracotta) 0%, var(--color-terracotta-dark) 100%);color:#fff;font-size:var(--text-sm);border-radius:var(--radius-full);transition:all var(--transition-base);white-space:nowrap;flex-shrink:0;font-weight:600;display:inline-flex;box-shadow:0 4px 12px #2d5a304d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #2d5a3066}.btn-primary:active{transform:translateY(0)scale(.98)}.btn-primary:disabled{opacity:.72;cursor:not-allowed;transform:none}.btn-primary .btn-text{color:inherit}.btn-secondary{justify-content:center;align-items:center;gap:var(--space-2);height:44px;padding:0 var(--space-6);background:var(--color-background);color:var(--color-charcoal);font-size:var(--text-sm);border:2px solid var(--color-border);border-radius:var(--radius-full);transition:all var(--transition-base);font-weight:600;display:inline-flex}.btn-secondary:hover{border-color:var(--color-terracotta);color:var(--color-terracotta);background:var(--color-terracotta-light)}.btn-danger{align-items:center;gap:var(--space-2);height:40px;padding:0 var(--space-5);background:var(--color-danger-light);color:var(--color-danger);font-size:var(--text-sm);border-radius:var(--radius-full);transition:all var(--transition-base);font-weight:600;display:inline-flex}.btn-danger:hover{background:var(--color-danger);color:#fff}.btn-danger-outline{justify-content:center;align-items:center;gap:var(--space-2);width:100%;height:40px;padding:0 var(--space-5);color:var(--color-danger);font-size:var(--text-sm);border:2px solid var(--color-danger-light);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);margin-top:var(--space-4);background:0 0;font-weight:600;display:inline-flex}.btn-danger-outline:hover{background:var(--color-danger-light);border-color:var(--color-danger)}.btn-clear{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);color:var(--color-taupe);font-size:var(--text-sm);border-radius:var(--radius-full);transition:all var(--transition-fast);font-weight:500;display:inline-flex}.btn-clear:hover{background:var(--color-cream);color:var(--color-charcoal)}.visibility-section{padding:var(--space-4);background:var(--color-cream);border-radius:var(--radius-md);margin-top:var(--space-2)}.visibility-control{gap:var(--space-2);flex-direction:column;display:flex}.visibility-hint{font-size:var(--text-xs);color:var(--color-taupe);margin:0;line-height:1.5}.btn-submit{justify-content:center;align-items:center;gap:var(--space-2);background:linear-gradient(135deg, var(--color-terracotta) 0%, var(--color-terracotta-dark) 100%);color:#fff;width:100%;height:52px;font-size:var(--text-base);border-radius:var(--radius-lg);margin-top:var(--space-4);transition:all var(--transition-base);font-weight:600;display:inline-flex;box-shadow:0 4px 12px #2d5a304d}.btn-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #2d5a3066}.btn-submit:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.btn-lg{height:56px;padding:0 var(--space-10);font-size:var(--text-base)}@media (width<=480px){.btn-lg{height:52px;padding:0 var(--space-8);font-size:var(--text-sm)}}.search-filter{margin-bottom:var(--space-10)}.search-bar{align-items:center;gap:var(--space-4);height:56px;padding:0 var(--space-5);background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-xl);transition:all var(--transition-base);box-shadow:var(--shadow-sm);display:flex}.search-bar:focus-within{border-color:var(--color-terracotta);box-shadow:0 0 0 4px var(--color-terracotta-light)}.search-icon{color:var(--color-sand);flex-shrink:0}.search-input{height:100%;color:var(--color-charcoal);box-shadow:none;font-size:var(--text-base);background:0 0;border:none;outline:none;flex:1}.search-input:focus{box-shadow:none;border:none;outline:none}.search-input::placeholder{color:var(--color-sand)}.filter-tags{gap:var(--space-2);margin-top:var(--space-5);flex-wrap:wrap;display:flex}.filter-tag{align-items:center;gap:var(--space-2);height:36px;padding:0 var(--space-4);background:var(--color-background);color:var(--color-brown);font-size:var(--text-sm);border:1.5px solid var(--color-border);border-radius:var(--radius-full);transition:all var(--transition-fast);font-weight:500;display:inline-flex}.filter-tag:hover{border-color:var(--color-terracotta);color:var(--color-terracotta);background:var(--color-terracotta-light)}.filter-tag.active{background:var(--color-terracotta);color:#fff;border-color:var(--color-terracotta)}.results-count{font-size:var(--text-sm);color:var(--color-taupe);margin-bottom:var(--space-6);font-weight:500}.recipe-grid{gap:var(--space-6);grid-template-columns:repeat(1,1fr);display:grid}@media (width>=560px){.recipe-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=900px){.recipe-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=1200px){.recipe-grid{grid-template-columns:repeat(4,1fr)}}.recipe-grid .recipe-card{animation:.5s ease-out backwards cardAppear}.recipe-grid .recipe-card:first-child{animation-delay:0s}.recipe-grid .recipe-card:nth-child(2){animation-delay:50ms}.recipe-grid .recipe-card:nth-child(3){animation-delay:.1s}.recipe-grid .recipe-card:nth-child(4){animation-delay:.15s}.recipe-grid .recipe-card:nth-child(5){animation-delay:.2s}.recipe-grid .recipe-card:nth-child(6){animation-delay:.25s}.recipe-grid .recipe-card:nth-child(7){animation-delay:.3s}.recipe-grid .recipe-card:nth-child(8){animation-delay:.35s}.recipe-grid .recipe-card:nth-child(n+9){animation-delay:.4s}@keyframes cardAppear{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.recipe-card{background:var(--color-background);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-md);border:1px solid #e8ddd080;position:relative;overflow:hidden}.recipe-card:before{content:"";opacity:0;transition:opacity var(--transition-base);pointer-events:none;z-index:1;background:linear-gradient(135deg,#c4553d0d 0%,#0000 50%);position:absolute;inset:0}.recipe-card:hover{box-shadow:var(--shadow-xl), var(--shadow-glow);transform:translateY(-6px)}.recipe-card:hover:before{opacity:1}.card-actions{top:var(--space-3);right:var(--space-3);gap:var(--space-2);opacity:0;z-index:10;transition:all var(--transition-fast);display:flex;position:absolute;transform:translateY(-8px)}.recipe-card:hover .card-actions,.cookbook-card:hover .card-actions,.recipe-card.swipe-actions-open .card-actions{opacity:1;transform:translateY(0)}.card-action{background:var(--color-background);width:36px;height:36px;color:var(--color-taupe);border-radius:var(--radius-md);box-shadow:var(--shadow-md);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.card-action:hover{background:var(--color-olive);color:#fff;transform:scale(1.1)}.card-action.card-delete:hover{background:var(--color-danger);color:#fff}.card-image{aspect-ratio:4/3;background:linear-gradient(135deg, var(--color-cream) 0%, var(--color-cream-dark) 100%);position:relative;overflow:hidden}.card-image:after{content:"";pointer-events:none;background:linear-gradient(#0000,#2d29261a);height:60px;position:absolute;bottom:0;left:0;right:0}.card-image img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.recipe-card:hover .card-image img{transform:scale(1.08)}.card-image-placeholder{width:100%;height:100%;color:var(--color-terracotta);background:linear-gradient(135deg, var(--color-terracotta-light) 0%, var(--color-cream) 100%);transition:all var(--transition-base);justify-content:center;align-items:center;display:flex}.recipe-card:hover .card-image-placeholder{background:linear-gradient(135deg, var(--color-terracotta-light) 0%, #fde8e4 100%)}.card-body{padding:var(--space-5)}.card-title{font-family:var(--font-display);font-size:var(--text-lg);margin-bottom:var(--space-2);-webkit-line-clamp:1;color:var(--color-charcoal);-webkit-box-orient:vertical;font-weight:500;display:-webkit-box;overflow:hidden}.card-footer{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-taupe);padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-sand);background:var(--color-cream);display:flex}.card-description{font-size:var(--text-sm);color:var(--color-taupe);margin-bottom:var(--space-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.6;display:-webkit-box;overflow:hidden}.card-meta{gap:var(--space-4);margin-bottom:var(--space-4);display:flex}.meta-item{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-taupe);font-weight:500;display:flex}.meta-item svg{color:var(--color-olive)}.card-tags{gap:var(--space-2);flex-wrap:wrap;display:flex}.tag{padding:var(--space-1) var(--space-3);background:var(--color-olive-light);color:var(--color-olive-dark);font-size:var(--text-xs);border-radius:var(--radius-full);text-transform:lowercase;letter-spacing:.02em;font-weight:600;display:inline-block}.tag-more{background:var(--color-mustard-light);color:var(--color-mustard)}.empty-state{padding:var(--space-20) var(--space-6);text-align:center;flex-direction:column;justify-content:center;align-items:center;animation:.6s ease-out fadeInUp;display:flex}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.empty-icon{color:var(--color-terracotta);opacity:.4;margin-bottom:var(--space-8);animation:3s ease-in-out infinite gentleBounce}@keyframes gentleBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.empty-state h3{font-family:var(--font-display);font-size:var(--text-2xl);margin-bottom:var(--space-3);color:var(--color-charcoal);font-weight:500}.empty-state p{color:var(--color-taupe);font-size:var(--text-base);margin-bottom:var(--space-8)}.modal-overlay{-webkit-backdrop-filter:blur(8px);padding:var(--space-6);z-index:1000;background:#2d292699;justify-content:center;align-items:flex-start;animation:.25s ease-out modalOverlayIn;display:flex;position:fixed;inset:0;overflow-y:auto}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}@media (width>=640px){.modal-overlay{padding:var(--space-8);align-items:center}}@media (width<=480px){.modal-overlay{background:var(--color-background);-webkit-backdrop-filter:none;backdrop-filter:none;padding:0}}.modal-content{width:100%;max-height:calc(100vh - var(--space-8));max-height:calc(100dvh - var(--space-8));background:var(--color-background);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);margin:var(--space-4) 0;flex-direction:column;animation:.35s ease-out modalContentIn;display:flex;position:relative;overflow:hidden}@keyframes modalContentIn{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=480px){.modal-content{min-height:100dvh;box-shadow:none;border-radius:0;flex-direction:column;margin:0;animation:none;display:flex}}.modal-form{max-width:min(520px,100%);padding:var(--space-8);flex:1;min-height:0;overflow-y:auto}@media (width<=640px){.modal-form{padding:var(--space-6)}}@media (width<=480px){.modal-form{padding:var(--space-5);padding-top:var(--space-8)}}.modal-detail{max-width:min(760px,100%);overflow-y:auto}@media (width<=480px){.modal-detail{-webkit-overflow-scrolling:touch;max-width:100%;height:100dvh;min-height:0;max-height:none}}.modal-close{top:var(--space-4);right:var(--space-4);width:36px;height:36px;color:var(--color-taupe);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-full);z-index:20;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;display:flex;position:absolute}.modal-close:hover{background:var(--color-charcoal);border-color:var(--color-charcoal);color:#fff;transform:scale(1.05)}@media (width<=480px){.modal-close{top:var(--space-3);right:var(--space-3)}}.modal-header{align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);padding-right:var(--space-12);display:flex}.modal-icon{color:var(--color-terracotta)}.modal-header h2{font-size:var(--text-2xl)}.tab-group{gap:var(--space-1);background:var(--color-cream);border-radius:var(--radius-md);margin-bottom:var(--space-6);border:1px solid var(--color-border);padding:4px;display:flex}.swipe-tab-group,.swipe-pagination,.swipe-close-region{touch-action:pan-y}.tab-btn{justify-content:center;align-items:center;gap:var(--space-2);height:44px;font-size:var(--text-sm);color:var(--color-taupe);border-radius:var(--radius-sm);transition:all var(--transition-fast);flex:1;font-weight:500;display:flex}.tab-btn:hover:not(.active){color:var(--color-charcoal)}.tab-btn.active{background:var(--color-terracotta);color:#fff;box-shadow:var(--shadow-sm);font-weight:600}.form{gap:var(--space-5);flex-direction:column;display:flex}.form-group{gap:var(--space-2);flex-direction:column;min-width:0;display:flex}.form-group label{font-size:var(--text-sm);color:var(--color-charcoal);font-weight:600}.form-group input,.form-group textarea{width:100%;height:48px;padding:0 var(--space-4);background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-charcoal);transition:all var(--transition-fast);font-size:var(--text-base)}.form-group textarea{height:auto;min-height:100px;padding:var(--space-4);resize:vertical;line-height:1.6}.form-group input:hover,.form-group textarea:hover{border-color:var(--color-sand)}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-terracotta);box-shadow:0 0 0 4px var(--color-terracotta-light);outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-sand)}.form-row{gap:var(--space-4);min-width:0;display:grid}.form-row-3{grid-template-columns:repeat(3,1fr)}@media (width<=520px){.form-row-3{grid-template-columns:1fr 1fr}.form-row-3 .form-group:last-child{grid-column:span 2}}@media (width<=380px){.form-row-3{grid-template-columns:1fr}.form-row-3 .form-group:last-child{grid-column:span 1}}.suggested-tags{gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap;display:flex}.suggested-tag{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);color:var(--color-taupe);border:1.5px solid var(--color-border);border-radius:var(--radius-full);transition:all var(--transition-fast);font-weight:600;display:inline-flex}.suggested-tag:hover{border-color:var(--color-olive);color:var(--color-olive);background:var(--color-olive-light)}.tag-input-container{gap:var(--space-3);flex-direction:column;display:flex}.tag-input-field{align-items:center;gap:var(--space-2);min-height:48px;padding:var(--space-2) var(--space-3);background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:text;transition:border-color var(--transition-fast);flex-wrap:wrap;display:flex}.tag-input-field:focus-within{border-color:var(--color-terracotta)}.tag-chip{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);padding-right:var(--space-1);background:var(--color-terracotta);color:#fff;font-size:var(--text-xs);border-radius:var(--radius-full);white-space:nowrap;font-weight:600;display:inline-flex}.tag-chip-remove{color:#fff;cursor:pointer;width:18px;height:18px;transition:background var(--transition-fast);background:#fff3;border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex}.tag-chip-remove:hover{background:#fff6}.tag-input{min-width:100px;padding:var(--space-1) 0;font-size:var(--text-sm);color:var(--color-text);background:0 0;border:none;outline:none;flex:1}.tag-input::placeholder{color:var(--color-taupe)}.tag-suggestions{gap:var(--space-2);flex-wrap:wrap;display:flex}.tag-suggestion{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);color:var(--color-taupe);border:1.5px dashed var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);background:0 0;font-weight:600;display:inline-flex}.tag-suggestion:hover{border-color:var(--color-terracotta);color:var(--color-terracotta);background:var(--color-terracotta-light);border-style:solid}.url-notice{align-items:flex-start;gap:var(--space-4);padding:var(--space-5);background:var(--color-mustard-light);border-radius:var(--radius-md);margin-bottom:var(--space-4);color:var(--color-mustard);border:1px solid #d4a03d4d;display:flex}.url-notice p{font-size:var(--text-sm);color:var(--color-brown);margin:0}.url-notice .notice-subtle{color:var(--color-taupe);margin-top:var(--space-1)}.file-input-hidden{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.image-upload-area{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-8);border:2px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);color:var(--color-taupe);background:var(--color-cream);flex-direction:column;display:flex}.image-upload-area:hover{border-color:var(--color-terracotta);background:var(--color-terracotta-light);color:var(--color-terracotta)}.image-upload-area span{font-size:var(--text-sm);font-weight:600}.image-picker{margin-bottom:var(--space-4)}.image-picker-header{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2);color:var(--color-taupe);font-size:var(--text-sm);font-weight:600;display:flex}.image-picker-grid{gap:var(--space-2);max-height:220px;padding:var(--space-1);grid-template-columns:repeat(auto-fill,minmax(84px,1fr));display:grid;overflow-y:auto}.image-picker-option{aspect-ratio:1;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-cream);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);position:relative;overflow:hidden}.image-picker-option:hover{border-color:var(--color-terracotta);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.image-picker-option.selected{border-color:var(--color-terracotta);box-shadow:0 0 0 3px var(--color-terracotta-light)}.image-picker-option img{object-fit:cover;width:100%;height:100%;display:block}.image-picker-check{top:var(--space-1);right:var(--space-1);border-radius:var(--radius-full);background:var(--color-terracotta);color:#fff;width:22px;height:22px;box-shadow:var(--shadow-sm);justify-content:center;align-items:center;display:flex;position:absolute}.upload-hint{font-size:var(--text-xs);color:var(--color-taupe)}.image-preview{border-radius:var(--radius-lg);position:relative;overflow:hidden}.image-preview img{object-fit:cover;width:100%;height:180px;display:block}.image-remove{top:var(--space-3);right:var(--space-3);background:var(--color-background);width:32px;height:32px;color:var(--color-taupe);border-radius:var(--radius-md);box-shadow:var(--shadow-md);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:absolute}.image-remove:hover{background:var(--color-danger);color:#fff}.image-preview-actions{margin-top:var(--space-3);display:flex}.image-upload-secondary{width:100%}.detail-header{flex-direction:column;display:flex}@media (width>=900px){.detail-header{flex-direction:row}}.detail-image{flex-shrink:0}@media (width>=900px){.detail-image{width:300px}}.detail-image img{object-fit:cover;width:100%;height:220px}@media (width>=900px){.detail-image img{border-radius:var(--radius-xl) 0 0 0;height:100%;min-height:300px}}.detail-image-placeholder{background:linear-gradient(135deg, var(--color-terracotta-light) 0%, var(--color-cream) 100%);width:100%;height:220px;color:var(--color-terracotta);justify-content:center;align-items:center;display:flex}@media (width>=900px){.detail-image-placeholder{border-radius:var(--radius-xl) 0 0 0;height:100%;min-height:300px}}.detail-info{padding:var(--space-8);flex:1}@media (width<=480px){.detail-info{padding:var(--space-5);padding-top:var(--space-6)}}@media (width>=900px){.detail-info{padding:var(--space-10) var(--space-8) var(--space-6) var(--space-8)}}.detail-title{font-family:var(--font-display);font-size:var(--text-2xl);margin-bottom:var(--space-3);padding-right:var(--space-12)}@media (width>=900px){.detail-title{font-size:var(--text-3xl)}}.detail-description{font-size:var(--text-base);color:var(--color-taupe);margin-bottom:var(--space-4);line-height:1.7}.detail-meta{gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.meta-block{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:var(--color-olive-light);border-radius:var(--radius-full);color:var(--color-olive-dark);display:flex}.meta-block>div{flex-direction:column;display:flex}.meta-label{font-size:var(--text-xs);color:var(--color-olive);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.meta-value{font-size:var(--text-sm);color:var(--color-charcoal);font-weight:600}.detail-tags{gap:var(--space-2);margin-bottom:var(--space-5);flex-wrap:wrap;display:flex}.source-link{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-terracotta);transition:all var(--transition-fast);font-weight:600;display:inline-flex}.source-link:hover{color:var(--color-terracotta-dark)}.detail-actions-row{align-items:center;gap:var(--space-4);margin-top:var(--space-3);flex-wrap:wrap;display:flex}@media (width<=480px){.detail-actions-row{gap:var(--space-3)}.detail-actions-row .detail-icon-action{flex:0 0 44px;width:44px;padding:0}.detail-actions-row .detail-icon-action span{display:none}}.btn-share{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-sage);color:#fff;border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:500;display:inline-flex}.btn-share:hover{background:var(--color-sage-dark)}.btn-share:active{transform:scale(.98)}.share-copied-message{font-size:var(--text-sm);color:var(--color-olive);font-weight:500}.detail-body{gap:var(--space-6);padding:var(--space-5) var(--space-8) var(--space-8);background:var(--color-cream);display:grid}@media (width<=480px){.detail-body{padding:var(--space-2) var(--space-5) var(--space-5);gap:var(--space-5)}}@media (width>=900px){.detail-body{grid-template-columns:1fr 1fr}}.detail-section{background:var(--color-background);padding:var(--space-6);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}@media (width<=480px){.detail-section{padding:var(--space-5)}}.detail-section h3{font-family:var(--font-display);font-size:var(--text-lg);margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:2px solid var(--color-border);color:var(--color-charcoal);font-weight:500}.ingredients-list{list-style:none}.ingredients-list li{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) 0;font-size:var(--text-sm);border-bottom:1px solid var(--color-border);display:flex}.ingredients-list li:last-child{border-bottom:none}.ingredients-list input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-olive);cursor:pointer;flex-shrink:0;margin-top:1px}.ingredients-list label{cursor:pointer;transition:all var(--transition-fast);flex:1;line-height:1.6}.ingredients-list input:checked+label{color:var(--color-sand);text-decoration:line-through}.instructions-list{counter-reset:step;list-style:none}.instructions-list li{padding:var(--space-4) 0 var(--space-4) var(--space-10);font-size:var(--text-sm);counter-increment:step;line-height:1.7;position:relative}.instructions-list li:before{content:counter(step);left:0;top:var(--space-4);background:linear-gradient(135deg, var(--color-terracotta) 0%, var(--color-terracotta-dark) 100%);color:#fff;width:28px;height:28px;font-size:var(--text-xs);border-radius:var(--radius-full);justify-content:center;align-items:center;font-weight:700;display:flex;position:absolute}.detail-footer{justify-content:flex-end;gap:var(--space-3);padding:var(--space-5) var(--space-8);border-top:1px solid var(--color-border);display:flex}.detail-footer .btn-secondary{height:40px;padding:0 var(--space-5)}.detail-footer .btn-primary:disabled{transform:none}.footer{padding:var(--space-8);border-top:1px solid var(--color-border);background:var(--color-cream)}.footer-content{align-items:center;gap:var(--space-4);text-align:center;flex-direction:column;max-width:1200px;margin:0 auto;display:flex}.footer-brand{align-items:center;gap:var(--space-2);font-family:var(--font-display);font-size:var(--text-base);color:var(--color-terracotta);letter-spacing:.02em;transition:color var(--transition-fast);font-weight:500;text-decoration:none;display:flex}.footer-brand:hover{color:var(--color-terracotta-dark)}.footer-links{align-items:center;gap:var(--space-6);display:flex}.footer-links a{color:var(--color-taupe);font-size:var(--text-sm);transition:color var(--transition-fast);text-decoration:none}.footer-links a:hover{color:var(--color-terracotta)}.footer-copyright{font-size:var(--text-xs);color:var(--color-taupe)}@media (width<=900px){.footer{padding-bottom:calc(var(--mobile-nav-offset) + var(--space-6))}}.static-page{max-width:720px;padding:var(--space-8) var(--space-4);margin:0 auto}.static-page .back-link{align-items:center;gap:var(--space-2);color:var(--color-taupe);font-size:var(--text-sm);margin-bottom:var(--space-6);transition:color var(--transition-fast);text-decoration:none;display:inline-flex}.static-page .back-link:hover{color:var(--color-terracotta)}.static-page h1{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-charcoal);margin-bottom:var(--space-2);font-weight:600}.static-page .last-updated,.static-page .page-intro{color:var(--color-taupe);font-size:var(--text-sm);margin-bottom:var(--space-8)}.static-page section{margin-bottom:var(--space-8)}.static-page h2{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-charcoal);margin-bottom:var(--space-3);font-weight:600}.static-page p{color:var(--color-brown);margin-bottom:var(--space-4);line-height:1.7}.static-page ul{margin-left:var(--space-6);margin-bottom:var(--space-4)}.static-page li{color:var(--color-brown);margin-bottom:var(--space-2);line-height:1.7}.static-page a{color:var(--color-terracotta);text-decoration:underline}.static-page a.btn-primary{color:#fff;text-decoration:none}.feedback-page{max-width:600px}.feedback-form{margin-top:var(--space-8);gap:var(--space-6);flex-direction:column;display:flex}.feedback-form .form-group{gap:var(--space-3)}.feedback-form .form-group label{font-size:var(--text-base);font-weight:600}.feedback-type-options{gap:var(--space-3);margin-top:var(--space-1);flex-wrap:wrap;display:flex}.feedback-type-btn{padding:var(--space-3) var(--space-5);border:2px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-background);color:var(--color-taupe);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);font-weight:500}.feedback-type-btn:hover{border-color:var(--color-terracotta);color:var(--color-terracotta)}.feedback-type-btn.active{border-color:var(--color-terracotta);background:var(--color-terracotta);color:#fff}.feedback-form textarea{min-height:160px}.feedback-form .form-hint{font-size:var(--text-sm);color:var(--color-taupe);margin-top:var(--space-1)}.feedback-form .btn-submit{margin-top:var(--space-4);padding:var(--space-4) var(--space-8);align-self:flex-start;gap:var(--space-3)}.feedback-success{text-align:center;padding:var(--space-16) 0}.feedback-success svg{color:var(--color-terracotta);margin-bottom:var(--space-6)}.feedback-success h1{margin-bottom:var(--space-4)}.feedback-success p{max-width:400px;margin:0 auto var(--space-8);color:var(--color-taupe);line-height:1.6}.feedback-rate-limit{text-align:center;padding:var(--space-4) 0 var(--space-12)}.feedback-rate-limit p{color:var(--color-taupe);margin-bottom:var(--space-4);line-height:1.6}.feedback-rate-limit p:first-child{color:var(--color-charcoal);font-weight:600}.feedback-submit-row{align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.feedback-remaining{font-size:var(--text-sm);color:var(--color-taupe);margin:0}.footer-link{align-items:center;gap:var(--space-2);color:var(--color-terracotta);transition:all var(--transition-fast);text-decoration:none;display:flex}.footer-link:hover{color:var(--color-terracotta-dark)}.landing{padding:var(--space-10);background:radial-gradient(ellipse at 30% 20%, #c4553d14 0%, transparent 50%), radial-gradient(ellipse at 70% 80%, #6b7f5914 0%, transparent 50%), var(--color-background);flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.landing:before{content:"";background:radial-gradient(circle,#c4553d0d 0%,#0000 60%);border-radius:50%;width:600px;height:600px;animation:20s ease-in-out infinite floatBlob;position:absolute;top:-50%;right:-20%}.landing:after{content:"";background:radial-gradient(circle,#6b7f590d 0%,#0000 60%);border-radius:50%;width:400px;height:400px;animation:15s ease-in-out infinite reverse floatBlob;position:absolute;bottom:-30%;left:-10%}@keyframes floatBlob{0%,to{transform:translate(0)scale(1)}33%{transform:translate(30px,-30px)scale(1.05)}66%{transform:translate(-20px,20px)scale(.95)}}@media (width<=480px){.landing{padding:var(--space-6);padding-top:var(--space-16);align-items:flex-start}}.landing-content{text-align:center;z-index:1;width:100%;max-width:480px;animation:.8s ease-out landingAppear;position:relative}@keyframes landingAppear{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.landing-mascot{color:var(--color-terracotta);margin-bottom:var(--space-8);filter:drop-shadow(0 8px 24px #c4553d40);animation:3s ease-in-out infinite mascotBounce}@keyframes mascotBounce{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-8px)rotate(-2deg)}75%{transform:translateY(-4px)rotate(2deg)}}@media (width<=480px){.landing-mascot{margin-bottom:var(--space-6);width:100px!important;height:100px!important}}.landing-content h1{font-family:var(--font-display);font-size:var(--text-4xl);color:var(--color-charcoal);margin-bottom:var(--space-4);letter-spacing:-.02em;font-weight:600}@media (width<=480px){.landing-content h1{font-size:var(--text-3xl)}}.landing-content p{font-size:var(--text-lg);color:var(--color-taupe);margin-bottom:var(--space-10);line-height:1.7}@media (width<=480px){.landing-content p{font-size:var(--text-base);margin-bottom:var(--space-8)}}.landing-actions{gap:var(--space-4);flex-direction:column;display:flex}@media (width>=480px){.landing-actions{flex-direction:row;justify-content:center}}.loading-screen{color:var(--color-terracotta);flex:1;justify-content:center;align-items:center;display:flex}.modal-auth{max-width:min(420px,100%);padding:var(--space-10);flex:1;min-height:0;overflow-y:auto}@media (width<=640px){.modal-auth{padding:var(--space-8)}}@media (width<=480px){.modal-auth{max-width:100%;padding:var(--space-5);padding-top:var(--space-12);justify-content:flex-start}}.auth-header{text-align:center;margin-bottom:var(--space-8)}.auth-header.register{margin-bottom:var(--space-5)}.auth-top-switch{justify-content:center;align-items:center;gap:var(--space-1);margin-top:var(--space-2);color:var(--color-taupe);font-size:var(--text-sm);display:flex}.auth-mascot{color:var(--color-terracotta);margin-bottom:var(--space-5);filter:drop-shadow(0 4px 12px #c4553d33)}.auth-mascot-link{color:var(--color-terracotta);margin-bottom:var(--space-5);transition:transform var(--transition-bounce);text-decoration:none;display:inline-flex}.auth-mascot-link:hover{transform:rotate(-8deg)scale(1.05)}.auth-mascot-link .auth-mascot{margin-bottom:0}@media (width<=480px){.auth-mascot{width:64px!important;height:64px!important}}.auth-header h2{font-family:var(--font-display);font-size:var(--text-2xl);margin-bottom:var(--space-2)}@media (width<=480px){.auth-header h2{font-size:var(--text-xl)}}.auth-header p{font-size:var(--text-sm);color:var(--color-taupe)}.auth-form{gap:var(--space-5);flex-direction:column;display:flex}.auth-error{padding:var(--space-4);background:var(--color-danger-light);color:var(--color-danger);font-size:var(--text-sm);border-radius:var(--radius-md);text-align:center;font-weight:600}.auth-field{gap:var(--space-2);flex-direction:column;display:flex}.auth-field label{font-size:var(--text-sm);color:var(--color-charcoal);font-weight:600}.auth-input-wrapper{align-items:center;gap:var(--space-3);height:52px;padding:0 var(--space-5);background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast);color:var(--color-sand);display:flex}.auth-input-wrapper:focus-within{border-color:var(--color-terracotta);box-shadow:0 0 0 4px var(--color-terracotta-light)}.auth-input-wrapper input{height:100%;color:var(--color-charcoal);font-size:var(--text-base);background:0 0;border:none;outline:none;flex:1;min-width:0}.auth-input-wrapper input::placeholder{color:var(--color-sand)}.password-toggle{color:var(--color-taupe);padding:var(--space-2);margin:calc(-1 * var(--space-2));border-radius:var(--radius-sm);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.password-toggle:hover{color:var(--color-charcoal);background:var(--color-cream)}.password-requirements{font-size:var(--text-xs);color:var(--color-taupe);margin:0;margin-top:var(--space-1)}.auth-submit{justify-content:center;align-items:center;gap:var(--space-2);background:linear-gradient(135deg, var(--color-terracotta) 0%, var(--color-terracotta-dark) 100%);color:#fff;width:100%;height:52px;font-size:var(--text-base);border-radius:var(--radius-md);margin-top:var(--space-4);transition:all var(--transition-base);font-weight:600;display:flex;box-shadow:0 4px 12px #2d5a304d}.auth-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #2d5a3066}.auth-submit:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.auth-footer{text-align:center;margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--color-border)}.auth-footer p{font-size:var(--text-sm);color:var(--color-taupe)}.auth-toggle{color:var(--color-terracotta);margin-left:var(--space-1);transition:all var(--transition-fast);font-weight:600}.auth-toggle:hover{color:var(--color-terracotta-dark);text-decoration:underline}.dev-login-btn{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3);margin-top:var(--space-4);border-radius:var(--radius-md);color:#92400e;font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);background:#fef3c7;border:1px dashed #d97706;font-weight:500;display:flex}.dev-login-btn:hover{background:#fde68a}.forgot-password-link{font-size:var(--text-sm);color:var(--color-terracotta);text-align:right;margin-top:var(--space-2);transition:all var(--transition-fast)}.forgot-password-link:hover{color:var(--color-terracotta-dark);text-decoration:underline}.forgot-password-success{text-align:center;padding:var(--space-6) 0}.forgot-password-success .success-icon{color:var(--color-olive);margin-bottom:var(--space-5)}.forgot-password-success p{font-size:var(--text-base);color:var(--color-charcoal);margin-bottom:var(--space-4);line-height:1.6}.forgot-password-success p strong{color:var(--color-terracotta)}.forgot-password-note{font-size:var(--text-sm)!important;color:var(--color-taupe)!important}.reset-password-page{min-height:100vh;padding:var(--space-6);background:var(--color-background);justify-content:center;align-items:center;display:flex}.reset-password-container{background:var(--color-surface);width:100%;max-width:440px;padding:var(--space-10);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}@media (width<=480px){.reset-password-container{padding:var(--space-6);border-radius:var(--radius-lg)}}.reset-password-page .auth-header h1{font-family:var(--font-display);font-size:var(--text-2xl);margin-bottom:var(--space-2)}.reset-password-success,.reset-password-error{text-align:center;padding:var(--space-6) 0}.reset-password-success .success-icon{color:var(--color-olive);margin-bottom:var(--space-5)}.reset-password-error .error-icon{color:var(--color-danger);margin-bottom:var(--space-5)}.reset-password-success p,.reset-password-error p{font-size:var(--text-base);color:var(--color-charcoal);margin-bottom:var(--space-6);line-height:1.6}.verify-email-page{min-height:100vh;padding:var(--space-6);background:var(--color-background);justify-content:center;align-items:center;display:flex}.verify-email-card{background:var(--color-surface);width:100%;max-width:440px;padding:var(--space-10);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);text-align:center}.verify-email-mascot{margin-bottom:var(--space-4)}.verify-email-home{color:var(--color-terracotta);margin-bottom:var(--space-4);transition:transform var(--transition-bounce);text-decoration:none;display:inline-flex}.verify-email-home:hover{transform:rotate(-8deg)scale(1.05)}.verify-email-home .verify-email-mascot{margin-bottom:0}.verify-email-icon{margin-bottom:var(--space-4);color:var(--color-taupe)}.verify-email-icon.success{color:var(--color-olive)}.verify-email-icon.error{color:var(--color-danger)}.verify-email-card h1{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--color-charcoal);margin-bottom:var(--space-3)}.verify-email-card p{color:var(--color-taupe);line-height:1.6}.verify-email-resend{margin-top:var(--space-6)}.verify-email-resend p{margin-bottom:var(--space-3)}.resend-form{gap:var(--space-2);display:flex}.resend-form input{padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);flex:1}.resend-form button{padding:var(--space-3) var(--space-4);white-space:nowrap}.back-to-login{margin-top:var(--space-6);color:var(--color-terracotta);font-size:var(--text-sm);text-decoration:none;display:inline-block}.back-to-login:hover{text-decoration:underline}.resend-success{color:var(--color-olive);font-size:var(--text-sm);margin-top:var(--space-3)}.modal-verification{text-align:center;padding:var(--space-8) var(--space-6)}.verification-content{align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.verification-icon-wrapper{background:var(--color-terracotta-light);width:64px;height:64px;color:var(--color-terracotta);margin-bottom:var(--space-2);border-radius:50%;justify-content:center;align-items:center;display:flex}.modal-verification h2{font-size:var(--text-2xl);color:var(--color-charcoal);margin:0}.verification-email{color:var(--color-charcoal);font-weight:600;font-size:var(--text-base)}.verification-message{color:var(--color-taupe);font-size:var(--text-sm);max-width:280px;margin-top:var(--space-2)}.verification-note{font-size:var(--text-sm);color:var(--color-taupe);margin-top:var(--space-1)}.verification-actions{margin-top:var(--space-6)}.btn-resend{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-charcoal);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;font-weight:500;display:inline-flex}.btn-resend:hover:not(:disabled){background:var(--color-cream);border-color:var(--color-terracotta)}.btn-resend:disabled{opacity:.7;cursor:not-allowed}.cookbook-card{gap:var(--space-3);cursor:pointer;flex-direction:column;display:flex;position:relative}.cookbook-card:hover .cookbook-book{transform:rotateY(-15deg)rotateX(5deg)scale(1.02);box-shadow:12px 12px 30px #0003,inset -3px 0 10px #0000001a}.cookbook-card:hover .cookbook-spine{box-shadow:inset -2px 0 8px #0000004d}.cookbook-book{aspect-ratio:3/4;width:100%;transform-style:preserve-3d;transition:all .4s;position:relative;transform:perspective(1000px)rotateY(-5deg)}.cookbook-spine{background:linear-gradient(90deg, var(--color-terracotta-dark,#9a4a38) 0%, var(--color-terracotta) 40%, var(--color-terracotta-dark,#9a4a38) 100%);transform-origin:100%;border-radius:3px 0 0 3px;justify-content:center;align-items:center;width:20px;display:flex;position:absolute;top:0;bottom:0;left:0;overflow:hidden;transform:translateZ(-2px)rotateY(90deg);box-shadow:inset -1px 0 5px #0003}.cookbook-spine-title{writing-mode:vertical-rl;text-orientation:mixed;color:#ffffffe6;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;text-overflow:ellipsis;max-height:90%;padding:var(--space-1);font-size:10px;font-weight:700;overflow:hidden;transform:rotate(180deg)}.cookbook-cover{background:linear-gradient(145deg, var(--color-terracotta) 0%, var(--color-terracotta-dark,#9a4a38) 100%);border-radius:0 var(--radius-md) var(--radius-md) 0;position:absolute;inset:0 0 0 6px;overflow:hidden;box-shadow:4px 4px 15px #00000026,inset 0 0 30px #ffffff1a}.cookbook-cover:before{content:"";background:linear-gradient(90deg,#00000026 0%,#0000 100%);width:10px;position:absolute;top:0;bottom:0;left:0}.cookbook-cover-image{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.cookbook-cover-placeholder{color:#ffffff80;background:linear-gradient(145deg,#ffffff1a 0%,#0000 50%);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.cookbook-cover-overlay{padding:var(--space-4);background:linear-gradient(#0000 0%,#0000004d 50%,#000000b3 100%);flex-direction:column;justify-content:flex-end;display:flex;position:absolute;inset:0}.cookbook-cover-title{color:#fff;font-size:var(--text-base);text-shadow:0 1px 3px #0006;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-weight:700;line-height:1.2;display:-webkit-box;overflow:hidden}.cookbook-cover-subtitle{color:#fffc;font-size:var(--text-xs);margin-top:var(--space-1);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.cookbook-pages{background:repeating-linear-gradient(90deg,#f8f4ef 0 1px,#e8e4df 1px 2px);border-radius:0 2px 2px 0;width:8px;position:absolute;top:4px;bottom:4px;right:2px;transform:translateZ(-5px)}.cookbook-info{padding:0 var(--space-2);justify-content:space-between;align-items:center;display:flex}.cookbook-recipe-count{font-size:var(--text-sm);color:var(--color-taupe);font-weight:500}.cookbook-owner{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-olive);font-weight:500;display:flex}.cookbook-cover-preview{padding:var(--space-4) 0;background:var(--color-cream);border-radius:var(--radius-md);margin-bottom:var(--space-4);justify-content:center;display:flex}.cookbook-book-preview{width:100px;height:130px;transform-style:preserve-3d;position:relative;transform:perspective(500px)rotateY(-10deg)}.cookbook-spine-preview{background:linear-gradient(90deg, var(--color-terracotta-dark,#9a4a38) 0%, var(--color-terracotta) 40%, var(--color-terracotta-dark,#9a4a38) 100%);transform-origin:100%;border-radius:2px 0 0 2px;justify-content:center;align-items:center;width:14px;display:flex;position:absolute;top:0;bottom:0;left:0;overflow:hidden;transform:translateZ(-2px)rotateY(90deg)}.cookbook-spine-preview span{writing-mode:vertical-rl;text-orientation:mixed;color:#ffffffe6;text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;max-height:90%;font-size:8px;font-weight:700;overflow:hidden;transform:rotate(180deg)}.cookbook-cover-preview-inner{background:linear-gradient(145deg, var(--color-terracotta) 0%, var(--color-terracotta-dark,#9a4a38) 100%);border-radius:0 var(--radius-sm) var(--radius-sm) 0;justify-content:center;align-items:center;display:flex;position:absolute;inset:0 0 0 4px;overflow:hidden}.cookbook-cover-preview-inner img{object-fit:cover;width:100%;height:100%}.cookbook-cover-preview-placeholder{color:#ffffff80}.form-group label svg{vertical-align:middle;margin-right:var(--space-1);display:inline}.form-hint{font-size:var(--text-xs);color:var(--color-taupe);margin-top:var(--space-1)}.cookbook-list{gap:var(--space-6);flex-direction:column;display:flex}.cookbook-tabs-container{justify-content:flex-start;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);display:flex}.cookbook-tabs{gap:var(--space-1);background:var(--color-cream);border-radius:var(--radius-full);border:1px solid var(--color-border);padding:4px;display:flex}.cookbook-tab{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);font-size:var(--text-sm);color:var(--color-taupe);border-radius:var(--radius-full);transition:all var(--transition-fast);font-weight:500;display:flex}.cookbook-tab:hover:not(.active){color:var(--color-charcoal)}.cookbook-tab.active{background:var(--color-terracotta);color:#fff;box-shadow:var(--shadow-sm);font-weight:600}.tab-count{min-width:22px;height:22px;padding:0 var(--space-2);background:var(--color-terracotta-light);color:var(--color-terracotta);font-size:var(--text-xs);border-radius:var(--radius-full);justify-content:center;align-items:center;font-weight:700;display:inline-flex}.cookbook-grid{gap:var(--space-5);grid-template-columns:repeat(1,1fr);display:grid}@media (width>=560px){.cookbook-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=900px){.cookbook-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=1200px){.cookbook-grid{grid-template-columns:repeat(4,1fr)}}.cookbook-grid .cookbook-card{animation:.5s ease-out backwards cardAppear}.cookbook-grid .cookbook-card:first-child{animation-delay:0s}.cookbook-grid .cookbook-card:nth-child(2){animation-delay:50ms}.cookbook-grid .cookbook-card:nth-child(3){animation-delay:.1s}.cookbook-grid .cookbook-card:nth-child(4){animation-delay:.15s}.cookbook-grid .cookbook-card:nth-child(n+5){animation-delay:.2s}.cookbook-card-link{color:inherit;text-decoration:none;display:block}.cookbook-card-link:hover .cookbook-book,.cookbook-card-link:focus .cookbook-book{transform:rotateY(-8deg)translateZ(6px)}.cookbook-detail-page{padding-bottom:var(--space-8)}.cookbook-detail-page .back-link{align-items:center;gap:var(--space-2);color:var(--color-taupe);font-size:var(--text-sm);margin-bottom:var(--space-4);transition:color var(--transition);font-weight:500;text-decoration:none;display:inline-flex}.cookbook-detail-page .back-link:hover{color:var(--color-terracotta)}.cookbook-detail-page .cookbook-detail-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);padding-bottom:var(--space-5);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-5);display:flex}.cookbook-detail-page .cookbook-detail-info{flex:1;min-width:0}.cookbook-detail-page .cookbook-detail-info h1{font-family:var(--font-display);font-size:var(--text-2xl);margin-bottom:var(--space-2);line-height:1.2}.cookbook-detail-page .cookbook-detail-description{color:var(--color-taupe);margin-bottom:var(--space-3);line-height:1.5}.cookbook-detail-page .cookbook-detail-owner{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-olive);font-weight:500;display:inline-flex}.cookbook-detail-page .cookbook-detail-actions{gap:var(--space-2);flex-shrink:0;display:flex}@media (width<=640px){.cookbook-detail-page .cookbook-detail-header{gap:var(--space-3);flex-direction:column}.cookbook-detail-page .cookbook-detail-actions{width:100%}.cookbook-detail-page .cookbook-detail-actions button{flex:1}}.cookbook-detail-overlay{padding-top:var(--space-10);align-items:flex-start}@media (width<=480px){.cookbook-detail-overlay{padding-top:0}}.cookbook-detail{background:var(--color-background);border-radius:var(--radius-xl);width:100%;max-width:min(960px,100%);box-shadow:var(--shadow-xl);max-height:calc(100vh - var(--space-20));max-height:calc(100dvh - var(--space-20));flex-direction:column;display:flex;position:relative;overflow-y:auto}@media (width<=640px){.cookbook-detail{max-height:calc(100vh - var(--space-12));max-height:calc(100dvh - var(--space-12));border-radius:var(--radius-lg)}}@media (width<=480px){.cookbook-detail{max-width:100%;max-height:100dvh;box-shadow:none;border-radius:0}}.cookbook-detail-header{justify-content:space-between;align-items:flex-start;gap:var(--space-5);padding:var(--space-6);padding-top:var(--space-8);border-bottom:1px solid var(--color-border);display:flex}@media (width<=640px){.cookbook-detail-header{padding:var(--space-5);padding-top:var(--space-10);gap:var(--space-4);flex-direction:column}}@media (width<=480px){.cookbook-detail-header{padding:var(--space-4);padding-top:var(--space-10)}}.cookbook-detail-info h2{font-family:var(--font-display);font-size:var(--text-2xl);margin-bottom:var(--space-3);padding-right:0}.cookbook-detail-description{color:var(--color-taupe);margin-bottom:var(--space-4)}.cookbook-detail-owner{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-olive);font-weight:500;display:flex}.cookbook-detail-actions{gap:var(--space-3);flex-shrink:0;display:flex}.cookbook-detail-content{padding:var(--space-8);background:var(--color-cream);flex:1;min-height:220px;overflow-y:auto}@media (width<=640px){.cookbook-detail-content{padding:var(--space-5)}}.cookbook-search-filter{margin-bottom:var(--space-4)}.cookbook-search-bar{align-items:center;gap:var(--space-3);height:44px;padding:0 var(--space-4);background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-base);display:flex}.cookbook-search-bar:focus-within{border-color:var(--color-terracotta);box-shadow:0 0 0 3px var(--color-terracotta-light)}.cookbook-search-bar input{height:100%;box-shadow:none;font-size:var(--text-sm);background:0 0;border:none;outline:none;flex:1}.cookbook-search-bar input:focus{box-shadow:none;border:none;outline:none}.cookbook-filter-tags{gap:var(--space-2);margin-top:var(--space-3);flex-wrap:wrap;display:flex}.cookbook-detail-page .results-count{margin-bottom:var(--space-4)}.cookbook-detail-page .recipe-grid{gap:var(--space-5)}.cookbook-detail-page .empty-state{padding:var(--space-12) var(--space-4)}@media (width<=640px){.cookbook-detail-page .recipe-grid{gap:var(--space-4)}.cookbook-detail-page .empty-state{padding:var(--space-8) var(--space-4)}}.cookbook-recipe-view{flex-direction:column;display:flex}.cookbook-recipe-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);background:var(--color-background);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}@media (width<=480px){.cookbook-recipe-header{padding:var(--space-3) var(--space-4)}}.btn-back{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);color:var(--color-terracotta);font-size:var(--text-sm);border-radius:var(--radius-full);transition:all var(--transition-fast);font-weight:600;display:flex}.btn-back:hover{background:var(--color-terracotta-light)}.btn-back span{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}@media (width<=480px){.btn-back span{max-width:150px}}.cookbook-recipe-content{flex:1;overflow-y:auto}.cookbook-recipe-view .detail-header,.cookbook-recipe-view .detail-image img,.cookbook-recipe-view .detail-image-placeholder{border-radius:0}@media (width>=640px){.cookbook-recipe-view .detail-image img,.cookbook-recipe-view .detail-image-placeholder{border-radius:0}}.cookbook-recipe-view .modal-close{box-shadow:none;border:1px solid var(--color-border);flex-shrink:0;position:static}.cookbook-recipe-card{position:relative}.remove-from-cookbook{bottom:var(--space-4);right:var(--space-4);background:var(--color-background);width:32px;height:32px;color:var(--color-taupe);border-radius:var(--radius-md);opacity:0;z-index:10;box-shadow:var(--shadow-md);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:absolute}.cookbook-recipe-card:hover .remove-from-cookbook{opacity:1}.remove-from-cookbook:hover{background:var(--color-danger-light);color:var(--color-danger)}.recipe-added-by{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted);background:var(--color-cream);border-radius:0 0 var(--radius-md) var(--radius-md);margin-top:-4px;display:flex}.confirm-modal-overlay{z-index:10000;animation:modalOverlayIn var(--transition-fast) ease-out;background:#2d292680;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-modal{background:var(--color-background);border-radius:var(--radius-lg);padding:var(--space-6);max-width:400px;width:calc(100% - var(--space-8));box-shadow:var(--shadow-xl);animation:modalContentIn var(--transition-base) ease-out}.confirm-modal h3{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-text);margin-bottom:var(--space-2)}.confirm-modal p{color:var(--color-text-muted);margin-bottom:var(--space-6);line-height:1.5}.confirm-modal p strong{color:var(--color-text)}.confirm-modal-actions{gap:var(--space-3);justify-content:flex-end;display:flex}.confirm-modal-actions .btn-danger{align-items:center;gap:var(--space-2);display:flex}.confirm-modal-icon{width:48px;height:48px;margin-bottom:var(--space-4);border-radius:50%;justify-content:center;align-items:center;display:flex}.confirm-modal-icon.danger{background:var(--color-error-light,#fef2f2);color:var(--color-error)}.confirm-modal-icon.warning{color:#d97706;background:#fef3c7}.confirm-modal-icon.info{background:var(--color-primary-light);color:var(--color-primary)}.loading-state{padding:var(--space-16);color:var(--color-terracotta);justify-content:center;align-items:center;display:flex}.notification-dropdown{position:relative}.notification-btn{color:var(--color-text);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:relative}.notification-btn:hover{background:var(--color-primary-light);color:var(--color-primary)}.notification-badge{background:var(--color-error);color:#fff;text-align:center;border-radius:10px;min-width:16px;padding:2px 5px;font-size:10px;font-weight:600;position:absolute;top:-2px;right:-2px}.notification-panel{margin-top:var(--space-2);background:var(--color-background);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:100;width:360px;max-height:480px;animation:slideDown var(--transition-fast) ease-out;position:absolute;top:100%;right:0;overflow:hidden}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.notification-header{padding:var(--space-4);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.notification-header h3{font-family:var(--font-display);font-size:var(--text-lg);margin:0;font-weight:600}.notification-header-actions{align-items:center;gap:var(--space-2);display:flex}.mark-all-read,.clear-all-notifications{font-size:var(--text-xs);cursor:pointer;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;display:flex}.mark-all-read{color:var(--color-olive)}.mark-all-read:hover{background:var(--color-olive-light)}.clear-all-notifications{color:var(--color-text-muted)}.clear-all-notifications:hover{background:var(--color-danger-light);color:var(--color-danger)}.notification-list{max-height:400px;overflow-y:auto}.notification-empty{padding:var(--space-8);color:var(--color-text-muted);justify-content:center;align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.notification-item{gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--transition-fast);display:flex;position:relative}.notification-item:hover{background:var(--color-cream-dark)}.notification-item.unread{background:var(--color-primary-light)}.notification-item.unread:hover{background:#c3684926}.notification-icon{background:var(--color-cream-dark);width:36px;height:36px;color:var(--color-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.notification-content{flex:1;min-width:0}.notification-message{font-size:var(--text-sm);color:var(--color-text);margin:0 0 var(--space-1);line-height:1.4}.notification-time{font-size:var(--text-xs);color:var(--color-text-muted)}.notification-actions{gap:var(--space-2);margin-top:var(--space-2);display:flex}.notification-actions .btn-accept,.notification-actions .btn-decline{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-xs);cursor:pointer;border:none;font-weight:500;display:flex}.notification-actions .btn-accept{background:var(--color-olive);color:#fff}.notification-actions .btn-accept:hover{background:var(--color-olive-dark)}.notification-actions .btn-accept:disabled,.notification-actions .btn-decline:disabled{cursor:not-allowed;opacity:.7}.notification-actions .btn-decline{background:var(--color-cream-dark);color:var(--color-text-muted)}.notification-actions .btn-decline:hover{background:var(--color-border);color:var(--color-text)}.notification-dot{background:var(--color-primary);width:8px;height:8px;top:var(--space-4);right:var(--space-4);border-radius:50%;position:absolute}@media (width<=480px){.notification-panel{width:calc(100vw - var(--space-4));right:calc(-1 * var(--space-2))}}.user-menu{position:relative}.user-menu-trigger{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4) var(--space-2) var(--space-2);background:var(--color-cream);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);border:none;display:flex;position:relative}.user-menu-trigger:hover{background:var(--color-cream-dark)}.user-menu-trigger .user-avatar{background:linear-gradient(135deg, var(--color-terracotta) 0%, var(--color-terracotta-dark) 100%);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.user-menu-trigger .user-name{font-size:var(--text-sm);color:var(--color-charcoal);font-weight:600}.user-notification-dot{background:var(--color-terracotta);border:2px solid var(--color-cream);border-radius:50%;width:10px;height:10px;position:absolute;top:4px;left:28px}.user-menu-trigger:hover .user-notification-dot{border-color:var(--color-cream-dark)}.user-menu-panel{margin-top:var(--space-2);background:var(--color-background);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:100;width:320px;max-height:480px;animation:slideDown var(--transition-fast) ease-out;position:absolute;top:100%;right:0;overflow:hidden}.user-menu-header{align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-cream);display:flex}.user-menu-avatar{background:linear-gradient(135deg, var(--color-terracotta) 0%, var(--color-terracotta-dark) 100%);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.user-menu-info{flex-direction:column;gap:2px;display:flex}.user-menu-name{color:var(--color-charcoal);font-weight:600}.user-menu-email{font-size:var(--text-xs);color:var(--color-taupe)}.user-menu-divider{background:var(--color-border);height:1px}.user-menu-notifications{padding:var(--space-3)}.user-menu-notifications-header{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.user-menu-notifications-header h4{font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-charcoal);margin:0;font-weight:600}.user-menu-notifications-list{max-height:240px;overflow-y:auto}.user-menu-notifications-list .notification-item{border-radius:var(--radius-md);margin-bottom:var(--space-1);border-bottom:none}.user-menu-notifications-list .notification-icon{width:28px;height:28px}.user-menu-notifications-list .notification-empty{padding:var(--space-4)}.user-menu-item{align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);color:var(--color-text);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;text-decoration:none;display:flex}.user-menu-item:hover{background:var(--color-cream);color:var(--color-terracotta)}.user-menu-logout{align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;display:flex}.user-menu-logout:hover{background:var(--color-cream);color:var(--color-danger)}@media (width<=640px){.user-menu-trigger .user-name{display:none}.user-menu-trigger{padding:var(--space-2)}.user-menu-panel{width:calc(100vw - var(--space-4));right:calc(-1 * var(--space-2))}}.settings-page{max-width:600px;padding:var(--space-8) 0;margin:0 auto}.settings-page h1{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--color-charcoal);margin-bottom:var(--space-8);font-weight:500}.settings-section{background:var(--color-cream);border-radius:var(--radius-lg);padding:var(--space-6)}.settings-section+.settings-section{margin-top:var(--space-5)}.settings-section h2{font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-4);font-weight:600}.settings-field{padding:var(--space-4) 0;border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.settings-field:last-child{border-bottom:none;padding-bottom:0}.settings-field:first-of-type{padding-top:0}.settings-field label{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);font-weight:500;display:flex}.settings-value{font-size:var(--text-base);color:var(--color-charcoal)}.settings-plan-value{align-items:center;gap:var(--space-2);font-weight:600;display:inline-flex}.settings-plan-value span{color:var(--color-text-muted);font-size:var(--text-sm);font-weight:500}.settings-muted,.settings-subscription-note{color:var(--color-text-muted);font-size:var(--text-sm);margin:var(--space-4) 0 0;line-height:1.6}.settings-subscription-actions{margin-top:var(--space-4)}.settings-billing-button{justify-content:center;align-items:center;gap:var(--space-2);min-height:40px;padding:var(--space-2) var(--space-4);background:var(--color-background);color:var(--color-terracotta);border:1px solid var(--color-terracotta);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:700;display:inline-flex}.settings-billing-button:hover:not(:disabled){background:var(--color-terracotta-light)}.settings-manage-billing{margin-top:var(--space-3);width:fit-content;max-width:220px}.settings-error{margin-top:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--color-danger-light);color:var(--color-danger);font-size:var(--text-sm);font-weight:600}@media (width<=640px){.settings-page{padding:var(--space-6) 0}.settings-field{align-items:flex-start;gap:var(--space-2);flex-direction:column}.settings-manage-billing{max-width:100%}}.profile-avatar{background:linear-gradient(135deg, var(--color-terracotta) 0%, var(--color-olive-dark) 100%);color:#fff;border-radius:var(--radius-full);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;line-height:1;display:flex;overflow:hidden}.profile-avatar img{object-fit:cover;width:100%;height:100%}.profile-avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.profile-avatar-md{width:42px;height:42px;font-size:var(--text-sm)}.profile-avatar-lg{width:64px;height:64px;font-size:var(--text-xl)}.profile-avatar-xl{width:128px;height:128px;font-size:var(--text-3xl);box-shadow:var(--shadow-md)}.profile-page{padding:var(--space-8) 0 var(--space-4)}.profile-loading,.profile-empty{justify-content:center;align-items:center;gap:var(--space-4);text-align:center;flex-direction:column;min-height:360px;display:flex}.profile-empty h1{font-size:var(--text-2xl)}.profile-hero{align-items:center;gap:var(--space-8);margin-bottom:var(--space-8);padding:var(--space-8);background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex}.profile-hero-main{flex:1;min-width:0}.profile-title-row{justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-5);display:flex}.profile-identity{align-items:center;column-gap:var(--space-3);row-gap:var(--space-2);flex-wrap:wrap;flex:auto;min-width:0;display:flex}.profile-title-row h1{min-width:0;max-width:100%;font-size:var(--text-3xl);overflow-wrap:anywhere;flex:none}.profile-badges{align-items:center;gap:var(--space-2);flex-wrap:wrap;flex:none;display:flex}.profile-badge{align-items:center;gap:var(--space-1);isolation:isolate;width:fit-content;min-height:30px;padding:var(--space-1) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-background);color:var(--color-text-muted);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;transition:background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);font-weight:800;line-height:1;display:inline-flex;position:relative;overflow:hidden}.profile-badge svg{z-index:1;flex-shrink:0;position:relative}.profile-badge-early-adopter{color:#5f5012;box-shadow:none;background:#fff8db;border-color:#dec76b}.profile-badge-early-adopter svg{color:#8d7213;filter:none}.profile-badge-top-contributor{color:#493706;box-shadow:none;background:#f2d165;border-color:#c99827}.profile-badge-top-contributor svg{color:#735407;filter:none}.profile-badge-early-adopter:hover,.profile-badge-top-contributor:hover{box-shadow:none;transform:none}.profile-title-actions{justify-content:flex-end;gap:var(--space-3);flex-wrap:wrap;display:flex}.profile-action-btn{flex-shrink:0}.profile-action-btn.friend{color:var(--color-danger)}.profile-stats{gap:var(--space-3);flex-wrap:wrap;display:flex}.profile-stat{min-width:112px;padding:var(--space-3) var(--space-4);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:left}.profile-stat strong{font-size:var(--text-xl);color:var(--color-charcoal);line-height:1.1;display:block}.profile-stat span{margin-top:var(--space-1);font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700;display:block}.profile-stat-button{cursor:pointer;transition:border-color var(--transition-fast), transform var(--transition-fast)}.profile-stat-button:hover{border-color:var(--color-terracotta);transform:translateY(-1px)}.friends-modal-add{align-items:center;gap:var(--space-3);margin-top:var(--space-5);padding:var(--space-4);background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex}.profile-input-row{align-items:center;gap:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:0;padding:var(--space-3) var(--space-4);flex:1;display:flex}.profile-input-row:focus-within{border-color:var(--color-terracotta);box-shadow:0 0 0 3px var(--color-terracotta-light)}.profile-input-row svg{color:var(--color-text-muted);flex-shrink:0}.profile-input-row input,.profile-form-field input{width:100%;min-width:0;color:var(--color-text);background:0 0;border:none;outline:none}.profile-section-empty{align-items:center;gap:var(--space-3);margin-bottom:var(--space-8);padding:var(--space-5);color:var(--color-text-muted);background:var(--color-cream);border:1px dashed var(--color-border);border-radius:var(--radius-md);display:flex}.profile-section-empty h2{font-family:var(--font-body);font-size:var(--text-base);font-weight:600}.profile-edit-modal,.friends-modal{max-width:520px;padding:var(--space-6)}.profile-edit-modal form{gap:var(--space-5);flex-direction:column;display:flex}.profile-edit-header,.friends-modal-header{align-items:center;gap:var(--space-3);padding-right:var(--space-10);display:flex}.profile-edit-header h2,.friends-modal-header h2{font-size:var(--text-xl)}.profile-form-field{gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);flex-direction:column;font-weight:700;display:flex}.profile-form-field>input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);padding:var(--space-3) var(--space-4)}.profile-form-field>input:focus{border-color:var(--color-terracotta);box-shadow:0 0 0 3px var(--color-terracotta-light)}.profile-avatar-upload{gap:var(--space-3);padding:var(--space-4);background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;display:flex}.profile-avatar-upload-preview{align-items:center;gap:var(--space-3);color:var(--color-text-muted);display:flex}.profile-avatar-upload-preview .profile-avatar{flex-shrink:0}.profile-avatar-upload-preview p{margin:0 0 var(--space-1);color:var(--color-charcoal);font-size:var(--text-sm);font-weight:600}.profile-avatar-upload-actions{gap:var(--space-3);flex-wrap:wrap;display:flex}.profile-avatar-upload-button{cursor:pointer}.profile-edit-actions{justify-content:flex-end;gap:var(--space-3);display:flex}.friends-modal-loading,.friends-modal-empty{padding:var(--space-8);color:var(--color-text-muted);justify-content:center;display:flex}.profile-modal-feedback,.friends-modal-feedback{align-items:center;gap:var(--space-2);margin-top:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:700;display:flex}.profile-modal-feedback.success,.friends-modal-feedback.success{background:var(--color-olive-light);color:var(--color-olive-dark)}.profile-modal-feedback.error,.friends-modal-feedback.error{background:var(--color-danger-light);color:var(--color-danger)}.profile-modal-feedback svg,.friends-modal-feedback svg{flex-shrink:0}.friends-list{gap:var(--space-2);margin-top:var(--space-5);flex-direction:column;max-height:min(420px,65vh);display:flex;overflow-y:auto}.friend-list-item{justify-content:space-between;align-items:center;gap:var(--space-2);border-radius:var(--radius-md);transition:background var(--transition-fast);display:flex}.friend-list-item:hover{background:var(--color-cream)}.friend-list-link{align-items:center;gap:var(--space-3);min-width:0;padding:var(--space-3);flex:1;display:flex}.friend-list-link span{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-weight:600;overflow:hidden}.friend-remove-button{width:36px;height:36px;margin-right:var(--space-2);border-radius:var(--radius-md);color:var(--color-danger);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), opacity var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.friend-remove-button:hover:not(:disabled){background:var(--color-danger-light)}.friend-remove-button:disabled{cursor:not-allowed;opacity:.65}.profile-page .carousel-header,.profile-page .carousel-content{padding-left:0;padding-right:0}.profile-page .cookbook-card{width:220px}.profile-page>.carousel:last-of-type,.profile-page>.profile-section-empty:last-of-type{margin-bottom:0}@media (width<=700px){.profile-page{padding-top:var(--space-4)}.profile-hero{align-items:flex-start;gap:var(--space-5);padding:var(--space-5);flex-direction:column}.profile-avatar-xl{width:96px;height:96px;font-size:var(--text-2xl)}.profile-title-row{flex-direction:column;align-items:flex-start}.profile-title-row h1{font-size:var(--text-2xl)}.profile-title-actions{justify-content:flex-start;width:100%}.profile-stats{grid-template-columns:repeat(3,minmax(0,1fr));width:100%;display:grid}.profile-stat{min-width:0;padding:var(--space-3)}.friends-modal-add{flex-direction:column;align-items:stretch}}.share-modal{max-width:min(500px,100%);padding:var(--space-8);flex:1;min-height:0;overflow-y:auto}@media (width<=640px){.share-modal{padding:var(--space-6)}}@media (width<=480px){.share-modal{max-width:100%;padding:var(--space-5);padding-top:var(--space-8)}}.share-modal h2{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--space-6);padding-right:var(--space-12)}.share-tabs{gap:var(--space-1);background:var(--color-cream);border-radius:var(--radius-md);margin-bottom:var(--space-6);border:1px solid var(--color-border);padding:4px;display:flex}.share-tab{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3);font-size:var(--text-sm);color:var(--color-taupe);border-radius:var(--radius-sm);transition:all var(--transition-fast);flex:1;font-weight:500;display:flex}.share-tab:hover:not(.active){color:var(--color-charcoal)}.share-tab.active{background:var(--color-terracotta);color:#fff;box-shadow:var(--shadow-sm);font-weight:600}.share-content{gap:var(--space-5);flex-direction:column;display:flex}.share-input-group{gap:var(--space-3);display:flex}.share-input-group input{height:48px;padding:0 var(--space-4);background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);transition:all var(--transition-fast);flex:1}.share-input-group input:focus{border-color:var(--color-olive);box-shadow:0 0 0 4px var(--color-olive-light);outline:none}.share-input-group .btn-primary{flex-shrink:0}.share-friend-list{gap:var(--space-3);flex-direction:column;display:flex}.share-friend-item{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex}.share-friend-info{align-items:center;gap:var(--space-3);min-width:0;display:flex}.share-friend-info>div{flex-direction:column;min-width:0;display:flex}.share-friend-action{height:36px;padding:0 var(--space-4)}.share-empty-state{padding:var(--space-5);background:var(--color-cream);border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-taupe);font-size:var(--text-sm);text-align:center;font-weight:600}.share-list{gap:var(--space-3);margin-bottom:var(--space-6);flex-direction:column;display:flex}.share-list h4{font-size:var(--text-sm);color:var(--color-taupe);margin-bottom:var(--space-2);font-weight:600}.share-item{padding:var(--space-4);background:var(--color-cream);border-radius:var(--radius-md);justify-content:space-between;align-items:center;display:flex}.share-item-info{flex-direction:column;display:flex}.share-item-name{font-size:var(--text-sm);color:var(--color-charcoal);font-weight:600}.share-item-email{font-size:var(--text-xs);color:var(--color-taupe)}.share-item-remove{width:32px;height:32px;color:var(--color-taupe);border-radius:var(--radius-md);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.share-item-remove:hover{background:var(--color-danger-light);color:var(--color-danger)}.share-link-info{font-size:var(--text-sm);color:var(--color-taupe)}.create-link-btn{align-self:flex-start}.share-links-list{gap:var(--space-3);flex-direction:column;display:flex}.share-links-list h4{font-size:var(--text-sm);color:var(--color-taupe);margin-bottom:var(--space-2);font-weight:600}.share-link-item{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-cream);border-radius:var(--radius-md);display:flex}.share-link-item+.share-link-item{margin-top:var(--space-2)}.share-link-url{font-size:var(--text-sm);color:var(--color-taupe);text-overflow:ellipsis;white-space:nowrap;background:0 0;min-width:0;overflow:hidden}.share-link-expiry{color:var(--color-text-light);font-size:var(--text-xs);white-space:nowrap}.share-link-actions{align-items:center;gap:var(--space-1);flex-shrink:0;display:flex}.share-link-actions .btn-icon{cursor:pointer;background:0 0;border:none;width:32px;height:32px}.btn-danger-icon:hover{background:var(--color-danger-light);color:var(--color-danger)}.form-error{padding:var(--space-4);background:var(--color-danger-light);color:var(--color-danger);font-size:var(--text-sm);border-radius:var(--radius-md);font-weight:600}.form-success{padding:var(--space-4);background:var(--color-olive-light);color:var(--color-olive-dark);font-size:var(--text-sm);border-radius:var(--radius-md);font-weight:600}.add-to-cookbook-modal{max-width:min(420px,100%);padding:var(--space-8);flex:1;min-height:0;overflow-y:auto}@media (width<=640px){.add-to-cookbook-modal{padding:var(--space-6)}}@media (width<=480px){.add-to-cookbook-modal{max-width:100%;padding:var(--space-5);padding-top:var(--space-8)}}.add-to-cookbook-modal h2{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--space-2);padding-right:var(--space-12)}.modal-subtitle{font-size:var(--text-sm);color:var(--color-taupe);margin-bottom:var(--space-6)}.cookbook-checkbox-loading{padding:var(--space-8);color:var(--color-taupe);justify-content:center;align-items:center;display:flex}.cookbook-checkbox-list{gap:var(--space-3);margin-bottom:var(--space-5);flex-direction:column;display:flex}.cookbook-checkbox-item{align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-cream);border-radius:var(--radius-md);text-align:left;transition:all var(--transition-fast);border:2px solid #0000;display:flex}.cookbook-checkbox-item:hover:not(:disabled),.cookbook-checkbox-item.added{background:var(--color-olive-light);border-color:var(--color-olive)}.cookbook-checkbox-item.added .cookbook-checkbox-icon{background:var(--color-olive);color:#fff}.cookbook-checkbox-item.added .cookbook-checkbox-status{background:var(--color-olive);color:#fff;border-radius:50%}.cookbook-checkbox-item:disabled{cursor:default}.cookbook-checkbox-icon{background:var(--color-background);width:44px;height:44px;color:var(--color-olive);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;display:flex}.cookbook-checkbox-info{flex-direction:column;flex:1;display:flex}.cookbook-checkbox-name{font-size:var(--text-sm);color:var(--color-charcoal);font-weight:600}.cookbook-checkbox-count{font-size:var(--text-xs);color:var(--color-taupe)}.cookbook-checkbox-status{width:28px;height:28px;color:var(--color-olive);justify-content:center;align-items:center;display:flex}.no-cookbooks-message{padding:var(--space-6);text-align:center;color:var(--color-taupe);font-size:var(--text-sm)}.create-cookbook-btn{width:100%}.shared-view{flex-direction:column;min-height:100vh;display:flex}.shared-header{background:linear-gradient(135deg, var(--color-terracotta-light) 0%, var(--color-cream) 100%);padding:var(--space-8);border-bottom:1px solid var(--color-border)}.shared-header-content{align-items:center;gap:var(--space-5);max-width:1200px;margin:0 auto;display:flex}.shared-header-home{color:var(--color-terracotta);transition:transform var(--transition-bounce);flex-shrink:0;text-decoration:none;display:inline-flex}.shared-header-home:hover{transform:rotate(-8deg)scale(1.05)}.shared-header-info h1{font-family:var(--font-display);font-size:var(--text-2xl);margin-bottom:var(--space-2)}.shared-header-info p{font-size:var(--text-sm);color:var(--color-taupe);margin-bottom:var(--space-3)}.shared-owner{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-olive);font-weight:500;display:flex}.shared-main{padding:var(--space-10) 0 var(--space-16);flex:1}@media (width<=640px){.shared-main{padding:var(--space-6) 0 var(--space-10)}}.shared-error{text-align:center;padding:var(--space-10);flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.shared-error h1{font-family:var(--font-display);font-size:var(--text-2xl);margin:var(--space-5) 0 var(--space-3)}.shared-error p{color:var(--color-taupe);margin-bottom:var(--space-8)}.shared-recipe-preview .recipe-preview-content{border-radius:var(--radius-lg);max-width:800px;padding:var(--space-6);box-shadow:var(--shadow-lg);background:#fff;margin:0 auto}.shared-recipe-preview .preview-image{margin-bottom:var(--space-6);border-radius:var(--radius-lg);overflow:hidden}.shared-recipe-preview .preview-image img{object-fit:cover;width:100%;height:auto;max-height:400px}.shared-recipe-preview .preview-meta{flex-wrap:wrap}.shared-recipe-preview .preview-section h3{font-family:var(--font-display);font-size:var(--text-lg);margin-bottom:var(--space-4);color:var(--color-olive)}.shared-recipe-preview .preview-actions{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--color-border)}@media (width<=640px){.shared-recipe-preview .preview-sections{grid-template-columns:1fr}}.spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:focus-visible{outline:3px solid var(--color-terracotta);outline-offset:2px}::selection{background:var(--color-terracotta-light);color:var(--color-charcoal)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-cream)}::-webkit-scrollbar-thumb{background:var(--color-sand);border-radius:var(--radius-full);border:2px solid var(--color-cream)}::-webkit-scrollbar-thumb:hover{background:var(--color-taupe)}.card-delete{position:relative}.toast-container{bottom:var(--space-6);right:var(--space-6);z-index:1000;gap:var(--space-3);flex-direction:column;max-width:400px;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#fff;animation:.3s ease-out toast-slide-in;display:flex}.toast-success{border-left:4px solid var(--color-olive)}.toast-error{border-left:4px solid var(--color-terracotta)}.toast-info{border-left:4px solid var(--color-taupe)}.toast-message{font-size:var(--text-sm);color:var(--color-text);flex:1}.toast-action{color:var(--color-terracotta);font-size:var(--text-sm);cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:background var(--transition-fast);background:0 0;border:none;font-weight:600}.toast-action:hover{background:var(--color-terracotta-light)}.toast-dismiss{color:var(--color-text-muted);font-size:var(--text-lg);cursor:pointer;padding:var(--space-1);opacity:.6;transition:opacity var(--transition-fast);background:0 0;border:none;line-height:1}.toast-dismiss:hover{opacity:1}@keyframes toast-slide-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@media (width<=480px){.toast-container{left:var(--space-4);right:var(--space-4);bottom:var(--space-4);max-width:none}}.discovery-page{padding-bottom:var(--space-8)}.discovery-header{text-align:center;margin-bottom:var(--space-8)}.discovery-header h1{font-size:var(--text-3xl);justify-content:center;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2);display:flex}.discovery-header p{color:var(--color-text-muted);font-size:var(--text-lg)}.discovery-search{max-width:500px;margin:0 auto var(--space-6)}.search-input-wrapper{align-items:center;gap:var(--space-3);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast);display:flex}.search-input-wrapper:focus-within{border-color:var(--color-terracotta);box-shadow:0 0 0 3px var(--color-terracotta-light)}.search-input-wrapper input{font-size:var(--text-base);background:0 0;border:none;outline:none;flex:1}.search-input-wrapper svg{color:var(--color-text-muted);flex-shrink:0}.discovery-tags{align-items:center;gap:var(--space-2);margin-bottom:var(--space-6);flex-wrap:wrap;justify-content:center;display:flex}.tags-label{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:500}.tag-btn{font-size:var(--text-sm);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:var(--color-cream-dark);color:var(--color-text);transition:all var(--transition-fast)}.tag-btn:hover{background:var(--color-terracotta-light)}.tag-btn.active{background:var(--color-terracotta);color:#fff}.tag-clear{font-size:var(--text-sm);color:var(--color-text-muted);margin-left:var(--space-2);text-decoration:underline}.tag-clear:hover{color:var(--color-text)}.discovery-tabs{justify-content:center;gap:var(--space-4);margin-bottom:var(--space-8);border-bottom:2px solid var(--color-border);padding-bottom:var(--space-3);display:flex}.tab-btn{align-items:center;gap:var(--space-2);font-size:var(--text-base);color:var(--color-text-muted);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);transition:all var(--transition-fast);font-weight:500;display:flex}.tab-btn:hover{color:var(--color-text);background:var(--color-cream-dark)}.tab-btn.active{color:var(--color-terracotta);background:var(--color-terracotta-light)}.tab-btn .count{font-size:var(--text-sm);opacity:.7}.discovery-content{min-height:400px}@media (width>=768px){.discovery-grid{gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}.discovery-card{background:var(--color-surface);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);overflow:hidden}.discovery-card-placeholder{background:linear-gradient(135deg, var(--color-terracotta-light), var(--color-cream-dark));width:100%;height:100%;color:var(--color-terracotta);justify-content:center;align-items:center;display:flex}.cookbook-placeholder{background:linear-gradient(135deg, var(--color-olive-light), var(--color-cream-dark));color:var(--color-olive)}.discovery-save-btn{top:var(--space-2);right:var(--space-2);border-radius:var(--radius-full);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:32px;height:32px;color:var(--color-text);transition:all var(--transition-fast);opacity:0;background:#ffffffe6;justify-content:center;align-items:center;display:flex;position:absolute;transform:scale(.8)}.discovery-card:hover .discovery-save-btn{opacity:1;transform:scale(1)}.discovery-save-btn.saved{background:var(--color-terracotta);color:#fff;opacity:1;transform:scale(1)}.discovery-save-btn.saved span{font-size:var(--text-xs);font-weight:700;line-height:1}.discovery-save-btn.saved:disabled{cursor:default}.discovery-card-title{font-family:var(--font-display);font-size:var(--text-base);margin-bottom:var(--space-1);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-weight:500;line-height:1.3;display:-webkit-box;overflow:hidden}.discovery-card-author{width:fit-content;max-width:100%;font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-2);text-align:left;cursor:pointer;background:0 0;border:none;padding:0;display:inline-flex}.discovery-card-author:hover{color:var(--color-terracotta);text-decoration:underline}.discovery-card-count{font-size:var(--text-sm);color:var(--color-terracotta);font-weight:500}.tag-sm{font-size:var(--text-xs);background:var(--color-cream-dark);border-radius:var(--radius-sm);color:var(--color-text-muted);padding:2px 6px}.discovery-loading,.discovery-empty{padding:var(--space-16);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.discovery-empty h3{font-family:var(--font-display);font-size:var(--text-xl);margin:var(--space-4) 0 var(--space-2)}.discovery-empty p{color:var(--color-text-muted)}.discovery-load-more{margin-top:var(--space-8);justify-content:center;display:flex}.meal-planner-page{gap:var(--space-6);max-width:920px;padding-bottom:var(--space-8);flex-direction:column;margin:0 auto;display:flex}.meal-planner-header{text-align:center}.meal-planner-title{justify-content:center;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2);display:flex}.meal-planner-title svg{color:var(--color-mustard)}.meal-planner-title h1{font-size:var(--text-3xl)}.meal-planner-header p{max-width:680px;color:var(--color-text-muted);font-size:var(--text-lg);margin:0 auto}.meal-planner-toolbar{justify-content:center;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.meal-planner-status-item{align-items:center;gap:var(--space-2);min-height:40px;padding:var(--space-2) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:var(--text-sm);font-weight:600;display:inline-flex}.meal-planner-status-item svg{color:var(--color-terracotta);flex-shrink:0}.meal-planner-status-link{text-decoration:none}.meal-planner-status-link:hover,.meal-planner-status-link:focus-visible{background:var(--color-terracotta-light);border-color:var(--color-terracotta);color:var(--color-charcoal)}.meal-planner-form{gap:var(--space-3);padding:var(--space-5);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);flex-direction:column;display:flex}.meal-planner-form label{color:var(--color-charcoal);font-weight:700}.meal-planner-form textarea{resize:vertical;width:100%;min-height:180px;padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-background);color:var(--color-text);transition:all var(--transition-fast);outline:none;line-height:1.55}.meal-planner-form textarea:focus{border-color:var(--color-terracotta);box-shadow:0 0 0 3px var(--color-terracotta-light)}.meal-planner-form-footer{justify-content:space-between;align-items:center;gap:var(--space-4);color:var(--color-text-muted);font-size:var(--text-sm);display:flex}.meal-planner-submit{min-width:172px}.meal-planner-submit:disabled{pointer-events:none;cursor:not-allowed;opacity:.72;box-shadow:none;transform:none}.meal-planner-samples{gap:var(--space-3);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.meal-planner-sample{min-height:96px;padding:var(--space-4);background:var(--color-background);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);text-align:left;line-height:1.4;font-size:var(--text-sm);box-shadow:var(--shadow-sm);font-weight:600}.meal-planner-sample:hover{border-color:var(--color-mustard);background:var(--color-mustard-light);transform:translateY(-1px)}.meal-planner-message{padding:var(--space-4);border-radius:var(--radius-sm);font-weight:600}.meal-planner-error{background:var(--color-danger-light);color:var(--color-danger);border:1px solid #b91c1c33}.meal-planner-paywall{align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--color-mustard-light);border-radius:var(--radius-sm);border:1px solid #6a5a123d;grid-template-columns:auto 1fr auto;display:grid}.meal-planner-paywall>svg{color:var(--color-mustard)}.meal-planner-paywall h2,.meal-planner-result h2,.meal-planner-history h2{font-size:var(--text-xl);margin-bottom:var(--space-1)}.meal-planner-paywall p{color:var(--color-text-muted)}.meal-planner-paywall-action{min-width:112px}.meal-planner-result{padding:var(--space-5);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast)}.meal-planner-result.is-highlighted{background:var(--color-mustard-light);border-color:var(--color-mustard);box-shadow:0 0 0 4px #d4a65a38, var(--shadow-md);animation:3.2s ease-out mealPlannerResultHighlight}.meal-planner-result-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);display:flex}.meal-planner-result-header svg{color:var(--color-terracotta)}.meal-planner-result-text{white-space:pre-wrap;color:var(--color-text);line-height:1.7}.meal-planner-recipe-link{color:var(--color-terracotta);text-underline-offset:3px;vertical-align:baseline;padding:0;font-weight:700;text-decoration:underline;text-decoration-thickness:1px;display:inline}.meal-planner-recipe-link:hover{color:var(--color-terracotta-dark)}.meal-planner-cookbook-action{justify-content:space-between;align-items:center;gap:var(--space-4);margin-top:var(--space-5);padding-top:var(--space-5);border-top:1px solid var(--color-border);display:flex}.meal-planner-cookbook-action h3{font-size:var(--text-lg);margin-bottom:var(--space-1)}.meal-planner-cookbook-action p,.meal-planner-mentioned{color:var(--color-text-muted);font-size:var(--text-sm)}.meal-planner-mentioned{align-items:center;gap:var(--space-2);margin-top:var(--space-4);display:flex}.meal-planner-mentioned svg{color:var(--color-terracotta);flex-shrink:0}@keyframes mealPlannerResultHighlight{0%{background:var(--color-background);border-color:var(--color-border);box-shadow:var(--shadow-md)}12%,58%{background:var(--color-mustard-light);border-color:var(--color-mustard);box-shadow:0 0 0 4px #d4a65a38, var(--shadow-md)}to{background:var(--color-mustard-light);border-color:var(--color-mustard);box-shadow:0 0 0 4px #d4a65a38, var(--shadow-md)}}@media (prefers-reduced-motion:reduce){.meal-planner-result.is-highlighted{background:var(--color-mustard-light);border-color:var(--color-mustard);box-shadow:0 0 0 4px #d4a65a38, var(--shadow-md);animation:none}}.meal-planner-history{padding:var(--space-5);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.meal-planner-history-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);text-align:left;width:100%;display:flex}.meal-planner-history-heading{align-items:flex-start;gap:var(--space-3);display:flex}.meal-planner-history-heading>svg,.meal-planner-history-chevron{color:var(--color-terracotta);flex-shrink:0}.meal-planner-history-header p,.meal-planner-history-empty,.meal-planner-history-meta{color:var(--color-text-muted);font-size:var(--text-sm)}.meal-planner-history-chevron{margin-top:var(--space-1);transition:transform var(--transition-fast)}.meal-planner-history-chevron.open{transform:rotate(180deg)}.meal-planner-history-empty,.meal-planner-history-list{margin-top:var(--space-5)}.meal-planner-history-list{gap:var(--space-4);display:grid}.meal-planner-history-item{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);overflow:hidden}.meal-planner-history-item:hover,.meal-planner-history-item.is-expanded{border-color:var(--color-olive);box-shadow:var(--shadow-md)}.meal-planner-history-toggle{align-items:center;gap:var(--space-4);width:100%;padding:var(--space-4);color:var(--color-text);text-align:left;grid-template-columns:minmax(0,1fr) 24px;display:grid}.meal-planner-history-toggle:hover{background:var(--color-cream)}.meal-planner-history-summary{gap:var(--space-2);flex-direction:column;min-width:0;display:flex}.meal-planner-history-meta{gap:var(--space-3);flex-wrap:wrap;font-weight:600;display:flex}.meal-planner-history-prompt{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-charcoal);font-weight:700;line-height:1.4}.meal-planner-history-chevron{color:var(--color-text-muted);transition:transform var(--transition-fast)}.meal-planner-history-item.is-expanded .meal-planner-history-chevron{transform:rotate(180deg)}.meal-planner-history-detail{padding:var(--space-4);border-top:1px solid var(--color-border)}@media (width<=760px){.meal-planner-title h1{font-size:var(--text-2xl)}.meal-planner-header p{font-size:var(--text-base)}.meal-planner-toolbar{justify-content:center;gap:var(--space-2);flex-wrap:wrap;margin:0;padding:0}.meal-planner-status-item{min-width:0;min-height:32px;padding:var(--space-1) var(--space-3);font-size:var(--text-xs);text-align:center;white-space:normal;flex:180px;justify-content:center}.meal-planner-status-item span{overflow-wrap:anywhere}.meal-planner-samples{grid-template-columns:1fr}.meal-planner-sample{min-height:auto}.meal-planner-form-footer,.meal-planner-paywall{align-items:stretch}.meal-planner-form-footer{flex-direction:column}.meal-planner-submit,.meal-planner-paywall-action{width:100%}.meal-planner-paywall{grid-template-columns:1fr}.meal-planner-cookbook-action{flex-direction:column;align-items:stretch}.meal-planner-cookbook-action .btn-primary{width:100%}}@media (width<=640px){.discovery-header h1{font-size:var(--text-2xl)}.discovery-header p{font-size:var(--text-base)}.discovery-grid{gap:var(--space-3);grid-template-columns:repeat(2,1fr)}.discovery-card-body{padding:var(--space-2)}.discovery-card-title{font-size:var(--text-sm)}.discovery-card-author{font-size:var(--text-xs)}.discovery-save-btn{opacity:1;width:28px;height:28px;transform:scale(1)}}.detail-author{align-items:center;gap:var(--space-1);width:fit-content;font-size:var(--text-sm);color:var(--color-terracotta);margin-bottom:var(--space-2);background:0 0;border:none;padding:0;font-weight:500;display:flex}.detail-author:not(:disabled):hover{text-decoration:underline}.detail-author:disabled{cursor:default}.public-home{min-height:100vh}.public-header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border);z-index:100;background:#fffffff2;position:sticky;top:0}.public-header-content{max-width:1200px;padding:var(--space-3) var(--space-6);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.public-header-logo{align-items:center;gap:var(--space-2);font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-olive);transition:color var(--transition-fast);font-weight:600;text-decoration:none;display:flex}.public-header-logo:hover{color:var(--color-olive-dark)}.public-header-nav{align-items:center;gap:var(--space-3);display:flex}.public-header-nav .btn-text{color:var(--color-text-secondary);font-weight:500}.public-header-nav .btn-text:hover{color:var(--color-olive)}.public-header-nav .btn-primary{padding:var(--space-2) var(--space-4)}.hero-section{padding:var(--space-12) var(--space-6);text-align:center;background:linear-gradient(180deg, var(--color-cream) 0%, var(--color-background) 100%)}.hero-content{max-width:700px;margin:0 auto}.hero-mascot{margin-bottom:var(--space-4)}.hero-section h1{font-family:var(--font-display);font-size:var(--text-4xl);margin-bottom:var(--space-4);background:linear-gradient(135deg, var(--color-terracotta) 0%, var(--color-olive) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{font-size:var(--text-lg);color:var(--color-text-muted);margin-bottom:var(--space-8);line-height:1.6}.url-extract-form{max-width:600px;margin:0 auto}.url-input-wrapper{align-items:center;gap:var(--space-3);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-md);transition:all var(--transition-fast);background:#fff;display:flex}.url-input-wrapper:focus-within{border-color:var(--color-terracotta);box-shadow:var(--shadow-lg), 0 0 0 3px var(--color-terracotta-light)}.url-input-wrapper svg{color:var(--color-text-muted);flex-shrink:0}.url-input-wrapper input{font-size:var(--text-base);background:0 0;border:none;outline:none;flex:1;min-width:0}.extract-btn{align-items:center;gap:var(--space-2);background:var(--color-terracotta);color:#fff;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);white-space:nowrap;transition:all var(--transition-fast);font-weight:600;display:flex}.extract-btn svg{color:#fff}.extract-btn:hover:not(:disabled){background:var(--color-terracotta-dark)}.extract-btn:disabled{opacity:.6;cursor:not-allowed}.extract-error{color:var(--color-danger);margin-top:var(--space-4);font-size:var(--text-sm)}.extracted-preview{padding:var(--space-8) var(--space-6);background:var(--color-background)}.preview-card{max-width:700px;margin:0 auto var(--space-8);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-lg);background:#fff}.preview-header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);color:var(--color-terracotta);display:flex}.preview-header h2{font-family:var(--font-display);font-size:var(--text-2xl)}.preview-description{color:var(--color-text-muted);margin-bottom:var(--space-4)}.preview-meta{gap:var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border);display:flex}.preview-sections{gap:var(--space-6);margin-bottom:var(--space-6);grid-template-columns:1fr 1fr;display:grid}.preview-section h4{font-family:var(--font-display);font-size:var(--text-base);margin-bottom:var(--space-3);color:var(--color-olive)}.preview-section ul,.preview-section ol{font-size:var(--text-sm);color:var(--color-text-muted);padding-left:var(--space-4)}.preview-section li{margin-bottom:var(--space-2)}.preview-section .more{color:var(--color-terracotta);margin-left:calc(-1 * var(--space-4));font-style:italic;list-style:none}.preview-actions{gap:var(--space-3);flex-wrap:wrap;display:flex}.share-link-result{margin-top:var(--space-4);align-items:center;gap:var(--space-2);display:flex}.share-link-result input{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-sm);background:var(--color-cream);flex:1}.share-link-result span{color:var(--color-olive);font-size:var(--text-sm);font-weight:500}.signup-prompt{text-align:center;max-width:500px;padding:var(--space-8);background:linear-gradient(135deg, var(--color-terracotta-light) 0%, var(--color-olive-light) 100%);border-radius:var(--radius-lg);margin:0 auto}.signup-prompt h3{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--space-2)}.signup-prompt p{color:var(--color-text-muted);margin-bottom:var(--space-4)}.prompt-actions{gap:var(--space-2);flex-direction:column;align-items:center;display:flex}.btn-text{color:var(--color-text-muted);font-size:var(--text-sm);background:0 0}.btn-text:hover{color:var(--color-text);text-decoration:underline}.public-discover-section{padding:var(--space-8) var(--space-6) var(--space-10);background:var(--color-background)}.public-section-header{max-width:620px;margin:0 auto var(--space-5);text-align:center}.public-section-kicker{align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);color:var(--color-terracotta);font-size:var(--text-sm);font-weight:600;display:inline-flex}.public-section-header h2{font-size:var(--text-3xl);margin-bottom:var(--space-3)}.public-section-header p{color:var(--color-text-muted);font-size:var(--text-base);line-height:1.6}.public-discover-section .carousel{max-width:1100px;margin:0 auto}.public-discover-section .carousel-content{gap:var(--space-4);padding:var(--space-1) var(--space-2) var(--space-2)}.public-discover-card{border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;width:250px;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);background:#fff;overflow:hidden}.public-discover-card:hover,.public-discover-card:focus-visible{border-color:var(--color-terracotta);box-shadow:var(--shadow-md);outline:none;transform:translateY(-2px)}.public-discover-card-image{aspect-ratio:4/3;background:var(--color-cream);overflow:hidden}.public-discover-card-image img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-base)}.public-discover-card:hover .public-discover-card-image img,.public-discover-card:focus-visible .public-discover-card-image img{transform:scale(1.04)}.public-discover-card-placeholder{background:linear-gradient(135deg, var(--color-olive-light), var(--color-cream-dark));justify-content:center;align-items:center;width:100%;height:100%;display:flex}.public-discover-card-body{padding:var(--space-4)}.public-discover-card-body h3{font-size:var(--text-base);margin-bottom:var(--space-1);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.public-discover-card-body p{color:var(--color-text-muted);font-size:var(--text-sm);margin-bottom:var(--space-3)}.public-discover-card-tags{gap:var(--space-1);flex-wrap:wrap;display:flex}.features-section{padding:var(--space-10) var(--space-6);text-align:center;background:#fff}.features-section h2{font-family:var(--font-display);font-size:var(--text-3xl);margin-bottom:var(--space-6)}.features-grid{gap:var(--space-6);grid-template-columns:repeat(4,minmax(0,1fr));max-width:1000px;margin:0 auto;display:grid}@media (width<=900px){.features-grid{grid-template-columns:repeat(2,minmax(0,1fr));max-width:640px}}.feature-card{padding:var(--space-6);background:var(--color-cream);border-radius:var(--radius-lg);text-align:center;transition:all var(--transition-fast)}.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.feature-icon{width:60px;height:60px;margin:0 auto var(--space-4);background:var(--color-terracotta-light);color:var(--color-terracotta);border-radius:var(--radius-lg);justify-content:center;align-items:center;display:flex}.feature-card h3{font-family:var(--font-display);font-size:var(--text-lg);margin-bottom:var(--space-2)}.feature-card p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6}.cta-section{padding:var(--space-10) var(--space-6);text-align:center;background:linear-gradient(180deg, var(--color-background) 0%, var(--color-cream) 100%)}.cta-section h2{font-family:var(--font-display);font-size:var(--text-2xl);margin:var(--space-4) 0 var(--space-2)}.cta-section p{color:var(--color-text-muted);margin-bottom:var(--space-6);max-width:500px;margin-left:auto;margin-right:auto}.cta-actions{justify-content:center;gap:var(--space-4);flex-wrap:wrap;display:flex}@media (width<=640px){.hero-section{padding:var(--space-8) var(--space-4)}.hero-section h1{font-size:var(--text-2xl)}.hero-subtitle{font-size:var(--text-base)}.url-input-wrapper{padding:var(--space-3);flex-wrap:wrap}.url-input-wrapper input{order:2;width:100%}.extract-btn{order:3;justify-content:center;width:100%}.preview-sections{grid-template-columns:1fr}.preview-card{padding:var(--space-4)}.public-discover-section{padding:var(--space-6) var(--space-4) var(--space-8)}.public-section-header h2{font-size:var(--text-2xl)}.public-discover-section .carousel-content{padding-inline:var(--space-1)}.public-discover-card{width:min(78vw,280px)}.public-discover-card-body{padding:var(--space-3)}.public-discover-card-body h3{font-size:var(--text-sm)}.public-discover-card-body p{font-size:var(--text-xs)}.features-section{padding:var(--space-10) var(--space-4)}.features-section h2{font-size:var(--text-2xl)}.features-grid{grid-template-columns:1fr;max-width:360px}}.carousel{margin-bottom:var(--space-8)}.carousel-header{margin-bottom:var(--space-4);padding:0 var(--space-4);justify-content:space-between;align-items:center;display:flex}.carousel-header.controls-only{margin-bottom:var(--space-2);justify-content:flex-end}.carousel-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:500}.carousel-arrows{gap:var(--space-2);display:flex}.carousel-arrow{border-radius:var(--radius-full);background:var(--color-surface);border:1px solid var(--color-border);width:32px;height:32px;color:var(--color-text);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.carousel-arrow:hover:not(:disabled){background:var(--color-cream-dark)}.carousel-arrow:disabled{opacity:.3;cursor:not-allowed}.carousel-track{scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;overflow-x:auto}.carousel-track::-webkit-scrollbar{display:none}.carousel-content{gap:var(--space-3);padding:0 var(--space-4);display:flex}.carousel-content>*{scroll-snap-align:start;flex-shrink:0}@media (width<=768px){.carousel-arrows{display:none}}.recipe-card-compact{background:var(--color-surface);border-radius:var(--radius-md);cursor:pointer;touch-action:pan-y;width:140px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);overflow:hidden}.recipe-card-compact:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.compact-card-image{aspect-ratio:1;position:relative;overflow:hidden}.compact-card-image img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-base)}.recipe-card-compact:hover .compact-card-image img{transform:scale(1.05)}.compact-card-placeholder{background:linear-gradient(135deg, var(--color-terracotta-light), var(--color-cream-dark));width:100%;height:100%;color:var(--color-terracotta);justify-content:center;align-items:center;display:flex}.compact-card-actions{top:var(--space-1);right:var(--space-1);gap:var(--space-1);opacity:0;pointer-events:none;transition:opacity var(--transition-fast);display:flex;position:absolute}.recipe-card-compact:hover .compact-card-actions,.recipe-card-compact.swipe-actions-open .compact-card-actions{opacity:1;pointer-events:auto}.compact-action{border-radius:var(--radius-full);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:24px;height:24px;color:var(--color-text);transition:all var(--transition-fast);background:#ffffffe6;justify-content:center;align-items:center;display:flex}.compact-action:hover{background:var(--color-terracotta);color:#fff}.compact-delete:hover{background:var(--color-danger)}.compact-card-body{padding:var(--space-2)}.compact-card-title{font-family:var(--font-display);font-size:var(--text-sm);-webkit-line-clamp:2;line-clamp:2;margin-bottom:var(--space-1);-webkit-box-orient:vertical;font-weight:500;line-height:1.3;display:-webkit-box;overflow:hidden}.compact-card-meta{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-text-muted);display:flex}@media (width<=640px){.recipe-grid{gap:var(--space-3);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.recipe-card{border-radius:var(--radius-md);touch-action:pan-y}.card-image{aspect-ratio:4/3}.card-body{padding:var(--space-2) var(--space-3)}.card-title{font-size:var(--text-sm);margin-bottom:var(--space-1)}.card-description{display:none}.card-meta{margin-bottom:var(--space-1)}.meta-item{font-size:var(--text-xs)}.card-tags{display:none}.card-actions{top:var(--space-1);right:var(--space-1);opacity:0;pointer-events:none;transform:translate(8px)}.recipe-card:hover .card-actions{opacity:0;pointer-events:none;transform:translate(8px)}.recipe-card.swipe-actions-open .card-actions,.recipe-card.swipe-actions-open:hover .card-actions{opacity:1;pointer-events:auto;transform:translate(0)}.card-action{width:28px;height:28px}.mobile-nav{padding:var(--space-2) var(--space-3);padding-bottom:calc(var(--space-2) + env(safe-area-inset-bottom))}.mobile-nav-container{gap:var(--space-1)}.mobile-nav-item{padding:var(--space-2) var(--space-1);gap:var(--space-1);font-size:.6875rem}.mobile-nav-item svg{width:18px;height:18px}.header{height:56px}.header-content{padding:0 var(--space-3)}.logo-section{gap:var(--space-2)}.logo-icon{width:36px;height:36px}.logo-text h1{font-size:var(--text-lg)}.btn-primary{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.btn-text{display:none}.cookbook-grid{gap:var(--space-3);grid-template-columns:repeat(2,minmax(0,1fr))}.cookbook-card{border-radius:var(--radius-md)}.cookbook-card-image{aspect-ratio:4/3}.cookbook-card-body{padding:var(--space-2) var(--space-3)}.cookbook-card-title{font-size:var(--text-sm)}.cookbook-card-count{font-size:var(--text-xs)}.cookbook-card-owner{display:none}}.visibility-toggle{align-items:center;gap:var(--space-2);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-md);transition:all var(--transition-fast);background:0 0;border:none;display:inline-flex}.visibility-toggle:hover:not(.disabled){background:var(--color-cream-dark)}.visibility-toggle.disabled{opacity:.5;cursor:not-allowed}.visibility-toggle-track{background:var(--color-border);border-radius:var(--radius-full);width:44px;height:24px;transition:all var(--transition-fast);position:relative}.visibility-toggle.public .visibility-toggle-track{background:var(--color-terracotta)}.visibility-toggle-thumb{width:20px;height:20px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:2px;left:2px}.visibility-toggle.public .visibility-toggle-thumb{left:22px}.visibility-toggle-thumb svg{color:var(--color-taupe)}.visibility-toggle.public .visibility-toggle-thumb svg{color:var(--color-terracotta)}.visibility-toggle-label{font-size:var(--text-sm);color:var(--color-text);font-weight:500}.visibility-toggle.sm .visibility-toggle-track{width:36px;height:20px}.visibility-toggle.sm .visibility-toggle-thumb{width:16px;height:16px}.visibility-toggle.sm.public .visibility-toggle-thumb{left:18px}.visibility-toggle.sm .visibility-toggle-label{font-size:var(--text-xs)}.visibility-badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:500;display:inline-flex}.visibility-badge.private{background:var(--color-cream-dark);color:var(--color-taupe)}.visibility-badge.public{background:var(--color-terracotta-light);color:var(--color-terracotta)}.visibility-badge.md{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.infinite-scroll-sentinel{padding:var(--space-8);justify-content:center;display:flex}.infinite-scroll-sentinel.loading{opacity:1}.discovery-page{touch-action:pan-y;animation:.3s ease-out fadeIn}.discovery-header.discovery-hero{gap:var(--space-5);text-align:left;margin-bottom:var(--space-4);padding:var(--space-5);border:1px solid #2d5b302e;border-left:6px solid var(--color-mustard);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);background:linear-gradient(100deg,#fffffffa 0%,#faf6e8db 54%,#e8f2e9fa 100%);grid-template-columns:minmax(0,1fr) minmax(260px,420px);align-items:center;display:grid}.discovery-hero-copy{min-width:0}.discovery-eyebrow{align-items:center;gap:var(--space-2);margin-bottom:var(--space-1);color:var(--color-mustard);font-size:var(--text-sm);font-weight:700;display:inline-flex}.discovery-eyebrow svg{flex-shrink:0}.discovery-hero h1{justify-content:flex-start;gap:var(--space-2);margin:0 0 var(--space-2);font-size:var(--text-4xl);color:var(--color-charcoal)}.discovery-hero h1 svg{color:var(--color-terracotta)}.discovery-hero p{max-width:620px;color:var(--color-text-muted);font-size:var(--text-base);margin:0}.discovery-hero-stats{gap:var(--space-2);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.discovery-stat{align-items:center;gap:var(--space-2);min-height:58px;padding:var(--space-3);border-radius:var(--radius-sm);color:var(--color-text-muted);box-shadow:var(--shadow-sm);background:#ffffffc7;border:1px solid #2d5b3029;display:flex}.discovery-stat svg{color:var(--color-mustard)}.discovery-stat strong{color:var(--color-text);font-family:var(--font-display);font-size:var(--text-lg);line-height:1.1;display:block}.discovery-tools{--discovery-control-height:48px;gap:var(--space-3);margin-bottom:var(--space-4);padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);background:#fff;grid-template-columns:minmax(260px,.9fr) minmax(280px,1.1fr);grid-template-areas:"tabs search""tags tags";display:grid}.discovery-tools .discovery-search{grid-area:search;max-width:none;margin:0}.discovery-tools .search-input-wrapper{height:var(--discovery-control-height);border-radius:var(--radius-sm);background:var(--color-background);border-width:1px}.discovery-tools .discovery-tags{grid-area:tags;justify-content:flex-start;margin-bottom:0}.discovery-tools .tag-btn{border-radius:var(--radius-sm);background:var(--color-cream);border:1px solid #0000}.discovery-tools .tag-btn:hover{border-color:var(--color-terracotta)}.discovery-tools .tag-btn.active{border-color:var(--color-terracotta);background:var(--color-terracotta);color:#fff}.discovery-tools .discovery-tabs{justify-content:flex-start;gap:var(--space-2);height:var(--discovery-control-height);background:var(--color-cream);border:1px solid var(--color-border);border-radius:var(--radius-sm);grid-area:tabs;margin-bottom:0;padding:4px}.discovery-tools .tab-btn{height:100%;min-height:0;padding:0 var(--space-3);border-radius:var(--radius-sm);color:var(--color-text-muted);background:0 0;flex:180px;justify-content:center;line-height:1}.discovery-tools .tab-btn:hover{color:var(--color-text);background:#fff}.discovery-tools .tab-btn.active{background:var(--color-terracotta);color:#fff;box-shadow:var(--shadow-sm)}.discovery-section-heading{justify-content:space-between;align-items:flex-end;gap:var(--space-4);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid #2d5b3029;display:flex}.discovery-section-heading h2{color:var(--color-charcoal);font-size:var(--text-xl);margin:0}.discovery-section-heading p{max-width:420px;color:var(--color-text-muted);text-align:right;margin:0}.discovery-section-kicker{color:var(--color-mustard);font-size:var(--text-xs);margin-bottom:2px;font-weight:700;display:block}.discovery-grid{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}@media (width>=640px){.discovery-grid{gap:var(--space-5);grid-template-columns:repeat(3,1fr)}}@media (width>=900px){.discovery-grid{grid-template-columns:repeat(4,1fr)}}@media (width>=1200px){.discovery-grid{grid-template-columns:repeat(5,1fr)}}.discovery-card{border-radius:var(--radius-md);cursor:pointer;touch-action:pan-y;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);background:#fff;overflow:hidden}.discovery-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.discovery-card:focus-visible{outline:3px solid var(--color-primary);outline-offset:3px}.discovery-card-image{aspect-ratio:1;position:relative;overflow:hidden}.discovery-card-image img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-base)}.discovery-card:hover .discovery-card-image img{transform:scale(1.05)}.discovery-card-placeholder{background:var(--color-cream);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.discovery-save-btn{top:var(--space-2);right:var(--space-2);cursor:pointer;width:32px;height:32px;box-shadow:var(--shadow-md);transition:all var(--transition-fast);opacity:0;pointer-events:none;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute}.discovery-card:hover .discovery-save-btn,.discovery-card.swipe-actions-open .discovery-save-btn{opacity:1;pointer-events:auto}.discovery-save-btn:hover{background:var(--color-terracotta-light);color:var(--color-terracotta)}.discovery-save-btn:disabled{cursor:not-allowed}.discovery-save-btn.saved{opacity:1;pointer-events:auto;background:var(--color-terracotta);color:#fff;transform:scale(1)}.discovery-save-btn.saved:hover{background:var(--color-terracotta-dark);color:#fff}.discovery-owned-badge{top:var(--space-2);right:var(--space-2);min-width:48px;height:28px;padding:0 var(--space-2);border-radius:var(--radius-full);background:var(--color-olive);color:#fff;box-shadow:var(--shadow-md);font-size:var(--text-xs);pointer-events:none;justify-content:center;align-items:center;font-weight:700;line-height:1;display:inline-flex;position:absolute}.discovery-card-body{padding:var(--space-3)}.discovery-card-title{font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-text);margin-bottom:var(--space-1);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-weight:600;display:-webkit-box;overflow:hidden}.discovery-card-author{font-size:var(--text-xs);color:var(--color-taupe);margin-bottom:var(--space-2)}.discovery-card-tags{gap:var(--space-1);flex-wrap:wrap;display:flex}.tag-sm{background:var(--color-cream);border-radius:var(--radius-sm);color:var(--color-taupe);padding:2px 6px;font-size:10px}@media (width<=899px){.discovery-header.discovery-hero{gap:var(--space-3);padding:var(--space-4);grid-template-columns:1fr}.discovery-hero h1{font-size:var(--text-3xl)}.discovery-hero p{display:none}.discovery-hero-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.discovery-stat{min-height:48px;padding:var(--space-2) var(--space-3)}.discovery-stat strong{margin-right:4px;display:inline}.discovery-tools{--discovery-control-height:42px;gap:var(--space-2);padding:var(--space-2);grid-template-columns:1fr;grid-template-areas:"tabs""search""tags"}.discovery-tools .search-input-wrapper{min-height:0;padding:var(--space-2) var(--space-3)}.discovery-tools .discovery-tabs{grid-template-columns:repeat(2,minmax(0,1fr));padding:4px;display:grid}.discovery-tools .tab-btn{min-width:0;min-height:0;padding:0 var(--space-2);flex:none}.discovery-tools .discovery-tags{gap:var(--space-2);margin:0 calc(var(--space-2) * -1);padding:0 var(--space-2) 2px;scrollbar-width:none;flex-wrap:nowrap;overflow-x:auto}.discovery-tools .discovery-tags::-webkit-scrollbar{display:none}.discovery-tools .tags-label,.discovery-tools .tag-btn,.discovery-tools .tag-clear{white-space:nowrap;flex:none}.discovery-tools .tag-btn{padding:3px var(--space-2);font-size:var(--text-xs)}}@media (width<=640px){.discovery-header.discovery-hero{gap:var(--space-2);margin-bottom:var(--space-2);padding:var(--space-3);border-left-width:4px;grid-template-columns:1fr}.discovery-hero h1{font-size:var(--text-2xl);margin-bottom:0}.discovery-hero p{display:none}.discovery-eyebrow{font-size:var(--text-xs);margin-bottom:0}.discovery-hero-stats{gap:var(--space-2);grid-template-columns:repeat(2,minmax(0,1fr))}.discovery-stat{min-height:38px;padding:var(--space-2);font-size:var(--text-xs)}.discovery-stat svg{width:16px;height:16px}.discovery-stat strong{font-size:var(--text-base);margin-right:3px;display:inline}.discovery-tools{gap:var(--space-2);margin-bottom:var(--space-3);padding:var(--space-2);grid-template-columns:1fr;grid-template-areas:"tabs""search""tags"}.discovery-tools .search-input-wrapper{min-height:0;padding:var(--space-2) var(--space-3)}.discovery-tools .search-input-wrapper input{font-size:var(--text-sm)}.discovery-tools .discovery-tabs{grid-template-columns:repeat(2,minmax(0,1fr));padding:4px;display:grid}.discovery-tools .tab-btn{min-width:0;min-height:0;padding:0 var(--space-2);font-size:var(--text-sm);flex:none}.discovery-section-heading{margin-bottom:var(--space-2);padding-bottom:var(--space-1);flex-direction:row;align-items:center}.discovery-section-heading p{display:none}.discovery-section-heading h2{font-size:var(--text-lg)}.discovery-section-kicker{font-size:11px}.discovery-save-btn{opacity:1;width:28px;height:28px}.discovery-card-body{padding:var(--space-2)}.discovery-card-title{font-size:var(--text-xs)}.discovery-card-author{display:none}}.discovery-card.cookbook-card{background:linear-gradient(135deg, var(--color-sage-light) 0%, var(--color-cream) 100%);border:2px solid var(--color-sage);position:relative}.discovery-card.cookbook-card:before{content:"";background:linear-gradient(90deg, var(--color-sage) 0%, var(--color-sage-light) 100%);border-radius:var(--radius-md) 0 0 var(--radius-md);z-index:1;width:12px;position:absolute;top:0;bottom:0;left:0}.discovery-card.cookbook-card .discovery-card-image{aspect-ratio:4/3;margin:var(--space-3);margin-left:calc(var(--space-3) + 8px);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}.discovery-card.cookbook-card .discovery-card-placeholder{background:linear-gradient(135deg, var(--color-terracotta-light) 0%, var(--color-cream) 100%)}.discovery-card.cookbook-card .discovery-card-placeholder svg{color:var(--color-terracotta);opacity:.6}.discovery-card.cookbook-card .discovery-card-body{padding-left:calc(var(--space-3) + 8px)}.discovery-card.cookbook-card .discovery-card-count{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-sage-dark);font-weight:500;display:flex}.discovery-card.cookbook-card:hover{border-color:var(--color-terracotta);box-shadow:var(--shadow-lg)}.discovery-card.cookbook-card:hover:before{background:linear-gradient(90deg, var(--color-terracotta) 0%, var(--color-terracotta-light) 100%)}.public-cookbook-page{padding-bottom:var(--space-8);animation:.3s ease-out fadeIn}.public-cookbook-page .back-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-taupe);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--space-4);background:0 0;display:inline-flex}.public-cookbook-page .back-btn:hover{background:var(--color-cream);color:var(--color-text);border-color:var(--color-sage)}.public-cookbook-loading,.public-cookbook-empty{justify-content:center;align-items:center;gap:var(--space-4);text-align:center;min-height:400px;color:var(--color-taupe);flex-direction:column;display:flex}.public-cookbook-empty h2{font-family:var(--font-display);color:var(--color-text);margin:0}.public-cookbook-header{gap:var(--space-6);margin-bottom:var(--space-8);padding:var(--space-6);background:linear-gradient(135deg, var(--color-sage-light) 0%, var(--color-cream) 100%);border-radius:var(--radius-lg);border:2px solid var(--color-sage);display:flex;position:relative}.public-cookbook-header:before{content:"";background:linear-gradient(90deg, var(--color-sage) 0%, var(--color-sage-light) 100%);border-radius:var(--radius-lg) 0 0 var(--radius-lg);width:16px;position:absolute;top:0;bottom:0;left:0}.public-cookbook-cover{border-radius:var(--radius-md);width:200px;height:150px;box-shadow:var(--shadow-md);margin-left:var(--space-2);flex-shrink:0;overflow:hidden}.public-cookbook-cover img{object-fit:cover;width:100%;height:100%}.public-cookbook-cover-placeholder{background:linear-gradient(135deg, var(--color-terracotta-light) 0%, var(--color-cream) 100%);width:100%;height:100%;color:var(--color-terracotta);justify-content:center;align-items:center;display:flex}.public-cookbook-info{flex-direction:column;flex:1;justify-content:center;display:flex}.public-cookbook-info h1{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--color-text);margin:0 0 var(--space-2)}.public-cookbook-info .description{color:var(--color-taupe);margin:0 0 var(--space-3);line-height:1.6}.public-cookbook-info .meta{gap:var(--space-4);font-size:var(--text-sm);color:var(--color-sage-dark);display:flex}.public-cookbook-info .meta span{align-items:center;gap:var(--space-1);display:flex}.public-cookbook-actions{align-self:flex-start;gap:var(--space-2);margin-top:var(--space-4);flex-wrap:wrap;display:flex}.public-cookbook-recipes h2{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-text);margin:0 0 var(--space-4)}.public-cookbook-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.public-recipe-card{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);background:#fff;overflow:hidden}.public-recipe-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.public-recipe-card-image{aspect-ratio:1;position:relative;overflow:hidden}.public-recipe-card-image img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-base)}.public-recipe-card:hover .public-recipe-card-image img{transform:scale(1.05)}.public-recipe-card-placeholder{background:var(--color-cream);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.public-recipe-card .save-btn{top:var(--space-2);right:var(--space-2);cursor:pointer;width:32px;height:32px;box-shadow:var(--shadow-md);transition:all var(--transition-fast);opacity:0;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute}.public-recipe-card:hover .save-btn{opacity:1}.public-recipe-card .save-btn:hover{background:var(--color-terracotta-light);color:var(--color-terracotta)}.public-recipe-card .save-btn.saved{opacity:1;background:var(--color-terracotta);color:#fff}.public-recipe-card .save-btn.saved:hover{background:var(--color-terracotta-dark);color:#fff}.public-recipe-card-body{padding:var(--space-3)}.public-recipe-card-body h3{font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-text);margin:0 0 var(--space-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-weight:600;display:-webkit-box;overflow:hidden}.public-recipe-card-body .tags{gap:var(--space-1);flex-wrap:wrap;display:flex}.no-recipes{text-align:center;color:var(--color-taupe);padding:var(--space-8)}@media (width<=768px){.public-cookbook-header{text-align:center;padding:var(--space-4);flex-direction:column;align-items:center}.public-cookbook-header:before{display:none}.public-cookbook-cover{width:160px;height:120px;margin-left:0}.public-cookbook-info .meta{justify-content:center}.public-cookbook-actions{justify-content:center;align-self:center}.public-recipe-card .save-btn{opacity:1}}.my-recipes-page{padding-bottom:var(--space-8);animation:.3s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header{justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border);display:flex}.page-header-title{gap:var(--space-1);flex-direction:column;display:flex}.page-header-title h1{font-size:var(--text-3xl);color:var(--color-text);letter-spacing:-.02em;margin:0;font-weight:700}.page-subtitle{font-size:var(--text-base);color:var(--color-text-muted);margin:0}.my-recipes-toolbar{gap:var(--space-3);margin-bottom:var(--space-6);align-items:stretch;display:flex}.my-recipes-search-bar{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);background:#fff;flex:1;display:flex}.my-recipes-search-bar:focus-within{border-color:var(--color-olive);box-shadow:0 0 0 3px #455a481a, var(--shadow-sm)}.my-recipes-search-bar .search-icon{color:var(--color-text-muted);flex-shrink:0}.my-recipes-search-bar:focus-within .search-icon{color:var(--color-olive)}.my-recipes-search-bar .search-input{font-size:var(--text-base);color:var(--color-text);background:0 0;border:none;outline:none;flex:1}.my-recipes-search-bar .search-input::placeholder{color:var(--color-text-muted)}.btn-clear-input{background:var(--color-cream);width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex}.btn-clear-input:hover{background:var(--color-terracotta-light);color:var(--color-terracotta);transform:scale(1.1)}.filter-container{position:relative}.btn-filter{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;box-shadow:var(--shadow-sm);transition:all var(--transition-fast);white-space:nowrap;background:#fff;font-weight:600;display:flex}.btn-filter:hover{background:var(--color-cream);border-color:var(--color-text-muted);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-filter.active{background:var(--color-olive);border-color:var(--color-olive);color:#fff;box-shadow:var(--shadow-md), 0 0 0 3px #455a4826}.btn-filter.active:hover{background:var(--color-olive-dark)}.filter-badge{min-width:22px;height:22px;color:var(--color-olive);border-radius:var(--radius-full);font-size:var(--text-xs);margin-left:var(--space-1);background:#fff;justify-content:center;align-items:center;padding:0 7px;font-weight:700;display:flex}.btn-filter:not(.active) .filter-badge{background:var(--color-olive);color:#fff}.filter-menu{top:calc(100% + var(--space-2));border-radius:var(--radius-xl);z-index:100;width:340px;max-height:450px;padding:var(--space-5);background:#fff;animation:.2s ease-out filterMenuSlide;position:absolute;right:0;overflow-y:auto;box-shadow:0 20px 40px #00000026,0 0 0 1px #0000000d}@keyframes filterMenuSlide{0%{opacity:0;transform:translateY(-8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.filter-menu-header{margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.filter-menu-header h3{font-size:var(--text-lg);color:var(--color-text);margin:0;font-weight:700}.filter-menu-actions{align-items:center;gap:var(--space-2);margin-left:auto;display:flex}.btn-clear-filters{font-size:var(--text-sm);color:var(--color-terracotta);background:var(--color-terracotta-light);cursor:pointer;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:all var(--transition-fast);border:none;font-weight:600}.btn-clear-filters:hover{background:var(--color-terracotta);color:#fff;transform:translateY(-1px)}.btn-close-filter{background:var(--color-cream);border-radius:var(--radius-md);width:34px;height:34px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.btn-close-filter:hover{background:var(--color-cream-dark);color:var(--color-text);transform:translateY(-1px)}.filter-section{margin-bottom:var(--space-5)}.filter-section:last-child{margin-bottom:0}.filter-section h4{font-size:var(--text-xs);color:var(--color-olive);text-transform:uppercase;letter-spacing:.08em;margin:0 0 var(--space-3);align-items:center;gap:var(--space-2);font-weight:700;display:flex}.filter-section h4:after{content:"";background:var(--color-border);flex:1;height:1px}.filter-tags,.filter-owners{gap:var(--space-2);flex-wrap:wrap;display:flex}.filter-menu .filter-tag{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--color-cream);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;font-weight:500;display:flex}.filter-menu .filter-tag:hover{background:var(--color-cream-dark);border-color:var(--color-text-muted);transform:translateY(-1px)}.filter-menu .filter-tag.active{background:var(--color-olive);border-color:var(--color-olive);color:#fff;box-shadow:0 2px 8px #455a4840}.filter-owner{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-cream);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;font-weight:500;display:flex}.filter-owner:hover{background:var(--color-cream-dark);border-color:var(--color-text-muted);transform:translateY(-1px)}.filter-owner.active{background:var(--color-olive);border-color:var(--color-olive);color:#fff;box-shadow:0 2px 8px #455a4840}.recipe-pagination{justify-content:flex-end;align-items:center;gap:var(--space-4);margin-top:var(--space-5);display:flex}.pagination-status{color:var(--color-text-muted);font-size:var(--text-sm);font-weight:600}.pagination-buttons{align-items:center;gap:var(--space-2);display:flex}.pagination-btn,.pagination-page{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:36px;height:36px;color:var(--color-text);font-size:var(--text-sm);background:#fff;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.pagination-btn:hover:not(:disabled),.pagination-page:hover,.pagination-page.active{background:var(--color-olive);border-color:var(--color-olive);color:#fff}.pagination-btn:disabled{cursor:not-allowed;opacity:.45;transform:none}.my-recipes-grid{gap:var(--space-4)}@media (width>=720px){.my-recipes-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width>=980px){.my-recipes-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (width>=1180px){.my-recipes-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}@media (width<=640px){.page-header{align-items:stretch;gap:var(--space-4);padding-bottom:var(--space-4);flex-direction:column}.page-header-title h1{font-size:var(--text-2xl)}.page-header .btn-primary{justify-content:center;width:100%}.my-recipes-toolbar{gap:var(--space-2);flex-direction:row;align-items:stretch}.my-recipes-search-bar{min-width:0;padding:var(--space-3)}.my-recipes-search-bar .search-input{min-width:0}.btn-filter{height:100%;padding:var(--space-3);justify-content:center}.filter-menu{top:auto;right:max(var(--space-4), env(safe-area-inset-right));bottom:calc(var(--mobile-nav-offset) + var(--space-3));left:max(var(--space-4), env(safe-area-inset-left));width:auto;max-height:min(70dvh, calc(100dvh - var(--mobile-nav-offset) - var(--space-8)));padding:var(--space-4);border-radius:var(--radius-lg);overscroll-behavior:contain;position:fixed;transform:none}.recipe-pagination{flex-direction:column;align-items:stretch}.pagination-buttons{justify-content:center}}
