@charset "UTF-8";
@font-face {
  font-family: "D-DIN";
  src: url("../../fonts/D-DIN/D-DIN-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
:root {
  --c-sky-blue-01: #00a6f8;
  --c-sky-blue-02: #1094ff;
  --c-sky-blue-03: #3da4ff;
  --c-sky-blue-04: #008eff;
  --grad-blue-01: linear-gradient(90deg, #2294ff, #017fff);
}

/* --- layout.css: 余白ユーティリティ（本ページで使用分のみ） --- */
:root {
  --fs-12: clamp(9px, 9px + 3 * (100vw - 375px) / 905, 12px);
  --fs-13: clamp(10px, 10px + 3 * (100vw - 375px) / 905, 13px);
  --fs-14: clamp(11px, 11px + 3 * (100vw - 375px) / 905, 14px);
  --fs-15: clamp(12px, 12px + 3 * (100vw - 375px) / 905, 15px);
  --fs-16: clamp(14px, 14px + 2 * (100vw - 375px) / 905, 16px);
  --fs-17: clamp(14px, 14px + 3 * (100vw - 375px) / 905, 17px);
  --fs-18: clamp(16px, 16px + 2 * (100vw - 375px) / 905, 18px);
  --fs-19: clamp(16px, 16px + 3 * (100vw - 375px) / 905, 19px);
  --fs-20: clamp(16px, 16px + 4 * (100vw - 375px) / 905, 20px);
  --fs-21: clamp(17px, 17px + 7 * (100vw - 375px) / 905, 21px);
  --fs-22: clamp(17px, 17px + 5 * (100vw - 375px) / 905, 22px);
  --fs-23: clamp(17px, 17px + 6 * (100vw - 375px) / 905, 23px);
  --fs-24: clamp(17px, 17px + 7 * (100vw - 375px) / 905, 24px);
  --fs-27: clamp(18px, 18px + 7 * (100vw - 375px) / 905, 27px);
  --fs-28: clamp(19px, 19px + 9 * (100vw - 375px) / 905, 28px);
  --fs-30: clamp(20px, 20px + 10 * (100vw - 375px) / 905, 30px);
  --fs-32: clamp(21px, 21px + 11 * (100vw - 375px) / 905, 32px);
  --fs-35: clamp(22px, 22px + 12 * (100vw - 375px) / 905, 35px);
  --fs-37: clamp(23px, 23px + 13 * (100vw - 375px) / 905, 37px);
  --fs-40: clamp(25px, 25px + 15 * (100vw - 375px) / 905, 40px);
  --fs-48: clamp(29px, 29px + 19 * (100vw - 375px) / 905, 48px);
}
.mt4 {
  margin-top: clamp(2px, 2px + 2 * (100vw - 375px) / 905, 4px);
}
.mt80 {
  margin-top: clamp(38px, 38px + 42 * (100vw - 375px) / 905, 80px);
}
.mb24 {
  margin-bottom: clamp(20px, 20px + 4 * (100vw - 375px) / 905, 24px);
}
.mb48 {
  margin-bottom: clamp(30px, 30px + 18 * (100vw - 375px) / 905, 48px);
}
.mb56 {
  margin-bottom: clamp(32px, 32px + 24 * (100vw - 375px) / 905, 56px);
}
.mb92 {
  margin-bottom: clamp(40px, 40px + 52 * (100vw - 375px) / 905, 92px);
}
.pt16 {
  padding-top: clamp(14px, 14px + 2 * (100vw - 375px) / 905, 16px);
}
.pt80 {
  padding-top: clamp(38px, 38px + 42 * (100vw - 375px) / 905, 80px);
}
.pt240 {
  padding-top: clamp(110px, 110px + 130 * (100vw - 375px) / 905, 240px);
}
.pt300 {
  padding-top: clamp(140px, 140px + 160 * (100vw - 375px) / 905, 300px);
}
.pb24 {
  padding-bottom: clamp(20px, 20px + 4 * (100vw - 375px) / 905, 24px);
}
.pb64 {
  padding-bottom: clamp(34px, 34px + 30 * (100vw - 375px) / 905, 64px);
}
.pt120 {
  padding-top: clamp(50px, 50px + 70 * (100vw - 375px) / 905, 120px);
}
.pb120 {
  padding-bottom: clamp(50px, 50px + 70 * (100vw - 375px) / 905, 120px);
}
.pb140 {
  padding-bottom: clamp(60px, 60px + 80 * (100vw - 375px) / 905, 140px);
}
.pt180 {
  padding-top: clamp(80px, 80px + 100 * (100vw - 375px) / 905, 180px);
}
.pb180 {
  padding-bottom: clamp(80px, 80px + 100 * (100vw - 375px) / 905, 180px);
}

#tomakomai-port {
  color: #00268d;
}

/* --------------------------------
  tp-intro
--------------------------------*/
#tp-intro {
  position: relative;
}
#tp-intro .tp-intro__img,
#tp-intro .tp-intro__img-bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: bottom center;
}
#tp-intro .tp-intro__img {
  z-index: -2;
}
#tp-intro .tp-intro__img-bg {
  z-index: -1;
}
#tp-intro h2.cube-txt-anime {
  display: block;
  text-align: center;
}
#tp-intro h2 img {
  width: clamp(240px, 30vw, 470px);
  height: auto;
  margin-left: auto;
  margin-right: auto;
  mix-blend-mode: multiply;
}

#tp-intro p {
  text-align: center;
  font-size: var(--fs-19);
  font-weight: var(--fw-semibold);
  line-height: 1.6;
  letter-spacing: 0.1em;
  color: #0e3ba8;
  opacity: 0.7;
}

/* --------------------------------
  tp-feature
--------------------------------*/
#tp-feature .tp-feature__inner {
  display: flex;
  flex-wrap: wrap;
  row-gap: clamp(24px, 4vw, 32px);
  column-gap: clamp(24px, 4vw, 64px);
  align-items: stretch;
  /* 画像はみ出し量（画像側で使用） */
  --_breakout-right: max(0px, (100vw - 1100px) / 2);
}
#tp-feature .tp-feature__text {
  width: 100%;
  max-width: 480px;
  flex: 0 1 480px;
}
#tp-feature .tp-feature__title {
  margin: 0 0 clamp(20px, 3vw, 40px);
  font-size: var(--fs-28);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.7em;
}
#tp-feature .tp-feature__body p {
  line-height: 2;
}
#tp-feature .tp-feature__media {
  flex: 1 1 0;
  min-width: 0;
}
#tp-feature .tp-feature__media img {
  /* flex item ではなく画像自体をはみ出させる */
  width: calc(100% + var(--_breakout-right));
  max-width: none;
  height: 100%;
  object-fit: cover;
  object-position: left center;
  display: block;
}

#tp-feature .tp-feature__sub-ttl {
  flex: 0 0 100%;
  margin: 0;
  text-align: center;
  font-family: var(--font-shippori);
  font-size: var(--fs-48);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.15em;
  line-height: 1.5;
  background-image: linear-gradient(145deg, #003ea6, #01023e 99%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  text-align: right;
  text-decoration-line: underline;
  text-decoration-color: #f90000;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
}
@media screen and (max-width: 1200px) {
  #tp-feature .tp-feature__inner {
    /* container-1100 の padding: 0 5% に対応 */
    --_breakout-right: 5vw;
  }
}
@media screen and (max-width: 1024px) {
  #tp-feature .tp-feature__inner {
    flex-direction: column;
    --_breakout-right: 0px;
  }
  #tp-feature .tp-feature__text {
    max-width: 100%;
    flex: 0 0 100%;
  }
  #tp-feature .tp-feature__media {
    flex: 0 0 100%;
    width: 100%;
    height: fit-content;
  }
  #tp-feature .tp-feature__media img {
    width: 100%;
    height: auto;
    object-fit: contain;
  }
}
@media screen and (max-width: 768px) {
  #tp-feature .tp-feature__sub-ttl {
    font-size: var(--fs-35);
  }
  #tp-feature .tp-feature__title {
    font-size: var(--fs-24);
  }
}
/* --------------------------------
  tp-points
--------------------------------*/
#tp-points {
  position: relative;
}

#tp-points::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 340px;
  background-image: linear-gradient(#ffffff, #a3ecff);
  z-index: -1;
  pointer-events: none;
}
#tp-points .tp-points__outer {
  padding-bottom: 140px;
}

#tp-points .tp-points__intro {
  display: flex;
  align-items: flex-start;
}
#tp-points .tp-points__intro-title {
  margin: 0;
  writing-mode: vertical-rl;
  text-orientation: upright;
  font-family: var(--font-shippori);
  font-size: var(--fs-35);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.1em;
  line-height: 1.2;
  color: #262626;
  white-space: nowrap;
  flex: 0 0 auto;
  text-decoration: underline;
  text-decoration-color: var(--c-white);
  text-decoration-thickness: 1px;
  text-underline-offset: 10px;
  margin-right: 56px;
}
#tp-points .tp-points__intro-body {
  flex: 1 1 auto;
  min-width: 0;
  display: block;
}
#tp-points .tp-points__intro-kicker {
  display: flex;
  align-items: center;
  gap: 0.5em;
  margin: 0 0 10px;
  font-family: var(--font-shippori);
  font-size: var(--fs-30);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.1em;
  color: #262626;
}
#tp-points .tp-points__intro-kicker::before {
  content: "";
  flex-shrink: 0;
  width: 8px;
  height: 13px;
  background: #ff0000;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
}
#tp-points .tp-points__intro-note {
  font-size: var(--fs-14);
  line-height: 1.6;
  opacity: 0.85;
  color: #262626;
}
#tp-points .tp-points__intro-text {
  line-height: 1.9;
  color: #272727;
}

#tp-points .second-txt {
  padding-left: 7em;
}
#tp-points .tp-points__bg-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: top center;
  z-index: -2;
}
#tp-points .points__intro-img-01 {
  position: absolute;
  top: -40px;
  right: 100%;
  width: clamp(140px, 25vw, 439px);
  height: auto;
  aspect-ratio: 439 / 621;
  object-fit: contain;
  transform: translateX(25%);
  z-index: -1;
  pointer-events: none;
}
#tp-points .points__intro-img-02 {
  position: absolute;
  top: 24px;
  right: clamp(20px, 4%, 80px);
  width: clamp(40px, 10vw, 94px);
  height: auto;
  aspect-ratio: 94 / 133;
  object-fit: contain;
  pointer-events: none;
}
@media screen and (max-width: 1600px) {
  #tp-points .tp-points__outer {
    padding-bottom: clamp(38px, 38px + 42 * (100vw - 375px) / 905, 80px);
  }
}
@media screen and (max-width: 1400px) {
  #tp-points .points__intro-img-01 {
    top: 0;
    right: calc(100% + 16px);
  }
}

@media screen and (max-width: 1200px) {
  #tp-points .tp-points__outer {
    padding-bottom: 64px;
  }
  #tp-points .tp-points__intro {
    flex-direction: column;
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
  }
  #tp-points .tp-points__intro-title {
    writing-mode: horizontal-tb;
    text-orientation: mixed;
    white-space: normal;
    margin-right: 0;
    margin-bottom: 40px;
  }
  #tp-points .points__intro-img-01 {
    transform: translate(-75%, 0);
    right: auto;
    left: clamp(-20px, -5%, -80px);
    aspect-ratio: 298 / 646;
  }
}
@media screen and (max-width: 960px) {
  #tp-points .tp-points__intro {
    padding-left: 64px;
  }
  #tp-points .second-txt {
    padding-left: 4em;
  }
  #tp-points .points__intro-img-01 {
    transform: translate(-50%, 0);
  }
}
@media screen and (max-width: 768px) {
  #tp-points .tp-points__intro-kicker {
    font-size: var(--fs-24);
  }
}
@media screen and (max-width: 600px) {
  #tp-points .tp-points__intro,
  #tp-points .second-txt {
    padding-left: 0;
  }
  #tp-points .points__intro-img-01 {
    transform: translate(-50%, -10%);
    opacity: 0.5;
  }
}
/* --------------------------------
  tp-points__list
--------------------------------*/
#tp-points .tp-points__list {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(16px, 2.5vw, 24px);
}
#tp-points .tp-points__item {
  position: relative;
  flex: 1 1 calc((100% - 2 * clamp(20px, 3vw, 32px)) / 3);
  border: 1px solid var(--c-black-02);
  padding: clamp(40px, 4vw, 56px) clamp(16px, 2.5vw, 32px)
    clamp(16px, 2.5vw, 32px);
}
#tp-points .tp-points__no {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 62px;
  height: 62px;
  display: block;
}
#tp-points .tp-points__title {
  text-align: center;
  font-family: var(--font-shippori);
  font-size: var(--fs-24);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.1em;
  color: #262626;
  line-height: 1.8;
}
#tp-points .tp-points__body p {
  color: #505050;
  letter-spacing: 0.075em;
  line-height: 1.9;
}
#tp-points .points__list-img {
  width: 100%;
  height: clamp(100px, 20vw, 180px);
  display: block;
  object-fit: contain;
}
@media screen and (max-width: 1100px) {
  #tp-points .tp-points__list {
    gap: 12px;
  }
  #tp-points .tp-points__title {
    font-size: var(--fs-20);
  }
}
@media screen and (max-width: 960px) {
  #tp-points .tp-points__list {
    gap: 40px;
  }
  #tp-points .tp-points__item {
    flex-basis: 100%;
  }
  #tp-points .tp-points__no {
    width: 48px;
    height: 48px;
  }
}
/* --------------------------------
  tp-cargo
--------------------------------*/
#tp-cargo {
  color: #262626;
}
#tp-cargo .tp-cargo__header {
  text-align: center;
}
#tp-cargo .tp-cargo__title {
  font-family: var(--font-shippori);
  font-size: var(--fs-37);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.1em;
}
#tp-cargo .tp-cargo__subtitle {
  letter-spacing: 0.075em;
  text-align: center;
}
#tp-cargo .tp-cargo__top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  max-width: 1000px;
}
#tp-cargo .tp-cargo__chart {
  width: clamp(240px, 45vw, 516px);
  aspect-ratio: 516 / 326;
  flex: 1;
}
#tp-cargo .tp-cargo__chart-img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}
#tp-cargo .tp-cargo__stats {
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
  flex-shrink: 0;
}
#tp-cargo .tp-cargo__stat-row {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  /* max-width: 508px; */
}
#tp-cargo .tp-cargo__stat-row.blue--01 {
  border: 2.2px solid var(--c-sky-blue-01);
}
#tp-cargo .tp-cargo__stat-row.blue--02 {
  border: 2.2px solid var(--c-sky-blue-02);
}
#tp-cargo .tp-cargo__stat-label {
  width: 187px;
  height: 98px;
  padding: 12px 16px;
  color: var(--c-white);
  font-size: var(--fs-23);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.009em;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
#tp-cargo .tp-cargo__stat-row.blue--01 .tp-cargo__stat-label {
  background: var(--c-sky-blue-01);
}
#tp-cargo .tp-cargo__stat-row.blue--02 .tp-cargo__stat-label {
  background-image: var(--grad-blue-01);
}
#tp-cargo .tp-cargo__stat-value,
#tp-cargo .tp-cargo__card-body {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: center;
  gap: 0 0.4em;
  margin-top: auto;
  margin-bottom: auto;
  padding: 16px 8px;
  font-size: var(--fs-23);
  letter-spacing: 0.004em;
  font-weight: var(--fw-bold);
  line-height: 1;
}
#tp-cargo .tp-cargo__stat-row.blue--01 .tp-cargo__stat-value {
  color: var(--c-sky-blue-01);
}
#tp-cargo .tp-cargo__stat-row.blue--02 .tp-cargo__stat-value {
  color: var(--c-sky-blue-02);
}
#tp-cargo .tp-cargo__stat-note {
  display: block;
  width: 100%;
  margin-top: 4px;
  font-size: var(--fs-17);
  text-align: right;
  background-image: var(--grad-blue-01);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
#tp-cargo .tp-cargo__num {
  font-family: "D-DIN", var(--font-noto);
  line-height: 1;
  font-size: var(--fs-40);
  letter-spacing: 0.04em;
}
#tp-cargo .tp-cargo__source {
  letter-spacing: 0.075em;
  color: #272727;
  text-align: right;
}
#tp-cargo .tp-cargo__highlight {
  padding: 4px 16px;
  border-radius: 999px;
  background: #00117d;
  color: var(--c-white);
  font-size: var(--fs-21);
  letter-spacing: 0.12em;
  line-height: 1.7;
  text-align: center;
}
#tp-cargo .tp-cargo__ranking-title {
  font-size: var(--fs-21);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.55em;
  color: #002f88;
}
#tp-cargo .tp-cargo__cards {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: clamp(12px, 1.5vw, 40px);
  justify-content: center;
}
#tp-cargo .tp-cargo__card {
  flex: 1 1 200px;
  max-width: 360px;
  min-width: 0;
  background: var(--c-white);
  overflow: hidden;
}
#tp-cargo .tp-cargo__card.blue--01 {
  border: 2.2px solid var(--c-sky-blue-01);
}
#tp-cargo .tp-cargo__card.blue--03 {
  border: 2.2px solid var(--c-sky-blue-03);
}
#tp-cargo .tp-cargo__card-head {
  padding: 20px 16px;
  color: var(--c-white);
  font-size: var(--fs-27);
  font-weight: var(--fw-bold);
  letter-spacing: 0.05em;
  text-align: center;
  line-height: 1.4;
}
#tp-cargo .tp-cargo__card.blue--01 .tp-cargo__card-head {
  background: var(--c-sky-blue-01);
}
#tp-cargo .tp-cargo__card.blue--03 .tp-cargo__card-head {
  background: var(--grad-blue-01);
}
#tp-cargo .tp-cargo__card-head-num {
  font-size: var(--fs-22);
  font-family: "D-DIN", var(--font-noto);
  margin-right: 8px;
}
#tp-cargo .tp-cargo__card-head-rank {
  font-size: var(--fs-23);
  letter-spacing: 0.009em;
  font-weight: var(--fw-semibold);
  margin-right: 1em;
}
#tp-cargo #tp-cargo-ranking-national .tp-cargo__card-body {
  color: var(--c-sky-blue-01);
}
#tp-cargo #tp-cargo-ranking-domestic .tp-cargo__card-body {
  color: var(--c-sky-blue-04);
}
@media screen and (max-width: 1200px) {
  #tp-cargo .tp-cargo__chart {
    width: clamp(240px, 45vw, 480px);
    flex: 1;
  }
  #tp-cargo .tp-cargo__highlight {
    border-radius: 30px;
    padding: 15px;
    line-height: 1.5;
  }
}

@media screen and (max-width: 1024px) {
  #tp-cargo .tp-cargo__stat-row {
    flex-direction: column;
  }
  #tp-cargo .tp-cargo__stat-label {
    min-width: 0;
    height: auto;
    padding: 12px 16px;
    width: 100%;
    justify-content: center;
  }
  #tp-cargo .tp-cargo__card {
    max-width: none;
    flex-basis: 100%;
  }
  #tp-cargo .tp-cargo__num {
    font-size: var(--fs-35);
  }
  #tp-cargo .tp-cargo__stat-value,
  #tp-cargo .tp-cargo__card-body {
    font-size: var(--fs-20);
  }
  #tp-cargo .tp-cargo__card-head-rank {
    font-size: var(--fs-21);
  }
  #tp-cargo .tp-cargo__highlight {
    font-size: var(--fs-18);
    border-radius: 30px;
  }
}
@media screen and (max-width: 768px) {
  #tp-cargo .tp-cargo__top {
    flex-direction: column;
    gap: 24px;
    padding-bottom: 40px;
  }
  #tp-cargo .tp-cargo__chart {
    width: 80%;
    max-width: 400px;
    aspect-ratio: 397 /326;
  }
  #tp-cargo .tp-cargo__stats {
    width: 100%;
    align-items: center;
    max-width: 400px;
  }
  #tp-cargo .tp-cargo__stat-row {
    width: 100%;
  }
  #tp-cargo .tp-cargo__ranking-title {
    text-align: center;
  }
  #tp-cargo #tp-cargo-ranking-national .tp-cargo__card-body {
    gap: 4px;
  }
  #tp-cargo .tp-cargo__cards {
    gap: 4px;
  }
  #tp-cargo .tp-cargo__card {
    width: 100%;
  }
  #tp-cargo .tp-cargo__stat-label,
  #tp-cargo .tp-cargo__card-head {
    padding: 8px 0;
  }
  #tp-cargo .tp-cargo__source {
    font-size: var(--fs-12);
    margin-left: auto;
    margin-right: 0;
  }
  #tp-cargo .tp-cargo__card-body {
    font-size: var(--fs-16);
    padding: 16px 2px;
  }
}
@media screen and (max-width: 600px) {
  #tp-cargo .tp-cargo__card-head {
    font-size: var(--fs-24);
  }
  #tp-cargo .tp-cargo__stats {
    max-width: 100%;
  }
  #tp-cargo .tp-cargo__cards {
    flex-direction: column;
    align-items: center;
    gap: 12px;
  }
  #tp-cargo .tp-cargo__num {
    font-size: var(--fs-40);
  }
  #tp-cargo .tp-cargo__ranking-title {
    letter-spacing: 0.3em;
  }
}

/* --------------------------------
  tp-region
--------------------------------*/
#tp-region {
  color: #505050;
}
#tp-region .tp-region__bar {
  padding: 8px 16px;
  background: #0051cf;
  color: var(--c-white);
  font-family: var(--font-shippori);
  font-size: var(--fs-37);
  font-weight: var(--fw-semibold);
  text-align: center;
  line-height: 1.5;
}
#tp-region .tp-region__intro p {
  font-size: var(--fs-21);
  line-height: 1.85;
  letter-spacing: 0.075em;
}
#tp-region .tp-region__grid {
  --tp-region-gap: clamp(12px, 2.5vw, 24px);
  display: flex;
  flex-wrap: wrap;
  gap: var(--tp-region-gap);
  justify-content: center;
  list-style: none;
  margin: 0;
  padding: 0;
}
#tp-region .tp-region__grid > li {
  list-style: none;
}
#tp-region .tp-region__item {
  flex: 1 1 calc((100% - 2 * var(--tp-region-gap)) / 3);
  min-width: 0;
  box-sizing: border-box;
}
#tp-region .tp-region__media {
  margin: 0 0 clamp(16px, 2vw, 24px);
  overflow: hidden;
  aspect-ratio: 330 / 219;
}
#tp-region .tp-region__media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}
#tp-region .tp-region__title {
  margin: 0 0 12px;
  font-size: var(--fs-22);
  font-family: var(--font-shippori);
  font-weight: var(--fw-semibold);
  line-height: 1.55;
  text-align: center;
}
#tp-region .tp-region__text {
  letter-spacing: 0.075em;
}

@media screen and (max-width: 1024px) {
  #tp-region .tp-region__intro p,
  #tp-region .tp-region__title {
    font-size: var(--fs-18);
  }
}
@media screen and (max-width: 860px) {
  #tp-region .tp-region__bar {
    font-size: var(--fs-32);
  }
  #tp-region .tp-region__grid {
    flex-direction: column;
  }
  #tp-region .tp-region__grid > li {
    display: flex;
    gap: 24px;
    align-items: center;
  }
  #tp-region .tp-region__media {
    width: 50%;
  }
  #tp-region .tp-region__body-wrap {
    flex: 1;
  }
}
@media screen and (max-width: 768px) {
  #tp-region .tp-region__grid {
    gap: 32px;
  }
  #tp-region .tp-region__grid > li {
    flex-direction: column;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
    gap: 0;
  }
  #tp-region .tp-region__media {
    width: 100%;
  }
}
