@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200";:root{font-family:Pretendard,Noto Sans KR,Apple SD Gothic Neo,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#1f2431;background-color:#f7f8fb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}:root{--primary: #4cae4f;--background-light: #f6f7f6;--panel: #ffffff;--text-main: #0f172a;--text-sub: #64748b;--line: #e5e7eb}*{box-sizing:border-box}#root{min-height:100vh;font-family:Inter,sans-serif;color:var(--text-main)}.planner-page{min-height:100vh;display:flex;justify-content:center;padding:0;background:var(--background-light)}.planner-shell{width:min(375px,100vw);min-height:100vh;border-radius:0;overflow:hidden;background:var(--background-light);border:none;box-shadow:none;position:relative}.planner-header{display:flex;align-items:center;gap:10px;padding:16px;border-bottom:1px solid rgba(76,174,79,.14);background:#fff;position:sticky;top:0;z-index:5}.planner-header h1{margin:0;flex:1;text-align:center;font-size:.95rem;line-height:1.2;letter-spacing:-.01em;font-weight:700}.icon-btn{width:24px;height:24px;border:none;border-radius:999px;color:var(--primary);background:transparent;font-size:1rem;cursor:pointer}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:20px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased}.nav-fill{font-variation-settings:"FILL" 1}.planner-body{padding:0 16px 96px}.intro-block{display:flex;flex-direction:column;gap:8px;padding:24px 0 18px}.intro-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.intro-row h2{margin:0;font-size:2rem;letter-spacing:-.02em}.intro-block p{margin:0;color:var(--text-sub);font-size:.875rem}.goal-pill{background:#4cae4f1f;color:var(--primary);border:1px solid rgba(76,174,79,.15);border-radius:999px;font-size:.875rem;font-weight:700;padding:4px 12px;white-space:nowrap}.health-focus{margin-top:2px;border-radius:12px;border:1px solid rgba(76,174,79,.18);background:#4cae4f14;padding:12px;display:flex;align-items:flex-start;gap:8px}.focus-label{margin:0 0 3px;color:var(--primary);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.health-focus p{margin:0;color:#64748b;font-size:.75rem;line-height:1.4}.error-text{margin:10px 0 0;color:#be123c;font-size:.82rem;font-weight:700}.input-panel{margin-top:14px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px}.input-panel h3{margin:0 0 10px;font-size:.95rem}.dropzone{display:block;padding:12px;border-radius:10px;border:1.5px dashed #b2d4b3;background:#f8fcf8}.dropzone.drag-over{border-color:var(--primary);background:#eff8ef}.drop-main{margin:0;font-size:.82rem;font-weight:600}.drop-sub{margin:4px 0 8px;font-size:.76rem;color:var(--text-sub)}.file-name{margin:8px 0 0;font-size:.74rem;color:var(--text-sub)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.grid-inputs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:10px}label{display:block;font-size:.75rem;font-weight:600;color:#334155}input,textarea{width:100%;margin-top:5px;border:1px solid #d1d5db;border-radius:9px;padding:8px 9px;font-size:.8rem;background:#fff}textarea{resize:vertical;min-height:70px}input:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4cae4f26}.address-field{margin-top:10px}.inline-field-label{margin:0 0 7px;font-size:.75rem;font-weight:700}.cuisine-list,.family-history-list{display:flex;flex-wrap:wrap;gap:6px}.meal-preference-block{margin-top:8px}.meal-preference-block h4{margin:0 0 6px;font-size:.72rem;letter-spacing:.06em;color:#64748b}.chip-btn{border:1px solid #d1d5db;border-radius:999px;padding:6px 9px;font-size:.74rem;font-weight:700;background:#f8fafc;color:#1f2937;cursor:pointer}.chip-btn.active{border-color:#4cae4f8c;color:var(--primary);background:#4cae4f1a}.meal-cards{margin-top:24px;display:flex;flex-direction:column;gap:24px}.meal-card{border-radius:12px;background:var(--panel);border:1px solid rgba(76,174,79,.08);box-shadow:0 4px 12px #0f172a0f;overflow:hidden}.meal-image-wrap{width:100%;height:192px;background:#dde5de}.meal-image{width:100%;height:100%;object-fit:cover;display:block}.meal-content{padding:16px;display:flex;flex-direction:column;gap:12px}.meal-badge-row{display:flex;flex-wrap:wrap;gap:6px}.meal-badge{border-radius:999px;padding:3px 7px;font-size:.56rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:#2f8a3d;background:#e8f7e9}.meal-badge-strong{background:#4cae4f24}.meal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.meal-kind{margin:0;color:var(--primary);font-size:.5rem;font-weight:700;letter-spacing:.08em}.meal-head h3{margin:2px 0 0;font-size:1.02rem;line-height:1.24;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.meal-kcal{font-size:.875rem;font-weight:600;color:#475569}.macro-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding-top:8px;border-top:1px solid #edf1ee}.macro-grid span{display:block;font-size:.625rem;color:#94a3b8;letter-spacing:.08em}.macro-grid strong{display:block;margin-top:1px;font-size:.875rem;color:#1e293b}.macro-grid strong.green{color:var(--primary)}.restaurant-preview-note{margin:0;color:var(--primary);font-size:.75rem;font-weight:700}.meal-detail{border-top:1px solid #edf1ee;padding-top:8px}.meal-detail ul{margin:0;padding-left:18px}.meal-detail li{font-size:.78rem;color:#334155}.meal-detail p{margin:6px 0 0;font-size:.74rem;color:#64748b}.restaurant-list{margin-top:8px;border-radius:9px;border:1px solid #e5e7eb;background:#fafafa;padding:8px}.restaurant-list h4{margin:0 0 6px;font-size:.72rem}.restaurant-item p{margin:2px 0;font-size:.72rem}.detail-btn{width:100%;border:none;border-radius:8px;padding:8px 10px;background:#4cae4f1f;color:var(--primary);font-size:.875rem;font-weight:700;cursor:pointer}.pro-tip{margin-top:16px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;padding:12px}.pro-tip-head{display:flex;align-items:center;gap:6px}.pro-tip-head h4{margin:0;font-size:.875rem;font-weight:700}.pro-tip p{margin:6px 0 0;color:#64748b;font-size:.75rem;line-height:1.4}.action-grid{margin-top:24px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.secondary-btn,.primary-btn{border-radius:9px;padding:16px 12px;font-size:.875rem;font-weight:700;cursor:pointer}.secondary-btn{border:1px solid #d1d5db;background:#fff;color:#334155}.primary-btn{border:none;background:var(--primary);color:#fff;box-shadow:0 8px 18px #4cae4f47}.primary-btn:disabled,.secondary-btn:disabled{opacity:.65;cursor:not-allowed}.bottom-nav{position:absolute;left:0;right:0;bottom:0;display:flex;justify-content:space-around;background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid #e5e7eb;padding:8px 16px 24px}.nav-item{text-decoration:none;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:56px}.nav-item span{font-size:20px;line-height:1}.nav-item p{margin:0;font-size:10px;font-weight:600}.nav-item.muted{color:#9ca3af}.nav-item.active{color:var(--primary)}@media(max-width:980px){.grid-inputs{grid-template-columns:1fr}}
