:root{--he-bg: #FAF8F3;--he-sage: #5C7A52;--he-sage-light: #7A9E6E;--he-sage-faint: #EAF0E4;--he-gold: #B8944F;--he-gold-light: #D4B878;--he-charcoal: #2A2118;--he-gray: #5E5244;--he-light-gray: #9C8E7E;--he-border: #E0D8CC;--he-card-bg: #FFFDF9;--he-warm-cream: #F5F0E6;--he-rosemary: #4A6741;--he-wood: #6E4F2D;--he-wood-light: #8B6D4A}body{font-family:Inter,system-ui,sans-serif;background:var(--he-bg);color:var(--he-charcoal);margin:0}.he-hero{position:relative;width:100%;max-width:720px;margin:0 auto;height:220px;overflow:hidden;border-radius:1rem}@media(min-width:480px){.he-hero{height:280px}}@media(min-width:768px){.he-hero{height:320px}}.he-hero img{width:100%;height:100%;object-fit:cover;object-position:center 60%;display:block;image-rendering:auto}.he-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#2a21180f,#2a211805 40%,#faf8f380 78%,#faf8f3);pointer-events:none}.he-hero-tagline{position:absolute;bottom:1.25rem;left:0;right:0;text-align:center;font-family:Space Grotesk,sans-serif;font-size:1.1rem;font-weight:700;color:var(--he-rosemary);letter-spacing:.02em;pointer-events:none}@media(min-width:480px){.he-hero-tagline{font-size:1.25rem;bottom:1.5rem}}@keyframes heFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes heFadeOut{0%{opacity:1}to{opacity:0;transform:translateY(-6px)}}@keyframes heSpin{to{transform:rotate(360deg)}}.he-page{min-height:100vh;display:flex;flex-direction:column}.he-header{padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1rem}.he-back{display:inline-flex;align-items:center;gap:.35rem;color:var(--he-light-gray);text-decoration:none;font-size:.875rem;font-weight:500;transition:color .15s}.he-back:hover{color:var(--he-charcoal)}.he-back svg{width:16px;height:16px}.he-brand{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:1.15rem;color:var(--he-rosemary);display:flex;align-items:center;gap:.45rem}.he-brand-leaf{color:var(--he-sage-light);font-size:1.1em}.he-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem 1.5rem 3rem}.he-app{width:100%;max-width:480px;animation:heFadeIn .3s ease-out}.he-quiz{text-align:center}.he-quiz-intro-title{font-family:Space Grotesk,sans-serif;font-size:1.35rem;font-weight:700;color:var(--he-charcoal);margin:0 0 .3rem}.he-quiz-intro-sub{font-size:.85rem;color:var(--he-light-gray);margin:0 0 1.75rem}.he-progress-track{height:4px;background:var(--he-border);border-radius:2px;overflow:hidden;margin-bottom:.75rem}.he-progress-fill{height:100%;background:var(--he-sage);border-radius:2px;transition:width .3s ease}.he-progress-label{font-size:.8rem;color:var(--he-light-gray);margin:0 0 2rem}.he-quiz-cards{display:flex;flex-direction:column;gap:.75rem;align-items:center}@media(min-width:480px){.he-quiz-cards{flex-direction:row;gap:1rem}}.he-fade-in{animation:heFadeIn .25s ease-out}.he-fade-out{animation:heFadeOut .2s ease-out}.he-quiz-card{flex:1;width:100%;background:var(--he-card-bg);border:2px solid var(--he-border);border-radius:16px;padding:1.25rem 1rem;cursor:pointer;transition:all .15s ease;display:flex;flex-direction:column;align-items:center;gap:.35rem;font-family:inherit}.he-quiz-card:hover{border-color:var(--he-sage);background:var(--he-sage-faint);transform:translateY(-2px);box-shadow:0 4px 12px #4a67411f}.he-quiz-card:active{transform:translateY(0)}.he-quiz-card-emoji{font-size:2.2rem;line-height:1;margin-bottom:.15rem}.he-quiz-card-label{font-weight:600;font-size:.95rem;color:var(--he-charcoal);line-height:1.35;text-wrap:balance}.he-quiz-card-sub{font-size:.78rem;color:var(--he-light-gray)}.he-quiz-or{font-size:.8rem;color:var(--he-light-gray);font-weight:500;text-transform:lowercase}.he-constraints{animation:heFadeIn .3s ease-out}.he-section-title{font-family:Space Grotesk,sans-serif;font-size:1.35rem;font-weight:700;margin:0 0 .25rem;color:var(--he-charcoal)}.he-section-sub{font-size:.85rem;color:var(--he-light-gray);margin:0 0 1.5rem}.he-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.he-chip{padding:.5rem 1rem;border-radius:999px;border:1.5px solid var(--he-border);background:var(--he-card-bg);font-size:.85rem;font-weight:500;color:var(--he-gray);cursor:pointer;transition:all .15s;font-family:inherit}.he-chip:hover{border-color:var(--he-sage-light);color:var(--he-sage)}.he-chip-active{background:var(--he-sage);border-color:var(--he-sage);color:#fff}.he-chip-active:hover{background:var(--he-sage-light);border-color:var(--he-sage-light);color:#fff}.he-field-label{display:block;font-size:.8rem;font-weight:600;color:var(--he-gray);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.04em}.he-input{width:100%;padding:.65rem .9rem;border:1.5px solid var(--he-border);border-radius:10px;font-size:.9rem;font-family:inherit;color:var(--he-charcoal);background:var(--he-card-bg);transition:border-color .15s;box-sizing:border-box}.he-input:focus{outline:none;border-color:var(--he-sage);box-shadow:0 0 0 3px #5c7a521f}.he-input::placeholder{color:var(--he-light-gray)}.he-input-lg{padding:.85rem 1rem;font-size:1.05rem}.he-meal-size{margin:1.5rem 0}.he-toggle-group{display:flex;gap:0;margin-top:.4rem;border-radius:10px;overflow:hidden;border:1.5px solid var(--he-border)}.he-toggle{flex:1;padding:.55rem 1rem;font-size:.85rem;font-weight:500;border:none;background:var(--he-card-bg);color:var(--he-gray);cursor:pointer;transition:all .15s;font-family:inherit}.he-toggle:first-child{border-right:1.5px solid var(--he-border)}.he-toggle-active{background:var(--he-sage);color:#fff}.he-btn-primary{display:inline-block;padding:.75rem 2rem;border:none;border-radius:12px;background:var(--he-sage);color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s;margin-top:1.5rem;font-family:inherit}.he-btn-primary:hover{background:var(--he-sage-light)}.he-btn-primary:active{transform:scale(.98)}.he-btn-primary:disabled{opacity:.4;cursor:not-allowed}.he-btn-secondary{display:inline-block;padding:.65rem 1.5rem;border:1.5px solid var(--he-border);border-radius:12px;background:var(--he-card-bg);color:var(--he-gray);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}.he-btn-secondary:hover{border-color:var(--he-sage-light);color:var(--he-sage)}.he-link-btn{display:block;margin-top:2rem;padding:0;border:none;background:none;color:var(--he-light-gray);font-size:.8rem;cursor:pointer;text-decoration:underline;text-underline-offset:2px;font-family:inherit}.he-link-btn:hover{color:var(--he-sage)}.he-search{text-align:center;animation:heFadeIn .3s ease-out}.he-search-form{display:flex;flex-direction:column;gap:.75rem;margin-top:1.25rem}.he-recent{margin-top:1.5rem;text-align:left}.he-recent-label{font-size:.75rem;font-weight:600;color:var(--he-light-gray);text-transform:uppercase;letter-spacing:.04em}.he-recent-list{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.he-recent-item{padding:.35rem .8rem;border-radius:999px;border:1px solid var(--he-border);background:var(--he-card-bg);font-size:.8rem;color:var(--he-gray);cursor:pointer;transition:all .15s;font-family:inherit}.he-recent-item:hover{border-color:var(--he-sage-light);color:var(--he-sage)}.he-loading{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:3rem 0;animation:heFadeIn .3s ease-out}.he-spinner{width:36px;height:36px;border:3px solid var(--he-border);border-top-color:var(--he-sage);border-radius:50%;animation:heSpin .7s linear infinite}.he-loading-text{font-size:.9rem;color:var(--he-gray)}.he-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;border-radius:10px;padding:.65rem 1rem;font-size:.85rem;margin-bottom:1rem}.he-result{animation:heFadeIn .35s ease-out}.he-result-note{font-size:.8rem;color:var(--he-light-gray);font-style:italic;margin:0 0 .75rem}.he-result-card{background:var(--he-card-bg);border:1px solid var(--he-border);border-left:4px solid var(--he-rosemary);border-radius:14px;padding:1.5rem;box-shadow:0 2px 8px #2a21180f}.he-result-heading{font-family:Space Grotesk,sans-serif;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--he-sage);margin:0 0 .5rem}.he-result-order{font-size:1.1rem;font-weight:600;line-height:1.45;color:var(--he-charcoal);margin:0}.he-result-section{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--he-border)}.he-result-subhead{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--he-light-gray);margin:0 0 .4rem}.he-result-list{margin:0;padding-left:1.1rem;font-size:.9rem;line-height:1.6;color:var(--he-gray)}.he-result-list li{margin-bottom:.15rem}.he-picker{text-align:center;animation:heFadeIn .35s ease-out}.he-picker-title{font-family:Space Grotesk,sans-serif;font-size:1.2rem;font-weight:700;color:var(--he-charcoal);margin:0 0 .25rem}.he-picker-sub{font-size:.85rem;color:var(--he-light-gray);margin:0 0 1.5rem}.he-picker-cards{display:flex;flex-direction:column;gap:.75rem;align-items:center}@media(min-width:480px){.he-picker-cards{flex-direction:row;gap:1rem;align-items:stretch}}.he-picker-card{flex:1;width:100%;background:var(--he-card-bg);border:2px solid var(--he-border);border-radius:16px;padding:1.25rem 1.1rem;cursor:pointer;transition:all .15s ease;text-align:left;display:flex;flex-direction:column;gap:.5rem;font-family:inherit}.he-picker-card:hover{border-color:var(--he-sage);background:var(--he-sage-faint);transform:translateY(-2px);box-shadow:0 4px 12px #4a67411f}.he-picker-card:active{transform:translateY(0)}.he-picker-order{font-size:.95rem;font-weight:600;line-height:1.4;color:var(--he-charcoal);margin:0}.he-picker-why{font-size:.8rem;color:var(--he-light-gray);margin:0;line-height:1.4}.he-picker-or{font-size:.8rem;color:var(--he-light-gray);font-weight:500}.he-picker-photo,.he-result-photo{width:100%;border-radius:8px;overflow:hidden;aspect-ratio:16 / 10;background:var(--he-card-bg)}.he-picker-photo img,.he-result-photo img{width:100%;height:100%;object-fit:cover;display:block}.he-result-photo{margin-bottom:1rem;border-radius:10px}.he-actions{display:flex;gap:.75rem;margin-top:1.25rem;justify-content:center;flex-wrap:wrap}.he-actions .he-btn-primary{margin-top:0}
