@import"https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700&display=swap";.sidebar{width:var(--sidebar-width);min-height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100}@media(max-width:768px){.sidebar{display:none}}.logo{padding:var(--space-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;background:#fff}.logo-img{width:100%;max-width:180px;height:auto}.nav-menu{flex:1;padding:var(--space-md) .75rem;display:flex;flex-direction:column;gap:var(--space-xs)}.nav-divider{height:1px;background:var(--border);margin:var(--space-md) var(--space-sm)}.nav-section{display:flex;flex-direction:column}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem var(--space-md);background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.75rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase;cursor:pointer;transition:var(--transition-fast);text-align:left;width:100%}.nav-item:hover{background:var(--gray-200);color:var(--text-primary)}.nav-item:active{transform:scale(.98)}.nav-item.active{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px #2f998d4d}.nav-item.active svg{color:#fff}.nav-item.active:hover{background:linear-gradient(135deg,var(--primary-hover) 0%,var(--primary-dark) 100%);color:#fff}.sidebar-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border)}.version-info{font-size:.7rem;color:var(--text-tertiary);text-align:center}.nav-subitems{display:flex;flex-direction:column;margin-top:.25rem;margin-bottom:.5rem}.nav-subitem{display:flex;align-items:center;padding:.625rem 1rem .625rem 2.5rem;background:transparent;border:none;border-left:2px solid transparent;color:var(--text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease;text-align:left;width:100%}.nav-subitem:hover{background:#2f998d0d;color:var(--text-primary)}.nav-subitem.active{background:#2f998d1a;border-left-color:var(--primary);color:var(--primary);font-weight:600}.top-header{display:flex;align-items:center;justify-content:flex-end;padding:.75rem var(--space-lg);background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-right{display:flex;align-items:center;gap:var(--space-md)}.user-section{position:relative}.user-btn{display:flex;align-items:center;gap:.75rem;padding:.375rem var(--space-sm) .375rem .75rem;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast)}.user-btn:hover{background:var(--gray-200)}.user-name{font-size:.9rem;font-weight:500;color:var(--text-primary)}.user-tier{font-size:.65rem;font-weight:600;color:#fff;background:var(--gradient-nature);padding:.125rem var(--space-sm);border-radius:var(--radius-sm);letter-spacing:.03em;box-shadow:0 1px 4px #2f998d4d}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient-sunset);display:flex;align-items:center;justify-content:center;overflow:hidden;color:#fff;box-shadow:0 2px 8px #2f998d4d}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar .avatar-initials{font-size:.875rem;font-weight:600;color:#fff;line-height:1}.user-menu{position:absolute;top:calc(100% + var(--space-sm));right:0;min-width:180px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden;z-index:200}.user-menu button{width:100%;display:flex;align-items:center;gap:.625rem;padding:.75rem var(--space-md);background:transparent;border:none;color:var(--text-secondary);font-size:.9rem;text-align:left;cursor:pointer;transition:var(--transition-fast)}.user-menu button:hover{background:var(--gray-100);color:var(--text-primary)}.user-menu button.sign-out{border-top:1px solid var(--border);color:var(--red)}.user-menu button.sign-out:hover{background:var(--red-light)}@media(max-width:768px){.top-header{display:none}}.recipe-actions-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.recipe-actions-menu{background:#fff;border:1px solid #e5e7eb;box-shadow:0 20px 60px #0003,0 0 0 1px #2f998d1a;overflow:hidden;animation:scaleIn .2s ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.recipe-actions-menu.desktop{width:320px;border-radius:16px;margin-bottom:10vh}.recipe-actions-menu.mobile{width:100%;max-width:480px;border-radius:24px 24px 0 0;align-self:flex-end;animation:slideUpMobile .3s ease-out}@keyframes slideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.recipe-menu-container{position:relative;overflow:hidden}.recipe-menu-level{display:flex;flex-direction:column;transition:transform .25s ease-in-out,opacity .25s ease-in-out;width:100%}.recipe-menu-level.primary{transform:translate(0);opacity:1}.recipe-menu-level.secondary{position:absolute;top:0;left:0;width:100%;background:#fff;transform:translate(100%);opacity:0;pointer-events:none}.recipe-actions-menu.secondary-level .recipe-menu-container{min-height:350px}.recipe-actions-menu.secondary-level .recipe-menu-level.primary{transform:translate(-100%);opacity:0;pointer-events:none}.recipe-actions-menu.secondary-level .recipe-menu-level.secondary{transform:translate(0);opacity:1;pointer-events:auto}.recipe-menu-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border:none;border-bottom:1px solid #f3f4f6;cursor:pointer;transition:all .15s ease;text-align:left;width:100%;min-height:64px}.recipe-menu-item:last-child{border-bottom:none}.recipe-menu-item:hover{background:#2f998d0d}.recipe-menu-item:active{background:#2f998d1a;transform:scale(.98)}.recipe-menu-item:focus{outline:none;background:#2f998d0d;box-shadow:inset 0 0 0 2px #2f998d33}.recipe-menu-item.back-button{background:#f9fafb;border-bottom:1px solid #e5e7eb}.recipe-menu-item.back-button:hover{background:#f3f4f6}.recipe-menu-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.recipe-menu-icon.create{background:linear-gradient(135deg,#2f998d26,#2f998d0d);color:#2f998d}.recipe-menu-icon.upload{background:linear-gradient(135deg,#3b82f626,#3b82f60d);color:#3b82f6}.recipe-menu-icon.document{background:linear-gradient(135deg,#a855f726,#a855f70d);color:#a855f7}.recipe-menu-icon.picture{background:linear-gradient(135deg,#ec489926,#ec48990d);color:#ec4899}.recipe-menu-icon.camera{background:linear-gradient(135deg,#f59e0b26,#f59e0b0d);color:#f59e0b}.recipe-menu-icon.manual{background:linear-gradient(135deg,#10b98126,#10b9810d);color:#10b981}.recipe-menu-icon.back{background:linear-gradient(135deg,#6b728026,#6b72800d);color:#6b7280}.recipe-menu-info{flex:1;display:flex;flex-direction:column;gap:4px}.recipe-menu-title{font-size:14px;font-weight:600;color:#1a1a2e;line-height:1.2}.recipe-menu-subtitle{font-size:12px;color:#6b7280;line-height:1.3}@media(max-width:768px){.recipe-menu-item{min-height:72px;padding:14px 18px}.recipe-menu-icon{width:48px;height:48px}.recipe-menu-title{font-size:15px}.recipe-menu-subtitle{font-size:13px}.recipe-actions-menu.secondary-level .recipe-menu-container{min-height:400px}}@media(hover:none)and (pointer:coarse){.recipe-menu-item:active{transform:scale(.98);background:#2f998d26}.recipe-menu-item.back-button:active{background:#e5e7eb}}@media(prefers-reduced-motion:reduce){.recipe-actions-overlay,.recipe-actions-menu,.recipe-menu-level,.recipe-menu-item{animation:none;transition:none}.recipe-menu-item:active{transform:none}}@media(prefers-contrast:high){.recipe-actions-menu{border:2px solid #000}.recipe-menu-item{border-bottom:2px solid #e5e7eb}.recipe-menu-item:focus{box-shadow:inset 0 0 0 3px #2f998d}}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:80px;padding-bottom:env(safe-area-inset-bottom,0px);background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -2px 10px #0000000d;z-index:var(--z-bottom-nav, 500);align-items:center;padding-left:var(--space-md);padding-right:var(--space-md)}@media(max-width:768px){.bottom-nav{display:flex}}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-width:48px;min-height:48px;padding:8px 12px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;transition:var(--transition-fast);position:relative;-webkit-tap-highlight-color:transparent;flex:1}.bottom-nav-item:active{transform:scale(.95);background:var(--primary-light)}.bottom-nav-item.active{color:var(--primary)}.bottom-nav-item.active:after{content:"";position:absolute;bottom:2px;width:4px;height:4px;background:var(--primary);border-radius:50%}.bottom-nav-label{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.02em}.bottom-nav-item.active .bottom-nav-label{font-weight:600}.bottom-nav-center-container{position:relative;display:flex;align-items:center;justify-content:center;flex:1}.bottom-nav-center-btn{width:56px;height:56px;background:var(--gradient-primary);border:none;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transform:translateY(-16px);box-shadow:0 4px 16px #2f998d59;transition:var(--transition-base);-webkit-tap-highlight-color:transparent;position:relative;z-index:10}.bottom-nav-center-btn:hover{background:linear-gradient(135deg,var(--primary-hover) 0%,var(--primary-dark) 100%);transform:translateY(-18px);box-shadow:0 6px 20px #2f998d66}.bottom-nav-center-btn:active{transform:translateY(-14px) scale(.95);box-shadow:0 2px 8px #2f998d40}.bottom-nav-center-btn.close-mode{background:var(--gray-200);box-shadow:0 4px 12px #0000001a;color:var(--text-secondary);cursor:not-allowed;opacity:.6}.bottom-nav-center-btn.close-mode:hover{background:var(--gray-200);box-shadow:0 4px 12px #0000001a;transform:translateY(-16px)}.bottom-nav-center-btn.close-mode:active{background:var(--gray-200);transform:translateY(-16px);box-shadow:0 4px 12px #0000001a}.add-menu-dropdown{position:absolute;bottom:calc(100% + 1rem);left:50%;transform:translate(-50%);min-width:200px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:slideUp .15s ease;z-index:var(--z-bottom-nav-menu, 510);pointer-events:auto}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.add-menu-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:transparent;border:none;color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer;text-align:left;transition:var(--transition-fast);border-bottom:1px solid var(--border-light);min-height:48px}.add-menu-item:last-child{border-bottom:none}.add-menu-item:hover{background:var(--primary-light);color:var(--primary)}.add-menu-item:active{background:var(--primary-light);color:var(--primary);transform:scale(.98)}.add-menu-item svg{color:var(--primary);flex-shrink:0}.bottom-nav-more-overlay{display:none;position:fixed;inset:0;background:var(--overlay);z-index:var(--z-overlay, 900);align-items:flex-end;justify-content:center;animation:fadeIn .15s ease}@media(max-width:768px){.bottom-nav-more-overlay{display:flex}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.bottom-nav-more-menu{background:var(--surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:400px;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px));box-shadow:var(--shadow-lg);animation:slideUpMenu .2s ease}@keyframes slideUpMenu{0%{transform:translateY(100%)}to{transform:translateY(0)}}.more-menu-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border);font-weight:600;color:var(--text-primary)}.more-menu-close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast)}.more-menu-close:active{background:var(--gray-200);transform:scale(.95)}.more-menu-item{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:var(--space-md) var(--space-lg);background:transparent;border:none;color:var(--text-primary);font-size:1rem;font-weight:500;text-align:left;cursor:pointer;transition:var(--transition-fast);min-height:56px}.more-menu-item:active{background:var(--gray-100)}.more-menu-item.active{color:var(--primary);background:var(--primary-light)}.more-menu-item svg{color:var(--primary);flex-shrink:0}.lab-nav-container{position:relative;display:flex;align-items:center;justify-content:center}.lab-mode-badge{position:absolute;top:4px;right:8px;width:16px;height:16px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border:2px solid var(--surface);border-radius:50%;color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 2px 4px #00000026}.lab-mode-menu{position:absolute;bottom:calc(100% + 1rem);left:50%;transform:translate(-50%);min-width:240px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:slideUp .2s ease;z-index:var(--z-bottom-nav-menu, 510);pointer-events:auto}.lab-mode-item{width:100%;display:flex;align-items:center;gap:.875rem;padding:1rem 1.125rem;background:transparent;border:none;color:var(--text-primary);cursor:pointer;text-align:left;transition:var(--transition-fast);border-bottom:1px solid var(--border-light);min-height:64px}.lab-mode-item:last-child{border-bottom:none}.lab-mode-item:hover{background:var(--primary-light)}.lab-mode-item:active{background:var(--primary-light);transform:scale(.98)}.lab-mode-item.active{background:linear-gradient(135deg,#2f998d1a,#2f998d0d);border-left:3px solid var(--primary)}.lab-mode-item svg{color:var(--primary);flex-shrink:0}.lab-mode-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.lab-mode-title{font-size:.95rem;font-weight:600;color:var(--text-primary)}.lab-mode-desc{font-size:.75rem;color:var(--text-secondary);line-height:1.3}.lab-mode-item.active .lab-mode-title{color:var(--primary)}.lab-mode-item.active .lab-mode-desc{color:var(--primary-dark)}@media(max-width:768px){.lab-mode-menu{min-width:260px}.lab-mode-item{min-height:72px;padding:1.125rem 1.25rem}.lab-mode-badge{width:18px;height:18px;font-size:10px}}@media(prefers-reduced-motion:reduce){.bottom-nav-center-btn,.bottom-nav-item,.add-menu-dropdown,.bottom-nav-more-menu,.bottom-nav-more-overlay,.lab-mode-menu{animation:none;transition:none}.bottom-nav-center-btn:hover,.bottom-nav-center-btn:active{transform:translateY(-16px)}.bottom-nav-item:active{transform:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#2f998d,#16213e);padding:20px;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(47,153,141,.15) 0%,transparent 40%),radial-gradient(circle at 70% 80%,rgba(66,133,244,.1) 0%,transparent 40%);animation:float 20s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(2%,2%) rotate(1deg)}50%{transform:translateY(4%) rotate(0)}75%{transform:translate(-2%,2%) rotate(-1deg)}}.login-card{background:linear-gradient(180deg,#fff,#fafbfc);border-radius:16px;padding:48px;max-width:400px;width:100%;text-align:center;box-shadow:0 20px 60px #0000004d;position:relative;z-index:1}.login-logo{margin-bottom:32px}.logo-text{display:block;font-size:24px;font-weight:700;color:#1a1a2e;letter-spacing:2px}.logo-sub{display:block;font-size:14px;font-weight:500;color:#666;letter-spacing:4px;margin-top:4px}.login-card h1{font-size:24px;color:#1a1a2e;margin:0 0 12px;font-weight:600}.login-card p{color:#666;margin:0 0 24px;font-size:14px;line-height:1.5}.login-error{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}.google-signin-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:14px 24px;background:#fff;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s}.google-signin-btn:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}.google-signin-btn:disabled{opacity:.6;cursor:not-allowed}.google-icon{flex-shrink:0}.back-btn{display:block;width:100%;padding:12px 24px;margin-top:12px;background:transparent;border:none;font-size:14px;color:#6b7280;cursor:pointer;transition:color .2s}.back-btn:hover{color:#374151}.divider{display:flex;align-items:center;margin:20px 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.divider span{padding:0 12px;color:#9ca3af;font-size:14px}.email-form{display:flex;flex-direction:column;gap:12px}.login-input{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;outline:none;transition:border-color .2s;box-sizing:border-box}.login-input:focus{border-color:#3b82f6}.email-signin-btn{width:100%;padding:12px 24px;background:linear-gradient(135deg,#2f998d,#247a70);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #2f998d4d}.email-signin-btn:hover:not(:disabled){background:linear-gradient(135deg,#248577,#1e6d63);transform:translateY(-1px);box-shadow:0 4px 12px #2f998d66}.email-signin-btn:disabled{opacity:.6;cursor:not-allowed}.toggle-mode-btn{margin-top:16px;background:none;border:none;color:#3b82f6;font-size:14px;cursor:pointer}.toggle-mode-btn:hover{text-decoration:underline}.login-note{margin-top:24px;font-size:12px;color:#9ca3af}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:400px;padding:2rem;background:linear-gradient(135deg,#f5f7fa,#e3e9f0)}.error-boundary-content{max-width:500px;text-align:center;background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 4px 6px #00000012,0 10px 20px #00000014}.error-icon{color:#ef4444;margin-bottom:1rem;display:flex;justify-content:center}.error-boundary-content h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin-bottom:.75rem}.error-message{color:#6b7280;font-size:.95rem;margin-bottom:1.5rem;line-height:1.5}.error-actions{display:flex;gap:.75rem;justify-content:center;margin-bottom:1rem}.error-btn-primary,.error-btn-secondary{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:8px;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all .2s ease}.error-btn-primary{background:#14b8a6;color:#fff}.error-btn-primary:hover{background:#0f9b8e;transform:translateY(-1px);box-shadow:0 4px 8px #14b8a64d}.error-btn-secondary{background:#f3f4f6;color:#374151}.error-btn-secondary:hover{background:#e5e7eb;transform:translateY(-1px)}.error-details{margin-top:1.5rem;text-align:left;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.error-details summary{cursor:pointer;font-weight:500;color:#374151;-webkit-user-select:none;user-select:none;padding:.25rem}.error-details summary:hover{color:#14b8a6}.error-stack{margin-top:.75rem;padding:1rem;background:#1f2937;color:#f3f4f6;border-radius:6px;font-size:.75rem;line-height:1.5;overflow-x:auto;white-space:pre-wrap;word-break:break-word}:root{--primary: #2F998D;--primary-hover: #248577;--primary-light: rgba(47, 153, 141, .1);--primary-dark: #1e6d63;--primary-blue: #33647f;--primary-blue-dark: #104859;--gray-50: #fafbfc;--gray-100: #f5f7f8;--gray-200: #f1f3f4;--gray-300: #e8eaed;--gray-400: #B8C3C8;--gray-500: #717D83;--gray-600: #5f6368;--gray-700: #3c4043;--gray-800: #202124;--gray-900: #0d1117;--green: #34a853;--green-light: #d1fae5;--red: #d93025;--red-light: #fee2e2;--yellow: #facc15;--yellow-light: #fef3c7;--blue: #4285f4;--blue-light: #dbeafe;--purple: #9333ea;--purple-light: #f3e8ff;--coral: #f97316;--coral-light: #ffedd5;--gradient-primary: linear-gradient(135deg, #2F998D 0%, #1e6d63 100%);--gradient-primary-soft: linear-gradient(135deg, rgba(47, 153, 141, .08) 0%, rgba(47, 153, 141, .02) 100%);--gradient-warm: linear-gradient(135deg, #33647f 0%, #2F998D 100%);--gradient-sunset: linear-gradient(135deg, #33647f 0%, #2F998D 100%);--gradient-nature: linear-gradient(135deg, #2F998D 0%, #9FD6C9 100%);--gradient-page: linear-gradient(180deg, #f5f7f8 0%, #e8f4f2 100%);--gradient-card: linear-gradient(180deg, #ffffff 0%, #fafbfc 100%);--background: #f5f7f8;--surface: #fff;--border: #e8eaed;--text-primary: #202124;--text-secondary: #5f6368;--text-tertiary: #9aa0a6;--font-serif: "Playfair Display", Georgia, serif;--font-sans: "Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 2.5rem;--space-3xl: 3rem;--sidebar-width: 220px;--bottom-nav-height: 100px;--safe-area-bottom: env(safe-area-inset-bottom, 0px);--page-padding: var(--space-xl);--page-padding-mobile: var(--space-md);--overlay: rgba(0, 0, 0, .6);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--transition-fast: .15s ease;--transition-base: .2s ease;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--z-base: 1;--z-sticky: 100;--z-fixed: 200;--z-dropdown: 400;--z-bottom-nav: 500;--z-bottom-nav-menu: 510;--z-overlay: 900;--z-modal: 1000;--z-toast: 1100}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-sans);font-size:16px;line-height:1.5;color:var(--text-primary);background:var(--background)}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:400;line-height:1.3;letter-spacing:.01em}p{color:var(--text-secondary)}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}img{max-width:100%;height:auto}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--gradient-primary);border:none;border-radius:var(--radius-md);color:#fff;font-size:.9rem;font-weight:500;transition:var(--transition-fast);box-shadow:0 2px 8px #2f998d40}.btn-primary:hover{background:linear-gradient(135deg,#248577,#1a5c54);box-shadow:0 4px 12px #2f998d59;transform:translateY(-1px)}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9rem;font-weight:500;transition:var(--transition-fast)}.btn-secondary:hover{border-color:var(--primary);color:var(--primary)}input,select,textarea{font-family:inherit;font-size:inherit}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}::selection{background:var(--primary-light);color:var(--primary)}.page-title{font-family:var(--font-serif);font-size:2rem;font-weight:500;color:var(--text-primary);margin-bottom:var(--space-lg)}.section-title{font-family:var(--font-sans);font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-md)}.subsection-title{font-family:var(--font-sans);font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.page-container{padding:var(--page-padding);min-height:100vh}@media(max-width:768px){.page-title{font-size:1.75rem}.page-container{padding:var(--page-padding-mobile)}}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite}.loading-spinner{width:32px;height:32px;border:3px solid var(--gray-300);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner.small{width:20px;height:20px;border-width:2px}.loading-spinner.large{width:48px;height:48px;border-width:4px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-3xl);color:var(--text-secondary);font-size:.9rem}.loading-container.fullscreen{min-height:60vh}.loading-container.inline{padding:var(--space-xl)}@media(max-width:768px){body{font-size:15px}}.app{display:flex;min-height:100vh;background:var(--gradient-page)}.main-content{flex:1;margin-left:220px;height:100vh;max-height:100vh;display:flex;flex-direction:column;overflow:hidden}@media(max-width:768px){.main-content{margin-left:0;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0)}}.page-content{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--gradient-page);color:var(--text-secondary);font-size:.9rem}.page-loader{flex:1;display:flex;align-items:center;justify-content:center;min-height:400px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#bdc1c6,#9aa0a6);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#2f998d,#247a70)}*:focus-visible{outline:2px solid #2F998D;outline-offset:2px;box-shadow:0 0 0 4px #2f998d26}button:focus:not(:focus-visible){outline:none}@media(max-width:768px){body{overflow-x:hidden}button,a,input,select,textarea{min-height:44px}.main-content{padding-bottom:env(safe-area-inset-bottom,0)}}.public-recipe-page{min-height:100vh;background:#f8f9fa}.public-recipe-container{max-width:800px;margin:0 auto;padding:24px}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;color:#666}.loading-icon{animation:pulse 2s infinite;color:#2f998d}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.error-state svg{color:#dc2626;margin-bottom:16px}.error-state h2{margin:0 0 8px;font-size:1.5rem;color:#1a1a2e}.error-state p{margin:0 0 24px}.recipe-header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.back-link{display:flex;align-items:center;gap:8px;color:#666;text-decoration:none;font-size:14px;transition:color .2s}.back-link:hover{color:#2f998d}.print-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fff;border:1px solid #ddd;border-radius:8px;font-size:14px;color:#333;cursor:pointer;transition:all .2s}.print-btn:hover{border-color:#2f998d;color:#2f998d}.recipe-article{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 24px #00000014}.recipe-hero{width:100%;height:400px;overflow:hidden}.recipe-hero img{width:100%;height:100%;object-fit:cover}.recipe-header{padding:32px 32px 24px;border-bottom:1px solid #eee}.recipe-header h1{margin:0 0 8px;font-size:2rem;font-weight:600;color:#1a1a2e;line-height:1.2}.recipe-subtitle{margin:0 0 20px;font-size:1.125rem;color:#666}.recipe-meta{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:16px}.meta-badge{padding:4px 12px;background:#2f998d1a;border-radius:16px;font-size:13px;font-weight:500;color:#2f998d}.meta-item{display:flex;align-items:center;gap:6px;font-size:14px;color:#666}.meta-item.total{font-weight:500;color:#333}.recipe-tags{display:flex;flex-wrap:wrap;gap:8px}.recipe-tags .tag{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;background:#f0f0f0;border-radius:16px;font-size:13px;color:#666}.recipe-body{padding:32px}.recipe-body section{margin-bottom:32px}.recipe-body section:last-child{margin-bottom:0}.recipe-body h2{margin:0 0 16px;font-size:1.25rem;font-weight:600;color:#1a1a2e;padding-bottom:8px;border-bottom:2px solid #2F998D;display:inline-block}.ingredients-list{list-style:none;padding:0;margin:0}.ingredients-list li{display:flex;padding:12px 0;border-bottom:1px solid #f0f0f0}.ingredients-list li:last-child{border-bottom:none}.ingredients-list .quantity{min-width:100px;color:#2f998d;font-weight:500}.ingredients-list .name{color:#333}.method-content{line-height:1.7}.method-step{display:flex;gap:16px;margin-bottom:20px}.step-number{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#2f998d;color:#fff;border-radius:50%;font-weight:600;font-size:14px;flex-shrink:0}.method-step p{margin:0;padding-top:4px;color:#333}.method-content>p{margin:0 0 16px;color:#333}.why-section p{margin:0;padding:16px;background:linear-gradient(135deg,#e8f5e9,#e0f2f1);border-radius:8px;color:#333;line-height:1.6}.notes-section p{margin:0;padding:16px;background:#fffbeb;border-radius:8px;color:#92400e;line-height:1.6;font-style:italic}.allergen-badges{display:flex;flex-wrap:wrap;gap:8px}.allergen-badge{padding:6px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:16px;font-size:13px;color:#dc2626}.recipe-footer{padding:24px 32px;background:#f8f9fa;text-align:center;font-size:14px;color:#666}.recipe-footer a{color:#2f998d;text-decoration:none;font-weight:500}.recipe-footer a:hover{text-decoration:underline}@media print{.no-print{display:none!important}.public-recipe-page{background:#fff}.public-recipe-container{max-width:none;padding:0}.recipe-article{box-shadow:none;border-radius:0}.recipe-hero{height:300px}.recipe-header,.recipe-body{padding:24px}.recipe-body h2{break-after:avoid}.ingredients-list,.method-content{break-inside:avoid}}@media(max-width:600px){.public-recipe-container{padding:16px}.recipe-hero{height:250px}.recipe-header{padding:24px 20px 20px}.recipe-header h1{font-size:1.5rem}.recipe-body{padding:24px 20px}.ingredients-list .quantity{min-width:80px}.method-step{flex-direction:column;gap:8px}}
