@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;1,400&family=Inter:wght@300;400;500;600&family=Dancing+Script:wght@500;700&display=swap";:root{--cream:#fff8f0;--warm-bg:#fef1e6;--peach:#f4a261;--terracotta:#e07a5f;--sage:#a8b5a2;--dark:#3d2c2c;--soft-brown:#7a5c52;--blush:#fadbd8;--card-bg:#fff;--shadow:0 2px 16px #3d2c2c14;--shadow-lg:0 4px 28px #3d2c2c1f;--error:#c44536}*{box-sizing:border-box;margin:0;padding:0}html,body{min-height:100%}#root{flex-direction:column;min-height:100svh;display:flex}body{background-color:var(--cream);color:var(--dark);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;overflow-x:hidden}a{color:var(--terracotta);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}.btn{cursor:pointer;text-align:center;border:none;border-radius:999px;justify-content:center;align-items:center;gap:.4rem;padding:.75rem 1.5rem;font-family:Inter,sans-serif;font-size:.9rem;font-weight:500;transition:transform .15s,box-shadow .2s,background .2s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--terracotta);color:#fff}.btn-primary:hover{box-shadow:var(--shadow);background:#c5674c}.btn-secondary{background:var(--warm-bg);color:var(--terracotta)}.btn-secondary:hover{background:var(--blush)}.btn-ghost{color:var(--soft-brown);background:0 0}.btn-ghost:hover{background:var(--warm-bg)}.btn-danger{color:var(--error);border:1px solid var(--error);background:0 0}.btn-danger:hover{background:var(--error);color:#fff}.btn-block{width:100%}.input,.textarea{width:100%;color:var(--dark);background:var(--cream);border:1.5px solid var(--blush);border-radius:12px;padding:.75rem 1rem;font-family:Inter,sans-serif;font-size:.95rem;transition:border .2s}.input:focus,.textarea:focus{border-color:var(--peach);outline:none}.textarea{resize:vertical;min-height:100px;font-family:Inter,sans-serif}.field{margin-bottom:1rem}.field label{color:var(--soft-brown);margin-bottom:.35rem;font-size:.8rem;font-weight:500;display:block}.display{color:var(--terracotta);padding-bottom:.1em;font-family:Dancing Script,cursive;font-weight:700;line-height:1.25}.serif{font-family:Playfair Display,serif;font-weight:600}.page{flex-direction:column;flex:1;display:flex}.page>.footer{margin-top:auto}.container{max-width:520px;margin:0 auto;padding:0 1.25rem}.topbar{z-index:10;-webkit-backdrop-filter:blur(12px);background:#fff8f0f5;border-bottom:1px solid #fadbd899;justify-content:space-between;align-items:center;gap:.75rem;min-height:72px;padding:1.25rem;display:flex;position:sticky;top:0;box-shadow:0 4px 16px #3d2c2c0d}.topbar-brand{min-width:0;color:var(--terracotta);align-items:center;gap:.65rem;text-decoration:none;display:flex}.topbar-brand:hover{text-decoration:none}.topbar-logo{color:var(--terracotta);flex-shrink:0;justify-content:center;align-items:center;display:flex}.topbar-title{color:var(--terracotta);white-space:nowrap;padding-bottom:.15em;font-family:Dancing Script,cursive;font-size:2rem;font-weight:700;line-height:1.4;overflow:visible}.topbar-nav{flex-shrink:0;align-items:center;gap:.35rem;display:flex}.topbar-link{color:var(--soft-brown);white-space:nowrap;border-radius:999px;padding:.5rem .9rem;font-family:Inter,sans-serif;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s}.topbar-link:hover{background:var(--warm-bg);color:var(--terracotta);text-decoration:none}.topbar-link-btn{cursor:pointer;background:0 0;border:none;font-family:Inter,sans-serif}@media (width<=600px){.topbar{gap:.5rem;min-height:60px;padding:.9rem 1rem}.topbar-title{font-size:1.25rem}.topbar-logo svg{width:32px;height:32px}.topbar-link{padding:.4rem .65rem;font-size:.78rem}}@media (width<=380px){.topbar-title{font-size:1.05rem}.topbar-logo svg{width:28px;height:28px}.topbar-link{padding:.35rem .5rem;font-size:.74rem}}.hero{text-align:center;background:linear-gradient(170deg, var(--warm-bg) 0%, var(--cream) 50%, var(--blush) 100%);flex-direction:column;justify-content:center;align-items:center;min-height:80svh;padding:2rem 1.5rem 3rem;display:flex}.hero-doodle{color:var(--terracotta);margin-bottom:1rem;animation:3s ease-in-out infinite float;display:inline-flex}.hero-animation{width:100%;max-width:360px;margin:0 auto .5rem}.hero-animation>div{width:100%!important;height:auto!important}@media (width>=720px){.hero-animation{max-width:440px}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.hero h1{margin-bottom:.5rem;padding-bottom:.1em;font-size:3rem;line-height:1.2}.hero-sub{color:var(--soft-brown);max-width:320px;margin:0 auto;font-family:Inter,sans-serif;font-size:.95rem;font-weight:400;line-height:1.6}.hero-dedication{color:var(--sage);letter-spacing:.04em;margin-top:1.25rem;font-size:.8rem;font-weight:300}.section-title{color:var(--terracotta);text-align:center;padding:3rem 1.5rem .1em;font-family:Dancing Script,cursive;font-size:2.6rem;font-weight:700;line-height:1.25}.section-sub{text-align:center;color:var(--soft-brown);max-width:380px;margin:0 auto;padding:0 1.5rem 1.75rem;font-size:.95rem;font-weight:400;line-height:1.6}@media (width>=720px){.section-title{font-size:3rem}.section-sub{max-width:420px;font-size:1rem}}.meal-grid{flex-direction:column;gap:1.25rem;padding:0 1.25rem;display:flex}.meal-card{background:var(--card-bg);box-shadow:var(--shadow);cursor:pointer;color:inherit;border-radius:16px;text-decoration:none;transition:transform .2s,box-shadow .2s;display:block;overflow:hidden}.meal-card:hover{box-shadow:var(--shadow-lg);text-decoration:none;transform:translateY(-2px)}.meal-card-photo{aspect-ratio:4/3;object-fit:cover;background:var(--warm-bg);width:100%}.meal-card-placeholder{aspect-ratio:4/3;background:linear-gradient(135deg, var(--warm-bg), var(--blush));justify-content:center;align-items:center;width:100%;font-size:3rem;display:flex}.meal-card-body{padding:1rem 1.25rem 1.25rem}.meal-card-name{margin-bottom:.3rem;font-family:Playfair Display,serif;font-size:1.15rem;font-weight:600}.meal-card-meta{color:var(--soft-brown);align-items:center;gap:.5rem;font-size:.8rem;display:flex}.meal-card-meta .dot{color:var(--blush)}.stars{align-items:center;gap:.15rem;display:inline-flex}.star{color:#e6d3c9;cursor:default;background:0 0;border:none;padding:0;font-size:1rem;line-height:1}.star.filled{color:var(--peach)}.stars-interactive .star{cursor:pointer;padding:.2rem;font-size:1.8rem;transition:transform .15s}.stars-interactive .star:hover{transform:scale(1.15)}.meal-photo-hero{object-fit:cover;object-position:center 75%;background:var(--warm-bg);width:100%;height:38svh;min-height:220px;max-height:420px;display:block}.meal-detail-body{max-width:520px;margin:0 auto;padding:1.5rem 1.25rem}.meal-detail-name{margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.8rem;font-weight:600}.meal-detail-rating{color:var(--soft-brown);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.85rem;display:flex}.meal-detail-meta{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.meal-meta-chip{background:var(--warm-bg);color:var(--terracotta);border-radius:999px;padding:.35rem .75rem;font-size:.78rem;font-weight:500}.meal-section{margin-bottom:1.75rem}.meal-section h3{color:var(--dark);align-items:center;gap:.4rem;margin-bottom:.6rem;font-family:Playfair Display,serif;font-size:1.05rem;font-weight:600;display:flex}.meal-section p,.meal-section li{color:var(--soft-brown);font-size:.92rem;line-height:1.7}.meal-section ul{padding-left:1.25rem}.meal-section ul li{margin-bottom:.3rem}.pre-wrap{white-space:pre-wrap}.review-form{background:var(--card-bg);box-shadow:var(--shadow);border-radius:16px;margin-bottom:1.5rem;padding:1.5rem 1.25rem}.review-form h3{text-align:center;margin-bottom:1rem;font-family:Playfair Display,serif;font-size:1.1rem;font-weight:600}.stars-label{text-align:center;color:var(--soft-brown);margin-bottom:.5rem;font-size:.85rem;display:block}.stars-wrap{justify-content:center;margin-bottom:1rem;display:flex}.comment-list{flex-direction:column;gap:.9rem;display:flex}.comment{background:var(--card-bg);box-shadow:var(--shadow);border-radius:14px;padding:1rem 1.15rem}.comment-head{justify-content:space-between;align-items:center;margin-bottom:.35rem;display:flex}.comment-name{color:var(--dark);font-size:.9rem;font-weight:600}.comment-date{color:var(--sage);font-size:.7rem}.comment-text{color:var(--soft-brown);white-space:pre-wrap;font-size:.88rem;line-height:1.6}.comment-stars{margin-bottom:.3rem}.no-content{text-align:center;color:var(--sage);padding:2rem 1rem;font-size:.9rem;font-style:italic}.form-msg{border-radius:10px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.85rem}.form-msg.error{color:var(--error);background:#fadede}.form-msg.success{color:#3d6d3d;background:#dcebd8}.loading{text-align:center;color:var(--sage);padding:3rem 1rem;font-family:Dancing Script,cursive;font-size:1.4rem}.admin-card{background:var(--card-bg);box-shadow:var(--shadow);border-radius:16px;margin-bottom:1rem;padding:1.25rem}.admin-meal-item{background:var(--card-bg);box-shadow:var(--shadow);border-radius:14px;align-items:center;gap:.85rem;margin-bottom:.75rem;padding:.85rem;display:flex}.admin-meal-thumb{object-fit:cover;background:var(--warm-bg);border-radius:10px;flex-shrink:0;width:60px;height:60px}.admin-meal-info{flex:1;min-width:0}.admin-meal-info .n{white-space:nowrap;text-overflow:ellipsis;margin-bottom:.15rem;font-family:Playfair Display,serif;font-size:.95rem;font-weight:600;overflow:hidden}.admin-meal-info .m{color:var(--sage);font-size:.75rem}.admin-meal-actions{gap:.4rem;display:flex}.admin-meal-actions .btn{padding:.5rem .85rem;font-size:.8rem}.photo-preview{aspect-ratio:4/3;object-fit:cover;background:var(--warm-bg);border-radius:12px;width:100%;margin-bottom:.75rem}.footer{text-align:center;background:linear-gradient(0deg, var(--blush), var(--cream));padding:2.5rem 1.5rem 3rem}.footer-heart{margin-bottom:.4rem;font-size:1.8rem}.footer-msg{color:var(--terracotta);padding-bottom:.1em;font-family:Dancing Script,cursive;font-size:1.2rem;line-height:1.4}.footer-note{color:var(--sage);margin-top:.6rem;font-size:.7rem;font-weight:300}.modal-bg{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;background:#3d2c2c66;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.modal{background:var(--cream);border-radius:20px 20px 0 0;width:100%;max-width:520px;max-height:92svh;padding:1.25rem 1.25rem 2rem;animation:.3s slide-up;overflow-y:auto;box-shadow:0 -4px 24px #3d2c2c26}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.modal-title{font-family:Playfair Display,serif;font-size:1.2rem;font-weight:600}.modal-close{color:var(--soft-brown);cursor:pointer;background:0 0;border:none;font-size:1.4rem;line-height:1}.scroll-hint{color:var(--peach);margin-top:1.5rem;font-size:1.4rem;animation:2s ease-in-out infinite bounce}@keyframes bounce{0%,to{opacity:.6;transform:translateY(0)}50%{opacity:1;transform:translateY(6px)}}@media (width>=720px){.hero h1{font-size:3.6rem}.hero-sub{max-width:380px;font-size:1rem}.meal-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem;max-width:720px;margin:0 auto;display:grid}.meal-detail-body{padding:2rem}.meal-detail-name{font-size:2.2rem}}
