@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=Inter:wght@400;500;600;700&family=Crimson+Pro:ital,wght@0,400;0,600;1,400&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #3d6b45;--green-light: #dceade;--green-dark: #2a4f31;--red: #b91c1c;--red-light: #fee2e2;--amber: #b45309;--amber-light: #fef3c7;--gray-50: #faf7f2;--gray-100: #f2ede5;--gray-200: #e5ddd3;--gray-300: #d1c9bf;--gray-400: #a89f94;--gray-500: #7c746b;--gray-600: #5a524b;--gray-700: #3d3730;--gray-800: #282220;--gray-900: #1a1512;--radius: 10px;--radius-lg: 16px;--radius-xl: 24px;--shadow: 0 1px 3px rgba(60,40,20,.08), 0 1px 2px rgba(60,40,20,.06);--shadow-md: 0 4px 12px rgba(60,40,20,.1), 0 2px 4px rgba(60,40,20,.06);--shadow-lg: 0 8px 28px rgba(60,40,20,.13), 0 4px 8px rgba(60,40,20,.08);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-serif: "Playfair Display", Georgia, serif;--font-reading: "Crimson Pro", Georgia, serif}body{font-family:var(--font-sans);background-color:var(--gray-50);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");color:var(--gray-800);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font:inherit}input,textarea,select{font:inherit;border:1.5px solid var(--gray-300);border-radius:var(--radius);padding:10px 14px;width:100%;outline:none;background:#fff;color:var(--gray-800);transition:border-color .15s,box-shadow .15s}input:focus,textarea:focus,select:focus{border-color:var(--green);box-shadow:0 0 0 3px #3d6b4526}img{max-width:100%;display:block}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--radius);font-weight:600;font-size:.9rem;transition:all .15s;cursor:pointer;white-space:nowrap}.btn-primary{background:var(--green);color:#fff;box-shadow:0 1px 3px #3d6b454d}.btn-primary:hover{background:var(--green-dark);box-shadow:0 2px 6px #3d6b4559}.btn-outline{background:#fff;color:var(--green);border:1.5px solid var(--green)}.btn-outline:hover{background:var(--green-light)}.btn-ghost{background:transparent;color:var(--gray-600)}.btn-ghost:hover{background:var(--gray-100);color:var(--gray-800)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#991b1b}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;border:1px solid var(--gray-200)}.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:4px;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-family:var(--font-sans)}.badge-green{background:var(--green-light);color:var(--green-dark)}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.badge-red{background:var(--red-light);color:var(--red)}.badge-amber{background:var(--amber-light);color:var(--amber)}.stars{display:inline-flex;gap:2px;color:#d97706}.spinner{width:28px;height:28px;border:3px solid var(--gray-200);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.grid-2{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px}.topbar{position:sticky;top:0;z-index:100;background:linear-gradient(180deg,#3a6642 0%,var(--green) 100%);color:#fff;padding:0 20px;height:60px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #0003;border-bottom:3px solid var(--green-dark)}.topbar:after{content:"";position:absolute;bottom:-6px;left:0;right:0;height:2px;background:repeating-linear-gradient(90deg,transparent 0px,transparent 6px,rgba(61,107,69,.3) 6px,rgba(61,107,69,.3) 8px);pointer-events:none}.topbar-brand{display:flex;align-items:center;gap:10px;color:#fff;font-family:var(--font-serif);font-size:1.25rem;font-weight:700;letter-spacing:.3px}.topbar-brand-icon{font-size:1.4rem;line-height:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.topbar-brand-leaf{font-size:.9rem;opacity:.75;margin:0 -4px}.topbar-user{display:flex;align-items:center;gap:10px}.topbar-username{font-size:.82rem;opacity:.8;font-weight:500;font-style:italic;font-family:var(--font-reading)}.topbar-logout{background:#ffffff26;color:#fff;padding:5px 14px;border-radius:20px;font-size:.78rem;font-weight:600;border:1px solid rgba(255,255,255,.2);transition:background .15s}.topbar-logout:hover{background:#ffffff42}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--gray-50);border-top:2px solid var(--gray-200);display:flex;z-index:100;padding:4px 8px env(safe-area-inset-bottom,6px);gap:2px;box-shadow:0 -2px 16px #3c28141a}.bottom-nav:before{content:"";position:absolute;top:-4px;left:0;right:0;height:2px;background:repeating-linear-gradient(90deg,transparent 0px,transparent 6px,var(--gray-300) 6px,var(--gray-300) 8px);pointer-events:none}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:6px 4px 4px;font-size:.67rem;gap:3px;border-radius:var(--radius);transition:all .15s;color:var(--gray-400);font-weight:500;letter-spacing:.02em;text-decoration:none;text-transform:uppercase}.bottom-nav-item:hover{background:var(--gray-100);color:var(--gray-600)}.bottom-nav-item.active{color:var(--green-dark);background:var(--green-light);font-weight:700}.bottom-nav-icon{font-size:1.2rem;line-height:1}.recipe-card{background:#fffef9;border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--gray-200);overflow:hidden;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;position:relative}.recipe-card:hover{transform:translateY(-4px);box-shadow:0 10px 32px #3c281424,0 3px 8px #3c281414}.recipe-card-accent{height:4px;background:linear-gradient(90deg,var(--green-dark) 0%,var(--green) 55%,#6aaa72 100%)}.recipe-card-image{width:100%;height:190px;object-fit:cover}.recipe-card-placeholder{width:100%;height:190px;background:repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(61,107,69,.035) 20px,rgba(61,107,69,.035) 21px),linear-gradient(180deg,#f2ede5,#e8e0d5);display:flex;align-items:center;justify-content:center;font-size:3rem;filter:grayscale(.1)}.recipe-card-body{padding:14px 16px 16px}.recipe-card-title{font-family:var(--font-reading);font-size:1.15rem;font-weight:600;margin-bottom:8px;line-height:1.3;color:var(--gray-900)}.recipe-card-divider{height:1px;background:var(--gray-200);margin:10px 0;background-image:repeating-linear-gradient(90deg,var(--gray-200) 0px,var(--gray-200) 4px,transparent 4px,transparent 8px)}.recipe-card-badges{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}.recipe-card-meta{display:flex;justify-content:space-between;align-items:center;color:var(--gray-500);font-size:.78rem;font-family:var(--font-reading);font-style:italic}.recipe-card-meta-left{display:flex;gap:10px;align-items:center}.brand-peace{font-style:italic;opacity:.88;letter-spacing:.5px}@keyframes login-breathe{0%,to{background-position:0% 60%}50%{background-position:100% 40%}}.login-page{min-height:100vh;background:linear-gradient(165deg,#f5efe4,#eef3ee,#d2e8d2 60%,#a8c8a8,#7aaa82);background-size:200% 200%;animation:login-breathe 12s ease-in-out infinite;display:flex;align-items:center;justify-content:center;padding:16px;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(ellipse at 5% 5%,rgba(61,107,69,.12) 0%,transparent 45%),radial-gradient(ellipse at 95% 95%,rgba(61,107,69,.1) 0%,transparent 40%),radial-gradient(ellipse at 90% 5%,rgba(245,239,228,.4) 0%,transparent 35%);pointer-events:none}@keyframes card-rise{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.login-card{background:#fffef9;border-radius:var(--radius-xl);padding:40px 32px;width:100%;max-width:400px;box-shadow:0 20px 60px #2a4f312e,0 4px 16px #2a4f311a;position:relative;z-index:1;border-top:3px solid var(--green);animation:card-rise .5s ease both}.login-hero{text-align:center;margin-bottom:32px}.login-icon{width:76px;height:76px;background:linear-gradient(145deg,var(--green-light),#c8e6c9);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;box-shadow:0 4px 16px #3d6b4533}.login-title{font-family:var(--font-serif);font-size:2.1rem;font-weight:700;color:var(--gray-900);line-height:1.15;margin-bottom:8px;letter-spacing:-.5px}.login-tagline{color:var(--green-dark);font-size:.88rem;font-family:var(--font-reading);font-style:italic;opacity:.8;margin-bottom:4px}.login-subtitle{color:var(--gray-400);font-size:.82rem}.login-form{display:flex;flex-direction:column;gap:14px}.login-form label{display:block;font-size:.82rem;font-weight:600;color:var(--gray-600);margin-bottom:5px}.login-error{background:var(--red-light);color:var(--red);font-size:.88rem;padding:10px 14px;border-radius:var(--radius);text-align:center}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px}.page-title{font-family:var(--font-serif);font-size:1.5rem;font-weight:700;color:var(--gray-900)}.deco-rule{display:flex;align-items:center;gap:10px;margin:6px 0 18px;color:var(--gray-400);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-reading);font-style:italic}.deco-rule:before,.deco-rule:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gray-300),transparent)}.recipes-search-wrap{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200);box-shadow:var(--shadow);padding:14px 16px;margin-bottom:16px}.recipes-count{color:var(--gray-400);font-size:.85rem;margin-bottom:16px;font-family:var(--font-reading);font-style:italic;text-align:right}.empty-state{text-align:center;padding:60px 16px;color:var(--gray-400)}.empty-state-icon{font-size:3.5rem;margin-bottom:14px}.empty-state-title{font-size:1.15rem;font-weight:600;color:var(--gray-500);margin-bottom:6px}.empty-state-body{font-size:.9rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.login-divider{display:flex;align-items:center;gap:12px;margin:20px 0 12px;color:var(--gray-400);font-size:.82rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--gray-200)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a15128c;display:flex;align-items:center;justify-content:center;z-index:500;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-card{background:#fff;border-radius:var(--radius-xl);padding:32px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-title{font-family:var(--font-serif);font-size:1.4rem;font-weight:700;color:var(--gray-900)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);color:var(--gray-500);font-size:.9rem;transition:background .15s,color .15s}.modal-close:hover{background:var(--gray-100);color:var(--gray-800)}
