/* =====================================================================
   우리집 초록친구 — 전역 스타일 (styles/styles.css)
   - 디자인 토큰(:root 변수)만 참조, 하드코딩 금지
   - 본문 18px+, 제목 24~32px, 버튼 48px+, 선택카드 96px+, 대비 4.5:1+
   - Pretendard → Noto Sans KR 폴백, 모바일 우선 반응형
   - :hover 와 :focus-visible 동일 처리(호버 의존 금지)
   - prefers-reduced-motion 존중, 전환 200ms 이내
   ===================================================================== */

/* ---------------------------------------------------------------------
   옛 변수 → 새 토큰(tokens.css) 별칭 매핑
   - tokens.css 가 단일 출처. 여기서는 기존 규칙이 깨지지 않도록
     옛 이름(--color-*, --font-* 등)을 새 토큰에 연결만 한다.
   - 수치는 tokens.css 값을 그대로 따른다(임의 변경 금지).
   - 단, '시니어 안전 글래스모피즘' 규격에 맞춰 모서리/그림자/유리 등은
     아래 컴포넌트 규칙에서 새 규격으로 적용한다.
   --------------------------------------------------------------------- */
:root {
  /* 폰트: tokens.css --font 사용(Light/Thin 금지, 본문 weight 500) */
  --font-sans: var(--font, "Pretendard", "Pretendard Variable",
    "Noto Sans KR", -apple-system, BlinkMacSystemFont,
    "Apple SD Gothic Neo", "Malgun Gothic", sans-serif);

  /* 글자 크기 → 새 토큰 매핑 (본문 18px 미만 금지) */
  --font-base: var(--fs-body);     /* 18px */
  --font-caption: var(--fs-body);  /* 보조 텍스트도 18px 유지 */
  --font-h3: var(--fs-h3);         /* 20px */
  --font-h2: var(--fs-h2);         /* 24px */
  --font-h1: var(--fs-h1);         /* 32px */
  --font-lead: var(--fs-lead);     /* 20px */
  --line-height: var(--lh);        /* 1.7 */

  /* 색 → 새 토큰 매핑 */
  --color-text: var(--ink);            /* 본문 잉크 #1A1A1A */
  --color-text-sub: var(--ink-sub);    /* 보조 글씨 #4A4A4A */
  --color-bg: var(--beige);            /* 베이지 배경 */
  --color-surface: var(--card);        /* 카드 불투명 흰 */
  --color-primary: var(--green-600);   /* 메인 초록 */
  --color-primary-dark: var(--green-700);   /* 초록 hover/focus/강조 */
  --color-primary-darker: var(--green-700); /* 초록 active */
  --color-on-primary: var(--on-green);
  --color-secondary: var(--earth);     /* 흙색 보조 */
  --color-on-secondary: var(--on-green);
  --color-soft: var(--green-100);      /* 연초록: 선택 배경/장식 전용 */
  --color-point: var(--earth);
  --color-warning-text: #B3261E;       /* 경고 텍스트(토큰 외 고대비 빨강 유지) */
  --color-border: var(--line);         /* 카드 구분 테두리 */
  --color-choice-border: var(--green-600); /* 선택 카드 강조 테두리 */
  --color-disabled-bg: #D7D2C4;        /* 비활성 배경 */
  --color-disabled-text: #5A564B;      /* 비활성 텍스트 (대비 3:1+) */

  /* 터치 타깃 → 새 토큰 (--tap-min 은 tokens.css 의 48px 를 그대로 상속) */
  --tap-primary: var(--btn-min-h);     /* 56px */
  --tap-card: var(--choice-min-h);     /* 96px */
  --gap-min: 12px;                     /* 버튼 간 최소 간격 12px */

  /* 간격: 기존 styles.css 규칙이 쓰는 옛 이름(--space-1..4) 유지.
     tokens.css 의 --space-1..6 과 이름이 겹치므로, 순환 참조를 피하려고
     중립 별칭(--sp-*)으로 새로 정의한다. 이 사이트 본문 스케일은 12/16/24/32 로
     tokens.css 의 --space-2..5(12/16/24/32)와 한 단계씩 대응한다.
     특히 --space-4(=32px)는 tokens.css 의 --space-5(32px)와 같은 값이며,
     tokens.css 의 --space-4(24px) 값은 이 본문 스케일에선 --space-3 로 쓰인다.
     수치 출처는 tokens.css(8/12/16/24/32/48), 여기선 그 값을 그대로 인용만 한다. */
  --sp-1: 12px;   /* = tokens --space-2 */
  --sp-2: 16px;   /* = tokens --space-3 */
  --sp-3: 24px;   /* = tokens --space-4 */
  --sp-4: 32px;   /* = tokens --space-5 */
  --space-1: var(--sp-1);
  --space-2: var(--sp-2);
  --space-3: var(--sp-3);
  --space-4: var(--sp-4);

  /* 모서리 → 새 토큰 (그림자/유리/pill 은 tokens.css 변수를 직접 사용) */
  --radius: var(--radius-card);        /* 카드 24px */
  --radius-button: var(--radius-btn);  /* 버튼 16px */
  --focus-width: 3px;

  /* 레이아웃 */
  --content-max: 480px;
  --base-width: 360px;
  --bottomnav-h: 72px;    /* 하단 고정 네비 높이 */
}

/* ---------------------------------------------------------------------
   리셋·기본
   --------------------------------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

* {
  transition-duration: 200ms;   /* 화면 전환 200ms 이내, 급격한 점프 금지 */
}

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--font-base);
  font-weight: var(--weight-body);   /* 500 — Light/Thin 금지 */
  line-height: var(--line-height);
  letter-spacing: 0.01em;
  color: var(--color-text);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
}

img {
  max-width: 100%;
}

a {
  color: var(--color-primary-dark);   /* 크림 위 대비 여유 확보(약 6:1) */
}

/* 사용자가 모션 최소화를 켜면 모든 애니메이션·전환 제거 */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
  /* :active 등 눌림 이동(transform)도 제거해 화면 점프 방지 */
  *:active,
  .btn-primary:active,
  .btn:active,
  .choice-card:active,
  .bottomnav__btn:active,
  .related-plants a:active {
    transform: none !important;
  }
}

/* 공통 포커스 링: 키보드 접근성 (Tab 이동 시 또렷하게) */
:focus-visible {
  outline: var(--focus-width) solid var(--color-primary);
  outline-offset: 2px;
}

/* 화면낭독 전용 텍스트 */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* 본문 바로가기(skip link) */
.skip-link {
  position: absolute;
  left: var(--space-2);
  top: -200px;
  z-index: 200;
  padding: var(--space-1) var(--space-3);
  min-height: var(--tap-min);
  display: inline-flex;
  align-items: center;
  font-size: var(--font-base);
  font-weight: 700;
  color: var(--color-on-primary);
  background: var(--color-primary);
  border-radius: var(--radius);
  text-decoration: none;
}
.skip-link:focus {
  top: var(--space-2);
}

/* ---------------------------------------------------------------------
   레이아웃 컨테이너 (모바일 우선 1열)
   --------------------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--space-2);
}

/* 하단 고정 네비가 본문을 가리지 않도록 여백 확보(필요한 페이지에서 클래스 부여) */
.has-bottomnav {
  padding-bottom: calc(var(--bottomnav-h) + var(--space-4));
}

/* ---------------------------------------------------------------------
   헤더 / 푸터 (사이트 공통)
   --------------------------------------------------------------------- */
/* 헤더 띠 — 유리 효과 허용(장식 영역). 로고/링크 글씨는 진한 색으로 대비 4.5:1+ 유지.
   가독을 위해 유리 불투명도를 0.82로 상향한 띠 위에 글씨를 얹는다. */
.site-header {
  position: sticky;
  top: 0;
  z-index: 90;
  background: rgba(255, 255, 255, 0.82);
  -webkit-backdrop-filter: var(--glass-blur);
  backdrop-filter: var(--glass-blur);
  border-bottom: 1px solid var(--line);
}
/* 블러 미지원 브라우저: 불투명 흰색으로 폴백 → 글씨 대비 보장 */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .site-header { background: var(--card); }
}
.site-header__inner {
  width: 100%;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--space-1) var(--space-2);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}
.site-header__logo {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: var(--tap-min);
  font-size: var(--font-h3);
  font-weight: 700;
  color: var(--color-primary-dark);   /* green-700: 유리 띠 위 대비 강화 */
  text-decoration: none;
}
.site-header__logo img { width: 32px; height: 32px; }

.site-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.site-nav a {
  display: inline-flex;
  align-items: center;
  min-height: var(--tap-min);
  padding: 0 var(--space-1);
  font-size: var(--font-caption);
  font-weight: 700;
  color: var(--color-text);   /* 잉크: 유리 띠 위 대비 4.5:1+ 확보 */
  text-decoration: none;
  border-radius: var(--radius-button);
}
.site-nav a:hover,
.site-nav a:focus-visible {
  text-decoration: underline;
  text-underline-offset: 4px;
}

.site-footer {
  margin-top: var(--space-4);
  background: var(--color-surface);
  border-top: 2px solid var(--color-soft);
}
.site-footer__inner {
  width: 100%;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--space-3) var(--space-2);
}
.site-footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap-min);
  list-style: none;
  margin: 0 0 var(--space-2);
  padding: 0;
}
.site-footer__links a {
  display: inline-flex;
  align-items: center;
  min-height: var(--tap-min);
  padding: 0 var(--space-1);
  font-size: var(--font-base);
  font-weight: 600;
  color: var(--color-secondary);
  text-decoration: none;
}
.site-footer__links a:hover,
.site-footer__links a:focus-visible {
  text-decoration: underline;
  text-underline-offset: 4px;
}
.site-footer__note {
  margin: 0;
  font-size: var(--font-caption);
  color: var(--color-text);
}

/* ---------------------------------------------------------------------
   타이포 (페이지 본문)
   --------------------------------------------------------------------- */
h1 { font-size: var(--font-h1); font-weight: 700; line-height: 1.3; margin: 0 0 var(--space-2); }
h2 { font-size: var(--font-h2); font-weight: 700; line-height: 1.4; margin: var(--space-4) 0 var(--space-2); }
h3 { font-size: var(--font-h3); font-weight: 600; line-height: 1.5; margin: var(--space-3) 0 var(--space-1); }
p  { margin: 0 0 var(--space-2); }
li { margin: 0 0 8px; }

.lead {
  font-size: var(--font-lead);   /* 20px */
  font-weight: var(--weight-body);
  color: var(--color-text);
}

.section {
  margin: var(--space-4) 0;
}

/* ---------------------------------------------------------------------
   범용 텍스트 카드 .card — 불투명 흰 카드 + 고대비 (반투명/블러 금지)
   --------------------------------------------------------------------- */
.card {
  background: var(--card);
  border-radius: var(--radius-card);
  padding: var(--pad-card);
  box-shadow: var(--shadow-card);
  color: var(--color-text);
}

/* 페이지 본문 컨테이너로 쓰인 .prose 는 '불투명 흰 카드' 위에 글씨를 둔다.
   (소개·정책·문의·사진출처·식물 상세 본문) — 베이지 위 반투명 글씨 금지 원칙. */
.container.prose {
  background: var(--card);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: var(--pad-card);
  margin-top: var(--space-2);
  margin-bottom: var(--space-2);
}

/* 콘텐츠(소개·정책·문의) 본문 가독성 */
.prose p,
.prose li {
  font-size: var(--font-base);
  line-height: var(--line-height);
}
.prose h2 { color: var(--color-secondary); }
.prose ul { padding-left: 1.2em; }
.prose hr {
  border: 0;
  border-top: 1px solid var(--color-soft);
  margin: var(--space-3) 0;
}

/* ---------------------------------------------------------------------
   1. 큰 시작 버튼 .btn-primary
   --------------------------------------------------------------------- */
.btn-primary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  width: 100%;                      /* 모바일 full-width */
  min-height: var(--btn-min-h);     /* 56px */
  padding: var(--space-1) var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--fs-lead);        /* 20px */
  font-weight: var(--weight-head);  /* 700 */
  color: var(--color-on-primary);
  background: var(--color-primary); /* green-600 */
  border: 0;
  border-radius: var(--radius-button);  /* 16px */
  box-shadow: var(--shadow-card);
  text-decoration: none;
  cursor: pointer;
}
.btn-primary__icon { width: 28px; height: 28px; }

.btn-primary:hover,
.btn-primary:focus-visible {
  background: var(--color-primary-dark);
  outline: var(--focus-width) solid var(--color-secondary);
  outline-offset: 2px;
}
.btn-primary:active { background: var(--color-primary-darker); transform: translateY(1px); }
.btn-primary:disabled {
  background: var(--color-disabled-bg);
  color: var(--color-disabled-text);
  cursor: not-allowed;
}

/* ---------------------------------------------------------------------
   2. 선택 카드 버튼 .choice-card
   --------------------------------------------------------------------- */
.choice-group { display: flex; flex-direction: column; gap: var(--gap-min); }

.choice-card {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
  min-height: var(--choice-min-h);  /* 96px */
  padding: var(--space-2) var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--fs-h3);          /* 20px */
  font-weight: var(--weight-head);  /* 700 */
  text-align: left;
  color: var(--color-text);
  background: var(--card);          /* 불투명 흰 카드 */
  border: 2px solid var(--line);
  border-radius: var(--radius-card);   /* 24px */
  box-shadow: var(--shadow-card);
  cursor: pointer;
}
.choice-card__emoji { font-size: 40px; line-height: 1; flex: 0 0 auto; }
.choice-card__label { flex: 1 1 auto; }
.choice-card__check {
  flex: 0 0 auto;
  font-size: 28px; font-weight: 700;
  color: var(--color-primary);
  visibility: hidden;
}

.choice-card:hover,
.choice-card:focus-visible {
  outline: var(--focus-width) solid var(--color-primary);
  outline-offset: 2px;
}
.choice-card:active { transform: translateY(1px); }

/* 선택됨: 색만으로 알리지 않도록 2px 초록 테두리 + 연초록 배경 + ✓ 병기 */
.choice-card[aria-pressed="true"] {
  border-width: 2px;
  border-color: var(--green-600);
  background: var(--green-100);     /* 연초록 위 잉크 고대비 */
}
.choice-card[aria-pressed="true"] .choice-card__check { visibility: visible; }

.choice-card:disabled {
  background: var(--color-disabled-bg);
  color: var(--color-disabled-text);
  border-color: var(--color-disabled-text);
  cursor: not-allowed;
}

/* ---------------------------------------------------------------------
   3. 진행바 .progress
   --------------------------------------------------------------------- */
/* quiz.html <nav class="progress"> 컨테이너 — 가로 넘침 방지 보호막.
   내부 .progress__list 가 실제 칸을 그린다(quiz.js 렌더). */
.progress {
  width: 100%;
  overflow-x: hidden;   /* 만일의 미세 넘침에도 가로스크롤 차단 */
}
.progress__list {
  display: flex;
  flex-wrap: nowrap;            /* 7칸일 때도 줄바꿈/넘침 없이 한 줄 유지 */
  justify-content: center;
  gap: 4px;                     /* 7칸이 320px 안에 들어가도록 간격 축소 */
  list-style: none; margin: 0; padding: var(--space-2) 0;
}
.progress__step {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  flex: 1 1 0;
  font-size: var(--font-caption);
  color: var(--color-text-sub);
  text-align: center;
}
/* 큰 동그라미 (지름 44px) — 숫자/체크 텍스트 병기로 색 외 정보 전달 */
.progress__num {
  display: flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  font-size: var(--font-h3); font-weight: 700; line-height: 1;
  border-radius: var(--radius-pill);
  background: var(--card);
  color: var(--color-text-sub);
  border: 2px solid var(--line);   /* 다음 단계: 회색 테두리 */
}

/* 지난 단계: 체크 + 초록 채움 */
.progress__step.is-done { color: var(--color-primary-dark); }
.progress__step.is-done .progress__num {
  background: var(--green-100);
  color: var(--color-primary-dark);
  border-color: var(--green-600);
}

/* 현재 단계: 초록 채움 + 흰 숫자 */
.progress__step.is-current { font-weight: 700; color: var(--color-primary-dark); }
.progress__step.is-current .progress__num {
  background: var(--green-600);
  color: var(--on-green);
  border-color: var(--green-600);
}
.progress__step.is-current .progress__text {
  text-decoration: underline;
  text-underline-offset: 4px;
}

/* ---------------------------------------------------------------------
   4. 식물 카드 .plant-card
   --------------------------------------------------------------------- */
.plant-card {
  background: var(--card);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  margin-bottom: var(--space-3);
}
/* 상단 사진: 위쪽 모서리만 둥글게. 사진 위 글씨 금지(장식·식별용). */
.plant-card__photo {
  display: block; width: 100%; height: auto;
  aspect-ratio: 3 / 2; object-fit: cover;
  background: var(--green-100);
}
.plant-card__body { padding: var(--space-3); }
.plant-card__badges {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin: 0 0 var(--space-1);
}
.badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px;
  font-size: var(--font-caption);
  font-weight: 700;
  color: var(--color-text);
  background: var(--color-soft);
  border-radius: 999px;
}
.badge--warn {
  color: var(--color-warning-text);
  background: var(--color-surface);
  border: 2px solid var(--color-warning-text);
}
.plant-card__name {
  font-size: var(--font-h2);
  font-weight: 700; margin: 0 0 var(--space-1);
}
.plant-card__why {
  font-size: var(--font-base);
  margin: 0 0 var(--space-3);
}

.plant-card__actions { display: flex; flex-direction: column; gap: var(--gap-min); }

.btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  min-height: var(--btn-min-h);     /* 56px — 보조 버튼도 주 CTA와 높이 통일 */
  padding: var(--space-1) var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--font-base); font-weight: 700;
  border-radius: var(--radius-button);  /* 16px */
  text-decoration: none; cursor: pointer; border: 2px solid transparent;
}
.btn--detail { background: var(--color-primary); color: var(--color-on-primary); }
.btn--shop   { background: var(--color-secondary); color: var(--color-on-secondary); }
.btn--share  { background: var(--color-surface); color: var(--color-secondary);
               border-color: var(--color-secondary); }

.btn:hover, .btn:focus-visible {
  outline: var(--focus-width) solid var(--color-primary);
  outline-offset: 2px;
}
.btn:active { transform: translateY(1px); }
.btn:disabled {
  background: var(--color-disabled-bg); color: var(--color-disabled-text);
  border-color: transparent; cursor: not-allowed;
}

/* ---------------------------------------------------------------------
   5. 하단 고정 네비
   --------------------------------------------------------------------- */
/* 떠있는 하단 네비 — 알약형, 하단에서 띄움, --shadow-float.
   여기에만 유리 허용: 반투명 + 블러. 라벨은 진한 잉크로 대비 4.5:1+ 유지.
   가독을 위해 유리 불투명도를 0.85로 상향. 블러 미지원 시 불투명 폴백. */
.bottomnav {
  position: fixed; left: 50%; bottom: 0; z-index: 100;
  transform: translateX(-50%);
  display: flex; gap: var(--gap-min);
  width: calc(100% - 2 * var(--space-2));
  max-width: calc(var(--content-max) - 2 * var(--space-2));
  margin: 0 auto var(--space-2);
  padding: var(--space-1) var(--space-2);
  min-height: var(--bottomnav-h);
  background: rgba(255, 255, 255, 0.85);
  -webkit-backdrop-filter: var(--glass-blur);
  backdrop-filter: var(--glass-blur);
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-float);
  padding-bottom: calc(var(--space-1) + env(safe-area-inset-bottom));
}
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .bottomnav { background: var(--card); }
}
.bottomnav__btn {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  flex: 1 1 0;
  min-height: var(--tap-min);
  font-family: var(--font-sans);
  font-size: var(--font-base); font-weight: 700;
  border-radius: var(--radius-pill); cursor: pointer;
}
.bottomnav__btn--back {
  background: var(--card); color: var(--color-text);
  border: 2px solid var(--color-secondary);
}
.bottomnav__btn--restart {
  background: var(--color-secondary); color: var(--color-on-secondary); border: 0;
}
.bottomnav__btn:hover, .bottomnav__btn:focus-visible {
  outline: var(--focus-width) solid var(--color-primary);
  outline-offset: 2px;
}
.bottomnav__btn:active { transform: translateY(1px); }
.bottomnav__btn:disabled {
  background: var(--color-disabled-bg); color: var(--color-disabled-text);
  border-color: transparent; cursor: not-allowed;
}

/* ---------------------------------------------------------------------
   6. 상세 페이지 정보 블록 .info-grid
   --------------------------------------------------------------------- */
.info-grid { display: flex; flex-direction: column; gap: var(--space-2); }
.info-card {
  display: grid;
  grid-template-columns: 48px 1fr;
  grid-template-areas: "icon title" "icon value";
  column-gap: var(--space-2); row-gap: 4px;
  padding: var(--pad-card);
  background: var(--card);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
}
.info-card__icon  { grid-area: icon; font-size: 36px; line-height: 1; }
.info-card__title { grid-area: title; margin: 0;
                    font-size: var(--font-h3); font-weight: 700; }
.info-card__value { grid-area: value; margin: 0;
                    font-size: var(--font-base); }

.info-card--warn { border-left: 6px solid var(--color-warning-text); }
.info-card__warnlabel {
  display: inline-block; margin-right: 6px;
  color: var(--color-warning-text); font-weight: 700;
}

/* ---------------------------------------------------------------------
   7. 광고 슬롯 .ad-slot — 콘텐츠 하단 전용
   --------------------------------------------------------------------- */
.ad-slot {
  margin: var(--space-4) 0 0;
  padding: var(--space-2);
  background: var(--card);
  border: 1px dashed var(--color-secondary);
  border-radius: var(--radius-card);
  text-align: center;
}
.ad-slot__tag {
  margin: 0 0 var(--space-1);
  font-size: var(--font-caption);
  font-weight: 700; color: var(--color-secondary);
}
.ad-slot__body { min-height: 100px; }

/* ---------------------------------------------------------------------
   Hero (index)
   --------------------------------------------------------------------- */
/* 히어로 — 배경 사진(장식) + 어둡게 오버레이. 사진 위에는 글씨를 올리지 않는다.
   글씨는 반드시 그 위의 불투명 흰 인트로 카드(.hero__card)에만 얹는다. */
.hero {
  position: relative;
  margin: var(--space-2) 0 var(--space-3);
  padding: var(--space-4) var(--space-2) var(--space-5);
  border-radius: var(--radius-card);
  overflow: hidden;
  background-image:
    linear-gradient(rgba(0, 0, 0, 0.32), rgba(0, 0, 0, 0.32)),
    url("/public/hero-bg.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
/* 불투명 흰 인트로 카드 — 글씨가 올라가는 유일한 영역 */
.hero__card {
  position: relative;
  max-width: 100%;
  margin: 0 auto;
  background: var(--card);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-float);
  padding: var(--pad-card);
  text-align: center;
}
.hero__logo { width: 80px; height: 80px; margin: 0 auto var(--space-1); display: block; }
.hero__title { font-size: var(--font-h1); color: var(--color-text); margin: 0 0 var(--space-1); }
.hero__subtitle { font-size: var(--font-lead); color: var(--color-text); margin: 0 0 var(--space-2); }
.hero__subtitle--soft { font-size: var(--font-base); color: var(--color-text-sub); }
.hero__cta { margin: var(--space-2) 0 0; }

/* 안심 문구 카드 — 불투명 흰 카드 */
.reassure {
  background: var(--card);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: var(--pad-card);
  margin: var(--space-3) 0;
}
.reassure ul { list-style: none; margin: 0; padding: 0; }
.reassure li {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: var(--font-base);
  margin-bottom: var(--space-1);
}
.reassure li::before { content: "🌿"; flex: 0 0 auto; }

/* 3단계 소개 */
.steps-3 { display: flex; flex-direction: column; gap: var(--space-2); }
.step-item {
  display: grid;
  grid-template-columns: 56px 1fr;
  align-items: center;
  gap: var(--space-2);
  padding: var(--pad-card);
  background: var(--card);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
}
.step-item__num {
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  font-size: var(--font-h2); font-weight: 700;
  color: var(--color-on-primary);
  background: var(--color-primary);
  border-radius: 999px;
}
.step-item__text { margin: 0; font-size: var(--font-base); }
.step-item__text strong { display: block; font-size: var(--font-h3); margin-bottom: 2px; }

/* ---------------------------------------------------------------------
   결과/상태 안내 박스
   --------------------------------------------------------------------- */
.result-head { margin-bottom: var(--space-3); }
.result-head__title { font-size: var(--font-h1); margin: 0 0 4px; }
.result-head__subtitle { font-size: var(--font-h3); color: var(--color-secondary); margin: 0; }

/* 결과 카드 그리드(모바일 1열 → 768px↑ 2열) */
.result-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--gap-min);
}
.result-cards .plant-card { margin-bottom: 0; }
@media (min-width: 768px) {
  .result-cards { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
}

.notice {
  padding: var(--space-3);
  background: var(--color-soft);
  color: var(--color-text);
  border-radius: var(--radius);
  margin: 0 0 var(--space-3);
  font-size: var(--font-base);
}

.state-box {
  text-align: center;
  padding: var(--space-4) var(--space-2);
}
.state-box h2 { margin-top: 0; }
.state-box .btn-primary { margin-top: var(--space-3); }

/* 케어가이드 허브 목록 */
.guide-list { display: flex; flex-direction: column; gap: var(--space-2); list-style: none; margin: 0; padding: 0; }
.guide-item a {
  display: flex; align-items: center; gap: var(--space-2);
  min-height: var(--tap-card);
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-h3); font-weight: 600;
  color: var(--color-text);
  background: var(--color-surface);
  border: 2px solid var(--color-border);
  border-radius: var(--radius);
  text-decoration: none;
}
.guide-item a:hover, .guide-item a:focus-visible {
  outline: var(--focus-width) solid var(--color-primary);
  outline-offset: 2px;
}
.guide-item__thumb {
  width: 64px; height: 64px; flex: 0 0 auto;
  object-fit: cover; border-radius: var(--radius);
  background: var(--color-soft);
}
.guide-item__name { flex: 1 1 auto; }
.guide-item__diff { font-size: var(--font-caption); color: var(--color-secondary); font-weight: 600; }

/* ---------------------------------------------------------------------
   사진 출처 목록 (credits.html) — 기존 토큰만 사용, 본문 18px+·대비 유지
   --------------------------------------------------------------------- */
.credits-list {
  list-style: none;
  margin: var(--space-2) 0 var(--space-3);
  padding: 0;
}
.credits-list li {
  margin: 0 0 var(--gap-min);
  padding: var(--space-2) var(--space-3);
  background: var(--color-surface);
  border: 1px solid var(--color-soft);
  border-radius: var(--radius);
}
.credits-list strong {
  display: block;
  font-size: var(--font-h3);
  font-weight: 700;
  margin-bottom: 4px;
}
.credits-list__meta {
  display: block;
  font-size: var(--font-base);
  line-height: var(--line-height);
  color: var(--color-text);
}
.credits-list__meta a {
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 4px;
}
.credits-list__meta a:hover,
.credits-list__meta a:focus-visible {
  color: var(--color-primary);
}

/* ---------------------------------------------------------------------
   8. 상세 페이지 보조 요소
   (breadcrumb / guide-figure / related-plants / ad-disclosure)
   기존 토큰만 사용, 본문 18px+·대비 4.5:1+ 유지
   --------------------------------------------------------------------- */

/* 현재 위치(빵부스러기) */
.breadcrumb {
  font-size: var(--font-caption);
  color: var(--color-text);
  margin: 0 0 var(--space-2);
  line-height: var(--line-height);
}
.breadcrumb a {
  display: inline-block;
  min-height: var(--tap-min);
  line-height: var(--tap-min);
  color: var(--color-secondary);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 4px;
}
.breadcrumb a:hover,
.breadcrumb a:focus-visible {
  color: var(--color-primary);
}
.breadcrumb [aria-current="page"] {
  font-weight: 700;
  color: var(--color-text);
}

/* 본문 중간 설명 사진 */
.guide-figure {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 3 / 2;
  object-fit: cover;
  margin: var(--space-2) 0 var(--space-3);
  background: var(--color-soft);
  border: 1px solid var(--color-soft);
  border-radius: var(--radius);
}
.guide-figure + figcaption,
figure > figcaption {
  margin: calc(-1 * var(--space-2)) 0 var(--space-3);
  font-size: var(--font-caption);
  color: var(--color-secondary);
  text-align: center;
}

/* 관련 식물 카드 그리드 */
.related-plants {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--gap-min);
  list-style: none;
  margin: var(--space-2) 0 var(--space-3);
  padding: 0;
}
.related-plants li { margin: 0; }
.related-plants a {
  display: flex;
  align-items: center;
  min-height: var(--tap-card);
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-h3);
  font-weight: 600;
  color: var(--color-text);
  background: var(--color-surface);
  border: 2px solid var(--color-border);
  border-radius: var(--radius);
  text-decoration: none;
}
.related-plants a::before {
  content: "🌿";
  margin-right: var(--space-2);
  flex: 0 0 auto;
}
.related-plants a:hover,
.related-plants a:focus-visible {
  outline: var(--focus-width) solid var(--color-primary);
  outline-offset: 2px;
}
.related-plants a:active { transform: translateY(1px); }

/* 광고/제휴 고지 문구 */
.ad-disclosure {
  margin: var(--space-1) 0 var(--space-3);
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-caption);
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-soft);
  border-left: 6px solid var(--color-secondary);
  border-radius: var(--radius);
}

@media (min-width: 768px) {
  .related-plants { grid-template-columns: repeat(2, 1fr); }
}

/* ---------------------------------------------------------------------
   반응형 (모바일 우선 → 큰 화면 확장)
   기준: 320 / 375 / 414 / 768 / 1024 / 1920
   --------------------------------------------------------------------- */
@media (min-width: 768px) {
  :root {
    --content-max: 640px;
  }
  /* 떠있는 알약 네비는 큰 화면에서도 알약 유지 */
  .bottomnav { border-radius: var(--radius-pill); }
}

@media (min-width: 1024px) {
  :root {
    --content-max: 760px;
  }
  /* .result-cards 2열 전환은 768px 미디어쿼리에서 이미 적용됨(중복 제거). */
}

@media (min-width: 1920px) {
  :root {
    --content-max: 880px;
    --font-base: 20px;
  }
}

/* 진행바 7칸(정밀 추천) 대응: 화면이 좁아질수록 동그라미 지름 축소.
   숫자/체크는 18px 이상 유지(시니어 가독). 320px에서도 가로 넘침 없음. */
@media (max-width: 414px) {
  .progress__num { width: 40px; height: 40px; }
}

/* 아주 좁은 화면(320px) 보호: 가로 스크롤 금지 */
@media (max-width: 360px) {
  .container { padding: var(--space-1); }
  /* 내비 글자는 18px 유지하되 패딩/간격을 줄여 줄바꿈·가로스크롤 방지 */
  .site-nav { gap: 2px; }
  .site-nav a { font-size: var(--font-base); padding: 0 6px; }
  /* 하단 네비 버튼 글자 빠듯함 완화(18px 미만 금지, 패딩만 축소) */
  .bottomnav { gap: var(--space-1); padding-left: var(--space-1); padding-right: var(--space-1); }
  .bottomnav__btn { padding-left: 6px; padding-right: 6px; }
  /* 진행바: 7칸이 320px 안에 들어가도록 동그라미·간격 축소.
     숫자/체크 font-size 는 18px(--font-base) 로 18px 하한 유지. */
  .progress__num { width: 34px; height: 34px; font-size: var(--font-base); }
  .progress__list { gap: 2px; }
  /* 진행바 한글 단어 줄바꿈 방지 */
  .progress__text { word-break: keep-all; }
}

/* 9. 사진 출처 안내(결과 화면) */
.photo-credit-note {
  margin: var(--space-4, 16px) auto 0;
  max-width: 60ch;
  text-align: center;
  font-size: var(--font-caption, 18px);
  color: var(--color-point, #5D4037);
}
.photo-credit-note a {
  color: var(--color-primary-dark, #1B5E20);
  font-weight: 700;
}
