/*
 * Learn & Stay — 공유 디자인 토큰 (중앙화)
 * SoT: Figma 디자이너 variables — "L&S 공장" PUmwAV935rCMEqvn6nDByV / 406:2
 *      + "CLAUDE HAND OFF" QTqvK6D3gUr8ij5aNQ2Fd4 (페이지 디자인)
 * Updated: 2026-06-08
 *
 * 정책(Nova 확정):
 *  - 폰트는 Pretendard 유지 (디자이너 SUIT Variable 미채택), 타이틀 ChosunilboNM
 *  - 폰트 외 토큰(컬러·간격·시맨틱)은 디자이너 값 반영
 *  - 기존 _v14_figma 페이지 호환을 위해 레거시 --ls-* 변수명 전부 보존
 *
 * 6개 페이지 공용. 각 index.html 은 ../tokens.css 로 참조.
 */

:root {
  /* ═══════════════════════════════════════════════════════════
   * 1. COLOR — 디자이너 확정값
   * ═══════════════════════════════════════════════════════════ */

  /* Forest Green — 메인 브랜드/CTA/다크 섹션 (구 #273617 → #0f3e17) */
  --ls-forest:           #0f3e17;        /* forest-green (디자이너) */
  --ls-forest-deep:      #0a2d10;        /* hover (파생) */
  --ls-forest-soft:      #273617;        /* = Olive/900 (구 forest) */

  /* Olive — eyebrow·서브·딥톤 */
  --ls-olive-900:        #273617;        /* Text/Point */
  --ls-olive-500:        #aeb49a;        /* Olive/500 */
  --ls-olive-dark-bg:    #888950;        /* BG=Dark/Ol */
  --ls-label-main:       #5f6c37;        /* Text/Label_main — eyebrow */
  --ls-olive-dark:       #5f6c37;        /* 레거시 alias → Label_main */
  --ls-olive:            #69783c;        /* 레거시 보존 */
  --ls-olive-light:      #8a9656;        /* 레거시 보존 */

  /* Cream / BG */
  --ls-cream-canvas:     #fffefc;        /* 순백 베이스 */
  --ls-bg-main:          #fbfaf6;        /* Fill/BG/Main — 기본 페이지 배경 */
  --ls-bg-white:         #ffffff;
  --ls-cream-soft:       #efe9d4;        /* 레거시 보존 */
  --ls-cream-warm:       #f4ecdc;        /* 레거시 보존 */

  /* Apricot — 액센트 (레거시 보존) */
  --ls-apricot:          #c25b1f;
  --ls-apricot-soft:     #d4742e;

  /* Text — 디자이너 */
  --ls-text-title:       #3c3c3c;        /* Text/Title */
  --ls-text-default:     #3c3c3c;        /* Text/Default */
  --ls-text-sub:         #6b6b6b;        /* Text/Sub */
  --ls-text-point:       #273617;        /* Text/Point */
  --ls-text-label-sub:   #bdbdbd;        /* Text/Label_sub */
  --ls-ink-secondary-d:  #2b2b2b;        /* ink-secondary (디자이너) */

  /* Ink — 레거시 5단 (값 디자이너 정렬) */
  --ls-ink:              #1a1a1a;
  --ls-ink-text:         #3c3c3c;        /* ← Text/Default 정렬 (구 #2a2a2a) */
  --ls-ink-secondary:    #6b6b6b;        /* ← Text/Sub 정렬 (구 #4a4a4a) */
  --ls-ink-muted:        #8a8a8a;
  --ls-ink-soft:         #bdbdbd;        /* ← Text/Label_sub 정렬 */

  /* On-dark — Forest BG 위 텍스트 (레거시 보존) */
  --ls-on-dark:          rgba(255, 254, 252, 0.95);
  --ls-on-dark-soft:     rgba(255, 254, 252, 0.78);
  --ls-on-dark-muted:    rgba(255, 254, 252, 0.55);
  --ls-on-dark-line:     rgba(255, 254, 252, 0.18);

  /* Fill — 카드·칩 (디자이너) */
  --ls-card-main:        rgba(125, 143, 82, 0.04);   /* Fill/Card/main #7d8f520a */
  --ls-chip-default:     rgba(125, 143, 82, 0.06);   /* Fill/Chip/default #7d8f520f */

  /* Border (디자이너) */
  --ls-border-main:      rgba(43, 43, 43, 0.08);     /* Border/Main #2b2b2b14 */
  --ls-border:           rgba(43, 43, 43, 0.08);     /* 레거시 alias */
  --ls-border-strong:    rgba(43, 43, 43, 0.16);
  --ls-border-point:     #ffffff;                    /* Border/Point */
  --ls-divider-soft:     rgba(95, 108, 55, 0.18);

  /* Icon (디자이너) */
  --ls-icon-contents:    rgba(43, 43, 43, 0.8);      /* Icon/Contents */
  --ls-icon-fill:        rgba(255, 255, 255, 0.2);   /* Icon/fill */

  /* Status (디자이너) */
  --ls-positive:         #7a9e0c;        /* Fill/Positive/strong */
  --ls-negative:         #cc5d31;        /* Fill/Negative/strong */
  --ls-negative-weak:    rgba(204, 93, 49, 0.08);    /* Fill/Negative/weak */
  --ls-bg-negative:      #f9f2f0;        /* Fill/BG/Negative */
  --ls-text-negative:    #c04616;        /* Text/Negative */

  /* ═══════════════════════════════════════════════════════════
   * 2. TYPOGRAPHY — 폰트 Pretendard 유지 / 스케일 디자이너 값
   * ═══════════════════════════════════════════════════════════ */

  /* 폰트 패밀리 */
  --ls-font-kr:          'Pretendard Variable', Pretendard, 'Noto Sans KR', sans-serif;  /* 본문/UI (SUIT 대체) */
  --ls-font-display-kr:  'ChosunilboNM', 'Pretendard Variable', serif;   /* 타이틀 명조 (CDN 패밀리명 정정) */
  --ls-font-display:     'ChosunilboNM', 'Pretendard Variable', serif;   /* alias */
  --ls-font-label:       'Inter', 'Pretendard Variable', sans-serif;
  --ls-font-serif-en:    'Playfair Display', Georgia, serif;             /* 'Learn & Stay' & 시그니처 */

  /* weight */
  --ls-fw-regular:       400;
  --ls-fw-medium:        500;
  --ls-fw-semibold:      600;
  --ls-fw-bold:          700;

  /* 디자이너 타입 스케일 (size) */
  --ls-fs-title-40:      40px;   /* Title_40_R — display */
  --ls-fs-title-36:      36px;   /* Title_36_R — display */
  --ls-fs-title-32:      32px;   /* Title_32_R — display */
  --ls-fs-title-28:      28px;   /* Title_28_B */
  --ls-fs-title-24:      24px;   /* Title_24_B */
  --ls-fs-head-20:       20px;   /* Head_20 */
  --ls-fs-head-18:       18px;   /* Head_18 */
  --ls-fs-body-16:       16px;   /* Body_16 */
  --ls-fs-sub-14:        14px;   /* SubBody/Label_14 */
  --ls-fs-label-12:      12px;   /* Label/Caption_12 */

  /* 레거시 스케일 alias (기존 페이지 호환) */
  --ls-fs-display:       62px;
  --ls-fs-h1:            44px;
  --ls-fs-h1-md:         38px;
  --ls-fs-h2:            56px;
  --ls-fs-h2-md:         42px;
  --ls-fs-h3:            22px;
  --ls-fs-body-lg:       19px;
  --ls-fs-body:          18px;
  --ls-fs-body-md:       17px;
  --ls-fs-body-sm:       16px;
  --ls-fs-caption:       15px;
  --ls-fs-label:         13px;
  --ls-fs-meta:          12px;

  /* Letter-spacing (디자이너: 본문 -2% / eyebrow +16%) */
  --ls-tracking-display: -0.02em;   /* Title_* */
  --ls-tracking-tight:   -0.025em;
  --ls-tracking-snug:    -0.02em;
  --ls-tracking-body:    -0.02em;   /* ← 디자이너 -2% 정렬 */
  --ls-tracking-wide:    0.14em;
  --ls-tracking-wider:   0.16em;    /* ← Label_12_R +16% */

  /* Line-height (디자이너) */
  --ls-lh-display:       1.3;     /* Title_* lh 1.3 */
  --ls-lh-h1:            1.3;
  --ls-lh-h2:            1.3;
  --ls-lh-h3:            1.4;     /* Head_20 lh 1.4 */
  --ls-lh-body:          1.6;     /* Body/Head_18 lh 1.6 */
  --ls-lh-body-tight:    1.5;
  --ls-lh-caption:       1.4;     /* Caption lh 1.4 */

  /* ═══════════════════════════════════════════════════════════
   * 3. LAYOUT
   * ═══════════════════════════════════════════════════════════ */

  --ls-container-max:    1200px;   /* 웹 컨테이너 (디자인 1440 - 좌우 120 패딩) */
  --ls-container-pad:    24px;

  /* ═══════════════════════════════════════════════════════════
   * 4. RADIUS
   * ═══════════════════════════════════════════════════════════ */

  --ls-radius-none:      0;
  --ls-radius-xs:        4px;     /* SDS radius-100 */
  --ls-radius-sm:        8px;
  --ls-radius-md:        12px;
  --ls-radius-lg:        16px;
  --ls-radius-xl:        24px;
  --ls-radius-pill:      9999px;  /* chip·CTA */

  /* ═══════════════════════════════════════════════════════════
   * 5. SPACING (8px base + SDS 4/12)
   * ═══════════════════════════════════════════════════════════ */

  --ls-sp-1:             4px;     /* SDS space-100 */
  --ls-sp-2:             8px;
  --ls-sp-3:             12px;    /* SDS space-300 */
  --ls-sp-4:             16px;
  --ls-sp-5:             24px;
  --ls-sp-6:             32px;
  --ls-sp-7:             48px;
  --ls-sp-8:             56px;
  --ls-sp-9:             64px;
  --ls-sp-10:            80px;
  --ls-sp-11:            96px;
  --ls-sp-12:            120px;

  /* ═══════════════════════════════════════════════════════════
   * 6. SHADOW (절제 — flat 우선) + Motion
   * ═══════════════════════════════════════════════════════════ */

  --ls-shadow-none:      none;
  --ls-shadow-1:         0 1px 3px rgba(0, 0, 0, 0.04);
  --ls-shadow-2:         0 4px 12px rgba(0, 0, 0, 0.06);
  --ls-shadow-3:         0 12px 32px rgba(0, 0, 0, 0.10);

  --ls-dur-fast:         150ms;
  --ls-dur-normal:       250ms;
  --ls-dur-slow:         400ms;
  --ls-ease-out:         cubic-bezier(0.65, 0, 0.35, 1);
}

/* ──────────────────────────────────────
 * Base reset + body (웹)
 * ────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  background: var(--ls-bg-main);
  font-family: var(--ls-font-kr);
  font-size: var(--ls-fs-body-16);
  font-weight: var(--ls-fw-regular);
  line-height: var(--ls-lh-body);
  color: var(--ls-text-default);
  letter-spacing: var(--ls-tracking-body);
  word-break: keep-all;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { font-family: inherit; cursor: pointer; }

/* 반응형 줄바꿈 헬퍼 */
@media (max-width: 767px) { br.pc { display: none; } }
@media (min-width: 768px) { br.mo { display: none; } }

/* ──────────────────────────────────────
 * 공통 컴포넌트 — Contact CTA + Footer (전 페이지 통일, 기준=한달살기)
 * 각 페이지는 동일 HTML 마크업만 두면 됨. 배경사진 = ./assets/cta-beach.jpg (Nova 추후 교체)
 * ────────────────────────────────────── */
.s-cta {
  position: relative; min-height: 720px; overflow: hidden;
  display: flex; align-items: center; justify-content: center; padding: 40px 24px;
  background: linear-gradient(150deg, #f6ecd6 0%, #efd3a6 52%, #e4a866 100%); /* 주황크림 base (구 초록 폐기, 피그마 기준) */
}
.s-cta__bg { position: absolute; inset: 0; background-image: url('./_assets/cta-family.webp'); background-size: cover; background-position: center; }
.s-cta__veil { position: absolute; inset: 0; background:
  radial-gradient(ellipse 58% 52% at center, rgba(45,30,16,0.42) 0%, rgba(45,30,16,0.18) 72%),
  linear-gradient(180deg, rgba(58,36,16,0.30) 0%, rgba(58,36,16,0.46) 100%); }
.cta-glass {
  position: relative; z-index: 2; width: 100%; max-width: 1152px; min-height: 600px; padding: 56px 40px;
  background: rgba(42,34,26,0.30);
  backdrop-filter: blur(24px) saturate(135%); -webkit-backdrop-filter: blur(24px) saturate(135%);
  border: 1px solid rgba(255,255,255,0.2); border-radius: var(--ls-radius-xl);
  display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 32px;
}
.cta-glass__label { font-family: var(--ls-font-display-kr); font-size: 16px; color: rgba(255,255,255,0.9); letter-spacing: 0.02em; margin: 0; }
.cta-glass__title { font-family: var(--ls-font-display-kr); font-size: clamp(26px, 3vw, 32px); line-height: 1.5; color: #fff; margin: 0; font-weight: 400; filter: drop-shadow(0 0 12px rgba(0,0,0,0.25)); }
.cta-glass__body { font-family: var(--ls-font-kr); font-size: clamp(14px, 1.8vw, 16px); line-height: 1.7; color: rgba(255,255,255,0.92); letter-spacing: -0.02em; max-width: 560px; margin: 0; }
.cta-glass__btn {
  display: inline-flex; align-items: center; justify-content: center; width: 100%; max-width: 478px; height: 60px;
  background: #fff; border-radius: var(--ls-radius-lg); box-shadow: 0 10px 20px rgba(0,0,0,0.12);
  font-family: var(--ls-font-kr); font-size: 18px; font-weight: 600; color: var(--ls-text-point); letter-spacing: -0.02em; text-decoration: none;
  transition: transform var(--ls-dur-fast), background var(--ls-dur-fast);
}
.cta-glass__btn:hover { transform: translateY(-2px); background: #f5f5f5; }
@media (max-width: 767px) {
  .cta-glass { min-height: auto; padding: 32px 16px; border-radius: var(--ls-radius-lg); gap: 14px; }
  .cta-glass__label { font-size: 13px; }
  .cta-glass__title { font-size: 20px; line-height: 1.34; }
  .cta-glass__body { font-size: 13px; line-height: 1.65; }
  .cta-glass__btn { height: 54px; font-size: 16px; }
  .s-cta { min-height: 460px; }
}

.ftr { background: var(--ls-cream-soft); border-top: 1px solid var(--ls-border); padding: 48px 0 96px; }
.ftr__inner { max-width: 1200px; margin: 0 auto; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.ftr__brand { font-family: var(--ls-font-kr); font-size: 17px; font-weight: 600; color: var(--ls-forest); text-decoration: none; letter-spacing: -0.02em; }
.ftr__brand em { font-family: var(--ls-font-serif-en); font-style: italic; font-weight: 400; }
.ftr__meta { font-family: var(--ls-font-kr); font-size: 13px; color: var(--ls-ink-muted); }
.ftr__links { display: flex; gap: 20px; }
.ftr__links a { font-family: var(--ls-font-kr); font-size: 13px; color: var(--ls-ink-muted); text-decoration: none; }
.ftr__links a:hover { color: var(--ls-forest); }

/* ══════════════════════════════════════════════════════════════
 * A4. 공통 히어로 배경 (기준 = product 페이지 prod-hero)
 *   forest-soft + olive 글로우 2개. flat color 금지 — 전 페이지 공통.
 *   사용: <section class="hero-bg"> ... <div class="hero-bg__glow hero-bg__glow--a"></div>
 *   배경 위 텍스트는 흰색. 페이지별 inner/타이포는 각자 두되 배경 레이어만 공통.
 * ══════════════════════════════════════════════════════════════ */
.hero-bg { position: relative; overflow: hidden; background: var(--ls-forest-soft); }
.hero-bg__glow { position: absolute; border-radius: 50%; filter: blur(80px); mix-blend-mode: plus-lighter; pointer-events: none; z-index: 0; }
.hero-bg__glow--a { width: 600px; height: 320px; right: -100px; top: -80px; background: radial-gradient(circle, rgba(174,180,154,0.30), transparent 70%); }
.hero-bg__glow--b { width: 800px; height: 260px; left: -180px; bottom: -80px; background: radial-gradient(circle, rgba(136,137,80,0.25), transparent 70%); }
.hero-bg > :not(.hero-bg__glow) { position: relative; z-index: 1; }

/* ══════════════════════════════════════════════════════════════
 * A5. 공통 캐러셀 — 3-up 미리보기 (이전·다음 카드 양옆 노출, 중앙만 활성)
 *   마크업:
 *   <div class="c3"> <div class="c3__viewport"><div class="c3__track">…슬라이드…</div></div>
 *     <button class="c3__nav c3__nav--prev"></button><button class="c3__nav c3__nav--next"></button>
 *     <div class="c3__dots"></div> </div>
 *   JS(공통 carousel.js)가 --c3-index 갱신. 중앙 슬라이드만 pointer-events 활성.
 * ══════════════════════════════════════════════════════════════ */
.c3 { position: relative; width: 100vw; margin-left: calc(50% - 50vw); --c3-gap: 24px; }  /* 풀블리드: 컨테이너 밖 100vw */
.c3__viewport { overflow: hidden; padding: 8px 0; }
.c3__track {
  display: flex; gap: var(--c3-gap);
  transition: transform var(--ls-dur-slow) var(--ls-ease-out);
  will-change: transform;   /* translateX 는 carousel.js 가 px 로 직접 구동(중앙 정렬·무한 루프) */
}
.c3__slide { flex: 0 0 68vw; max-width: 1040px; opacity: 0.4; transform: scale(0.93); transition: opacity var(--ls-dur-slow) var(--ls-ease-out), transform var(--ls-dur-slow) var(--ls-ease-out); pointer-events: none; }
.c3__slide.is-active { opacity: 1; transform: scale(1); pointer-events: auto; }
@media (max-width: 767px) { .c3__slide { flex-basis: 84vw; } }
/* c3--multi: 카드 3개 동시 노출(텍스트 카드용 — 후기 등). 중앙 강조 없이 균일 */
.c3--multi .c3__slide { flex: 0 0 30vw; max-width: 380px; opacity: 1; transform: none; pointer-events: auto; }
.c3--multi .c3__slide.is-active { transform: none; }
@media (max-width: 1024px) { .c3--multi .c3__slide { flex-basis: 44vw; } }
@media (max-width: 767px) { .c3--multi .c3__slide { flex-basis: 80vw; } }
/* iOS Safari: flex stretch 안에서 aspect-ratio 미계산 → 카드 높이 붕괴 방지 */
.c3--multi .c3__slide { align-self: flex-start; }
.c3--multi .prog__pcard__img { height: 64vw; max-height: 320px; }
@media (min-width: 768px) { .c3--multi .prog__pcard__img { height: auto; aspect-ratio: 5 / 4; max-height: none; } }
.c3__nav { position: absolute; top: 50%; transform: translateY(-50%); z-index: 3; width: 48px; height: 48px; border-radius: 50%; border: 1px solid var(--ls-border-main); background: rgba(255,255,255,0.92); display: flex; align-items: center; justify-content: center; color: var(--ls-forest); box-shadow: var(--ls-shadow-2); transition: transform var(--ls-dur-fast); }
.c3__nav:hover { transform: translateY(-50%) scale(1.06); }
.c3__nav--prev { left: 24px; } .c3__nav--next { right: 24px; }
.c3__nav svg { width: 20px; height: 20px; }
.c3__dots { display: flex; justify-content: center; gap: 8px; margin-top: 24px; }
.c3__dot { width: 8px; height: 8px; border-radius: 50%; border: 0; background: var(--ls-border-strong); padding: 0; transition: background var(--ls-dur-fast), width var(--ls-dur-fast); }
.c3__dot.is-active { background: var(--ls-forest); width: 22px; border-radius: 4px; }
@media (max-width: 767px) { .c3 { --c3-peek: 8%; --c3-gap: 12px; } }

/* ══════════════════════════════════════════════════════════════
 * A6. 공통 정보형 푸터 (기준 = beautifulmom.net) — 전 페이지 통일
 *   로고/브랜드 + 내비 + 사업자 정보 + copyright + 정책.
 *   ⚠️ 사업자번호·통신판매업번호·주소·전화는 [Nova 확인] placeholder.
 * ══════════════════════════════════════════════════════════════ */
.site-ftr { background: var(--ls-forest-deep); color: var(--ls-on-dark); }  /* 더 깊은 forest (구 밝은 초록 아님) */
.site-ftr__inner { max-width: var(--ls-container-max); margin: 0 auto; padding: 64px 24px 48px; }
.site-ftr__top { display: flex; justify-content: space-between; align-items: flex-start; gap: 32px; flex-wrap: wrap; padding-bottom: 36px; border-bottom: 1px solid var(--ls-on-dark-line); }
.site-ftr__brand { font-family: var(--ls-font-kr); font-size: 22px; font-weight: 600; color: #fff; letter-spacing: -0.02em; }
.site-ftr__brand em { font-family: var(--ls-font-serif-en); font-style: italic; font-weight: 400; }
.site-ftr__nav { display: flex; gap: 28px; flex-wrap: wrap; }
.site-ftr__nav a { font-family: var(--ls-font-kr); font-size: 12px; color: var(--ls-on-dark-soft); transition: color var(--ls-dur-fast); }
.site-ftr__nav a:hover { color: #fff; }
.site-ftr__info { display: flex; flex-wrap: wrap; gap: 10px 28px; padding: 28px 0 24px; }
.site-ftr__cell { display: flex; gap: 8px; font-family: var(--ls-font-kr); font-size: 12px; line-height: 1.6; }
.site-ftr__cell dt { color: var(--ls-on-dark-muted); white-space: nowrap; }
.site-ftr__cell dd { color: var(--ls-on-dark-soft); margin: 0; }
.site-ftr__cell dd a { color: var(--ls-on-dark-soft); }
.site-ftr__bottom { display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; padding-top: 24px; border-top: 1px solid var(--ls-on-dark-line); }
.site-ftr__copy { font-family: var(--ls-font-label); font-size: 12px; letter-spacing: 0.02em; color: var(--ls-on-dark-muted); }
.site-ftr__policy { display: flex; gap: 18px; }
.site-ftr__policy a { font-family: var(--ls-font-kr); font-size: 12px; color: var(--ls-on-dark-muted); }
.site-ftr__policy a:hover { color: #fff; }
@media (max-width: 767px) {
  .site-ftr__inner { padding: 36px 20px 28px; }
  .site-ftr__top { flex-direction: column; gap: 16px; padding-bottom: 24px; }
  .site-ftr__nav { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 16px; justify-items: start; }
  .site-ftr__info { gap: 6px 18px; padding: 18px 0 16px; }
  .site-ftr__bottom { flex-direction: column; align-items: flex-start; gap: 10px; padding-top: 16px; }
}

/* ═══════════════════════════════════════════════════════════
 * 모바일 풀스크린 슬라이드 메뉴 (.ls-mobnav) — JS 불요(체크박스)
 * 헤더 .hdr__inner 끝(cta 뒤)에 마크업 삽입:
 *   <input type="checkbox" id="ls-mobnav-cb" class="ls-mobnav__cb">
 *   <label for="ls-mobnav-cb" class="ls-mobnav__burger" aria-label="메뉴"><span></span><span></span><span></span></label>
 *   <div class="ls-mobnav"> <label for=.. class="ls-mobnav__dim"></label>
 *     <nav class="ls-mobnav__panel"> <label for=.. class="ls-mobnav__close">✕</label> …a 링크… </nav> </div>
 * ═══════════════════════════════════════════════════════════ */
.ls-mobnav__cb { display: none; }
.ls-mobnav__burger {
  display: none; width: 40px; height: 40px; cursor: pointer; margin-left: 4px;
  flex-direction: column; justify-content: center; align-items: center; gap: 5px;
}
.ls-mobnav__burger span { display: block; width: 22px; height: 2px; background: var(--ls-forest); border-radius: 2px; }
.ls-mobnav { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; z-index: 300; visibility: hidden; overflow-x: clip; }  /* parked 패널(translateX 100%)이 가로 스크롤 만드는 것 차단 — 열리면 화면 안이라 정상 */
.ls-mobnav__dim { position: absolute; inset: 0; background: rgba(15,30,12,0.5); opacity: 0; transition: opacity .35s; }
.ls-mobnav__panel {
  position: absolute; inset: 0; background: var(--ls-forest);
  transform: translateX(100%); transition: transform .38s cubic-bezier(0.16,1,0.3,1);
  display: flex; flex-direction: column; justify-content: center; gap: 2px;
  padding: 80px 32px 48px; text-align: center;
}
.ls-mobnav__close { position: absolute; top: 20px; right: 24px; font-size: 26px; line-height: 1; color: rgba(255,255,255,0.85); cursor: pointer; }
.ls-mobnav__panel a {
  font-family: var(--ls-font-display-kr); font-size: 24px; color: #fff;
  text-decoration: none; padding: 13px 0; letter-spacing: -0.02em;
}
.ls-mobnav__panel a.ls-mobnav__cta {
  margin-top: 22px; background: #fff; color: var(--ls-forest);
  border-radius: var(--ls-radius-pill); font-family: var(--ls-font-kr);
  font-size: 17px; font-weight: 600; padding: 14px 0;
}
.ls-mobnav__cb:checked ~ .ls-mobnav { visibility: visible; }
.ls-mobnav__cb:checked ~ .ls-mobnav .ls-mobnav__dim { opacity: 1; }
.ls-mobnav__cb:checked ~ .ls-mobnav .ls-mobnav__panel { transform: translateX(0); }
@media (max-width: 900px) { .ls-mobnav__burger { display: flex; } }

/* ═══ 모바일 하단 고정 상담 버튼 (.mob-fab) — 마크업: <div class="mob-fab"><a href="../counsel_v14_figma/index.html">무료 상담</a></div> ═══ */
.mob-fab { display: none; position: fixed; left: 14px; right: 14px; bottom: 14px; z-index: 250; }
.mob-fab a {
  display: block; width: 100%; padding: 15px; text-align: center;
  background: var(--ls-forest); color: #fff;
  font-family: var(--ls-font-kr); font-size: 15px; font-weight: 700;
  border-radius: 12px; text-decoration: none; letter-spacing: -0.02em;
  box-shadow: 0 6px 18px rgba(15,62,23,0.32);
}
@media (max-width: 767px) { .mob-fab { display: block; } .hdr__cta { display: none; } }

/* ═══════════════════════════════════════════════════════════
 * 모바일 아코디언 (.ls-macc) — 데스크탑 항상 펼침 / 모바일(≤767)만 접기 (JS 불요, 체크박스 방식)
 * 사용:
 *   <div class="ls-macc">
 *     <input type="checkbox" class="ls-macc__cb" id="acc-NN" hidden>
 *     <label class="ls-macc__sum" for="acc-NN">제목</label>
 *     <div class="ls-macc__body"> …상세… </div>
 *   </div>
 *  (id 는 페이지 내 고유. 데스크탑은 체크박스 무시하고 본문 항상 노출)
 * ═══════════════════════════════════════════════════════════ */
.ls-macc { display: contents; }        /* 데스크탑: 레이아웃 투명 → 본문이 부모 레이아웃에 그대로 참여 */
.ls-macc__cb { display: none; }
.ls-macc__sum { display: none; }        /* 데스크탑: 토글 헤더 숨김 */
.ls-macc__body { display: contents; }   /* 데스크탑: 투명(자식이 부모 flex/grid에 직접 참여) */
@media (max-width: 767px) {
  .ls-macc { display: block; margin: 8px 0; }
  /* '자세히보기 ▾' ↔ '접기 ▴' — 명확한 버튼형 토글. 라벨 텍스트는 비워두면 됨 */
  .ls-macc__sum {
    display: inline-flex; align-items: center; gap: 6px; width: fit-content;
    padding: 8px 16px; cursor: pointer;
    border: 1px solid var(--ls-forest); border-radius: var(--ls-radius-pill);
    font-family: var(--ls-font-kr); font-size: 13px; font-weight: 600;
    color: var(--ls-forest); letter-spacing: -0.02em;
    transition: background var(--ls-dur-fast);
  }
  .ls-macc__sum:active { background: rgba(15,62,23,0.06); }
  .ls-macc__sum::before { content: '자세히보기'; }
  .ls-macc__cb:checked ~ .ls-macc__sum::before { content: '접기'; }
  .ls-macc__sum::after {
    content: '▾'; font-size: 11px; line-height: 1; transition: transform .25s ease;
  }
  .ls-macc__cb:checked ~ .ls-macc__sum::after { transform: rotate(180deg); }
  .ls-macc__body { display: none; }
  .ls-macc__cb:checked ~ .ls-macc__body { display: block; margin-top: 12px; }
}

/* ═══════════════════════════════════════════════════════════
 * 전역 컴포넌트 통일 — 2026-07-01
 * (데스크탑 편집 컨버전스를 전 페이지에 동일 적용. 페이지 <style>가
 *  tokens.css 뒤에 로드되므로 전역 우선순위 확보 위해 !important 사용)
 * ═══════════════════════════════════════════════════════════ */

/* Eyebrow — 전 페이지 통일: weight 400 + letter-spacing 0.48px */
[class*="eyebrow"] {
  font-weight: 400 !important;
  letter-spacing: 0.48px !important;
  font-size: 14px !important;
}

/* 히어로 eyebrow 가독성 — 사진/딥그린 히어로 위에서 흐려 안 보이던 것 개선.
 * (prod-hero '안 보임' 지적 해결 / a-month 흰색 처리와 통일) */
.prod-hero__eyebrow,
.s-hero__eyebrow,
.hero__eyebrow,
.faq__eyebrow,
.counsel-eyebrow {
  color: rgba(255, 255, 255, 0.92) !important;
}

/* 아코디언 +버튼 — product .compare-acc__toggle 원형(28px 테두리+) 디자인으로 전역 통일.
 * faq·mothers-learn FAQ 아코디언의 plain +/− 마커를 원형 버튼으로. */
.faq__item summary::after,
.faq-item summary::after {
  width: 28px !important; height: 28px !important;
  border: 1px solid var(--ls-border-main) !important;
  border-radius: 50% !important;
  display: flex !important; align-items: center; justify-content: center;
  font-size: 18px !important; line-height: 1 !important;
  color: var(--ls-forest) !important;
  flex-shrink: 0;
}
.faq__item details[open] summary::after,
.faq-item details[open] summary::after {
  background: var(--ls-chip-default) !important;
  color: var(--ls-forest) !important;
}

/* 섹션 h2 타이틀 — 전 페이지 28px / line-height 1.35 통일 (데스크탑).
 * (a-month·about·ml은 이미 28 / main·product 32 → 28로 정렬. 히어로 h1은 제외) */
@media (min-width: 768px) {
  .sec-title,
  .sec__title,
  .prod-title,
  .faq-title {
    font-size: 28px !important;
    line-height: 1.5 !important;
  }
}

/* 아코디언 질문/답변 폰트 — 전 페이지 공통 통일 (2026-07-02).
 * 페이지별 .faq__item summary {17px} 등 더 높은 우선순위 규칙이 계속 덮어써서
 * 여기서 !important 로 못박음 (질문 15px/1.5 · 답변 14px/1.5). */
.faq__item summary,
.faq-item summary {
  font-size: 15px !important;
  line-height: 1.5 !important;
  font-weight: 600 !important;
}
.faq__answer,
.faq-body,
.faq-body-text {
  font-size: 14px !important;
  line-height: 1.5 !important;
  word-break: keep-all !important;
}

/* A4 모바일 햄버거 메뉴 — 메인 기준 전 페이지 통일 (2026-07-02).
 * 메뉴 링크 16px·중앙정렬·탭영역 확보, CTA 버튼 52px·radius 12. */
@media (max-width: 767px) {
  nav.ls-mobnav__panel > a {
    font-size: 16px !important;
    padding-top: 6px !important; padding-bottom: 6px !important;
    min-height: 44px;
    display: flex !important; align-items: center; justify-content: center;
  }
  a.ls-mobnav__cta {
    height: 52px !important; border-radius: 12px !important;
    display: flex !important; align-items: center; justify-content: center;
    font-size: 16px;
  }
}

/* h2 섹션 타이틀 line-height 1.5 전 페이지·전 뷰포트 통일 (2026-07-03 R4) */
.sec-title, .sec__title, .prod-title, .faq-title { line-height: 1.5 !important; }

/* 서브페이지 히어로 h1 — 데스크탑 36px 고정 통일 (2026-07-03 R5. clamp 들쭉날쭉 제거) */
@media (min-width: 768px) {
  .s-hero__title, .prod-hero__title,
  .counsel-hero__title, .faq__hero-title { font-size: 36px !important; line-height: 1.5 !important; }
  /* (리밸런스 .hero__title은 메인과 동명 → 페이지 로컬 36px 처리, 메인 오프닝 48px 유지) */
}

/* SVG 워드마크 로고 (2026-07-03) — 헤더 원색(#273617) / 푸터 흰색 반전 */
.hdr__logo { height: 28px; width: auto; display: block; }
.site-ftr__brand .hdr__logo { height: 24px; filter: brightness(0) invert(1); }
@media (max-width: 767px) { .hdr__logo { height: 24px; } }
