/* ===== 우리집 식단표 - 모바일 우선 스타일 ===== */
:root{
  --green:#2f9e6e; --green-dark:#258159; --bg:#f6f7f5; --card:#fff;
  --text:#222; --muted:#8a8f8c; --line:#e6e8e5; --danger:#e05656; --accent:#f5a623;
  --radius:14px; --tab-h:64px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Apple SD Gothic Neo","Noto Sans KR",sans-serif;
  background:var(--bg);color:var(--text);line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
.hidden{display:none!important}
.muted{color:var(--muted);font-size:.9rem}
.err{color:var(--danger);font-size:.85rem;min-height:1.2em;margin-top:.5rem}

/* 버튼 */
button{font-family:inherit;cursor:pointer}
.btn-primary{
  background:var(--green);color:#fff;border:none;border-radius:var(--radius);
  padding:.95rem 1.2rem;font-size:1rem;font-weight:600;width:100%;min-height:48px;
}
.btn-primary:active{background:var(--green-dark)}
.btn-ghost{
  background:#fff;color:var(--green);border:1.5px solid var(--green);
  border-radius:10px;padding:.5rem .8rem;font-size:.85rem;font-weight:600;min-height:40px;
}

/* 로그인 */
.login-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem}
.login-box{background:var(--card);border-radius:20px;padding:2.2rem 1.6rem;width:100%;max-width:360px;text-align:center;box-shadow:0 8px 30px rgba(0,0,0,.06)}
.login-box .logo{font-size:3rem}
.login-box h1{font-size:1.4rem;margin:.4rem 0}
.login-box input{
  width:100%;margin:1.2rem 0 .8rem;padding:.9rem;font-size:1.3rem;text-align:center;letter-spacing:.4em;
  border:1.5px solid var(--line);border-radius:12px;
}
.login-box input:focus{outline:none;border-color:var(--green)}

/* 상단바 */
.topbar{
  position:sticky;top:0;z-index:10;background:var(--green);color:#fff;
  padding:max(.9rem,env(safe-area-inset-top)) 1.1rem .9rem;
}
.topbar h1{font-size:1.2rem;font-weight:700}

/* 본문 */
.view{padding:1rem 1rem calc(var(--tab-h) + env(safe-area-inset-bottom) + 1rem)}

/* 식단표 카드 */
.fab-row{display:flex;gap:.6rem;margin-bottom:1rem}
.day-card{
  background:var(--card);border-radius:var(--radius);padding:.9rem 1rem;margin-bottom:.7rem;
  box-shadow:0 1px 4px rgba(0,0,0,.04);display:flex;align-items:center;gap:.8rem;
}
.day-badge{
  flex:0 0 auto;width:44px;height:44px;border-radius:12px;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;
}
.day-badge .dow{font-size:1rem}
.day-badge.theme-특식{background:#fde9cf;color:#a25e09}
.day-badge.theme-냉파{background:#dceee4;color:var(--green-dark)}
.day-badge.theme-가벼움{background:#e6f0fb;color:#2b6cb0}
.day-info{flex:1;min-width:0}
.day-info .dish{font-size:1.05rem;font-weight:600}
.day-info .meta{font-size:.8rem;color:var(--muted)}
.refresh-btn{
  flex:0 0 auto;width:44px;height:44px;border-radius:50%;border:none;background:var(--bg);
  font-size:1.2rem;display:flex;align-items:center;justify-content:center;
}
.refresh-btn:active{transform:rotate(180deg);transition:transform .3s}

/* 가족 카드 */
.member-card{
  background:var(--card);border-radius:var(--radius);padding:1rem;margin-bottom:.7rem;
  display:flex;align-items:center;gap:.9rem;box-shadow:0 1px 4px rgba(0,0,0,.04);
}
.avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;background:var(--bg)}
.member-card .info{flex:1}
.member-card .name{font-weight:600}
.cook-badge{display:inline-block;font-size:.72rem;background:var(--accent);color:#fff;border-radius:6px;padding:.1rem .4rem;margin-left:.35rem;vertical-align:middle}
.del-btn{background:none;border:none;color:var(--muted);font-size:1.3rem;padding:.3rem}

/* 폼 */
.form-card{background:var(--card);border-radius:var(--radius);padding:1.1rem;margin-bottom:1rem;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.form-card h3{font-size:1rem;margin-bottom:.8rem}
.field{margin-bottom:.75rem}
.field label{display:block;font-size:.82rem;color:var(--muted);margin-bottom:.3rem}
.field input,.field select{
  width:100%;padding:.7rem;font-size:1rem;border:1.5px solid var(--line);border-radius:10px;background:#fff;
}
.field input:focus,.field select:focus{outline:none;border-color:var(--green)}
.row{display:flex;gap:.6rem}
.row .field{flex:1}
.check-row{display:flex;align-items:center;gap:.5rem;font-size:.9rem}
.check-row input{width:auto}

/* 건강 사항 배지 / 경고 */
.health-badge{display:inline-block;font-size:.7rem;background:#e6f0fb;color:#2b6cb0;border-radius:6px;padding:.1rem .4rem;margin-left:.25rem;vertical-align:middle}
.warn-badge{display:inline-block;font-size:.72rem;background:#fbe0e0;color:var(--danger);border-radius:6px;padding:.1rem .4rem;margin-left:.4rem;vertical-align:middle;font-weight:600}
.chk-group{display:flex;gap:1rem;flex-wrap:wrap;padding-top:.2rem}
.chk-group .check-row{font-size:.9rem}
.disclaimer{font-size:.78rem;color:var(--muted);background:#fff7e6;border:1px solid #f0e0c0;border-radius:10px;padding:.6rem .8rem;margin:0 0 1rem;line-height:1.45}

/* 레시피 링크 */
.recipe-link{display:inline-block;font-size:.78rem;color:var(--green);text-decoration:none;margin-top:.3rem;font-weight:600}
.recipe-link:active{opacity:.6}
.recipe-edit{background:none;border:none;font-size:.85rem;padding:.1rem .3rem;margin-left:.3rem;opacity:.5}

/* 영양 리포트 */
.report-card{background:var(--card);border-radius:var(--radius);padding:1.1rem;margin-bottom:1rem;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.score-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.9rem}
.score-row .score{font-size:1.5rem;color:var(--green)}
.nbar-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem}
.nbar-label{flex:0 0 56px;font-size:.82rem}
.nbar-track{position:relative;flex:1;height:14px;background:var(--bg);border-radius:7px;overflow:visible}
.nbar-fill{height:100%;border-radius:7px;transition:width .4s}
.nbar-fill.ok{background:var(--green)}
.nbar-fill.off{background:var(--accent)}
.nbar-target{position:absolute;top:-3px;width:2px;height:20px;background:#444;transform:translateX(-1px)}
.nbar-val{flex:0 0 36px;text-align:right;font-size:.8rem;color:var(--muted)}
.nbar-legend{font-size:.72rem;margin:.4rem 0 .8rem}
.sugg-list{margin:0;padding-left:1.1rem;font-size:.88rem}
.sugg-list li{margin-bottom:.3rem}

/* 유통기한 뱃지 */
.exp-badge{display:inline-block;font-size:.7rem;border-radius:6px;padding:.1rem .4rem;margin-left:.2rem;background:var(--bg);color:var(--muted);vertical-align:middle}
.exp-badge.warn{background:#fdeecf;color:#a25e09}
.exp-badge.danger{background:#fbe0e0;color:var(--danger)}

/* 장보기 아이템 (마트 모드 - 큰 터치영역) */
.shop-item{
  display:flex;align-items:center;gap:.8rem;background:var(--card);border-radius:var(--radius);
  padding:1rem;margin-bottom:.6rem;box-shadow:0 1px 4px rgba(0,0,0,.04);min-height:56px;cursor:pointer;
}
.shop-item input{width:24px;height:24px;flex:0 0 auto;accent-color:var(--green)}
.shop-item .shop-name{flex:1;font-size:1.05rem;font-weight:600}
.shop-item .shop-qty{color:var(--muted);font-size:.9rem}
.shop-item.checked{opacity:.5}
.shop-item.checked .shop-name{text-decoration:line-through}

/* 안내/빈 상태 */
.empty{text-align:center;color:var(--muted);padding:3rem 1rem}
.empty .big{font-size:2.5rem;display:block;margin-bottom:.5rem}

/* 하단 탭바 */
.tabbar{
  position:fixed;bottom:0;left:0;right:0;height:calc(var(--tab-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);
  background:#fff;border-top:1px solid var(--line);display:flex;z-index:20;
}
.tab{
  flex:1;border:none;background:none;color:var(--muted);font-size:.72rem;font-weight:600;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;min-height:44px;
}
.tab span{font-size:1.3rem}
.tab.active{color:var(--green)}

/* 토스트 */
.toast{
  position:fixed;left:50%;bottom:calc(var(--tab-h) + 1rem);transform:translateX(-50%);
  background:#333;color:#fff;padding:.7rem 1.1rem;border-radius:24px;font-size:.85rem;z-index:50;
  opacity:0;transition:opacity .25s;pointer-events:none;
}
.toast.show{opacity:1}

/* ===== 데스크톱 확장 (모바일 우선 → 768px↑) ===== */
@media (min-width:768px){
  body{max-width:760px;margin:0 auto;box-shadow:0 0 40px rgba(0,0,0,.05)}
  .view{padding:1.4rem 1.6rem 6rem}
  .plan-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
  .plan-grid .day-card{margin-bottom:0}
  .tabbar,.topbar{max-width:760px;margin:0 auto}
  .topbar{border-radius:0}
}
