/* Bluefilm brand page responsive fix
   Add this block after the existing .bf-brand styles. */

html,
body {
  max-width: 100%;
}

.bf-brand *,
.bf-brand *::before,
.bf-brand *::after {
  box-sizing: border-box;
  min-width: 0;
}

.bf-brand .bf-brand__inner {
  width: calc(100% - 40px);
  max-width: 1180px;
  margin-right: auto;
  margin-left: auto;
}

.bf-brand {
  overflow: visible !important;
  padding-top:0;
  padding-bottom:0;
}

.bf-brand .bf-brand__hero::after {
  display: block;
}

.bf-brand .bf-brand__eyebrow::before {
  display: inline-block;
  flex: 0 0 auto;
}

@media screen and (max-width: 1100px) {
  html,
  body {
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  html {
    position: static !important;
    height: auto !important;
    min-height: 100% !important;
    left: auto !important;
    right: auto !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  body {
    position: static !important;
    height: auto !important;
    min-height: 100% !important;
    left: auto !important;
    right: auto !important;
    /*overflow-x: hidden !important;
    overflow-y: auto !important;*/
    overscroll-behavior: auto !important;
    touch-action: pan-y !important;
    -webkit-overflow-scrolling: touch;
  }

  #contents_wrap,
  #contents_wrap > div,
  .sub_contents,
  .bf-brand {
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    /*overflow-x: hidden !important;
    overflow-y: visible !important;*/
  }

  .bf-brand .bf-brand__cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .bf-brand .bf-brand__steps {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media screen and (max-width: 768px) {
  .bf-brand .bf-brand__inner {
    width: calc(100% - 28px);
  }

  .bf-brand .bf-brand__hero h2 {
    font-size: 30px;
    line-height: 1.28;
  }

  .bf-brand .bf-brand__eyebrow {
    font-size: 13px;
  }

  .bf-brand .bf-brand__sign {
    flex-wrap: wrap;
  }

  .bf-brand .bf-brand__cards,
  .bf-brand .bf-brand__steps {
    grid-template-columns: minmax(0, 1fr);
  }

  .bf-brand .bf-brand__cta-link {
    min-width: 0;
  }
}

@media screen and (max-width: 420px) {
  .bf-brand .bf-brand__hero h2 {
    font-size: 27px;
  }

  .bf-brand .bf-brand__title,
  .bf-brand .bf-brand__section-head h3,
  .bf-brand .bf-brand__cta h3 {
    font-size: 24px;
  }

  .bf-brand .bf-brand__card {
    padding: 24px 20px;
  }
}



.bf-brand {
  --bf-blue: #005aab;
  --bf-navy: #10243f;
  --bf-sky: #eaf5ff;
  --bf-line: #dce7f2;
  --bf-text: #1d2733;
  --bf-muted: #657486;
  width: 100%;
  color: var(--bf-text);
  font-family: "CarmenSansOTF-UltraLight", "Noto Sans KR", Arial, sans-serif;
  word-break: keep-all;
  overflow: hidden;
}

html,
body {
  max-width: 100%;
}

.bf-brand *,
.bf-brand *::before,
.bf-brand *::after {
  box-sizing: border-box;
  min-width: 0;
}

.bf-brand a {
  text-decoration: none;
}

.bf-brand .bf-brand__inner {
  width: calc(100% - 40px);
  max-width: 1180px;
  margin: 0 auto;
}

.bf-brand .bf-brand__hero {
  position: relative;
  min-height: 420px;
  display: flex;
  align-items: flex-end;
  padding: 92px 0 72px;
  background:
    linear-gradient(90deg, rgba(8, 28, 55, .88) 0%, rgba(8, 28, 55, .62) 47%, rgba(8, 28, 55, .18) 100%),
    url("/images/sin_03_f.jpg") center / cover no-repeat;
}

.bf-brand .bf-brand__hero::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 6px;
  /*background: linear-gradient(90deg, var(--bf-blue), #6bb8ff);*/
}

.bf-brand .bf-brand__hero-content {
  position: relative;
  z-index: 1;
  max-width: 660px;
}

.bf-brand .bf-brand__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  color: #b9dcff;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0;
}

.bf-brand .bf-brand__eyebrow::before {
  content: "";
  display: inline-block;
  flex: 0 0 auto;
  width: 34px;
  height: 2px;
  background: #7fc2ff;
}

.bf-brand .bf-brand__hero h2 {
  margin: 0;
  color: #fff;
  font-family: 'CarmenSansOTF-Heavy';
  font-size: 62px;
  line-height: 1.22;
  font-weight: 800;
  letter-spacing: 0;
}

.bf-brand .bf-brand__hero p {
  margin: 24px 0 0;
  color: rgba(255, 255, 255, .88);
  font-size: 19px;
  line-height: 1.75;
}

.bf-brand .bf-brand__intro {
  padding: 82px 0 74px;
  background: #fff;
}

.bf-brand .bf-brand__intro-grid {
  display: grid;
  grid-template-columns: .9fr 1fr;
  gap: 58px;
  align-items: start;
}

.bf-brand .bf-brand__title {
  margin: 0;
  color: var(--bf-navy);
  font-size: 34px;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: 0;
}

.bf-brand .bf-brand__title strong {
  color: var(--bf-blue);
  font-weight: 800;
}

.bf-brand .bf-brand__lead {
  margin: 20px 0 0;
  color: var(--bf-muted);
  font-size: 18px;
  line-height: 1.8;
}

.bf-brand .bf-brand__message {
  padding: 36px 38px;
  border-left: 4px solid var(--bf-blue);
  background: #f7fbff;
}

.bf-brand .bf-brand__message p {
  margin: 0;
  color: #2d3a48;
  font-size: 18px;
  line-height: 1.9;
}

.bf-brand .bf-brand__sign {
  display: flex;
  justify-content: flex-end;
  align-items: baseline;
  gap: 14px;
  margin-top: 28px;
  color: var(--bf-navy);
}

.bf-brand .bf-brand__sign span {
  color: var(--bf-muted);
  font-size: 16px;
}

.bf-brand .bf-brand__sign strong {
  font-size: 24px;
  font-weight: 800;
}

.bf-brand .bf-brand__strength {
  padding: 76px 0;
  background: var(--bf-sky);
}

.bf-brand .bf-brand__section-head {
  margin-bottom: 34px;
}

.bf-brand .bf-brand__section-head h3 {
  margin: 0;
  color: var(--bf-navy);
  font-size: 30px;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: 0;
}

.bf-brand .bf-brand__section-head p {
  margin: 12px 0 0;
  color: var(--bf-muted);
  font-size: 17px;
  line-height: 1.7;
}

.bf-brand .bf-brand__cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.bf-brand .bf-brand__card {
  min-height: 190px;
  padding: 28px 24px;
  border: 1px solid var(--bf-line);
  border-radius: 8px;
  background: #fff;
}

.bf-brand .bf-brand__card-num {
  display: block;
  margin-bottom: 24px;
  color: var(--bf-blue);
  font-family: Montserrat, Arial, sans-serif;
  font-size: 24px;
  font-weight: 400;
}

.bf-brand .bf-brand__card h4 {
  margin: 0 0 12px;
  color: var(--bf-navy);
  font-size: 21px;
  font-weight: 400;
  letter-spacing: 0;
}

.bf-brand .bf-brand__card p {
  margin: 0;
  color: var(--bf-muted);
  font-size: 16px;
  line-height: 1.7;
}

.bf-brand .bf-brand__process {
  padding: 78px 0 86px;
  background: #fff;
}

.bf-brand .bf-brand__steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-top: 1px solid var(--bf-line);
  border-bottom: 1px solid var(--bf-line);
}

.bf-brand .bf-brand__step {
  position: relative;
  padding: 30px 18px 32px;
  text-align: center;
}

.bf-brand .bf-brand__step + .bf-brand__step {
  border-left: 1px solid var(--bf-line);
}

.bf-brand .bf-brand__step span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  margin-bottom: 16px;
  border-radius: 50%;
  background: var(--bf-blue);
  color: #fff;
  font-family: Montserrat, Arial, sans-serif;
  font-size: 18px;
  font-weight: 400;
}

.bf-brand .bf-brand__step h4 {
  margin: 0 0 8px;
  color: var(--bf-navy);
  font-size: 18px;
  font-weight: 400;
}

.bf-brand .bf-brand__step p {
  margin: 0;
  color: var(--bf-muted);
  font-size: 15px;
  line-height: 1.55;
}

.bf-brand .bf-brand__cta {
  padding: 58px 0;
  background: #f5f3f3;
}

.bf-brand .bf-brand__cta-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.bf-brand .bf-brand__cta h3 {
  margin: 0;
  color: #111;
  font-size: 28px;
  line-height: 1.35;
  font-weight: 400;
}

.bf-brand .bf-brand__cta p {
  margin: 12px 0 0;
  color: #666;
  font-size: 17px;
  line-height: 1.7;
}

.bf-brand .bf-brand__cta-link {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 176px;
  height: 54px;
  padding: 0 26px;
  border-radius: 4px;
  background: #07162e;
  color: #fff;
  font-size: 17px;
  font-weight: 800;
}

@media screen and (max-width: 1100px) {
  html,
  body {
    min-width: 0 !important;
    width: 100% !important;
    /*overflow-x: hidden !important;*/
  }

  #contents_wrap,
  #contents_wrap > div,
  .sub_contents {
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    /*overflow-x: hidden !important;*/
  }

  .bf-brand .bf-brand__cards {
    grid-template-columns: repeat(2, 1fr);
  }

  .bf-brand .bf-brand__steps {
    grid-template-columns: repeat(3, 1fr);
  }

  .bf-brand .bf-brand__step:nth-child(4) {
    border-left: 0;
    border-top: 1px solid var(--bf-line);
  }

  .bf-brand .bf-brand__step:nth-child(5) {
    border-top: 1px solid var(--bf-line);
  }
}

@media screen and (max-width: 768px) {
  .bf-brand .bf-brand__inner {
    width: calc(100% - 28px);
  }

  .bf-brand .bf-brand__hero {
    min-height: 360px;
    padding: 70px 0 54px;
    background-position: center;
  }

  .bf-brand .bf-brand__hero h2 {
    font-size: 30px;
    line-height: 1.28;
  }

  .bf-brand .bf-brand__eyebrow {
    font-size: 13px;
  }

  .bf-brand .bf-brand__hero p,
  .bf-brand .bf-brand__lead,
  .bf-brand .bf-brand__message p {
    font-size: 16px;
  }

  .bf-brand .bf-brand__intro,
  .bf-brand .bf-brand__strength,
  .bf-brand .bf-brand__process {
    padding: 54px 0;
  }

  .bf-brand .bf-brand__intro-grid {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  .bf-brand .bf-brand__title,
  .bf-brand .bf-brand__section-head h3,
  .bf-brand .bf-brand__cta h3 {
    font-size: 26px;
  }

  .bf-brand .bf-brand__message {
    padding: 26px 22px;
  }

  .bf-brand .bf-brand__sign {
    flex-wrap: wrap;
  }

  .bf-brand .bf-brand__cards,
  .bf-brand .bf-brand__steps {
    grid-template-columns: 1fr;
  }

  .bf-brand .bf-brand__step + .bf-brand__step,
  .bf-brand .bf-brand__step:nth-child(4),
  .bf-brand .bf-brand__step:nth-child(5) {
    border-left: 0;
    border-top: 1px solid var(--bf-line);
  }

  .bf-brand .bf-brand__cta-box {
    display: block;
  }

  .bf-brand .bf-brand__cta-link {
    width: 100%;
    min-width: 0;
    margin-top: 24px;
  }
}

@media screen and (max-width: 420px) {
  .bf-brand .bf-brand__hero h2 {
    font-size: 27px;
  }

  .bf-brand .bf-brand__title,
  .bf-brand .bf-brand__section-head h3,
  .bf-brand .bf-brand__cta h3 {
    font-size: 24px;
  }

  .bf-brand .bf-brand__card {
    padding: 24px 20px;
  }
}



/* 필름효과 */
  .bf-film-effect {
    --bf-blue: #005aab;
    --bf-navy: #0b1f36;
    --bf-sky: #eaf5ff;
    --bf-line: #d9e3ee;
    --bf-text: #1f2937;
    --bf-muted: #667085;
    --bf-white: #fff;
    font-family: "CarmenSansOTF-UltraLight", "Apple SD Gothic Neo", "Malgun Gothic", Arial, sans-serif;
    color: var(--bf-text);
    background: #fff;
    overflow: hidden;
  }

  .bf-film-effect * {
    box-sizing: border-box;
  }

  .bf-film-wrap {
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
  }

  .bf-film-hero {
    position: relative;
    padding: 63px 0 72px;
    background:
      linear-gradient(115deg, rgba(5, 28, 52, .52), rgba(0, 90, 171, .15)),
      url("/images/sin_02_f.jpg") center/cover no-repeat;
    color: var(--bf-white);
  }

  .bf-film-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.02fr) minmax(320px, .98fr);
    gap: 44px;
    align-items: center;
  }

  .bf-film-kicker {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
    font-size: 15px;
    font-weight: 700;
    color: #cfe9ff;
  }

  .bf-film-kicker:before {
    content: "";
    width: 34px;
    height: 2px;
    background: #7cc7ff;
  }

  .bf-film-hero h2 {
    margin: 0;
    font-size: clamp(36px, 5vw, 60px);
    line-height: 1.14;
    letter-spacing: 0;
    font-weight: 800;
	font-size:62px;
	font-family: "CarmenSansOTF-Heavy";
  }

  .bf-film-hero p {
    max-width: 660px;
    margin: 22px 0 0;
    color: rgba(255, 255, 255, .86);
    font-size: 18px;
    line-height: 1.78;
    word-break: keep-all;
  }

  .bf-film-hero-points {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 30px;
    padding: 0;
    list-style: none;
  }

  .bf-film-hero-points li {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 14px;
    border: 1px solid rgba(255, 255, 255, .28);
    background: rgba(255, 255, 255, .1);
    color: #fff;
    font-size: 14px;
    font-weight: 400;
    backdrop-filter: blur(8px);
  }

  .bf-film-window {
    position: relative;
    min-height: 390px;
    border: 1px solid rgba(255, 255, 255, .28);
    background: rgba(255, 255, 255, .12);
    overflow: hidden;
    box-shadow: 0 24px 56px rgba(0, 0, 0, .26);
  }

  .bf-film-window:before,
  .bf-film-window:after {
    content: "";
    position: absolute;
    inset: 0;
  }

  .bf-film-window:before {
    background:
      linear-gradient(90deg, rgba(255, 255, 255, .16) 1px, transparent 1px),
      linear-gradient(0deg, rgba(255, 255, 255, .12) 1px, transparent 1px);
    background-size: 33.33% 100%, 100% 33.33%;
    z-index: 2;
  }

  .bf-film-window:after {
    background:
      linear-gradient(110deg, rgba(0, 90, 171, .72) 0 46%, rgba(255, 255, 255, .08) 46% 48%, rgba(255, 255, 255, .02) 48%),
      url("https://xn--jx2bj2ut0cqvp.com/theme/basic/img/0201_03.jpg") center/cover no-repeat;
    z-index: 1;
  }

  .bf-film-window-label {
    position: absolute;
    left: 24px;
    bottom: 24px;
    z-index: 3;
    display: grid;
    gap: 6px;
    padding: 15px 18px;
    background: rgba(7, 24, 42, .82);
    color: #fff;
  }

  .bf-film-window-label strong {
    font-size: 20px;
  }

  .bf-film-window-label span {
    font-size: 13px;
    color: #cfe9ff;
  }

  .bf-film-section {
    padding: 76px 0;
  }

  .bf-film-head {
    display: grid;
    grid-template-columns: minmax(0, .8fr) minmax(320px, 1fr);
    gap: 34px;
    align-items: end;
    margin-bottom: 34px;
  }

  .bf-film-head h3 {
    margin: 0;
    color: var(--bf-navy);
    font-size: clamp(28px, 3.4vw, 30px);
    line-height: 1.25;
    letter-spacing: 0;
  }

  .bf-film-head p {
    margin: 0;
    color: var(--bf-muted);
    font-size: 17px;
    line-height: 1.75;
    word-break: keep-all;
  }

  .bf-film-benefits {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
  }

  .bf-film-card {
    min-height: 276px;
    padding: 28px;
    border: 1px solid var(--bf-line);
    background: #fff;
    transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
  }

  .bf-film-card:hover {
    transform: translateY(-4px);
    border-color: rgba(0, 90, 171, .42);
    box-shadow: 0 18px 38px rgba(15, 45, 77, .12);
  }

  .bf-film-icon {
    display: grid;
    place-items: center;
    width: 56px;
    height: 56px;
    margin-bottom: 24px;
    background: var(--bf-sky);
    color: var(--bf-blue);
    font-size: 25px;
    font-weight: 800;
  }

  .bf-film-card h4 {
    margin: 0 0 12px;
    color: var(--bf-navy);
    font-size: 21px;
    line-height: 1.35;
    letter-spacing: 0;
	font-family: "CarmenSansOTF-Heavy";
  }

  .bf-film-card p {
    margin: 0;
    color: var(--bf-muted);
    font-size: 15.5px;
    line-height: 1.72;
    word-break: keep-all;
  }

  .bf-film-compare {
    background: #f6f9fc;
  }

  .bf-film-compare-grid {
    display: grid;
    grid-template-columns: minmax(0, .92fr) minmax(360px, 1.08fr);
    gap: 42px;
    align-items: center;
  }

  .bf-film-photo {
    position: relative;
    min-height: 420px;
    background: url("/images/window_af.jpg") center/cover no-repeat;
    overflow: hidden;
  }

  .bf-film-photo:after {
    content: "";
    position: absolute;
    inset: 0 50% 0 0;
    background: rgba(0, 90, 171, .42);
    border-right: 2px solid #fff;
  }

  .bf-film-badge {
    position: absolute;
    z-index: 2;
    right: 22px;
    top: 22px;
    padding: 12px 16px;
    background: #fff;
    color: var(--bf-blue);
    font-size: 14px;
    font-weight: 800;
    box-shadow: 0 14px 30px rgba(0, 0, 0, .14);
  }

  .bf-film-list {
    display: grid;
    gap: 14px;
    margin: 28px 0 0;
    padding: 0;
    list-style: none;
  }

  .bf-film-list li {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    padding: 18px 18px 0 18px;
    border: 1px solid var(--bf-line);
    background: #fff;
  }

  .bf-film-check {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    background: var(--bf-blue);
    color: #fff;
    font-size: 18px;
    font-weight: 800;
  }

  .bf-film-list strong {
    display: block;
    margin-bottom: 4px;
    color: var(--bf-navy);
    font-size: 17px;
  }

  .bf-film-list span {
    color: #fff;
    font-size: 15px;
    line-height: 1.65;
    word-break: keep-all;
  }

  .bf-film-process {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    border: 1px solid var(--bf-line);
  }

  .bf-film-step {
    min-height: 210px;
    padding: 26px;
    border-right: 1px solid var(--bf-line);
    background: #fff;
  }

  .bf-film-step:last-child {
    border-right: 0;
  }

  .bf-film-step em {
    display: block;
    margin-bottom: 44px;
    color: var(--bf-blue);
    font-style: normal;
    font-size: 14px;
    font-weight: 800;
  }

  .bf-film-step strong {
    display: block;
    margin-bottom: 10px;
    color: var(--bf-navy);
    font-size: 20px;
  }

  .bf-film-step p {
    margin: 0;
    color: var(--bf-muted);
    font-size: 15px;
    line-height: 1.62;
    word-break: keep-all;
  }

  .bf-film-cta {
    padding: 56px 0;
    background: var(--bf-navy);
    color: #fff;
  }

  .bf-film-cta-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
  }

  .bf-film-cta h3 {
    margin: 0 0 10px;
    font-size: clamp(25px, 3vw, 36px);
    letter-spacing: 0;
  }

  .bf-film-cta p {
    margin: 0;
    color: rgba(255, 255, 255, .76);
    font-size: 16px;
    line-height: 1.7;
    word-break: keep-all;
  }

  .bf-film-cta a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 172px;
    height: 52px;
    padding: 0 22px;
    background: #fff;
    color: var(--bf-blue);
    font-size: 16px;
    font-weight: 800;
    text-decoration: none;
  }

  @media (max-width: 1024px) {
    .bf-film-hero-grid,
    .bf-film-head,
    .bf-film-compare-grid {
      grid-template-columns: 1fr;
    }

    .bf-film-benefits {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .bf-film-process {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .bf-film-step:nth-child(2) {
      border-right: 0;
    }

    .bf-film-step:nth-child(-n + 2) {
      border-bottom: 1px solid var(--bf-line);
    }
  }

  @media (max-width: 640px) {
	.bf-film-hero h2{font-size:32px;}
    .bf-film-wrap {
      width: min(100% - 24px, 1180px);
    }

    .bf-film-hero {
      padding: 56px 0 48px;
    }

    .bf-film-hero p,
    .bf-film-head p {
      font-size: 15.5px;
    }

    .bf-film-window {
      min-height: 150px;
    }

    .bf-film-section {
      padding: 52px 0;
    }

    .bf-film-benefits,
    .bf-film-process {
      grid-template-columns: 1fr;
    }

    .bf-film-card {
      min-height: auto;
      padding: 24px;
    }

    .bf-film-photo {
      min-height: 300px;
    }

    .bf-film-step,
    .bf-film-step:nth-child(2) {
      border-right: 0;
      border-bottom: 1px solid var(--bf-line);
    }

    .bf-film-step:last-child {
      border-bottom: 0;
    }

    .bf-film-step em {
      margin-bottom: 24px;
    }

    .bf-film-cta-inner {
      display: grid;
    }

    .bf-film-cta a {
      width: 100%;
    }
  }
  
  
  
/* 제품 SSF */
	.ssf_wrap{width:1180px; margin:0 auto; font-family: 'CarmenSansOTF-UltraLight', sans-serif;}
  .ssf-hero {
    /*background: #0a1628;*/
	height:520px;
	/*background: url('https://globalwindowfilms.co.kr/theme/basic/img/architecture3_bg.jpg') center center no-repeat;*/
	background-size:cover;
    color: #fff;
    /*padding: 4rem 2.5rem 3.5rem;*/
    position: relative;
    overflow: hidden;
	 font-family: 'CarmenSansOTF-UltraLight', sans-serif;
  }
    
  .bg_prd_gr{width:100%; height:100%;background: linear-gradient(to right,    rgba(0, 28, 61, 1) 0%,   /* 1단계: 왼쪽 (불투명) */   rgba(0, 28, 61, .5) 40%,  /* 2단계: 중앙 (투명) */   rgba(0, 0, 0, 0) 100%  /* 3단계: 오른쪽 (불투명) */ );}
  .bg_prd_01{background: url('/images/bg_prd_01_v3.jpg') center center no-repeat;}
  
  .ssf-top-txt{width: calc(100% - 40px);    max-width: 1180px;    margin: 0 auto; padding-top:143px;}
  .ssf-hero::before {
    content: 'SSF';
    font-family: 'CarmenSansOTF-UltraLight', sans-serif;
    font-size: 14rem;
    color: rgba(255,255,255,0.04);
    position: absolute;
    right: -1rem;
    top: 50%;
    transform: translateY(-50%);
    line-height: 1;
    pointer-events: none;
  }
  .ssf-hero-badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: #7eb8f5;
    border: 1px solid rgba(126,184,245,0.4);
    padding: 4px 12px;
    border-radius: 2px;
    margin-bottom: 1.2rem;
  }
  .ssf-hero h1 {
    font-family: 'CarmenSansOTF-Heavy', sans-serif;
    font-size: 62px;
    letter-spacing: 0.05em;
    margin: 0 0 0.6rem;
    line-height: 1;
    color: #fff;
  }
  .ssf-hero p {
    font-size: 18px;
    color: #fff;
    line-height: 1.9;
    max-width: 520px;
    font-weight: 300;
  }

  .ssf-tabs {
    display: flex;
    border-bottom: 1px solid #e5e5e5;
    background: #fff;
    padding: 0 2.5rem;
    position: sticky;
    top: 0;
    z-index: 10;
  }
  .ssf-tab {
    font-size: 17px;
    font-weight: 500;
    color: #888;
    padding: 1rem 1.2rem 0.9rem;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    letter-spacing: 0.03em;
    transition: color 0.2s, border-color 0.2s;
    white-space: nowrap;
    text-decoration: none;
  }
  .ssf-tab:hover { color: #185FA5; }
  .ssf-tab.active { color: #185FA5; border-bottom-color: #185FA5; }

  .ssf-section {
    padding: 3rem 0;
    border-bottom: 1px solid #eee;
  }

  .ssf-label {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #185FA5;
    margin-bottom: 0.8rem;
  }
  .ssf-section-title {
    font-size: 28px;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 0.5rem;
  }
  .ssf-section-desc {
    font-size: 17px;
    color: #000;
    line-height: 1.8;
    font-weight: 300;
  }
  .ssf-desc-body {
    font-size: 17px;
    color: #000;
    line-height: 1.9;
    font-weight: 300;
    margin-top: 1rem;
  }

  .ssf-tech-block {
    background: #f7f8fa;
    border-radius: 12px;
    padding: 1.5rem;
    margin-top: 1.5rem;
    display: flex;
    gap: 1.2rem;
    align-items: flex-start;
  }
  .ssf-tech-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    background: #0a1628;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  .ssf-tech-icon i { font-size: 20px; color: #7eb8f5; }
  .ssf-tech-title { font-size: 19px; font-weight: 300; color: #1a1a1a; margin-bottom: 4px; }
  .ssf-tech-desc { font-size: 16px; color: #222; line-height: 1.7; font-weight: 300; }

  .ssf-spectrum {
    margin-top: 1.5rem;
    border-radius: 12px;
    border: 1px solid #eee;
    overflow: hidden;
  }
  .ssf-spectrum-row {
    display: grid;
    grid-template-columns: 100px 1fr;
    align-items: center;
    padding: 0.9rem 1.2rem;
    border-bottom: 1px solid #eee;
    gap: 1rem;
    font-size: 12px;
  }
  .ssf-spectrum-row:last-child { border-bottom: none; }
  .ssf-spectrum-row.header {
    background: #f7f8fa;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.05em;
    color: #000;
  }
  .ssf-spectrum-label { font-weight: 500; color: #1a1a1a; font-size: 12px; }
  .ssf-bar-wrap { height: 8px; background: #f0f0f0; border-radius: 4px; overflow: hidden; }
  .ssf-bar { height: 100%; border-radius: 4px; }
  .bar-pass { background: #378ADD; }
  .bar-block { background: #E24B4A; }
  .ssf-bar-val { font-size: 12px; font-weight: 500; text-align: right; }


  .ssf-spectrum-row-dr {
    display: grid;
    grid-template-columns: 1fr;
    align-items: center;
    padding: 0.9rem 1.2rem;
    border-bottom: 1px solid #eee;
    gap: 1rem;
    font-size: 12px;
  }
  
  .ssf-spectrum-row-dr2 {
    display: grid;
    grid-template-columns: 2fr;
    align-items: center;
    padding: 0.9rem 1.2rem;
    border-bottom: 1px solid #eee;
    gap: 1rem;
    font-size: 12px;
  }  
  
  .ssf-features {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1px;
    /*background: #eee;*/
    /*border: 1px solid #eee;*/
    /*border-radius: 12px;*/
    overflow: hidden;
    margin-top: 1.5rem;
	gap: 20px;
  }
  .ssf-feature-card {
    background: #fff;
    padding: 1.5rem 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
	border:1px solid #ddd;
	border-radius:8px;
  }
  .ssf-feature-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: #E6F1FB;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.3rem;
  }
  .ssf-feature-icon i { font-size: 18px; color: #185FA5; }
  .ssf-feature-title { font-size: 20px; font-weight: 400; color: #1a1a1a; }
  .ssf-feature-desc { font-size: 15px; color: #666; line-height: 1.7; font-weight: 300; }

  .ssf-spec-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 1.5rem;
    font-size: 17px;
  }
  .ssf-spec-table th {
    background: #0a1628;
    color: rgba(255,255,255,0.75);
    font-size: 11px;
    letter-spacing: 0.1em;
    font-weight: 500;
    text-align: center;
    padding: 11px 14px;
    text-transform: uppercase;
  }
  .ssf-spec-table th:first-child { text-align: left; border-radius: 8px 0 0 0; }
  .ssf-spec-table th:last-child { border-radius: 0 8px 0 0; }
  .ssf-spec-table td {
    padding: 17px 14px;
    border-bottom: 1px solid #eee;
    text-align: center;
    color: #1a1a1a;
  }
  .ssf-spec-table td:first-child {
    text-align: left;
    font-weight: 700;
    font-size: 15px;
    color: #185FA5;
  }
  .ssf-spec-table tr:last-child td { border-bottom: none; }
  .ssf-spec-table tr:nth-child(odd) td { background: #f7f8fa; }

  .ssf-spec-note {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    margin-top: 1rem;
  }
  .ssf-spec-pill {
    font-size: 11px;
    color: #666;
    border: 1px solid #ddd;
    border-radius: 20px;
    padding: 3px 10px;
  }
  .ssf-spec-pill strong { color: #1a1a1a; font-weight: 500; }

  .guide-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 1.2rem; }
  .guide-card {
    border: 1px solid #ddd;
    border-radius: 12px;
    padding: 1.2rem;
  }
  .guide-card.featured { border: 2px solid #185FA5; position: relative; }
  .guide-badge {
    position: absolute;
    top: -10px;
    left: 14px;
    background: #185FA5;
    color: #fff;
    font-size: 10px;
    font-weight: 500;
    padding: 2px 10px;
    border-radius: 10px;
    letter-spacing: 0.05em;
  }
  .guide-name {
    font-family: 'CarmenSansOTF-UltraLight', sans-serif;
    font-size: 1.7rem;
    letter-spacing: 0.05em;
    color: #185FA5;
    margin-bottom: 0.5rem;
  }
  .guide-desc { font-size: 16px; color: #666; line-height: 1.7; font-weight: 300; }
  .guide-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 0.8rem; }
  .guide-tag {
    font-size: 11px;
    background: #E6F1FB;
    color: #0C447C;
    padding: 3px 8px;
    border-radius: 3px;
  }

  .checklist-box {
    margin-top: 1.5rem;
    padding: 1.2rem;
    background: #f7f8fa;
    border-radius: 12px;
  }
  .checklist-title {
    font-size: 17px;
    font-weight: 500;
    color: #1a1a1a;
    margin-bottom: 0.7rem;
    display: flex;
    align-items: center;
    gap: 6px;
  }
  .checklist-title i { font-size: 16px; color: #185FA5; }
  .checklist-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
  }
  .checklist-item {
    font-size: 15px;
    color: #666;
    display: flex;
    gap: 6px;
    align-items: baseline;
  }
  .checklist-item span { color: #185FA5; font-weight: 500; }

  .ssf-cta {
    background: #0a1628;
    padding: 3rem 2.5rem;
    text-align: center;
	border-bottom:1px solid #1a1f2d;
  }
  .ssf-cta h2 { font-size: 22px; font-weight: 400; color: #fff; margin-bottom: 0.5rem; }
  .ssf-cta p { font-size: 17px; color: rgba(255,255,255,0.5); margin-bottom: 1.5rem; font-weight: 300; }
  .ssf-cta-btns { display: flex; justify-content: center; gap: 0.8rem; flex-wrap: wrap; }
  .btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #e3e1e1;
    color: #000;
    font-size: 17px;
    font-weight: 500;
    padding: 11px 24px;
    border-radius: 4px;
    border: none;
    cursor: pointer;
    font-family: 'CarmenSansOTF-UltraLight', sans-serif;
    text-decoration: none;
  }
  .btn-secondary {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #e3e1e1;
    color: rgba(255,255,255,0.7);
    font-size: 17px;
    font-weight: 500;
    padding: 11px 24px;
    border-radius: 4px;
    border: 1px solid rgba(255,255,255,0.2);
    cursor: pointer;
    font-family: 'CarmenSansOTF-UltraLight', sans-serif;
    text-decoration: none;
  }

  @media (max-width: 600px) {
	.ssf-top-txt{width:100%; padding:0 15px;}
	.ssf_wrap{width:100%; padding:0 5px;}
    .ssf-hero {/* padding: 2.5rem 1.2rem 2rem; */}
    .ssf-hero::before { font-size: 6rem; }
    .ssf-hero h1 { font-size: 2.6rem; }
    .ssf-tabs { padding: 0 1rem; overflow-x: auto; }
    .ssf-section { padding: 2rem 1.2rem; }
    .guide-grid { grid-template-columns: 1fr; }
    .checklist-grid { grid-template-columns: 1fr; }
    .ssf-cta { padding: 2rem 1.2rem; }
	.bg_prd_gr{padding:80px 15px 30px 15px;}
	.bg_prd_01{background-size:cover; background-position:right -74px bottom 0px;}
  }
  
  
  @media (max-width: 900px) {
	.ssf-top-txt{width:100%; padding:0 15px;}
	.ssf_wrap{width:100%; padding:0 5px;}
    .ssf-hero {/* padding: 2.5rem 1.2rem 2rem; */}
    .ssf-hero::before { font-size: 6rem; }
    .ssf-hero h1 { font-size: 2.6rem; }
    .ssf-tabs { padding: 0 1rem; overflow-x: auto; }
    .ssf-section { padding: 2rem 1.2rem; }
    .guide-grid { grid-template-columns: 1fr; }
    .checklist-grid { grid-template-columns: 1fr; }
    .ssf-cta { padding: 2rem 1.2rem; }
	.bg_prd_gr{padding:80px 15px 30px 15px;}
	.bg_prd_01{background-size:cover; background-position:right -74px bottom 0px;}
  }  
  
  
 /* refselctive */
  :root {
    --rf-gold:    #B8922A;
    --rf-gold-lt: #D4AA4A;
    --rf-gold-bg: #FDF8EE;
    --rf-dark:    #1A1610;
    --rf-gray:    #3D3830;
    --rf-mid:     #7A7060;
    --rf-line:    #E8DFC8;
    --rf-white:   #FFFFFF;
    --rf-smoke:   #F7F4EE;
    --font-head: 'CarmenSansOTF-UltraLight', 'Georgia', serif;
    --font-body: 'CarmenSansOTF-UltraLight', 'Apple SD Gothic Neo', 'Malgun Gothic', sans-serif;
  }
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--font-body);
    color: var(--rf-dark);
    background: var(--rf-white);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
  }

  /* ── Google Fonts ── */
  @import url('https://fonts.googleapis.com/css2?family=Noto+Serif+KR:wght@400;600;700&display=swap');

  /* ── Sub Nav ── */
  .rf-subnav {
    background: var(--rf-dark);
    padding: 0 24px;
    display: flex;
    gap: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .rf-subnav a {
    display: inline-block;
    padding: 14px 22px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    text-decoration: none;
    color: rgba(255,255,255,.45);
    white-space: nowrap;
    border-bottom: 2px solid transparent;
    transition: color .2s, border-color .2s;
  }
  .rf-subnav a:hover { color: rgba(255,255,255,.8); }
  .rf-subnav a.rf-active {
    color: var(--rf-gold-lt);
    border-bottom-color: var(--rf-gold-lt);
  }

  /* ── Hero ── */
  .rf-hero {
    position: relative;
    background: linear-gradient(135deg, #1A1610 0%, #2C2418 50%, #1A1610 100%);
    padding: 88px 24px 72px;
    overflow: hidden;
  }
  /* reflective shimmer lines */
  .rf-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
      repeating-linear-gradient(
        60deg,
        transparent,
        transparent 40px,
        rgba(184,146,42,.04) 40px,
        rgba(184,146,42,.04) 41px
      );
    pointer-events: none;
  }
  /* gold flare top-right */
  .rf-hero::after {
    content: '';
    position: absolute;
    top: -80px; right: -80px;
    width: 420px; height: 420px;
    background: radial-gradient(circle, rgba(212,170,74,.22) 0%, transparent 70%);
    pointer-events: none;
  }
  .rf-hero-inner {
    position: relative;
    max-width: 900px;
    margin: 0 auto;
  }
  .rf-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--rf-gold-lt);
    margin-bottom: 22px;
  }
  .rf-eyebrow::before {
    content: '';
    display: block;
    width: 28px; height: 1px;
    background: var(--rf-gold-lt);
  }
  .rf-hero-title {
    font-family: var(--font-head);
    font-size: clamp(36px, 6vw, 62px);
    font-weight: 700;
    color: var(--rf-white);
    line-height: 1.15;
    letter-spacing: -.01em;
    margin-bottom: 20px;
  }
  .rf-hero-title em {
    font-style: normal;
    background: linear-gradient(90deg, var(--rf-gold-lt), #F0CC70, var(--rf-gold-lt));
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: rf-shimmer 4s linear infinite;
  }
  @keyframes rf-shimmer {
    0% { background-position: 0% center; }
    100% { background-position: 200% center; }
  }
  .rf-hero-desc {
    font-size: 15px;
    color: rgba(255,255,255,.62);
    line-height: 1.8;
    max-width: 580px;
    margin-bottom: 40px;
  }
  .rf-hero-stats {
    display: flex;
    gap: 40px;
    flex-wrap: wrap;
  }
  .rf-hero-stat { }
  .rf-hero-stat .rf-stat-num {
    font-family: var(--font-head);
    font-size: 36px;
    font-weight: 700;
    color: var(--rf-gold-lt);
    line-height: 1;
    margin-bottom: 4px;
  }
  .rf-hero-stat .rf-stat-label {
    font-size: 11px;
    letter-spacing: .1em;
    color: rgba(255,255,255,.45);
    text-transform: uppercase;
  }
  .rf-hero-badge {
    position: absolute;
    top: 0; right: 0;
    background: var(--rf-gold);
    color: var(--rf-dark);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 6px 14px;
  }

  /* ── Tab Nav ── */
  .rf-tabs {
    position: sticky;
    top: 0;
    z-index: 50;
    background: var(--rf-white);
    border-bottom: 1px solid var(--rf-line);
    display: flex;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .rf-tabs button {
    flex-shrink: 0;
    padding: 16px 22px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--rf-mid);
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    transition: color .2s, border-color .2s;
  }
  .rf-tabs button:hover { color: var(--rf-gold); }
  .rf-tabs button.rf-tab-active {
    color: var(--rf-gold);
    border-bottom-color: var(--rf-gold);
  }

  /* ── Sections ── */
  .rf-section {
    padding: 80px 24px;
    max-width: 1180px;
    margin: 0 auto;
  }
  .rf-section-divider {
    border: none;
    border-top: 1px solid var(--rf-line);
    max-width: 1180px;
    margin: 0 auto;
  }
  .rf-section-label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--rf-gold);
    margin-bottom: 10px;
  }
  .rf-section-title {
    font-family: var(--font-head);
    font-size: 28px;
    font-weight: 700;
    color: var(--rf-dark);
    line-height: 1.3;
    margin-bottom: 12px;
  }
  .rf-section-sub {
    font-size: 17px;
    color: #000;
    line-height: 1.75;
    /*max-width: 600px;*/
    margin-bottom: 48px;
  }

  /* ── Overview: TSER Bar Chart ── */
  .rf-chart-wrap {
    background: var(--rf-smoke);
    border-radius: 12px;
    padding: 40px 32px 32px;
    margin-bottom: 24px;
  }
  .rf-chart-title {
    font-size: 17px;
    font-weight: 400;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #000;
    margin-bottom: 28px;
  }
  .rf-bar-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
  }
  .rf-bar-label {
    font-size: 17px;
    font-weight: 400;
    color: var(--rf-gray);
    width: 152px;
    flex-shrink: 0;
  }
  .rf-bar-track {
    flex: 1;
    height: 28px;
    background: var(--rf-line);
    border-radius: 4px;
    overflow: hidden;
    position: relative;
  }
  .rf-bar-fill {
    height: 100%;
    border-radius: 4px;
    display: flex;
    align-items: center;
    padding-left: 10px;
    font-size: 15px;
    font-weight: 400;
    color: var(--rf-dark);
    transition: width 1s cubic-bezier(.4,0,.2,1);
  }
  .rf-bar-fill.rf-gold-bar {
    background: linear-gradient(90deg, var(--rf-gold), var(--rf-gold-lt));
    color: var(--rf-dark);
  }
  .rf-bar-fill.rf-muted-bar {
    background: #C8BFA8;
    color: var(--rf-gray);
  }
  .rf-chart-note {
    font-size: 15px;
    color: var(--rf-mid);
    margin-top: 16px;
  }

  /* ── Features ── */
  .rf-features {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 24px;
  }
  .rf-feat-card {
    background: var(--rf-smoke);
    border-radius: 10px;
    padding: 28px 24px;
    border-top: 3px solid var(--rf-gold);
    transition: transform .2s, box-shadow .2s;
  }
  .rf-feat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(184,146,42,.12);
  }
  .rf-feat-icon {
    font-size: 28px;
    margin-bottom: 14px;
    display: block;
  }
  .rf-feat-title {
    font-size: 20px;
    font-weight: 400;
    color: var(--rf-dark);
    margin-bottom: 8px;
    line-height: 1.35;
  }
  .rf-feat-desc {
    font-size: 16px;
    color: var(--rf-mid);
    line-height: 1.7;
  }

  /* ── Spec Table ── */
  .rf-table-wrap {
    overflow-x: auto;
    border-radius: 10px;
    border: 1px solid var(--rf-line);
  }
  .rf-spec-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
  }
  .rf-spec-table thead tr {
    background: var(--rf-dark);
    color: var(--rf-white);
  }
  .rf-spec-table thead th {
    padding: 14px 18px;
    text-align: center;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    white-space: nowrap;
  }
  .rf-spec-table thead th:first-child { text-align: left; }
  .rf-spec-table thead th .rf-th-sub {
    display: block;
    font-size: 10px;
    font-weight: 400;
    opacity: .6;
    letter-spacing: .06em;
    text-transform: none;
    margin-top: 2px;
  }
  .rf-spec-table tbody tr {
    border-bottom: 1px solid var(--rf-line);
    transition: background .15s;
  }
  .rf-spec-table tbody tr:last-child { border-bottom: none; }
  .rf-spec-table tbody tr:hover { background: var(--rf-gold-bg); }
  .rf-spec-table tbody td {
    padding: 16px 18px;
    text-align: center;
    color: var(--rf-gray);
    font-weight: 500;
  }
  .rf-spec-table tbody td:first-child {
    text-align: left;
    font-weight: 400;
    color: var(--rf-dark);
    font-size: 17px;
  }
  .rf-spec-table .rf-tser-cell {
    color: var(--rf-gold);
    font-weight: 400;
    font-size: 15px;
  }
  .rf-spec-table .rf-highlight-row {
    background: var(--rf-gold-bg);
  }

  /* Legend */
  .rf-spec-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 24px;
    margin-top: 20px;
  }
  .rf-spec-legend span {
    font-size: 12px;
    color: var(--rf-mid);
  }
  .rf-spec-legend strong {
    color: var(--rf-dark);
    font-weight: 700;
  }

  /* ── Selection Guide ── */
  .rf-guide-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 20px;
    margin-bottom: 40px;
  }
  .rf-guide-card {
    border: 1.5px solid var(--rf-line);
    border-radius: 10px;
    padding: 28px 24px;
    position: relative;
    transition: border-color .2s, box-shadow .2s;
  }
  .rf-guide-card:hover {
    border-color: var(--rf-gold);
    box-shadow: 0 4px 20px rgba(184,146,42,.1);
  }
  .rf-guide-card.rf-guide-best {
    border-color: var(--rf-gold);
    background: var(--rf-gold-bg);
  }
  .rf-guide-best-badge {
    position: absolute;
    top: -1px; right: 20px;
    background: var(--rf-gold);
    color: var(--rf-dark);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: 4px 10px;
    border-radius: 0 0 6px 6px;
  }
  .rf-guide-product {
    font-size: 18px;
    font-weight: 800;
    color: var(--rf-dark);
    margin-bottom: 6px;
  }
  .rf-guide-tser {
    font-size: 16px;
    font-weight: 400;
    color: var(--rf-gold);
    margin-bottom: 14px;
  }
  .rf-guide-desc {
    font-size: 16px;
    color: var(--rf-mid);
    line-height: 1.7;
    margin-bottom: 16px;
  }
  .rf-guide-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
  }
  .rf-guide-tag {
    background: rgba(184,146,42,.1);
    color: var(--rf-gold);
    font-size: 13px;
    font-weight: 400;
    padding: 3px 10px;
    border-radius: 20px;
  }

  .rf-guide-checklist {
    background: var(--rf-smoke);
    border-radius: 10px;
    padding: 28px 28px 24px;
  }
  .rf-guide-checklist h4 {
    font-size: 18px;
    font-weight: 400;
    color: #333;
    letter-spacing: -0.5px;
    text-transform: uppercase;
    margin-bottom: 16px;
  }
  .rf-guide-checklist ul {
    list-style: none;
    display: grid;
    grid-template-columns:1fr 1fr;
    gap: 10px;
  }
  .rf-guide-checklist li {
    font-size: 16px;
    color: var(--rf-gray);
    /*padding-left: 18px;*/
    position: relative;
    line-height: 1.5;
  }
  .rf-guide-checklist li::before {
    content: '·';
    position: absolute;
    left: 6px;
    color: var(--rf-gold);
    font-weight: 700;
  }

  /* ── CTA ── */
  .rf-cta {
    background: linear-gradient(135deg, var(--rf-dark) 0%, #2C2418 100%);
    padding: 72px 24px;
    text-align: center;
    position: relative;
    overflow: hidden;
  }
  .rf-cta::before {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
      45deg,
      transparent,
      transparent 60px,
      rgba(184,146,42,.03) 60px,
      rgba(184,146,42,.03) 61px
    );
  }
  .rf-cta-inner { position: relative; max-width: 560px; margin: 0 auto; }
  .rf-cta h2 {
    font-family: var(--font-head);
    font-size: clamp(22px, 4vw, 32px);
    font-weight: 700;
    color: var(--rf-white);
    line-height: 1.35;
    margin-bottom: 14px;
  }
  .rf-cta p {
    font-size: 14px;
    color: rgba(255,255,255,.55);
    line-height: 1.75;
    margin-bottom: 36px;
  }
  .rf-cta-btns {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
  }
  .rf-btn-primary {
    display: inline-block;
    background: var(--rf-gold);
    color: var(--rf-dark);
    font-size: 13px;
    font-weight: 800;
    letter-spacing: .06em;
    text-decoration: none;
    padding: 14px 28px;
    border-radius: 4px;
    transition: background .2s, transform .15s;
  }
  .rf-btn-primary:hover {
    background: var(--rf-gold-lt);
    transform: translateY(-1px);
  }
  .rf-btn-secondary {
    display: inline-block;
    background: transparent;
    color: rgba(255,255,255,.75);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .06em;
    text-decoration: none;
    padding: 14px 28px;
    border-radius: 4px;
    border: 1.5px solid rgba(255,255,255,.25);
    transition: border-color .2s, color .2s;
  }
  .rf-btn-secondary:hover {
    border-color: rgba(255,255,255,.6);
    color: var(--rf-white);
  }

  /* ── Responsive ── */
  @media (max-width: 600px) {
    .rf-hero { padding: 60px 18px 52px; }
    .rf-hero-stats { gap: 24px; }
    .rf-section { padding: 56px 18px; }
    .rf-bar-label { width: 110px; font-size: 12px; }
    .rf-chart-wrap { padding: 28px 18px 20px; }
    .rf-tabs button { padding: 14px 16px; font-size: 11px; }
	
	
	
/* product_01 */
 .bf-product {
    --bf-ink: #15202b;
    --bf-muted: #5f6f80;
    --bf-line: #d8e4ee;
    --bf-blue: #005aab;
    --bf-cyan: #16a6d9;
    --bf-green: #20a66b;
    --bf-yellow: #f5c84c;
    --bf-bg: #f5f9fc;
    --bf-dark: #0d2235;
    color: var(--bf-ink);
    font-family: inherit;
    line-height: 1.65;
    word-break: keep-all;
    overflow: hidden;
  }

  .bf-product * {
    box-sizing: border-box;
  }

  .bf-product a {
    color: inherit;
    text-decoration: none;
  }

  .bf-product img {
    display: block;
    max-width: 100%;
    height: auto;
  }

  .bf-product .bf-wrap {
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
  }

  .bf-product .bf-hero {
    position: relative;
    min-height: 520px;
    display: grid;
    align-items: center;
    background:
      linear-gradient(90deg, rgba(9, 32, 50, 0.94) 0%, rgba(9, 32, 50, 0.8) 45%, rgba(9, 32, 50, 0.2) 100%),
      url("https://xn--jx2bj2ut0cqvp.com/theme/basic/img/0301_01.jpg") center / cover no-repeat;
  }

  .bf-product .bf-hero-body {
    max-width: 720px;
    padding: 86px 0;
    color: #fff;
  }

  .bf-product .bf-label {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
    color: #d9f4ff;
    font-size: 15px;
    font-weight: 700;
  }

  .bf-product .bf-label::before {
    content: "";
    width: 38px;
    height: 2px;
    background: var(--bf-cyan);
  }

  .bf-product .bf-hero h2 {
    margin: 0;
    font-size: clamp(34px, 5vw, 62px);
    line-height: 1.14;
    font-weight: 800;
    letter-spacing: 0;
  }

  .bf-product .bf-hero p {
    max-width: 620px;
    margin: 24px 0 0;
    color: rgba(255, 255, 255, 0.84);
    font-size: 19px;
  }

  .bf-product .bf-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 34px;
  }

  .bf-product .bf-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 22px;
    border: 1px solid transparent;
    border-radius: 6px;
    font-size: 16px;
    font-weight: 700;
    white-space: nowrap;
  }

  .bf-product .bf-btn-primary {
    background: var(--bf-cyan);
    color: #fff;
  }

  .bf-product .bf-btn-ghost {
    border-color: rgba(255, 255, 255, 0.55);
    color: #fff;
  }

  .bf-product .bf-section {
    padding: 84px 0;
  }

  .bf-product .bf-section-soft {
    background: var(--bf-bg);
  }

  .bf-product .bf-heading {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 28px;
    margin-bottom: 34px;
  }

  .bf-product .bf-heading h3 {
    margin: 0;
    font-size: clamp(28px, 3.2vw, 42px);
    line-height: 1.24;
    font-weight: 800;
    letter-spacing: 0;
  }

  .bf-product .bf-heading p {
    max-width: 550px;
    margin: 0;
    color: var(--bf-muted);
    font-size: 17px;
  }

  .bf-product .bf-feature-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
  }

  .bf-product .bf-feature {
    min-height: 196px;
    padding: 26px;
    border: 1px solid var(--bf-line);
    border-radius: 8px;
    background: #fff;
  }

  .bf-product .bf-feature strong {
    display: block;
    margin-top: 18px;
    font-size: 20px;
    line-height: 1.35;
  }

  .bf-product .bf-feature p {
    margin: 10px 0 0;
    color: var(--bf-muted);
    font-size: 15px;
  }

  .bf-product .bf-icon {
    display: inline-grid;
    place-items: center;
    width: 48px;
    height: 48px;
    border-radius: 8px;
    background: #e7f6fd;
    color: var(--bf-blue);
    font-size: 24px;
    font-weight: 800;
  }

  .bf-product .bf-split {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: 46px;
    align-items: center;
  }

  .bf-product .bf-photo {
    overflow: hidden;
    border-radius: 8px;
    border: 1px solid var(--bf-line);
    background: #fff;
  }

  .bf-product .bf-photo img {
    width: 100%;
  }

  .bf-product .bf-checks {
    display: grid;
    gap: 14px;
    margin: 28px 0 0;
    padding: 0;
    list-style: none;
  }

  .bf-product .bf-checks li {
    position: relative;
    padding: 16px 20px 16px 20px;
    border: 1px solid var(--bf-line);
    border-radius: 8px;
    background: #fff;
    color: var(--bf-muted);
  }

  .bf-product .bf-checks li::before {
    content: "";
    position: absolute;
    left: 18px;
    top: 22px;
    width: 12px;
    height: 7px;
    border-left: 2px solid var(--bf-green);
    border-bottom: 2px solid var(--bf-green);
    transform: rotate(-45deg);
  }

  .bf-product .bf-lineup {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
  }

  .bf-product .bf-lineup-card {
    overflow: hidden;
    border: 1px solid var(--bf-line);
    border-radius: 8px;
    background: #fff;
  }

  .bf-product .bf-lineup-card figure {
    margin: 0;
    aspect-ratio: 16 / 10;
    background: #eaf2f8;
    overflow: hidden;
  }

  .bf-product .bf-lineup-card figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .bf-product .bf-lineup-card div {
    padding: 24px;
  }

  .bf-product .bf-lineup-card h4 {
    margin: 0;
    font-size: 22px;
    line-height: 1.35;
  }

  .bf-product .bf-lineup-card p {
    margin: 10px 0 0;
    color: var(--bf-muted);
    font-size: 15px;
  }

  .bf-product .bf-spec {
    overflow: hidden;
    border: 1px solid var(--bf-line);
    border-radius: 8px;
    background: #fff;
  }

  .bf-product .bf-spec-row {
    display: grid;
    grid-template-columns: 220px 1fr;
    border-top: 1px solid var(--bf-line);
  }

  .bf-product .bf-spec-row:first-child {
    border-top: 0;
  }

  .bf-product .bf-spec-row strong,
  .bf-product .bf-spec-row span {
    padding: 18px 22px;
  }

  .bf-product .bf-spec-row strong {
    background: #edf5fb;
    color: var(--bf-dark);
  }

  .bf-product .bf-spec-row span {
    color: var(--bf-muted);
  }

  .bf-product .bf-detail-stack {
    display: grid;
    gap: 18px;
  }

  .bf-product .bf-detail-stack img {
    width: 100%;
    border: 1px solid var(--bf-line);
    border-radius: 8px;
    background: #fff;
  }

  .bf-product .bf-cta {
    background: var(--bf-dark);
    color: #fff;
  }

  .bf-product .bf-cta-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
    padding: 54px 0;
  }

  .bf-product .bf-cta h3 {
    margin: 0;
    font-size: clamp(26px, 3vw, 38px);
    line-height: 1.25;
  }

  .bf-product .bf-cta p {
    margin: 12px 0 0;
    color: rgba(255, 255, 255, 0.72);
  }

  @media (max-width: 980px) {
  
  .inquiry .btn_req{width:100%;}
  
    .bf-product .bf-hero {
      min-height: 460px;
      background:
        linear-gradient(90deg, rgba(9, 32, 50, 0.95) 0%, rgba(9, 32, 50, 0.78) 100%),
        url("https://xn--jx2bj2ut0cqvp.com/theme/basic/img/0301_01.jpg") center / cover no-repeat;
    }
	
	.main_prd_img{padding:0 15px 30px 15px;;}

    .bf-product .bf-heading,
    .bf-product .bf-cta-inner {
      display: block;
    }

    .bf-product .bf-heading p {
      margin-top: 14px;
    }

    .bf-product .bf-feature-grid,
    .bf-product .bf-lineup {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .bf-product .bf-split {
      grid-template-columns: 1fr;
      gap: 30px;
    }

    .bf-product .bf-cta .bf-hero-actions {
      margin-top: 24px;
    }
  }

  @media (max-width: 640px) {
    .bf-product .bf-wrap {
      width: min(100% - 28px, 1180px);
    }

    .bf-product .bf-hero-body {
      padding: 68px 0;
    }

    .bf-product .bf-hero p {
      font-size: 16px;
    }

    .bf-product .bf-section {
      padding: 58px 0;
    }

    .bf-product .bf-feature-grid,
    .bf-product .bf-lineup {
      grid-template-columns: 1fr;
    }

    .bf-product .bf-feature {
      min-height: auto;
      padding: 22px;
    }

    .bf-product .bf-hero-actions,
    .bf-product .bf-cta .bf-hero-actions {
      display: grid;
      grid-template-columns: 1fr;
    }

    .bf-product .bf-btn {
      width: 100%;
    }

    .bf-product .bf-spec-row {
      grid-template-columns: 1fr;
    }

    .bf-product .bf-spec-row span {
      padding-top: 0;
    }
  }
  
  
/* 상품 라인 본문 이미지 */
  @media (max-width: 980px) {
	.prd_img img{width:100%;} 
	.ssf-desc-body{font-size:15px;}
  }
