
  *, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
  :root {
    --w: #ffffff; --cream: #f4efe9; --soft: #f8f5f2; --warm: #f1ece6;
    --dark: #1c1b19; --mid: #6b6762; --light: #a5a09a; --line: #e3dcd5; --gold: #c3a679;
  }
  html { scroll-behavior: smooth; }
  body { font-family: 'Pretendard', -apple-system, BlinkMacSystemFont, sans-serif; color: var(--dark); background: var(--w); -webkit-font-smoothing: antialiased; line-height: 1; overflow-x: hidden; }
  .page-wrap { max-width: 1500px; margin: 0 auto; }
  a { text-decoration: none; color: inherit; }

  /* ── HEADER ── */
  header {
    position: fixed; inset: 0 0 auto 0; z-index: 200;
    height: 64px; padding: 0 52px;
    display: flex; align-items: center; justify-content: space-between;
    background: rgba(255,255,255,.97); backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(0,0,0,.07);
    transition: background .35s ease, border-color .35s ease;
  }
  .logo img { height: 36px; width: auto; display: block; }
  header nav { display: flex; gap: 32px; }
  header nav a { font-size: 13px; letter-spacing: .02em; transition: color .2s; }
  header nav a:hover, header nav a.active { color: var(--gold); }
  .h-right { display: flex; align-items: center; gap: 16px; }
  .h-login { font-size: 12px; color: var(--mid); }
  .h-book {
    font-size: 11.5px; letter-spacing: .06em;
    background: var(--dark); color: #fff;
    padding: 9px 22px; border-radius: 100px; transition: background .25s;
  }
  .h-book:hover { background: var(--gold); }

  /* ── INTRO ── */
  .intro { margin-top: 64px; padding: 88px 80px 80px;  }
  .intro-label { font-family: 'Montserrat', sans-serif; font-size: 28px; font-weight: 700; line-height: 28.435px; color: #BC8B55; display: block; margin-bottom: 20px; }
  .intro h1 { font-family: 'Pretendard', sans-serif; font-size: clamp(34px,5.21vw,75px); font-weight: 600; line-height: 1.167; margin-bottom: 18px; }
  .intro-sub { font-family: 'Pretendard', sans-serif; font-size: clamp(15px,1.74vw,25px); font-weight: 400; line-height: 42.653px; color: #000; }
  .intro-desc { font-size: 22px; color: var(--mid); line-height: 1.8; margin-top: 10px; }

  /* ── HERO IMAGE ── */
  .stem-hero { width: 100vw; margin-left: calc(-50vw + 50%); height: 400px; overflow: hidden; background: #fff; }
  .stem-hero img,
  .stem-hero video { width: 100%; height: 100%; object-fit: cover; display: block; }

  /* ── WHAT IS STEM CELL ── */
  .what-sec { display: grid; grid-template-columns: 4fr 6fr; gap: 80px; padding: 100px 80px; align-items: start; }
  .what-left h2 { font-size: clamp(24px,3.47vw,50px); font-weight: 700; line-height: 1.25; }
  .what-left .sub-label { font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 500; color: var(--light); letter-spacing: .08em; text-transform: uppercase; display: block; margin-bottom: 16px; }
  .what-right p { font-size: 22px; line-height: 1.7; color: var(--mid); }
  .what-right p + p { margin-top: 20px; }

  /* ── INJECTION SECTION ── */
  .inj-hd { padding: 0 80px 48px; }
  .inj-hd h2 { font-size: clamp(24px,3.47vw,50px); font-weight: 700; line-height: 1.25; }
  .inj-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 57px; padding: 0 80px 100px; }
  .inj-img { width: 100%; aspect-ratio: 16/10; overflow: hidden; border-radius: 0; margin-bottom: 20px; background: var(--soft); }
  .inj-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .inj-card h3 { font-size: 22px; font-weight: 700; margin-bottom: 10px; }
  .inj-card p { font-size: 22px; line-height: 1.8; color: var(--mid); }

  /* ── PROGRAM SPLIT ── */
  .program-sec { display: grid; grid-template-columns: 1fr 1fr; padding-left: 80px; margin-top: 130px; }
  .prog-photo { overflow: hidden; min-height: 600px; max-width: 650px;   }
  .prog-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .prog-body { padding: 40px 72px;  display: flex; flex-direction: column; justify-content: start;}
  .prog-body .en-cap { font-family: 'Inter', sans-serif; font-style: italic; font-size: 15px; letter-spacing: .04em; color: var(--light); display: block; margin-bottom: 16px; }
  .prog-body h2 { font-size: clamp(24px,3.47vw,50px); font-weight: 700; line-height: 1.25; margin-bottom: 28px; }
  .prog-body p { font-size: 22px; line-height: 1.8; color: var(--mid); }
  .prog-rule { width: 32px; height: 1px; background: var(--gold); margin: 28px 0; }

  /* ── DE-AGING SPLIT ── */
  .deaging-sec { display: grid; grid-template-columns: 1fr 1fr; }
  .deaging-body { padding: 80px 72px; background: var(--w); display: flex; flex-direction: column; justify-content: center; }
  .deaging-body .en-cap { font-family: 'Inter', sans-serif; font-style: italic; font-size: 15px; letter-spacing: .04em; color: var(--light); display: block; margin-bottom: 16px; }
  .deaging-body h2 { font-size: clamp(24px,3.47vw,50px); font-weight: 700; line-height: 1.25; margin-bottom: 28px; }
  .deaging-body p { font-size: 22px; line-height: 1.8; color: var(--mid); }
  .deaging-photo { overflow: hidden; min-height: 600px; max-width: 650px; margin-left: auto; margin-top: -70px;   }
  .deaging-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }

  /* ── BANNER ── */
  .stem-banner { position: relative; height: 420px; overflow: hidden; background: #1e2e3c; margin-top: 180px; }
  .stem-banner img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .banner-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.5); display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 40px; }
  .banner-overlay h2 { font-size: clamp(28px,4.17vw,60px); font-weight: 700; color: #fff; margin-bottom: 20px; letter-spacing: .04em; }
  .banner-overlay p { font-size: 22px; color: rgba(255,255,255,.78); line-height: 1.9; max-width: 720px; }

  /* ── CAUTION ── */
  .caution-sec { padding: 100px 80px; background: var(--w); }
  .caution-sec h2 { font-size: clamp(24px,3.47vw,50px); font-weight: 700; line-height: 1.25; margin-bottom: 48px; text-align: center; }
  .caution-list { max-width: 860px; margin: 0 auto; }
  .caution-item { border: 1px solid var(--line); margin-bottom: -1px; }
  .caution-q { display: flex; align-items: center; gap: 14px; padding: 20px 24px; cursor: pointer; user-select: none; background: var(--w); }
  .caution-check { flex-shrink: 0; }
  .caution-check svg { width: 18px; height: 18px; display: block; }
  .caution-q-text { font-size: 20px; font-weight: 500; color: var(--dark); flex: 1; }
  .caution-icon { width: 24px; height: 24px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: transform .3s ease; }
  .caution-icon svg { width: 16px; height: 16px; }
  .caution-item.open .caution-icon { transform: rotate(180deg); }
  .caution-a { height: 0; overflow: hidden; transition: height .45s cubic-bezier(.4,0,.2,1); }
  .caution-a-inner { padding: 16px 24px 20px 56px; background: var(--soft); }
  .caution-a-inner p,
  .caution-a-inner li { font-size: 18px; line-height: 1.8; color: var(--mid); }
  .caution-a-inner p strong { color: var(--dark); font-weight: 600; }
  .caution-a-inner ul { margin: 0; padding: 0 12px 0 22px; }
  .caution-a-inner li + li { margin-top: 10px; }

  /* ── FAQ ── */
  .faq-sec { padding: 0 80px 100px; background: var(--w); }
  .faq-sec h2 { font-size: clamp(24px,3.47vw,50px); font-weight: 700; line-height: 1.25; margin-bottom: 48px; text-align: center; }
  .faq-list { max-width: 860px; margin: 0 auto; }
  .faq-item { border-top: 1px solid var(--line); }
  .faq-item:last-child { border-bottom: 1px solid var(--line); }
  .faq-q { display: flex; align-items: center; justify-content: space-between; padding: 22px 0; cursor: pointer; user-select: none; }
  .faq-q-left { display: flex; align-items: center; gap: 14px; }
  .faq-badge { width: 28px; height: 28px; border-radius: 50%; background: var(--dark); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; flex-shrink: 0; font-family: 'Inter', sans-serif; }
  .faq-q-left p { font-size: 20px; font-weight: 500; color: var(--dark); }
  .faq-icon { width: 24px; height: 24px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: transform .3s ease; }
  .faq-icon svg { width: 16px; height: 16px; }
  .faq-item.open .faq-icon { transform: rotate(180deg); }
  .faq-a { height: 0; overflow: hidden; transition: height .45s cubic-bezier(.4,0,.2,1); }
  .faq-a-inner { padding: 16px 0 20px 42px; background: var(--soft); }
  .faq-a-inner p,
  .faq-a-inner li { font-size: 18px; line-height: 1.8; color: var(--mid); }
  .faq-a-inner p { padding: 0 24px 0 0; }
  .faq-a-inner ul { margin: 0; padding: 0 24px 0 22px; }
  .faq-a-inner li + li { margin-top: 10px; }

  /* ── SCROLL FADE-UP ── */
  .fade-up { opacity: 0; transform: translateY(40px); transition: opacity .7s ease, transform .7s ease; }
  .fade-up.on { opacity: 1; transform: translateY(0); }
  .fade-up:nth-child(2) { transition-delay: .12s; }
  .fade-up:nth-child(3) { transition-delay: .22s; }

  /* ── CONTACT ── */
  .contact { padding: 88px 80px; background: #fff; }
  .contact-grid { display: grid; grid-template-columns: 1fr 1.1fr 1.2fr; gap: 60px; align-items: start; }
  .contact-left h3 { font-family: 'Pretendard', sans-serif; font-size: 36px; font-weight: 700; margin-bottom: 28px; }
  .c-phone { font-family: 'Pretendard', sans-serif; font-size: 28px; font-weight: 400; letter-spacing: .02em; margin-bottom: 28px; color: var(--dark); }
  .c-phone span { font-size: 13px; font-weight: 400; color: var(--light); display: block; margin-bottom: 6px; letter-spacing: .04em; }
  .c-rows { border-top: 1px solid var(--line); }
  .c-row { display: grid; grid-template-columns: 68px 1fr; gap: 16px; padding: 15px 0; border-bottom: 1px solid var(--line); }
  .c-lbl { font-size: 11.5px; color: var(--light); padding-top: 1px; }
  .c-val { font-size: 13px; color: var(--mid); line-height: 1.9; }
  .c-form { display: flex; flex-direction: column; gap: 10px; }
  .c-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
  .c-field { display: flex; flex-direction: column; gap: 6px; }
  .c-field label { font-size: 11.5px; color: var(--light); letter-spacing: .04em; }
  .c-field label span { color: #c00; }
  .c-field input, .c-field textarea { width: 100%; padding: 11px 14px; border: 1px solid var(--line); background: #fafafa; font-family: 'Pretendard', sans-serif; font-size: 13px; color: var(--dark); outline: none; transition: border .2s; resize: none; box-sizing: border-box; }
  .c-field input::placeholder, .c-field textarea::placeholder { color: #bbb; }
  .c-field input:focus, .c-field textarea:focus { border-color: var(--dark); background: #fff; }
  .c-field textarea { height: 110px; }
  .c-agree { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin-top: 4px; }
  .c-agree-left { display: flex; align-items: center; gap: 8px; }
  .c-agree input[type=checkbox] { width: 14px; height: 14px; accent-color: var(--dark); cursor: pointer; }
  .c-agree-txt { font-size: 12px; color: var(--mid); }
  .c-agree-more { font-size: 11.5px; color: var(--light); border-bottom: 1px solid var(--line); cursor: pointer; white-space: nowrap; }
  .c-submit { width: 100%; padding: 15px; background: var(--dark); color: #fff; font-family: 'Pretendard', sans-serif; font-size: 13px; letter-spacing: .08em; border: none; cursor: pointer; transition: background .2s; margin-top: 4px; }
  .c-submit:hover { background: #333; }
  .map-box { height: 100%; min-height: 320px; overflow: hidden; }

  /* ── FOOTER ── */
  footer { background: var(--dark); color: rgba(255,255,255,.56); padding: 36px 52px 28px; }
  .ft-top { display: flex; justify-content: space-between; align-items: center; padding-bottom: 20px; margin-bottom: 16px; border-bottom: 1px solid rgba(255,255,255,.1); }
  .ft-logo { font-family: 'Pretendard', sans-serif; font-size: 16px; font-weight: 400; letter-spacing: .1em; color: rgba(255,255,255,.82); }
  .ft-nav { display: flex; gap: 24px; }
  .ft-nav a { font-size: 12px; color: rgba(255,255,255,.56); transition: color .2s; }
  .ft-nav a:hover { color: rgba(255,255,255,.82); }
  .ft-copy { font-size: 11px; }

  /* ── RESPONSIVE ── */
  @media (max-width: 1024px) {
    .intro { padding: 88px 40px 60px; }
    .what-sec { padding: 80px 40px; gap: 48px; }
    .what-right p { font-size: 22px; }
    .inj-hd { padding: 0 40px 40px; }
    .inj-grid { padding: 0 40px 80px; gap: 36px; }
    .program-sec { padding-left: 40px; margin-top: 80px; }
    .prog-body { padding: 40px; }
    .prog-body p { font-size: 22px; }
    .deaging-body { padding: 60px 40px; }
    .deaging-body p { font-size: 22px; }
    .stem-banner { margin-top: 100px; }
    .caution-sec { padding: 80px 40px; }
    .faq-sec { padding: 0 40px 80px; }
  }

  @media (max-width: 768px) {
    header { padding: 0 20px; }
    header nav { display: none; }

    .intro { padding: 56px 24px 40px; margin-top: 64px; }
    .intro-label { font-size: 18px; margin-bottom: 14px; }
    .intro h1 { font-size: 26px; margin-bottom: 12px; }
    .intro-sub { font-size: 15px; line-height: 1.6; }
    .intro-desc { font-size: 22px; }

    .stem-hero { height: 220px; }

    .what-sec { grid-template-columns: 1fr; padding: 48px 24px; gap: 24px; }
    .what-left h2 { font-size: 24px; }
    .what-right p { font-size: 22px; line-height: 1.8; }

    .inj-hd { padding: 0 24px 28px; }
    .inj-hd h2 { font-size: 24px; }
    .inj-grid { grid-template-columns: 1fr; padding: 0 24px 48px; gap: 28px; }
    .inj-card h3 { font-size: 18px; }
    .inj-card p { font-size: 22px; }

    .program-sec { grid-template-columns: 1fr; padding-left: 0; margin-top: 48px; }
    .prog-photo { min-height: 260px; }
    .prog-body { padding: 36px 24px; }
    .prog-body h2 { font-size: 24px; margin-bottom: 16px; }
    .prog-body p { font-size: 22px; }

    .deaging-sec { grid-template-columns: 1fr; display: flex; flex-direction: column-reverse; }
    .deaging-photo { min-height: 260px; margin-top: 0; margin-left: 0; max-width: 100%; }
    .deaging-body { padding: 36px 24px; }
    .deaging-body h2 { font-size: 24px; margin-bottom: 16px; }
    .deaging-body p { font-size: 22px; }

    .stem-banner { height: 320px; margin-top: 48px; }
    .banner-overlay { padding: 24px; }
    .banner-overlay h2 { font-size: 24px; }
    .banner-overlay p { font-size: 22px; line-height: 1.8; }

    .caution-sec { padding: 48px 24px; }
    .caution-sec h2 { font-size: 22px; margin-bottom: 32px; }
    .caution-q-text { font-size: 14px; }
    .caution-a-inner { padding: 14px 20px 16px 44px; }
    .caution-a-inner p,
    .caution-a-inner li { font-size: 18px; }

    .faq-sec { padding: 0 24px 48px; }
    .faq-sec h2 { font-size: 22px; margin-bottom: 32px; }
    .faq-q-left p { font-size: 14px; }
    .faq-a-inner { padding: 14px 20px 16px 36px; }
    .faq-a-inner p,
    .faq-a-inner li { font-size: 18px; }

    .contact { padding: 56px 24px; }
    .contact-grid { grid-template-columns: 1fr; gap: 36px; }
    footer { padding: 48px 24px 36px; }
    .ft-top { flex-direction: column; gap: 24px; }
  }

/* ── Stem page cleanup ───────────────────── */
:root {
  --stem-inner: 1420px;
  --stem-side: 52px;
}

.page-wrap {
  max-width: var(--stem-inner);
  padding: 0 var(--stem-side) 110px;
}

.intro {
  padding: 88px 0 80px;
}
.intro-label {
  font-size: 28px;
  line-height: 1.02;
  letter-spacing: 0;
  margin-bottom: 20px;
}
.intro h1 {
  font-size: clamp(30px, 4.51vw, 65px);
  line-height: 1.167;
  letter-spacing: -.03em;
}
.intro-sub {
  max-width: 920px;
  font-size: 20px;
  line-height: 1.62;
  color: #000;
}

.stem-hero {
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  height: clamp(300px, 28vw, 440px);
  aspect-ratio: auto;
  border-radius: 0;
}

.what-sec,
.inj-hd,
.inj-grid,
.program-sec,
.deaging-sec,
.caution-sec,
.faq-sec {
  padding-left: 0;
  padding-right: 0;
}

.what-sec {
  grid-template-columns: minmax(280px, 4fr) minmax(0, 6fr);
  gap: 80px;
  padding-top: 110px;
  padding-bottom: 100px;
}
.what-left h2,
.inj-hd h2,
.prog-body h2,
.deaging-body h2,
.caution-sec h2,
.faq-sec h2 {
  font-size: clamp(24px, 3.47vw, 50px);
  line-height: 1.25;
  letter-spacing: -.025em;
}
.what-left .sub-label,
.prog-body .en-cap,
.deaging-body .en-cap {
  font-size: 24px !important;
  line-height: 1.35;
  letter-spacing: .04em;
  color: var(--light);
  font-style: normal;
}
.what-right p,
.inj-card p,
.prog-body p,
.deaging-body p,
.banner-overlay p {
  font-size: 18px;
  line-height: 1.66;
  color: var(--mid);
}
.what-right p + p {
  margin-top: 18px;
}

.inj-hd {
  padding-bottom: 48px;
}
.inj-grid {
  gap: 56px;
  padding-bottom: 110px;
}
.inj-img {
  aspect-ratio: 16 / 10;
  margin-bottom: 24px;
}
.inj-card h3 {
  font-size: 24px;
  line-height: 1.4;
  margin-bottom: 10px;
}

.program-sec,
.deaging-sec {
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: center;
  margin-top: 80px;
}
.program-sec {
  padding-left: 0;
}
.prog-photo,
.deaging-photo {
  width: 100%;
  max-width: 650px;
  min-height: 600px;
  border-radius: 15px;
}
.prog-body,
.deaging-body {
  padding: 80px 72px;
  justify-content: center;
}
.prog-body h2,
.deaging-body h2 {
  margin-bottom: 18px;
}
.prog-body .en-cap,
.deaging-body .en-cap {
  margin-bottom: 24px;
}
.deaging-photo {
  margin-top: 0;
}

.stem-banner {
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  height: 460px;
  margin-top: 140px;
  border-radius: 0;
}
.banner-overlay {
  padding: 48px;
}
.banner-overlay h2 {
  font-size: clamp(28px, 4.17vw, 60px);
  line-height: 1.1;
}
.banner-overlay p {
  max-width: 880px;
  color: rgba(255,255,255,.82);
}

.caution-sec {
  padding-top: 110px;
  padding-bottom: 96px;
}
.faq-sec {
  padding-bottom: 110px;
}
.caution-sec h2,
.faq-sec h2 {
  margin-bottom: 48px;
}
.caution-list,
.faq-list {
  max-width: 960px;
}
.caution-q,
.faq-q {
  min-height: 72px;
}
.caution-q-text,
.faq-q-left p {
  font-size: 18px;
  line-height: 1.45;
}
.caution-a-inner p,
.caution-a-inner li,
.faq-a-inner p,
.faq-a-inner li {
  font-size: 16px;
  line-height: 1.62;
}

@media (max-width: 1024px) {
  :root { --stem-side: 40px; }

  .intro-label { font-size: 22px; }
  .intro h1 { font-size: 44px; }
  .intro-sub { font-size: 17px; line-height: 1.62; }

  .stem-hero {
    height: 300px;
  }

  .what-sec {
    grid-template-columns: 1fr;
    gap: 32px;
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .what-left .sub-label,
  .prog-body .en-cap,
  .deaging-body .en-cap {
    font-size: 18px !important;
  }
  .what-right p,
  .inj-card p,
  .prog-body p,
  .deaging-body p,
  .banner-overlay p {
    font-size: 16px;
    line-height: 1.64;
  }

  .inj-grid {
    gap: 36px;
    padding-bottom: 86px;
  }
  .program-sec,
  .deaging-sec {
    grid-template-columns: 1fr;
    gap: 36px;
    margin-top: 64px;
  }
  .prog-photo,
  .deaging-photo {
    max-width: none;
    min-height: 420px;
  }
  .prog-body,
  .deaging-body {
    padding: 0;
  }
  .deaging-sec {
    display: flex;
    flex-direction: column-reverse;
  }
}

@media (max-width: 768px) {
  :root { --stem-side: 24px; }

  .page-wrap {
    padding-bottom: 70px;
  }
  .intro {
    padding: 56px 0 42px;
  }
  .intro-label {
    font-size: 14px;
    line-height: 1.2;
    letter-spacing: .08em;
    margin-bottom: 12px;
  }
  .intro h1 {
    font-size: 30px;
    line-height: 1.18;
    margin-bottom: 14px;
  }
  .intro-sub {
    font-size: 14px;
    line-height: 1.58;
  }

  .stem-hero {
    height: 220px;
  }

  .what-sec {
    padding-top: 56px;
    padding-bottom: 56px;
    gap: 22px;
  }
  .what-left h2,
  .inj-hd h2,
  .prog-body h2,
  .deaging-body h2,
  .caution-sec h2,
  .faq-sec h2 {
    font-size: 28px;
    line-height: 1.22;
  }
  .what-left .sub-label,
  .prog-body .en-cap,
  .deaging-body .en-cap {
    font-size: 14px !important;
    line-height: 1.35;
    letter-spacing: .08em;
  }
  .what-right p,
  .inj-card p,
  .prog-body p,
  .deaging-body p,
  .banner-overlay p {
    font-size: 14px;
    line-height: 1.62;
  }

  .inj-hd {
    padding-bottom: 28px;
  }
  .inj-grid {
    grid-template-columns: 1fr;
    gap: 34px;
    padding-bottom: 62px;
  }
  .inj-card h3 {
    font-size: 18px;
    line-height: 1.45;
  }

  .program-sec,
  .deaging-sec {
    gap: 26px;
    margin-top: 48px;
  }
  .prog-photo,
  .deaging-photo {
    min-height: 260px;
    border-radius: 10px;
  }
  .prog-body h2,
  .deaging-body h2 {
    margin-bottom: 12px;
  }
  .prog-body .en-cap,
  .deaging-body .en-cap {
    margin-bottom: 16px;
  }

  .stem-banner {
    height: 320px;
    margin-top: 56px;
  }
  .banner-overlay {
    padding: 24px;
  }
  .banner-overlay h2 {
    font-size: 28px;
    margin-bottom: 14px;
  }

  .caution-sec {
    padding-top: 56px;
    padding-bottom: 56px;
  }
  .faq-sec {
    padding-bottom: 64px;
  }
  .caution-sec h2,
  .faq-sec h2 {
    margin-bottom: 28px;
  }
  .caution-q,
  .faq-q {
    min-height: 60px;
    padding-top: 16px;
    padding-bottom: 16px;
  }
  .caution-q-text,
  .faq-q-left p {
    font-size: 14px;
    line-height: 1.55;
  }
  .caution-a-inner {
    padding: 14px 18px 16px 44px;
  }
  .faq-a-inner {
    padding: 14px 18px 16px 36px;
  }
  .caution-a-inner p,
  .caution-a-inner li,
  .faq-a-inner p,
  .faq-a-inner li {
    font-size: 13.5px;
    line-height: 1.62;
  }
}
  