@charset "UTF-8";
/*----------------------------------------
  CSSカスタムプロパティ
----------------------------------------*/
:root {
  --focus-outline-color: #000;
  --vh: 100svh;
  --hero-height: 487px;
  --hero-blue-start: calc(var(--hero-height) - 138px);
  --hero-header-top: calc(var(--hero-height) + 33px);
  --oct-container: 1280px;
  --oct-radiusLg: 20px;
  --oct-radiusMd: 10px;
  --oct-blue: #004098;
  --oct-cellularCyan: #00a0e9;
  --oct-black: #1a2b43;
  --oct-orange: #ea5504;
  --oct-red: #a91017;
  --oct-white: #fff;
  --oct-softBlue: #f0f9ff;
  --oct-text: #1a2b43;
  --oct-muted: #58595a;
  --oct-line: #b7c2cf;
  --oct-pale: #ebf0f6;
  --oct-shadow: 2px 2px 10px rgba(26, 43, 67, 0.14);
  --font-family-base: "Noto Sans JP", sans-serif;
  --scroll-padding-gap: 110px;
}

@media (min-width: 768px) {
  :root {
    --hero-height: 1024px;
  }
}
/*----------------------------------------
  html / body
----------------------------------------*/
*,
*::before,
*::after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
}

html,
body {
  overscroll-behavior: none;
  height: 100%;
}

body {
  overflow-wrap: break-word;
  word-break: normal;
  line-break: strict;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/*----------------------------------------
  見出し・テキスト
----------------------------------------*/
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
}

/*----------------------------------------
  リスト
----------------------------------------*/
ul,
ol {
  list-style: none;
  padding: 0;
  margin: 0;
}

/*----------------------------------------
  リンク
----------------------------------------*/
a {
  color: inherit;
  text-decoration: none;
  background-color: transparent;
}

/*----------------------------------------
  メディア要素
----------------------------------------*/
img,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
  height: auto;
}

/*----------------------------------------
  テーブル
----------------------------------------*/
table {
  border-collapse: collapse;
  border-spacing: 0;
  box-sizing: border-box;
}

th,
td {
  padding: 0;
  border: 0;
}

/*----------------------------------------
  フォーム関連
----------------------------------------*/
input,
textarea,
select,
button {
  font: inherit;
  color: inherit;
  background: none;
  border: none;
  border-radius: 0;
  margin: 0;
  padding: 0;
}

button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  cursor: pointer;
  background: none;
  border: none;
}

input[type=checkbox],
input[type=radio] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

button,
a {
  touch-action: manipulation;
}

/*----------------------------------------
  details / summary
----------------------------------------*/
summary {
  list-style: none;
}

summary::-webkit-details-marker {
  display: none;
}

/*----------------------------------------
  html / body
----------------------------------------*/
html {
  font-size: 100%;
}

body {
  position: relative;
  font-family: "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.6;
  color: var(--oct-text);
  background-color: var(--oct-white);
  min-height: calc(var(--vh, 100vh));
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
body.is_noScroll {
  overflow: hidden;
}

/* SP・PCの切り替え */
@media screen and (min-width: 768px) {
  .hp_spOnly {
    display: none !important;
  }
}

.hp_pcOnly {
  display: none !important;
}
@media screen and (min-width: 768px) {
  .hp_pcOnly {
    display: block !important;
  }
}

@media screen and (min-width: 992px) {
  .hp_spOnlyM {
    display: none !important;
  }
}

.hp_pcOnlyM {
  display: none !important;
}
@media screen and (min-width: 992px) {
  .hp_pcOnlyM {
    display: block !important;
  }
}

@media screen and (min-width: 1280px) {
  .hp_spOnlyL {
    display: none !important;
  }
}

.hp_pcOnlyL {
  display: none !important;
}
@media screen and (min-width: 1280px) {
  .hp_pcOnlyL {
    display: block !important;
  }
}

/* font-weight */
.hp_fw900 {
  font-weight: 900 !important;
}

.hp_fw700 {
  font-weight: 700 !important;
}

.hp_fw600 {
  font-weight: 600 !important;
}

.hp_fw500 {
  font-weight: 500 !important;
}

.hp_fw400 {
  font-weight: 400 !important;
}

/* text-align */
.hp_tal {
  text-align: left !important;
}

.hp_tac {
  text-align: center !important;
}

.hp_tar {
  text-align: right !important;
}

/* font-style */
.hp_italic {
  font-style: italic !important;
}

/* font-size */
.hp_fsz10 {
  font-size: 1rem !important;
}

.hp_fsz11 {
  font-size: 1.1rem !important;
}

.hp_fsz12 {
  font-size: 1.2rem !important;
}

.hp_fsz13 {
  font-size: 1.3rem !important;
}

.hp_fsz14 {
  font-size: 1.4rem !important;
}

.hp_fsz15 {
  font-size: 1.5rem !important;
}

.hp_fsz16 {
  font-size: 1.6rem !important;
}

.hp_fsz17 {
  font-size: 1.7rem !important;
}

.hp_fsz18 {
  font-size: 1.8rem !important;
}

.hp_fsz19 {
  font-size: 1.9rem !important;
}

.hp_fsz20 {
  font-size: 2rem !important;
}

.hp_fsz21 {
  font-size: 2.1rem !important;
}

.hp_fsz22 {
  font-size: 2.2rem !important;
}

.hp_fsz23 {
  font-size: 2.3rem !important;
}

.hp_fsz24 {
  font-size: 2.4rem !important;
}

.hp_fsz25 {
  font-size: 2.5rem !important;
}

.hp_fsz26 {
  font-size: 2.6rem !important;
}

.hp_fsz27 {
  font-size: 2.7rem !important;
}

.hp_fsz28 {
  font-size: 2.8rem !important;
}

.hp_fsz29 {
  font-size: 2.9rem !important;
}

.hp_fsz30 {
  font-size: 3rem !important;
}

/* block */
.hp_d_block {
  display: block !important;
}

.hp_d_inline-block {
  display: inline-block !important;
}

.hp_d_inline {
  display: inline !important;
}

.hp_hidden {
  display: none !important;
}

/* flex */
.hp_d_flex {
  display: flex !important;
}

.hp_d_inline-flex {
  display: inline-flex !important;
}

/* flex | align-items */
.hp_ai_start {
  align-items: flex-start !important;
}

.hp_ai_center {
  align-items: center !important;
}

.hp_ai_end {
  align-items: flex-end !important;
}

/* flex | justify-content */
.hp_jc_start {
  justify-content: flex-start !important;
}

.hp_jc_center {
  justify-content: center !important;
}

.hp_jc_end {
  justify-content: flex-end !important;
}

.hp_jc_between {
  justify-content: space-between !important;
}

.hp_jc_around {
  justify-content: space-around !important;
}

/* flex | flex-direction */
.hp_fd_row {
  flex-direction: row !important;
}

.hp_fd_column {
  flex-direction: column !important;
}

/* flex | flex: 1 */
.hp_f_1 {
  flex: 1 !important;
}

/* flex | flex: 0 0 auto */
.hp_no_shrink {
  flex: 0 0 auto !important;
}

/* flex | flex-wrap */
.hp_fw_wrap {
  flex-wrap: wrap !important;
}

.hp_fw_nowrap {
  flex-wrap: nowrap !important;
}

/* flex or grid | gap （4の倍数） */
.hp_gap0 {
  gap: 0px !important;
}

.hp_gap4 {
  gap: 4px !important;
}

.hp_gap8 {
  gap: 8px !important;
}

.hp_gap12 {
  gap: 12px !important;
}

.hp_gap16 {
  gap: 16px !important;
}

.hp_gap20 {
  gap: 20px !important;
}

.hp_gap24 {
  gap: 24px !important;
}

.hp_gap28 {
  gap: 28px !important;
}

.hp_gap32 {
  gap: 32px !important;
}

.hp_gap36 {
  gap: 36px !important;
}

.hp_gap40 {
  gap: 40px !important;
}

.hp_gap44 {
  gap: 44px !important;
}

.hp_gap48 {
  gap: 48px !important;
}

.hp_gap52 {
  gap: 52px !important;
}

.hp_gap56 {
  gap: 56px !important;
}

.hp_gap60 {
  gap: 60px !important;
}

/* flex or grid | column-gap （4の倍数） */
.hp_gap_c0 {
  -moz-column-gap: 0px !important;
       column-gap: 0px !important;
}

.hp_gap_c4 {
  -moz-column-gap: 4px !important;
       column-gap: 4px !important;
}

.hp_gap_c8 {
  -moz-column-gap: 8px !important;
       column-gap: 8px !important;
}

.hp_gap_c12 {
  -moz-column-gap: 12px !important;
       column-gap: 12px !important;
}

.hp_gap_c16 {
  -moz-column-gap: 16px !important;
       column-gap: 16px !important;
}

.hp_gap_c20 {
  -moz-column-gap: 20px !important;
       column-gap: 20px !important;
}

.hp_gap_c24 {
  -moz-column-gap: 24px !important;
       column-gap: 24px !important;
}

.hp_gap_c28 {
  -moz-column-gap: 28px !important;
       column-gap: 28px !important;
}

.hp_gap_c32 {
  -moz-column-gap: 32px !important;
       column-gap: 32px !important;
}

.hp_gap_c36 {
  -moz-column-gap: 36px !important;
       column-gap: 36px !important;
}

.hp_gap_c40 {
  -moz-column-gap: 40px !important;
       column-gap: 40px !important;
}

.hp_gap_c44 {
  -moz-column-gap: 44px !important;
       column-gap: 44px !important;
}

.hp_gap_c48 {
  -moz-column-gap: 48px !important;
       column-gap: 48px !important;
}

.hp_gap_c52 {
  -moz-column-gap: 52px !important;
       column-gap: 52px !important;
}

.hp_gap_c56 {
  -moz-column-gap: 56px !important;
       column-gap: 56px !important;
}

.hp_gap_c60 {
  -moz-column-gap: 60px !important;
       column-gap: 60px !important;
}

/* flex or grid | row-gap （4の倍数） */
.hp_gap_r0 {
  row-gap: 0px !important;
}

.hp_gap_r4 {
  row-gap: 4px !important;
}

.hp_gap_r8 {
  row-gap: 8px !important;
}

.hp_gap_r12 {
  row-gap: 12px !important;
}

.hp_gap_r16 {
  row-gap: 16px !important;
}

.hp_gap_r20 {
  row-gap: 20px !important;
}

.hp_gap_r24 {
  row-gap: 24px !important;
}

.hp_gap_r28 {
  row-gap: 28px !important;
}

.hp_gap_r32 {
  row-gap: 32px !important;
}

.hp_gap_r36 {
  row-gap: 36px !important;
}

.hp_gap_r40 {
  row-gap: 40px !important;
}

.hp_gap_r44 {
  row-gap: 44px !important;
}

.hp_gap_r48 {
  row-gap: 48px !important;
}

.hp_gap_r52 {
  row-gap: 52px !important;
}

.hp_gap_r56 {
  row-gap: 56px !important;
}

.hp_gap_r60 {
  row-gap: 60px !important;
}

/* width（%）（5の倍数） */
.hp_w05 {
  width: 5% !important;
}

.hp_w10 {
  width: 10% !important;
}

.hp_w15 {
  width: 15% !important;
}

.hp_w20 {
  width: 20% !important;
}

.hp_w25 {
  width: 25% !important;
}

.hp_w30 {
  width: 30% !important;
}

.hp_w35 {
  width: 35% !important;
}

.hp_w40 {
  width: 40% !important;
}

.hp_w45 {
  width: 45% !important;
}

.hp_w50 {
  width: 50% !important;
}

.hp_w55 {
  width: 55% !important;
}

.hp_w60 {
  width: 60% !important;
}

.hp_w65 {
  width: 65% !important;
}

.hp_w70 {
  width: 70% !important;
}

.hp_w75 {
  width: 75% !important;
}

.hp_w80 {
  width: 80% !important;
}

.hp_w85 {
  width: 85% !important;
}

.hp_w90 {
  width: 90% !important;
}

.hp_w95 {
  width: 95% !important;
}

.hp_w100 {
  width: 100% !important;
}

/* 余白は4の倍数 */
/* padding (top + right + bottom + left) */
.hp_pd0 {
  padding: 0px !important;
}

.hp_pd4 {
  padding: 4px !important;
}

.hp_pd8 {
  padding: 8px !important;
}

.hp_pd12 {
  padding: 12px !important;
}

.hp_pd16 {
  padding: 16px !important;
}

.hp_pd20 {
  padding: 20px !important;
}

.hp_pd24 {
  padding: 24px !important;
}

.hp_pd28 {
  padding: 28px !important;
}

.hp_pd32 {
  padding: 32px !important;
}

.hp_pd36 {
  padding: 36px !important;
}

.hp_pd40 {
  padding: 40px !important;
}

.hp_pd44 {
  padding: 44px !important;
}

.hp_pd48 {
  padding: 48px !important;
}

.hp_pd52 {
  padding: 52px !important;
}

.hp_pd56 {
  padding: 56px !important;
}

.hp_pd60 {
  padding: 60px !important;
}

.hp_pd64 {
  padding: 64px !important;
}

.hp_pd68 {
  padding: 68px !important;
}

.hp_pd72 {
  padding: 72px !important;
}

.hp_pd76 {
  padding: 76px !important;
}

.hp_pd80 {
  padding: 80px !important;
}

/* padding (top + bottom) */
.hp_pdtb0 {
  padding-block: 0 !important;
}

.hp_pdtb4 {
  padding-block: 4px !important;
}

.hp_pdtb8 {
  padding-block: 8px !important;
}

.hp_pdtb12 {
  padding-block: 12px !important;
}

.hp_pdtb16 {
  padding-block: 16px !important;
}

.hp_pdtb20 {
  padding-block: 20px !important;
}

.hp_pdtb24 {
  padding-block: 24px !important;
}

.hp_pdtb28 {
  padding-block: 28px !important;
}

.hp_pdtb32 {
  padding-block: 32px !important;
}

.hp_pdtb36 {
  padding-block: 36px !important;
}

.hp_pdtb40 {
  padding-block: 40px !important;
}

.hp_pdtb44 {
  padding-block: 44px !important;
}

.hp_pdtb48 {
  padding-block: 48px !important;
}

.hp_pdtb52 {
  padding-block: 52px !important;
}

.hp_pdtb56 {
  padding-block: 56px !important;
}

.hp_pdtb60 {
  padding-block: 60px !important;
}

.hp_pdtb64 {
  padding-block: 64px !important;
}

.hp_pdtb68 {
  padding-block: 68px !important;
}

.hp_pdtb72 {
  padding-block: 72px !important;
}

.hp_pdtb76 {
  padding-block: 76px !important;
}

.hp_pdtb80 {
  padding-block: 80px !important;
}

/* padding (right + left) */
.hp_pdrl0 {
  padding-inline: 0 !important;
}

.hp_pdrl4 {
  padding-inline: 4px !important;
}

.hp_pdrl8 {
  padding-inline: 8px !important;
}

.hp_pdrl12 {
  padding-inline: 12px !important;
}

.hp_pdrl16 {
  padding-inline: 16px !important;
}

.hp_pdrl20 {
  padding-inline: 20px !important;
}

.hp_pdrl24 {
  padding-inline: 24px !important;
}

.hp_pdrl28 {
  padding-inline: 28px !important;
}

.hp_pdrl32 {
  padding-inline: 32px !important;
}

.hp_pdrl36 {
  padding-inline: 36px !important;
}

.hp_pdrl40 {
  padding-inline: 40px !important;
}

.hp_pdrl44 {
  padding-inline: 44px !important;
}

.hp_pdrl48 {
  padding-inline: 48px !important;
}

.hp_pdrl52 {
  padding-inline: 52px !important;
}

.hp_pdrl56 {
  padding-inline: 56px !important;
}

.hp_pdrl60 {
  padding-inline: 60px !important;
}

.hp_pdrl64 {
  padding-inline: 64px !important;
}

.hp_pdrl68 {
  padding-inline: 68px !important;
}

.hp_pdrl72 {
  padding-inline: 72px !important;
}

.hp_pdrl76 {
  padding-inline: 76px !important;
}

.hp_pdrl80 {
  padding-inline: 80px !important;
}

/* padding (top) */
.hp_pdt0 {
  padding-top: 0 !important;
}

.hp_pdt4 {
  padding-top: 4px !important;
}

.hp_pdt8 {
  padding-top: 8px !important;
}

.hp_pdt12 {
  padding-top: 12px !important;
}

.hp_pdt16 {
  padding-top: 16px !important;
}

.hp_pdt20 {
  padding-top: 20px !important;
}

.hp_pdt24 {
  padding-top: 24px !important;
}

.hp_pdt28 {
  padding-top: 28px !important;
}

.hp_pdt32 {
  padding-top: 32px !important;
}

.hp_pdt36 {
  padding-top: 36px !important;
}

.hp_pdt40 {
  padding-top: 40px !important;
}

.hp_pdt44 {
  padding-top: 44px !important;
}

.hp_pdt48 {
  padding-top: 48px !important;
}

.hp_pdt52 {
  padding-top: 52px !important;
}

.hp_pdt56 {
  padding-top: 56px !important;
}

.hp_pdt60 {
  padding-top: 60px !important;
}

.hp_pdt64 {
  padding-top: 64px !important;
}

.hp_pdt68 {
  padding-top: 68px !important;
}

.hp_pdt72 {
  padding-top: 72px !important;
}

.hp_pdt76 {
  padding-top: 76px !important;
}

.hp_pdt80 {
  padding-top: 80px !important;
}

/* padding (right) */
.hp_pdr0 {
  padding-right: 0 !important;
}

.hp_pdr4 {
  padding-right: 4px !important;
}

.hp_pdr8 {
  padding-right: 8px !important;
}

.hp_pdr12 {
  padding-right: 12px !important;
}

.hp_pdr16 {
  padding-right: 16px !important;
}

.hp_pdr20 {
  padding-right: 20px !important;
}

.hp_pdr24 {
  padding-right: 24px !important;
}

.hp_pdr28 {
  padding-right: 28px !important;
}

.hp_pdr32 {
  padding-right: 32px !important;
}

.hp_pdr36 {
  padding-right: 36px !important;
}

.hp_pdr40 {
  padding-right: 40px !important;
}

.hp_pdr44 {
  padding-right: 44px !important;
}

.hp_pdr48 {
  padding-right: 48px !important;
}

.hp_pdr52 {
  padding-right: 52px !important;
}

.hp_pdr56 {
  padding-right: 56px !important;
}

.hp_pdr60 {
  padding-right: 60px !important;
}

.hp_pdr64 {
  padding-right: 64px !important;
}

.hp_pdr68 {
  padding-right: 68px !important;
}

.hp_pdr72 {
  padding-right: 72px !important;
}

.hp_pdr76 {
  padding-right: 76px !important;
}

.hp_pdr80 {
  padding-right: 80px !important;
}

/* padding (bottom) */
.hp_pdb0 {
  padding-bottom: 0 !important;
}

.hp_pdb4 {
  padding-bottom: 4px !important;
}

.hp_pdb8 {
  padding-bottom: 8px !important;
}

.hp_pdb12 {
  padding-bottom: 12px !important;
}

.hp_pdb16 {
  padding-bottom: 16px !important;
}

.hp_pdb20 {
  padding-bottom: 20px !important;
}

.hp_pdb24 {
  padding-bottom: 24px !important;
}

.hp_pdb28 {
  padding-bottom: 28px !important;
}

.hp_pdb32 {
  padding-bottom: 32px !important;
}

.hp_pdb36 {
  padding-bottom: 36px !important;
}

.hp_pdb40 {
  padding-bottom: 40px !important;
}

.hp_pdb44 {
  padding-bottom: 44px !important;
}

.hp_pdb48 {
  padding-bottom: 48px !important;
}

.hp_pdb52 {
  padding-bottom: 52px !important;
}

.hp_pdb56 {
  padding-bottom: 56px !important;
}

.hp_pdb60 {
  padding-bottom: 60px !important;
}

.hp_pdb64 {
  padding-bottom: 64px !important;
}

.hp_pdb68 {
  padding-bottom: 68px !important;
}

.hp_pdb72 {
  padding-bottom: 72px !important;
}

.hp_pdb76 {
  padding-bottom: 76px !important;
}

.hp_pdb80 {
  padding-bottom: 80px !important;
}

/* padding (left) */
.hp_pdl0 {
  padding-left: 0 !important;
}

.hp_pdl4 {
  padding-left: 4px !important;
}

.hp_pdl8 {
  padding-left: 8px !important;
}

.hp_pdl12 {
  padding-left: 12px !important;
}

.hp_pdl16 {
  padding-left: 16px !important;
}

.hp_pdl20 {
  padding-left: 20px !important;
}

.hp_pdl24 {
  padding-left: 24px !important;
}

.hp_pdl28 {
  padding-left: 28px !important;
}

.hp_pdl32 {
  padding-left: 32px !important;
}

.hp_pdl36 {
  padding-left: 36px !important;
}

.hp_pdl40 {
  padding-left: 40px !important;
}

.hp_pdl44 {
  padding-left: 44px !important;
}

.hp_pdl48 {
  padding-left: 48px !important;
}

.hp_pdl52 {
  padding-left: 52px !important;
}

.hp_pdl56 {
  padding-left: 56px !important;
}

.hp_pdl60 {
  padding-left: 60px !important;
}

.hp_pdl64 {
  padding-left: 64px !important;
}

.hp_pdl68 {
  padding-left: 68px !important;
}

.hp_pdl72 {
  padding-left: 72px !important;
}

.hp_pdl76 {
  padding-left: 76px !important;
}

.hp_pdl80 {
  padding-left: 80px !important;
}

/* margin (top + right + bottom + left) */
.hp_mg0 {
  margin: 0 !important;
}

.hp_mg4 {
  margin: 4px !important;
}

.hp_mg8 {
  margin: 8px !important;
}

.hp_mg12 {
  margin: 12px !important;
}

.hp_mg16 {
  margin: 16px !important;
}

.hp_mg20 {
  margin: 20px !important;
}

.hp_mg24 {
  margin: 24px !important;
}

.hp_mg28 {
  margin: 28px !important;
}

.hp_mg32 {
  margin: 32px !important;
}

.hp_mg36 {
  margin: 36px !important;
}

.hp_mg40 {
  margin: 40px !important;
}

.hp_mg44 {
  margin: 44px !important;
}

.hp_mg48 {
  margin: 48px !important;
}

.hp_mg52 {
  margin: 52px !important;
}

.hp_mg56 {
  margin: 56px !important;
}

.hp_mg60 {
  margin: 60px !important;
}

.hp_mg64 {
  margin: 64px !important;
}

.hp_mg68 {
  margin: 68px !important;
}

.hp_mg72 {
  margin: 72px !important;
}

.hp_mg76 {
  margin: 76px !important;
}

.hp_mg80 {
  margin: 80px !important;
}

/* margin (top + bottom) */
.hp_mgtb0 {
  margin-block: 0 !important;
}

.hp_mgtb4 {
  margin-block: 4px !important;
}

.hp_mgtb8 {
  margin-block: 8px !important;
}

.hp_mgtb12 {
  margin-block: 12px !important;
}

.hp_mgtb16 {
  margin-block: 16px !important;
}

.hp_mgtb20 {
  margin-block: 20px !important;
}

.hp_mgtb24 {
  margin-block: 24px !important;
}

.hp_mgtb28 {
  margin-block: 28px !important;
}

.hp_mgtb32 {
  margin-block: 32px !important;
}

.hp_mgtb36 {
  margin-block: 36px !important;
}

.hp_mgtb40 {
  margin-block: 40px !important;
}

.hp_mgtb44 {
  margin-block: 44px !important;
}

.hp_mgtb48 {
  margin-block: 48px !important;
}

.hp_mgtb52 {
  margin-block: 52px !important;
}

.hp_mgtb56 {
  margin-block: 56px !important;
}

.hp_mgtb60 {
  margin-block: 60px !important;
}

.hp_mgtb64 {
  margin-block: 64px !important;
}

.hp_mgtb68 {
  margin-block: 68px !important;
}

.hp_mgtb72 {
  margin-block: 72px !important;
}

.hp_mgtb76 {
  margin-block: 76px !important;
}

.hp_mgtb80 {
  margin-block: 80px !important;
}

/* margin (left + right) */
.hp_mgrl0 {
  margin-inline: 0 !important;
}

.hp_mgrl4 {
  margin-inline: 4px !important;
}

.hp_mgrl8 {
  margin-inline: 8px !important;
}

.hp_mgrl12 {
  margin-inline: 12px !important;
}

.hp_mgrl16 {
  margin-inline: 16px !important;
}

.hp_mgrl20 {
  margin-inline: 20px !important;
}

.hp_mgrl24 {
  margin-inline: 24px !important;
}

.hp_mgrl28 {
  margin-inline: 28px !important;
}

.hp_mgrl32 {
  margin-inline: 32px !important;
}

.hp_mgrl36 {
  margin-inline: 36px !important;
}

.hp_mgrl40 {
  margin-inline: 40px !important;
}

.hp_mgrl44 {
  margin-inline: 44px !important;
}

.hp_mgrl48 {
  margin-inline: 48px !important;
}

.hp_mgrl52 {
  margin-inline: 52px !important;
}

.hp_mgrl56 {
  margin-inline: 56px !important;
}

.hp_mgrl60 {
  margin-inline: 60px !important;
}

.hp_mgrl64 {
  margin-inline: 64px !important;
}

.hp_mgrl68 {
  margin-inline: 68px !important;
}

.hp_mgrl72 {
  margin-inline: 72px !important;
}

.hp_mgrl76 {
  margin-inline: 76px !important;
}

.hp_mgrl80 {
  margin-inline: 80px !important;
}

.hp_mgrlAuto {
  margin-inline: auto !important;
}

/* margin (top) */
.hp_mgt0 {
  margin-top: 0 !important;
}

.hp_mgt4 {
  margin-top: 4px !important;
}

.hp_mgt8 {
  margin-top: 8px !important;
}

.hp_mgt12 {
  margin-top: 12px !important;
}

.hp_mgt16 {
  margin-top: 16px !important;
}

.hp_mgt20 {
  margin-top: 20px !important;
}

.hp_mgt24 {
  margin-top: 24px !important;
}

.hp_mgt28 {
  margin-top: 28px !important;
}

.hp_mgt32 {
  margin-top: 32px !important;
}

.hp_mgt36 {
  margin-top: 36px !important;
}

.hp_mgt40 {
  margin-top: 40px !important;
}

.hp_mgt44 {
  margin-top: 44px !important;
}

.hp_mgt48 {
  margin-top: 48px !important;
}

.hp_mgt52 {
  margin-top: 52px !important;
}

.hp_mgt56 {
  margin-top: 56px !important;
}

.hp_mgt60 {
  margin-top: 60px !important;
}

.hp_mgt64 {
  margin-top: 64px !important;
}

.hp_mgt68 {
  margin-top: 68px !important;
}

.hp_mgt72 {
  margin-top: 72px !important;
}

.hp_mgt76 {
  margin-top: 76px !important;
}

.hp_mgt80 {
  margin-top: 80px !important;
}

/* margin (right) */
.hp_mgr0 {
  margin-right: 0 !important;
}

.hp_mgr4 {
  margin-right: 4px !important;
}

.hp_mgr8 {
  margin-right: 8px !important;
}

.hp_mgr12 {
  margin-right: 12px !important;
}

.hp_mgr16 {
  margin-right: 16px !important;
}

.hp_mgr20 {
  margin-right: 20px !important;
}

.hp_mgr24 {
  margin-right: 24px !important;
}

.hp_mgr28 {
  margin-right: 28px !important;
}

.hp_mgr32 {
  margin-right: 32px !important;
}

.hp_mgr36 {
  margin-right: 36px !important;
}

.hp_mgr40 {
  margin-right: 40px !important;
}

.hp_mgr44 {
  margin-right: 44px !important;
}

.hp_mgr48 {
  margin-right: 48px !important;
}

.hp_mgr52 {
  margin-right: 52px !important;
}

.hp_mgr56 {
  margin-right: 56px !important;
}

.hp_mgr60 {
  margin-right: 60px !important;
}

.hp_mgr64 {
  margin-right: 64px !important;
}

.hp_mgr68 {
  margin-right: 68px !important;
}

.hp_mgr72 {
  margin-right: 72px !important;
}

.hp_mgr76 {
  margin-right: 76px !important;
}

.hp_mgr80 {
  margin-right: 80px !important;
}

.hp_mgrAuto {
  margin-right: auto !important;
}

/* margin (bottom) */
.hp_mgb0 {
  margin-bottom: 0 !important;
}

.hp_mgb4 {
  margin-bottom: 4px !important;
}

.hp_mgb8 {
  margin-bottom: 8px !important;
}

.hp_mgb12 {
  margin-bottom: 12px !important;
}

.hp_mgb16 {
  margin-bottom: 16px !important;
}

.hp_mgb20 {
  margin-bottom: 20px !important;
}

.hp_mgb24 {
  margin-bottom: 24px !important;
}

.hp_mgb28 {
  margin-bottom: 28px !important;
}

.hp_mgb32 {
  margin-bottom: 32px !important;
}

.hp_mgb36 {
  margin-bottom: 36px !important;
}

.hp_mgb40 {
  margin-bottom: 40px !important;
}

.hp_mgb44 {
  margin-bottom: 44px !important;
}

.hp_mgb48 {
  margin-bottom: 48px !important;
}

.hp_mgb52 {
  margin-bottom: 52px !important;
}

.hp_mgb56 {
  margin-bottom: 56px !important;
}

.hp_mgb60 {
  margin-bottom: 60px !important;
}

.hp_mgb64 {
  margin-bottom: 64px !important;
}

.hp_mgb68 {
  margin-bottom: 68px !important;
}

.hp_mgb72 {
  margin-bottom: 72px !important;
}

.hp_mgb76 {
  margin-bottom: 76px !important;
}

.hp_mgb80 {
  margin-bottom: 80px !important;
}

/* margin (left) */
.hp_mgl0 {
  margin-left: 0 !important;
}

.hp_mgl4 {
  margin-left: 4px !important;
}

.hp_mgl8 {
  margin-left: 8px !important;
}

.hp_mgl12 {
  margin-left: 12px !important;
}

.hp_mgl16 {
  margin-left: 16px !important;
}

.hp_mgl20 {
  margin-left: 20px !important;
}

.hp_mgl24 {
  margin-left: 24px !important;
}

.hp_mgl28 {
  margin-left: 28px !important;
}

.hp_mgl32 {
  margin-left: 32px !important;
}

.hp_mgl36 {
  margin-left: 36px !important;
}

.hp_mgl40 {
  margin-left: 40px !important;
}

.hp_mgl44 {
  margin-left: 44px !important;
}

.hp_mgl48 {
  margin-left: 48px !important;
}

.hp_mgl52 {
  margin-left: 52px !important;
}

.hp_mgl56 {
  margin-left: 56px !important;
}

.hp_mgl60 {
  margin-left: 60px !important;
}

.hp_mgl64 {
  margin-left: 64px !important;
}

.hp_mgl68 {
  margin-left: 68px !important;
}

.hp_mgl72 {
  margin-left: 72px !important;
}

.hp_mgl76 {
  margin-left: 76px !important;
}

.hp_mgl80 {
  margin-left: 80px !important;
}

.hp_mglAuto {
  margin-left: auto !important;
}

/* border */
.hp_borderRadius0 {
  border-radius: 0 !important;
}

/* Float */
.hp_floatLeft {
  float: left !important;
}

.hp_floatRight {
  float: right !important;
}

.hp_clearfix::after {
  content: "";
  display: block;
  clear: both;
}

/* TEL */
.hp_telRestricted[href^="tel:"] {
  pointer-events: none;
  cursor: default;
}
@media (hover: none) and (pointer: coarse) {
  .hp_telRestricted[href^="tel:"] {
    pointer-events: auto;
    cursor: pointer;
  }
}

/* color */
.hp_red {
  color: var(--oct-red) !important;
}

.hp_gray {
  color: #4d5d71 !important;
}

/* font */
.hp_fontEn {
  font-family: "Noto Sans", sans-serif !important;
}

/*----------------------------------------
  スクリーンリーダー専用表示
----------------------------------------*/
.a11y_srOnly {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/*----------------------------------------
  スキップリンク
----------------------------------------*/
.a11y_skip {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10000;
  color: var(--oct-text);
  background: var(--oct-white);
  padding: 8px 16px;
  transform: translateY(-250%);
  transition: transform 0.3s ease-out;
}
.a11y_skip:focus {
  transform: translateY(0);
}

/*----------------------------------------
  キーボードフォーカス強調
----------------------------------------*/
:focus-visible {
  outline: 3px solid var(--focus-outline-color);
  outline-offset: 3px;
}

.splide :focus-visible {
  outline: 3px solid var(--focus-outline-color) !important;
  outline-offset: -3px;
}

/*----------------------------------------
  prefers-reduced-motion 対応
----------------------------------------*/
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
/*----------------------------------------
  tabindex="-1" が付いている要素がフォーカスされた時、枠線を消す
----------------------------------------*/
[tabindex="-1"]:focus {
  outline: none !important;
}

/*-------------------------
	edit_btn 公開まで非表示
-------------------------*/
.un_editBtn {
  display: block;
  position: fixed;
  z-index: 1001;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 8px 12px;
  background: rgba(0, 0, 0, 0.45);
  border-top: 1px solid rgba(255, 255, 255, 0.25);
  box-shadow: 0 -3px 14px rgba(0, 0, 0, 0.2);
}
.un_editBtn_list {
  margin: 0 auto;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.un_editBtn_list > li a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 18px;
  color: #1e293b;
  border-radius: 4px;
  background: #fff;
  border: 1px solid rgba(148, 163, 184, 0.6);
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.1);
  font-weight: 600;
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}
.un_editBtn_list > li a:hover {
  background-color: #dbe7ff;
  color: #0f172a;
  border-color: #3b82f6;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.2);
}

/* noscript */
.noscript {
  text-align: center;
  font-size: 80%;
  padding: 5px;
  background: #ececec;
}

.ly_container {
  position: relative;
  min-height: var(--vh);
  display: flex;
  flex-direction: column;
}

#top .ly_header {
  position: relative;
  left: 0;
  transform: translateX(0);
  width: calc(100% - 40px);
  max-width: 1400px;
  height: 56px;
  margin-inline: auto;
  border-radius: 10px;
  box-shadow: 2px 2px 4px 0 rgba(var(--oct-black), 0.1);
  border: 1px solid #e5ecef;
}
@media screen and (min-width: 992px) {
  #top .ly_header {
    height: 85px;
  }
}
#top .ly_header_logo {
  max-width: 97px;
}
@media screen and (min-width: 992px) {
  #top .ly_header_logo {
    width: 11.1940298507%;
    max-width: 150px;
  }
}
#top .ly_header.is_fixed {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
}

.ly_header {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
  width: 100%;
  height: 80px;
  display: grid;
  place-items: center;
  padding-block: 8px;
  background-color: var(--oct-white);
  border-bottom: 1px solid var(--oct-line);
}
@media screen and (min-width: 992px) {
  .ly_header {
    height: 100px;
    padding-block: 0;
  }
}
.ly_header_inner {
  width: calc(100% - 32px);
  max-width: 1360px;
  margin-inline: auto;
  display: flex;
  align-items: center;
  gap: 0 20px;
}
@media screen and (min-width: 992px) {
  .ly_header_inner {
    width: calc(100% - 60px);
    height: 100%;
  }
}
@media screen and (min-width: 1280px) {
  .ly_header_inner {
    width: calc(100% - 80px);
  }
}
.ly_header_logo {
  max-width: 140px;
}
@media screen and (min-width: 992px) {
  .ly_header_logo {
    width: 11.1940298507%;
    max-width: 150px;
  }
}
.ly_header_logo > a {
  display: block;
}
.ly_header_logo > a img {
  display: block;
  width: 100%;
}
.ly_header_content {
  margin-left: auto;
}
@media screen and (min-width: 992px) {
  .ly_header_content {
    height: 100%;
    display: flex;
    gap: 0 24px;
  }
}
@media screen and (min-width: 1280px) {
  .ly_header_content {
    gap: 0 40px;
  }
}
.ly_header_util {
  display: none;
}
@media screen and (min-width: 992px) {
  .ly_header_util {
    display: flex;
    align-items: center;
    gap: 0 12px;
  }
}
@media screen and (min-width: 992px) and (min-width: 1280px) {
  .ly_header_util {
    gap: 0 16px;
  }
}

.ly_headerNav {
  display: none;
}
@media screen and (min-width: 992px) {
  .ly_headerNav {
    display: block;
  }
}
.ly_headerNav_list {
  height: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0 24px;
}
@media screen and (min-width: 1280px) {
  .ly_headerNav_list {
    gap: 0 40px;
  }
}
@media (hover: hover) {
  .ly_headerNav_list > li:hover > a,
  .ly_headerNav_list > li:hover > span,
  .ly_headerNav_list > li:hover > button {
    color: var(--oct-blue);
  }
}
.ly_headerNav_list > li > a,
.ly_headerNav_list > li > span,
.ly_headerNav_list > li > button {
  position: relative;
  display: grid;
  place-items: center;
  height: 100%;
  font-weight: 700;
  cursor: pointer;
  transition: color 0.2s ease, font-weight 0.2s ease;
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.05em;
}
.ly_headerNav_list > li > a:has(+ .ly_megaMenu),
.ly_headerNav_list > li > span:has(+ .ly_megaMenu),
.ly_headerNav_list > li > button:has(+ .ly_megaMenu) {
  padding-right: 20px;
}
.ly_headerNav_list > li > a:has(+ .ly_megaMenu)::after,
.ly_headerNav_list > li > span:has(+ .ly_megaMenu)::after,
.ly_headerNav_list > li > button:has(+ .ly_megaMenu)::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  background: url("/common/images/icons/icon-chevron-black.svg") no-repeat center;
  background-size: 100% 100%;
  transition: transform 0.2s ease;
}
.ly_headerNav_list > li > a.is_megaMenuOpen:has(+ .ly_megaMenu)::after,
.ly_headerNav_list > li > span.is_megaMenuOpen:has(+ .ly_megaMenu)::after,
.ly_headerNav_list > li > button.is_megaMenuOpen:has(+ .ly_megaMenu)::after {
  transform: translateY(-50%) rotate(180deg);
}
.ly_headerNav_list > li > a.is_megaMenuOpen + .ly_megaMenu,
.ly_headerNav_list > li > span.is_megaMenuOpen + .ly_megaMenu,
.ly_headerNav_list > li > button.is_megaMenuOpen + .ly_megaMenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.ly_headerIconLink_list {
  display: flex;
  align-items: center;
  gap: 0 12px;
}
@media screen and (min-width: 1280px) {
  .ly_headerIconLink_list {
    gap: 0 16px;
  }
}
.ly_headerIconLink_list > li > a,
.ly_headerIconLink_list > li > button {
  display: block;
}

.ly_headerUtilLink {
  display: flex;
  align-items: center;
  gap: 0 12px;
}
@media screen and (min-width: 1280px) {
  .ly_headerUtilLink {
    gap: 0 16px;
  }
}
.ly_headerUtilLink > li > a {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid var(--oct-line);
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1;
  letter-spacing: 0.04em;
}

.ly_menu {
  position: fixed;
  inset: 0;
  z-index: 100;
  width: 100%;
  height: 100%;
  padding: var(--alert-height, 20px) 20px 50px;
  background-color: var(--oct-cellularCyan);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  visibility: hidden;
  opacity: 0;
  transition: visibility 0.2s ease, opacity 0.2s ease, padding-top 0.2s ease;
}
@media screen and (min-width: 992px) {
  .ly_menu {
    display: none;
  }
}
.ly_menu.is_menuOpen {
  will-change: visibility, opacity;
  visibility: visible;
  opacity: 1;
  padding-top: calc(16px + var(--alert-height, 0px));
}
.ly_menu_logo {
  max-width: 97px;
}
.ly_menu_logo > a {
  display: block;
}
.ly_menu_logo > a img {
  display: block;
  width: 100%;
}
.ly_menu_close {
  position: relative;
  display: block;
  width: 40px;
  height: 40px;
  margin-left: auto;
  border: 1px solid var(--oct-line);
  border-radius: 10px;
}
.ly_menu_close > .line {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 22px;
  height: 2px;
  border-radius: 2px;
  background-color: var(--oct-black);
}
.ly_menu_close > .line:nth-of-type(1) {
  transform: translate3d(-50%, 0, 0) rotate(45deg);
}
.ly_menu_close > .line:nth-of-type(2) {
  transform: translate3d(-50%, 0, 0) rotate(-45deg);
}

.ly_menuHead {
  width: 100%;
  height: 56px;
  margin-inline: auto;
  padding-block: 8px;
  display: grid;
  place-items: center;
  background-color: var(--oct-white);
  border-radius: 10px;
  box-shadow: 2px 2px 4px 0 rgba(var(--oct-black), 0.1);
}
.ly_menuHead_inner {
  width: calc(100% - 32px);
  margin-inline: auto;
  display: flex;
  align-items: center;
  gap: 0 10px;
}

.ly_menuBody {
  margin-top: 10px;
  flex: 1;
}
.ly_menuBody_inner {
  width: 100%;
  margin-inline: auto;
}

.ly_menuNavUnit {
  margin-bottom: 15px;
  padding: 30px;
  border-radius: 10px;
  background-color: var(--oct-white);
  box-shadow: 2px 2px 4px 0 rgba(var(--oct-black), 0.1);
}

.ly_menuNav_list .ly_menuNav_item:first-child .ly_menuNav_header {
  padding-top: 0;
}
.ly_menuNav_list .ly_menuNav_item:last-child {
  border-bottom: none;
}
.ly_menuNav_list .ly_menuNav_item:last-child .ly_menuNav_header {
  padding-bottom: 0;
}
.ly_menuNav_item {
  border-bottom: 1px solid var(--oct-line);
}
.ly_menuNav_header {
  position: relative;
  display: block;
  width: 100%;
  text-align: left;
  padding: 16px 8px;
}
.ly_menuNav_header > span {
  position: relative;
  display: inline-block;
  font-weight: 500;
  font-size: 1rem;
  line-height: 1.75;
  letter-spacing: 0.05em;
}
.ly_menuNav_header[target=_blank] > span {
  padding-right: 26px;
}
.ly_menuNav_header[target=_blank] > span::after {
  content: "";
  position: absolute;
  top: 3px;
  right: 0;
  width: 20px;
  height: 20px;
  background: url("/common/images/icons/icon-external.svg") center no-repeat;
  background-size: 100% 100%;
}

.ly_menuLangChange {
  margin-top: 30px;
  display: flex;
  justify-content: center;
  font-size: 0.875rem;
  line-height: 1;
  letter-spacing: 0.04em;
}
.ly_menuLangChange > a {
  position: relative;
  display: block;
}
.ly_menuLangChange > a::before {
  content: "/";
  margin: 0 8px;
}
.ly_menuLangChange > a:first-child::before {
  content: none;
}
.ly_menuLangChange > a.ja {
  color: var(--oct-white);
  text-decoration: underline;
}

.ly_container.dir02_nature .ly_main {
  background-color: #F9F8EC;
}

.ly_main {
  flex-shrink: 0;
  background-color: var(--oct-white);
}

.ly_mainHead_content {
  position: relative;
  min-height: 180px;
  padding-block: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 992px) {
  .ly_mainHead_content {
    min-height: 320px;
    padding-block: 40px;
    justify-content: flex-start;
  }
}
.ly_mainHead_inner {
  width: calc(100% - 40px);
  max-width: 1200px;
  margin-inline: auto;
}
@media screen and (min-width: 992px) {
  .ly_mainHead_inner {
    width: calc(100% - 80px);
  }
}
.ly_mainHead_bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.ly_mainHead_bg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 335/180;
  border-radius: 10px;
}
@media screen and (min-width: 992px) {
  .ly_mainHead_bg img {
    aspect-ratio: 1360/320;
  }
}
.ly_mainHead_heading {
  position: relative;
  display: inline-block;
  padding: 8px 14px;
  background-color: var(--oct-white);
  border-radius: 2px;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.4166666667;
}
@media screen and (min-width: 992px) {
  .ly_mainHead_heading {
    padding: 12px 16px;
    font-size: 2.375rem;
    line-height: 1.2631578947;
  }
}
.ly_mainHead__simple .ly_mainHead_content {
  min-height: 90px;
  background-color: #f5f9fd;
  border-radius: 10px;
}
@media screen and (min-width: 992px) {
  .ly_mainHead__simple .ly_mainHead_content {
    min-height: 180px;
  }
}
.ly_mainHead__simple .ly_mainHead_inner {
  width: 100%;
  max-width: 100%;
}
.ly_mainHead__simple .ly_mainHead_heading {
  background-color: transparent;
  padding-left: 20px;
}
@media screen and (min-width: 992px) {
  .ly_mainHead__simple .ly_mainHead_heading {
    padding-left: 40px;
  }
}
.ly_mainHead__simple .ly_mainHead_heading::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 5px;
  height: 100%;
  background-color: var(--oct-blue);
  border-radius: 0 10px 10px 0;
}

.ly_mainContent {
  position: relative;
  padding-block: 60px 80px;
}
@media screen and (min-width: 992px) {
  .ly_mainContent {
    padding-block: 60px 120px;
  }
}

.ly_footer_wrap {
  position: relative;
  margin-top: auto;
}
.ly_footer_content {
  padding-block: 60px 140px;
  background-color: var(--oct-white);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 34px 0;
}
@media screen and (min-width: 992px) {
  .ly_footer_content {
    flex-direction: row;
    gap: 0 90px;
  }
}
.ly_footer_logo {
  max-width: 215px;
  margin-inline: auto;
}
.ly_footer_logo > a {
  display: block;
}
.ly_footer_logo > a img {
  display: block;
  width: 100%;
}
.ly_footer_primary {
  width: 100%;
}
@media screen and (min-width: 992px) {
  .ly_footer_primary {
    width: auto;
    min-width: 215px;
  }
}
.ly_footer_secondary {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 992px) {
  .ly_footer_secondary {
    flex: 1;
  }
}
.ly_footer_deco {
  margin: 40px auto 0;
  width: 63px;
}
@media screen and (min-width: 992px) {
  .ly_footer_deco {
    margin-right: 0;
    margin-left: auto;
  }
}
.ly_footer_deco img {
  display: block;
  width: 100%;
}
.ly_footer_copyright .copyright {
  display: block;
  text-align: center;
  padding: 16px;
  color: var(--oct-white);
  background-color: var(--oct-black);
  font-size: 0.75rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 992px) {
  .ly_footer_copyright .copyright {
    font-size: 1.125rem;
  }
}

.ly_footerSnsLink {
  margin-top: 28px;
}
@media screen and (min-width: 992px) {
  .ly_footerSnsLink {
    margin-top: 40px;
  }
}
.ly_footerSnsLink_list {
  display: flex;
  justify-content: center;
  gap: 0 10px;
}
.ly_footerSnsLink_list > li > a {
  display: block;
  padding: 6px;
  background-color: rgba(26, 43, 67, 0.8);
  border-radius: 10px;
  transition: transform 0.2s ease, background-color 0.2s ease;
}
@media (hover: hover) {
  .ly_footerSnsLink_list > li > a:hover {
    transform: translateY(-4px);
    background-color: var(--oct-blue);
  }
}
.ly_footerSnsLink_list > li > a img {
  display: block;
  width: 22px;
}

@media screen and (min-width: 992px) {
  .ly_footerNav {
    max-width: 820px;
    margin-left: auto;
  }
}
.ly_footerNav_list {
  display: flex;
  flex-wrap: wrap;
  gap: 18px 24px;
}
@media screen and (min-width: 992px) {
  .ly_footerNav_list {
    justify-content: flex-end;
    gap: 25px 40px;
  }
}
.ly_footerNav_list > li > a {
  position: relative;
  display: block;
  font-weight: 700;
  transition: color 0.2s ease;
  font-size: 1rem;
  line-height: 1.75;
  letter-spacing: 0.05em;
}
.ly_footerNav_list > li > a[target=_blank] {
  padding-right: 26px;
}
.ly_footerNav_list > li > a[target=_blank]::after {
  content: "";
  position: absolute;
  top: 4px;
  right: 0;
  width: 20px;
  height: 20px;
  background: url("/common/images/icons/icon-blank.svg") center no-repeat;
  background-size: 100% 100%;
}
@media (hover: hover) {
  .ly_footerNav_list > li > a:hover {
    color: var(--oct-blue);
  }
}

.ly_footerLegalLink {
  margin-top: 40px;
}
.ly_footerLegalLink_list {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
}
@media screen and (min-width: 992px) {
  .ly_footerLegalLink_list {
    justify-content: flex-end;
    gap: 25px 40px;
  }
}
.ly_footerLegalLink_list > li > a {
  display: block;
  color: var(--oct-muted);
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media (hover: hover) {
  .ly_footerLegalLink_list > li > a:hover {
    text-decoration: underline;
  }
}

.ly_centered {
  width: calc(100% - 40px);
  max-width: 1280px;
  margin-inline: auto auto;
}
@media screen and (min-width: 992px) {
  .ly_centered {
    width: calc(100% - 80px);
  }
}
.ly_centered__w1100 {
  max-width: 1100px;
}
.ly_centered__w1200 {
  max-width: 1200px;
}
.ly_centered__w1360 {
  max-width: 1360px;
}

@media screen and (min-width: 992px) {
  .ly_content {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    gap: 0 40px;
  }
}
.ly_content_side {
  display: none;
}
@media screen and (min-width: 992px) {
  .ly_content_side {
    display: block;
    width: 250px;
  }
}
@media screen and (min-width: 992px) {
  .ly_content_sticky {
    position: sticky;
    top: 30px;
    left: 0;
  }
}
@media screen and (min-width: 992px) {
  .ly_content_main {
    flex: 1;
  }
}

.ly_columns {
  display: flex;
  gap: 7px;
}
@media screen and (min-width: 768px) {
  .ly_columns {
    gap: 14px;
  }
}
.ly_columns .ly_column {
  flex: 1 1 0;
}
.ly_columns .ly_column > :first-child {
  margin-top: 0;
}
.ly_columns .ly_column > :last-child {
  margin-bottom: 0;
}
.ly_columns .ly_column figure img {
  width: 100%;
}
.ly_columns .ly_column .bl_tableWrap02 table {
  min-width: 100%;
}
.ly_columns__spRow {
  flex-direction: column;
}
@media screen and (min-width: 768px) {
  .ly_columns__spRow {
    flex-direction: row;
  }
}

.ly_pageTop {
  position: absolute;
  bottom: 88px;
  right: 20px;
}
@media screen and (min-width: 992px) {
  .ly_pageTop {
    right: min(5.55555556vw, 80px);
  }
}
.ly_pageTop_link {
  display: grid;
  place-items: center;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background-color: var(--oct-black);
  border: 2px solid var(--oct-black);
  transition: background-color 0.2s ease;
}
.ly_pageTop_link img {
  width: 24px;
  height: 24px;
  transform: rotate(-90deg);
}
.ly_pageTop_link::before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  transform: rotate(-90deg);
  background: url("/common/images/icons/icon-arrow-white.svg") no-repeat center;
  background-size: 100% 100%;
  transition: background-image 0.2s ease;
}
@media (hover: hover) {
  .ly_pageTop_link:hover {
    background-color: var(--oct-white);
  }
  .ly_pageTop_link:hover::before {
    background-image: url("/common/images/icons/icon-arrow-black.svg");
  }
}

.ly_megaMenu {
  position: absolute;
  top: calc(100% - 10px);
  left: 0;
  transform: translateY(-10px);
  z-index: 100;
  width: 100%;
  padding: 40px 20px;
  border-radius: 0 0 10px 10px;
  background-color: var(--oct-white);
  border-right: 1px solid var(--oct-white);
  border-left: 1px solid var(--oct-white);
  border-bottom: 1px solid var(--oct-white);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
}
.ly_megaMenu_inner {
  max-width: 1100px;
  margin-inline: auto;
}
.ly_megaMenu_list {
  display: flex;
  flex-wrap: wrap;
  gap: 0 50px;
}
.ly_megaMenu_list > li {
  width: calc((100% - 50px) / 2);
  border-bottom: 1px solid var(--oct-line);
}
.ly_megaMenu_list > li:nth-child(-n+2) > a {
  padding-top: 0;
}
.ly_megaMenu_list > li:nth-child(-n+2) > a::after {
  top: calc(50% - 10px);
}
.ly_megaMenu_list > li > a {
  position: relative;
  display: flex;
  align-items: center;
  height: 100%;
  padding: 20px 30px 20px 0;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.ly_megaMenu_list > li > a::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-black.svg") center no-repeat;
  background-size: 100% 100%;
}
.ly_megaMenu_logoList {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}
.ly_megaMenu_logoList > li {
  width: calc((100% - 28px) / 3);
  max-width: 96px;
}
.ly_megaMenu_logoList > li > a {
  display: block;
  height: 64px;
  padding: 4px;
  border-radius: 10px;
  border: 1px solid var(--oct-line);
}
.ly_megaMenu_logoList > li > a img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  border-radius: 10px;
}
.ly_megaMenu_panelList {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}
.ly_megaMenu_panelList > li {
  width: calc((100% - 14px) / 2);
  max-width: 150px;
}
.ly_megaMenu_panelList > li > a {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  height: 110px;
  padding: 12px 14px;
  border-radius: 10px;
}
.ly_megaMenu_panelList > li > a .img {
  position: absolute;
  inset: 0;
  width: 100%;
}
.ly_megaMenu_panelList > li > a .img img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 150/110;
  border-radius: 10px;
}
.ly_megaMenu_panelList > li > a .img::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.5);
}
.ly_megaMenu_panelList > li > a .ttl {
  position: relative;
  z-index: 1;
  font-weight: 800;
  font-size: 0.875rem;
  line-height: 1.3571428571;
  letter-spacing: 0.05em;
}

.ly_megaMenuItem {
  display: flex;
  align-items: flex-start;
}
.ly_megaMenuItem_head {
  min-width: 330px;
  width: 25%;
  padding-right: 20px;
}
.ly_megaMenuItem_heading {
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.4166666667;
  letter-spacing: 0.05em;
}
.ly_megaMenuItem_body {
  flex: auto;
  display: flex;
  gap: 0 50px;
}
.ly_megaMenuItem_ttl {
  display: block;
  margin-bottom: 16px;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}

.ly_menuToggle {
  position: relative;
  display: block;
  width: 40px;
  height: 40px;
  border: 1px solid var(--oct-line);
  border-radius: 10px;
  background: none;
  cursor: pointer;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
@media screen and (min-width: 992px) {
  .ly_menuToggle {
    display: none;
  }
}
.ly_menuToggle > .line {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 22px;
  height: 2px;
  border-radius: 2px;
  background-color: var(--oct-black);
}
.ly_menuToggle > .line:nth-of-type(1) {
  transform: translate3d(-50%, -8px, 0);
}
.ly_menuToggle > .line:nth-of-type(2) {
  transform: translate3d(-50%, 0, 0);
}
.ly_menuToggle > .line:nth-of-type(3) {
  transform: translate3d(-50%, 8px, 0);
}

.bl_breadcrumb {
  width: 100%;
  margin: 15px auto 20px;
}
.bl_breadcrumb_list {
  display: flex;
  flex-wrap: wrap;
  gap: 0 8px;
  width: calc(100% - 40px);
  max-width: 1360px;
  margin-inline: auto auto;
}
@media screen and (min-width: 992px) {
  .bl_breadcrumb_list {
    width: calc(100% - 80px);
  }
}
.bl_breadcrumb_list > li {
  display: flex;
  align-items: center;
  font-size: 0.875rem;
  line-height: 1.7142857143;
}
.bl_breadcrumb_list > li:not(:first-child)::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  margin: 0 8px 0 0;
  background: url("/common/images/icons/icon-arrow-chevron-gray.svg") no-repeat center;
  background-size: 100% 100%;
}
.bl_breadcrumb_list > li > a {
  opacity: 0.6;
}
@media (hover: hover) {
  .bl_breadcrumb_list > li > a:hover {
    opacity: 1;
    text-decoration: underline;
  }
}

.bl_section + .bl_section {
  padding-block: 80px 0;
}
@media screen and (min-width: 992px) {
  .bl_section + .bl_section {
    padding-block: 120px 0;
  }
}

.bl_section02 {
  padding-block: 80px 0;
}
@media screen and (min-width: 992px) {
  .bl_section02 {
    padding-block: 120px 0;
  }
}

.bl_section03 {
  padding-block: 0 80px;
}
@media screen and (min-width: 992px) {
  .bl_section03 {
    padding-block: 0 120px;
  }
}

.bl_newsList {
  padding: 30px;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--oct-line);
  border-radius: 10px;
}
@media screen and (min-width: 992px) {
  .bl_newsList {
    padding: 40px;
  }
}
.bl_newsList > li {
  border-bottom: 1px solid var(--oct-line);
}
.bl_newsList > li:first-of-type .bl_newsItem {
  padding-top: 0;
}
.bl_newsList > li:last-of-type {
  border-bottom: none;
}
.bl_newsList > li:last-of-type .bl_newsItem {
  padding-bottom: 0;
}
.bl_newsList__arrow .bl_newsItem_ttl {
  padding-right: 28px;
}
.bl_newsList__arrow .bl_newsItem_ttl::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-blue.svg") no-repeat center;
  background-size: 100% 100%;
}

.bl_newsItem {
  display: flex;
  flex-direction: column;
  gap: 12px 0;
  padding-block: 30px;
}
@media screen and (min-width: 992px) {
  .bl_newsItem {
    flex-direction: row;
    align-items: center;
    gap: 0;
    padding-block: 38px;
  }
}
.bl_newsItem_head {
  display: flex;
  align-items: center;
  gap: 0 15px;
}
@media screen and (min-width: 992px) {
  .bl_newsItem_head {
    padding-right: 20px;
    border-right: 1px solid var(--oct-line);
  }
}
.bl_newsItem_date {
  display: inline-block;
  min-width: 113px;
  font-size: 0.875rem;
  line-height: 1.5;
}
@media screen and (min-width: 992px) {
  .bl_newsItem_date {
    min-width: 90px;
    display: flex;
    flex-direction: column;
  }
}
@media screen and (min-width: 992px) {
  .bl_newsItem_date .lg {
    font-weight: 700;
    font-size: 1.125rem;
  }
}
.bl_newsItem_category {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px 12px;
  border-radius: 8px;
  background-color: var(--oct-white);
  border: 1px solid var(--oct-line);
  font-size: 0.8125rem;
  line-height: 1.5384615385;
}
@media screen and (min-width: 992px) {
  .bl_newsItem_category {
    padding: 4px 20px 6px;
    font-size: 1rem;
    line-height: 1.625;
  }
}
.bl_newsItem_ttl {
  position: relative;
  font-size: 1rem;
  line-height: 1.625;
}
@media screen and (min-width: 992px) {
  .bl_newsItem_ttl {
    flex: 1;
    padding-left: 20px;
  }
}
.bl_newsItem_ttl > a {
  display: inline-block;
  transition: color 0.2s ease;
  text-decoration: underline;
}
@media (hover: hover) {
  .bl_newsItem_ttl > a:hover {
    color: var(--oct-blue);
    text-decoration: none;
  }
}

.bl_indexLinks_list {
  display: flex;
  flex-direction: column;
  gap: 10px 0;
}
@media screen and (min-width: 768px) {
  .bl_indexLinks_list {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 20px 22px;
  }
}
.bl_indexLinks_list > li {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .bl_indexLinks_list > li {
    width: calc((100% - 22px) / 2);
  }
}
@media screen and (min-width: 992px) {
  .bl_indexLinks_list > li {
    width: calc((100% - 44px) / 3);
  }
}
.bl_indexLinks_list > li > a {
  position: relative;
  display: block;
  font-weight: 500;
  border-radius: 15px;
  border: 1px solid var(--color-background);
  background-color: var(--color-background);
  padding: 15px 15px 15px 46px;
  transition: border-color 0.3s ease-out;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .bl_indexLinks_list > li > a {
    padding: 15px 29px 15px 61px;
  }
}
.bl_indexLinks_list > li > a::before {
  position: absolute;
  top: 18px;
  left: 14px;
  display: block;
  content: "";
  width: 22px;
  height: 22px;
  background: url("/common/images/icons/icon-circle-arrow.svg") center no-repeat;
  background-size: 100% 100%;
}
@media screen and (min-width: 768px) {
  .bl_indexLinks_list > li > a::before {
    left: 29px;
  }
}
@media (hover: hover) {
  .bl_indexLinks_list > li > a:hover {
    text-decoration: underline;
    border-color: var(--color-accent);
  }
}
.bl_indexLinks_list > li > a[href^="#"]::before {
  transform: rotate(90deg);
}
.bl_indexLinks_list__vertical {
  flex-direction: column;
}
@media screen and (min-width: 768px) {
  .bl_indexLinks_list__vertical > li {
    width: auto;
  }
}
.bl_indexLinks_list__ver02 {
  flex-direction: column;
}
@media screen and (min-width: 768px) {
  .bl_indexLinks_list__ver02 > li {
    width: auto;
  }
}
.bl_indexLinks_list__ver02 > li > a {
  border: 1px solid var(--color-primary);
}
.bl_indexLinks_list__arrowRight > li a[href^="#"]:before {
  transform: rotate(0);
}

.bl_linkBoxes {
  display: flex;
  flex-direction: column;
  gap: 32px 0;
}

.bl_linkBox {
  width: 100%;
  border-radius: 30px;
  background-color: var(--color-background);
  padding: 30px 15px;
  border: 1px solid var(--oct-line);
  border-radius: var(--oct-radiusLg);
  box-shadow: var(--oct-shadow);
  transition: border-color 0.2s ease;
}
@media screen and (min-width: 768px) {
  .bl_linkBox {
    padding: 30px 40px;
  }
}
.bl_linkBox:hover {
  border-color: var(--oct-cellularCyan);
}
.bl_linkBox_heading {
  position: relative;
}
.bl_linkBox_heading > a {
  position: relative;
  display: block;
  font-weight: 500;
  padding-left: 32px;
  font-size: 1.5rem;
  line-height: 1.4166666667;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .bl_linkBox_heading > a {
    padding-left: 37px;
  }
}
.bl_linkBox_heading > a::before {
  position: absolute;
  top: 6px;
  left: 0;
  display: block;
  content: "";
  width: 22px;
  height: 22px;
  background: url("/common/images/icons/icon-circle-arrow.svg") center no-repeat;
  background-size: 100% 100%;
}
@media (hover: hover) {
  .bl_linkBox_heading > a:hover {
    text-decoration: underline;
  }
}
.bl_linkBox_list > li {
  position: relative;
  width: 100%;
}
.bl_linkBox_list > li::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  display: block;
  height: 1px;
  background-image: repeating-linear-gradient(to right, var(--color-border) 0 5px, transparent 5px 8px);
  background-size: 8px 1px;
  border-radius: 1px;
}
.bl_linkBox_list > li:first-child::before {
  content: none;
}
.bl_linkBox_list > li > a {
  position: relative;
  display: block;
  font-weight: 500;
  padding: 15px 0 14px 25px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .bl_linkBox_list > li > a {
    padding: 15px 0 14px 36px;
  }
}
.bl_linkBox_list > li > a::before {
  position: absolute;
  top: 19px;
  left: 0;
  display: block;
  content: "";
  width: 20px;
  height: 20px;
  background: url("/common/images/icons/icon-arrow.svg") center no-repeat;
  background-size: 100% 100%;
}
@media screen and (min-width: 768px) {
  .bl_linkBox_list > li > a::before {
    left: 6px;
  }
}
@media (hover: hover) {
  .bl_linkBox_list > li > a:hover {
    text-decoration: underline;
  }
}
@media screen and (min-width: 992px) {
  .bl_linkBox_list__2col {
    display: flex;
    flex-wrap: wrap;
    gap: 0 64px;
  }
}
@media screen and (min-width: 992px) {
  .bl_linkBox_list__2col > li {
    width: calc((100% - 64px) / 2);
  }
  .bl_linkBox_list__2col > li:nth-child(-n+2)::before {
    content: none;
  }
}
.bl_linkBox_body {
  position: relative;
  margin-top: 20px;
  padding-top: 15px;
}
@media screen and (min-width: 992px) {
  .bl_linkBox_body {
    padding: 15px 6px 0;
  }
}
.bl_linkBox_body:before {
  background-color: var(--color-accent);
  border-radius: 2px;
  top: 0;
  content: "";
  display: block;
  height: 2px;
  left: 0;
  position: absolute;
  width: 100%;
}

.bl_linkBox02 {
  width: 100%;
  border-radius: 30px;
  border: 1px solid var(--color-accent);
  background-color: var(--color-accent);
  overflow: hidden;
}
.bl_linkBox02_heading {
  background-color: var(--color-accent);
  padding: 16px 25px;
}
.bl_linkBox02_heading > a, .bl_linkBox02_heading > span {
  display: block;
  font-weight: 800;
  color: var(--color-on-accent);
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
@media (hover: hover) {
  .bl_linkBox02_heading > a:hover, .bl_linkBox02_heading > span:hover {
    text-decoration: underline;
  }
}
.bl_linkBox02_body {
  background-color: var(--color-background);
  padding: 9px 14px;
}
.bl_linkBox02_list > li:not(:last-child) {
  position: relative;
}
.bl_linkBox02_list > li:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  display: block;
  height: 1px;
  background-image: repeating-linear-gradient(to right, var(--color-border) 0 5px, transparent 5px 8px);
  background-size: 8px 1px;
  border-radius: 1px;
}
.bl_linkBox02_list > li:first-child .date {
  margin-top: 5px;
}
.bl_linkBox02_list > li .date {
  margin-top: 10px;
  font-size: 0.875rem;
  line-height: 1.7142857143;
}
.bl_linkBox02_list > li > a {
  position: relative;
  display: block;
  padding: 11px 0 12px 22px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.bl_linkBox02_list > li > a::before {
  position: absolute;
  top: 14px;
  left: 0;
  display: block;
  content: "";
  width: 16px;
  height: 20px;
  background: url("/common/images/icons/icon-arrow.svg") center no-repeat;
  background-size: 100% 100%;
}
@media (hover: hover) {
  .bl_linkBox02_list > li > a:hover {
    text-decoration: underline;
  }
}
.bl_linkBox02_list > li > a.is_current {
  color: var(--color-accent);
  font-weight: 700;
}
.bl_linkBox02 + .bl_linkBox02 {
  margin-top: 20px;
}
@media screen and (min-width: 992px) {
  .bl_linkBox02 + .bl_linkBox02 {
    margin-top: 30px;
  }
}

.bl_linkList {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
@media screen and (min-width: 992px) {
  .bl_linkList {
    gap: 16px;
  }
}
.bl_linkList > li > a {
  position: relative;
  display: block;
  padding: 20px 48px 20px 20px;
  border: 1px solid var(--oct-line);
  border-radius: 10px;
  font-weight: 500;
  transition: background-color 0.2s ease;
  font-size: 0.9375rem;
  line-height: 1.4666666667;
}
@media screen and (min-width: 992px) {
  .bl_linkList > li > a {
    padding-left: 28px;
  }
}
.bl_linkList > li > a::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-blue.svg") no-repeat center;
  background-size: 100% 100%;
}
@media (hover: hover) {
  .bl_linkList > li > a:hover {
    background-color: #f8fbfe;
  }
}
.bl_linkList > li > a.new {
  background-color: var(--oct-softBlue);
  border-color: #d8e7f5;
  transition: color 0.2s ease, border-color 0.2s ease;
}
@media (hover: hover) {
  .bl_linkList > li > a.new:hover {
    color: var(--oct-blue);
    border-color: var(--oct-line);
  }
}
.bl_linkList .tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 8px 5px 8px;
  margin-right: 8px;
  border-radius: 10px;
  background-color: var(--oct-blue);
  color: var(--oct-white);
  font-weight: 700;
  font-size: 0.625rem;
  line-height: 1;
}
@media screen and (min-width: 992px) {
  .bl_linkList .tag {
    margin-right: 16px;
  }
}
@media screen and (min-width: 992px) {
  .bl_linkList__2col {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 16px;
  }
}
@media screen and (min-width: 992px) {
  .bl_linkList__2col > li {
    width: calc((100% - 16px) / 2);
  }
}

.bl_linkList02 {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
  color: var(--oct-black);
}
@media screen and (min-width: 992px) {
  .bl_linkList02 {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 28px 32px;
  }
}
@media screen and (min-width: 992px) {
  .bl_linkList02 > li {
    width: calc((100% - 32px) / 2);
  }
}
@media screen and (min-width: 992px) {
  .bl_linkList02__3col {
    gap: 16px;
  }
}
@media screen and (min-width: 992px) {
  .bl_linkList02__3col > li {
    width: calc((100% - 32px) / 3);
  }
}
@media screen and (min-width: 992px) {
  .bl_linkList02__3col .bl_linkItem02 {
    gap: 0 16px;
  }
}

.bl_linkItem02 {
  display: flex;
  align-items: flex-start;
  gap: 0 24px;
  border-radius: 8px;
  padding: 16px 40px 16px 16px;
  border: 1px solid var(--oct-line);
  transition: background-color 0.2s ease;
}
@media screen and (min-width: 992px) {
  .bl_linkItem02 {
    height: 100%;
    padding: 24px 40px 24px 24px;
  }
}
.bl_linkItem02::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-black.svg") no-repeat center;
  background-size: 100% 100%;
}
.bl_linkItem02[target=_blank]::after {
  background-image: url("/common/images/icons/icon-blank.svg");
}
.bl_linkItem02[href^="#"]::after {
  transform: translateY(-50%) rotate(90deg);
}
@media (hover: hover) {
  .bl_linkItem02:hover {
    background-color: #f8fbfe;
  }
}
.bl_linkItem02_icon {
  width: 56px;
}
.bl_linkItem02_icon img {
  display: block;
  width: 100%;
}
.bl_linkItem02_cont {
  flex: 1;
}
.bl_linkItem02_ttl {
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5555555556;
}
.bl_linkItem02_txt {
  margin-top: 6px;
  color: #4d5d71;
  font-size: 0.8125rem;
  line-height: 1.6923076923;
}

.bl_linkList03 {
  display: flex;
  flex-direction: column;
  gap: 30px 0;
}
@media screen and (min-width: 992px) {
  .bl_linkList03 {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 30px;
  }
}
@media screen and (min-width: 992px) {
  .bl_linkList03 > li {
    width: calc((100% - 60px) / 3);
  }
}

.bl_linkItem03 {
  position: relative;
  display: flex;
  align-items: center;
  padding: 20px 50px 20px 20px;
  border-radius: 10px;
  background-color: #f3f7fb;
  font-weight: 700;
  transition: background-color 0.2s ease;
  font-size: 1rem;
  line-height: 1.625;
}
@media screen and (min-width: 992px) {
  .bl_linkItem03 {
    min-height: 126px;
    padding: 30px 70px 30px 30px;
    font-size: 1.125rem;
  }
}
.bl_linkItem03::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--oct-black) url("/common/images/icons/icon-arrow-white.svg") no-repeat center;
  background-size: 14px 14px;
  transition: right 0.2s ease;
}
@media screen and (min-width: 992px) {
  .bl_linkItem03::after {
    width: 34px;
    height: 34px;
    right: 30px;
    background-size: 24px 24px;
  }
}
@media (hover: hover) {
  .bl_linkItem03:hover {
    background-color: #eaf3ff;
  }
  .bl_linkItem03:hover::after {
    right: 26px;
  }
}

.el_homeLv2Heading {
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.4166666667;
}
@media screen and (min-width: 992px) {
  .el_homeLv2Heading {
    font-size: 2.625rem;
    line-height: 1.2380952381;
  }
}

.el_lv2Heading, .bl_richTxt h2 {
  margin-bottom: 30px;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.4166666667;
}
@media screen and (min-width: 992px) {
  .el_lv2Heading, .bl_richTxt h2 {
    margin-bottom: 40px;
    font-size: 2rem;
    line-height: 1.3125;
  }
}

.el_lv3Heading, .bl_richTxt h3 {
  position: relative;
  padding-left: 20px;
  margin-bottom: 20px;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.4166666667;
}
@media screen and (min-width: 992px) {
  .el_lv3Heading, .bl_richTxt h3 {
    font-size: 1.75rem;
    line-height: 1.3571428571;
  }
}
.el_lv3Heading::before, .bl_richTxt h3::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 5px;
  height: 100%;
  background-color: var(--oct-blue);
  border-radius: 0 10px 10px 0;
}

.el_lv4Heading, .bl_richTxt h4 {
  padding: 12px 16px;
  margin-bottom: 20px;
  background-color: #f5f9fd;
  border-radius: 10px;
  font-weight: 500;
  font-size: 1.25rem;
  line-height: 1.5;
}
@media screen and (min-width: 992px) {
  .el_lv4Heading, .bl_richTxt h4 {
    font-size: 1.5rem;
    line-height: 1.4166666667;
  }
}

.el_lv5Heading, .bl_richTxt h5 {
  margin-bottom: 15px;
  color: var(--oct-blue);
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5555555556;
}
@media screen and (min-width: 992px) {
  .el_lv5Heading, .bl_richTxt h5 {
    font-size: 1.25rem;
    line-height: 1.5;
  }
}

.el_link, .bl_richTxt a:not(.el_btn):not(.el_btn02):not(.bl_linkItem02):not(.bl_listIndexItem):not(.bl_mediaLinkList a) {
  color: var(--oct-text);
  transition: color 0.2s ease;
  text-decoration: underline;
}
@media (hover: hover) {
  .el_link:hover, .bl_richTxt a:hover:not(.el_btn):not(.el_btn02):not(.bl_linkItem02):not(.bl_listIndexItem):not(.bl_mediaLinkList a) {
    color: var(--oct-blue);
    text-decoration: none;
  }
}

.el_ul > li, .bl_richTxt ul > li {
  position: relative;
  padding-left: 1em;
}
.el_ul > li::before, .bl_richTxt ul > li::before {
  content: "";
  position: absolute;
  display: block;
  top: 0.563em;
  left: 0;
  width: 0.625em;
  height: 0.625em;
  border-radius: 50%;
  background-color: #d2d2d2;
}
.el_ul > li + li, .bl_richTxt ul > li + li {
  margin-top: 8px;
}
.el_ul__befBlue > li::before {
  background-color: var(--oct-blue);
}
.el_ul__sm {
  font-size: 0.875rem;
  line-height: 1.7142857143;
}

.el_ol, .bl_richTxt ol {
  counter-reset: counter calc(var(--start, 1) - 1);
}
.el_ol > li, .bl_richTxt ol > li {
  position: relative;
  padding-left: 1.6em;
}
.el_ol > li::before, .bl_richTxt ol > li::before {
  content: counter(counter) ".";
  counter-increment: counter;
  position: absolute;
  top: 0;
  left: 0;
  font-weight: 700;
  color: var(--oct-blue);
}
.el_ol > li + li, .bl_richTxt ol > li + li {
  margin-top: 8px;
}
.el_ol > li ol, .bl_richTxt ol > li ol {
  margin-top: 8px;
}
.el_ol > li ol > li, .bl_richTxt ol > li ol > li {
  position: relative;
  padding-left: 2.5em;
}
.el_ol > li ol > li::before, .bl_richTxt ol > li ol > li::before {
  content: counter(counter) ".";
  counter-increment: counter;
  position: absolute;
  top: 0;
  left: 1em;
  font-weight: 700;
  color: var(--oct-black);
}
.el_ol > li ol > li::after, .bl_richTxt ol > li ol > li::after {
  content: "";
  display: block;
  position: absolute;
  top: 10px;
  left: 0;
  transform: rotate(-45deg);
  width: 7px;
  height: 7px;
  border-right: 2px solid var(--oct-black);
  border-bottom: 2px solid var(--oct-black);
}

.el_linkIcon, .bl_richTxt a:not(.el_btn):not(.el_btn02):not(.bl_linkItem02):not(.bl_listIndexItem):not(.bl_mediaLinkList a) {
  display: inline;
  color: var(--oct-text);
  transition: color 0.2s ease;
  text-decoration: underline;
}
@media (hover: hover) {
  .el_linkIcon:hover, .bl_richTxt a:hover:not(.el_btn):not(.el_btn02):not(.bl_linkItem02):not(.bl_listIndexItem):not(.bl_mediaLinkList a) {
    color: var(--oct-blue);
    text-decoration: none;
  }
}
.el_linkIcon > .fileSize, .bl_richTxt a:not(.el_btn):not(.el_btn02):not(.bl_linkItem02):not(.bl_listIndexItem):not(.bl_mediaLinkList a) > .fileSize {
  display: inline-block;
  text-decoration: none;
}
.el_linkIcon > .fileSize::before, .bl_richTxt a:not(.el_btn):not(.el_btn02):not(.bl_linkItem02):not(.bl_listIndexItem):not(.bl_mediaLinkList a) > .fileSize::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-left: 4px;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  vertical-align: -4px;
}
.el_linkIcon__blank::after {
  display: inline-block;
  content: "";
  width: 20px;
  height: 20px;
  margin-left: 4px;
  vertical-align: -3px;
  background-image: url("/common/images/icons/icon-blank.svg");
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
.el_linkIcon__blank:has(> .fileSize)::after {
  content: none;
}
.el_linkIcon__pdf > .fileSize::before {
  background-image: url("/common/images/icons/file/icon-pdf.svg");
}
.el_linkIcon__word > .fileSize::before {
  background-image: url("/common/images/icons/file/icon-word.svg");
}
.el_linkIcon__excel > .fileSize::before {
  background-image: url("/common/images/icons/file/icon-excel.svg");
}

.bl_figure {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.bl_figure img {
  transition: opacity 0.3s ease-out;
}
.bl_figure figcaption {
  width: 100%;
  margin-top: 10px;
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.05em;
}

@media (hover: hover) {
  a:hover .bl_figure img {
    will-change: opacity;
    opacity: 0.7;
  }
}

.bl_table, .bl_richTxt table {
  width: 100%;
}
@media screen and (min-width: 992px) {
  .bl_table tr:not(:last-child) th, .bl_richTxt table tr:not(:last-child) th {
    border-bottom-color: var(--oct-line);
  }
}
.bl_table th, .bl_richTxt table th,
.bl_table td,
.bl_richTxt table td {
  border: 1px solid var(--oct-line);
  padding: 12px 14px;
  min-width: 70px;
  vertical-align: top;
}
.bl_table th, .bl_richTxt table th {
  font-weight: 700;
  text-align: left;
  background-color: #f2f5f8;
  vertical-align: middle;
  width: auto;
  white-space: nowrap;
}
.bl_table th.blank, .bl_richTxt table th.blank {
  border: none !important;
  background: none !important;
}
@media screen and (min-width: 992px) {
  .bl_table thead th:not(:last-child), .bl_richTxt table thead th:not(:last-child) {
    border-right: 1px solid var(--oct-line);
  }
}

.bl_tableWrap {
  padding-bottom: 8px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
@media screen and (min-width: 992px) {
  .bl_tableWrap {
    padding-bottom: 0;
  }
}
.bl_tableWrap::-webkit-scrollbar {
  height: 6px;
}
.bl_tableWrap::-webkit-scrollbar-track {
  background-color: #d2d2d2;
  border-radius: 6px;
}
.bl_tableWrap::-webkit-scrollbar-thumb {
  background: var(--oct-blue);
  border-radius: 6px;
}
.bl_tableWrap .bl_table, .bl_tableWrap .bl_richTxt table, .bl_richTxt .bl_tableWrap table {
  min-width: 460px;
}
@media screen and (min-width: 992px) {
  .bl_tableWrap .bl_table, .bl_tableWrap .bl_richTxt table, .bl_richTxt .bl_tableWrap table {
    min-width: auto;
  }
}

.bl_richTxt {
  font-size: 1rem;
  line-height: 1.625;
  /*----------------------------------------
    ブロック要素の間隔リズム
  ----------------------------------------*/
}
.bl_richTxt > section:first-of-type > div:first-of-type h2 {
  margin-top: 0;
}
.bl_richTxt > section:first-of-type h2:first-of-type {
  margin-top: 0;
}
.bl_richTxt > section + section {
  margin-top: 30px;
}
.bl_richTxt > section:first-child > *:first-child {
  margin-top: 0 !important;
}
.bl_richTxt {
  /*----------------------------------------
    見出し階層 (h1-h6)
  ----------------------------------------*/
}
.bl_richTxt h2 {
  margin-top: 80px;
}
.bl_richTxt h2 + * {
  margin-top: 20px !important;
}
.bl_richTxt h2 + h3 {
  margin-top: 30px !important;
}
.bl_richTxt h3 {
  margin-top: 60px;
}
.bl_richTxt h3 + * {
  margin-top: 20px !important;
}
.bl_richTxt h3 + h4 {
  margin-top: 30px !important;
}
.bl_richTxt h4 {
  margin-top: 50px;
}
.bl_richTxt h4 + * {
  margin-top: 20px !important;
}
.bl_richTxt h4 + h5 {
  margin-top: 30px !important;
}
.bl_richTxt h5 {
  margin-top: 40px;
}
.bl_richTxt h5 + * {
  margin-top: 10px !important;
}
.bl_richTxt h5 + h6 {
  margin-top: 30px !important;
}
.bl_richTxt {
  /*----------------------------------------
    段落・インライン
  ----------------------------------------*/
}
.bl_richTxt p {
  font-size: 1rem;
  line-height: 1.625;
}
.bl_richTxt p + p {
  margin-top: 1.625em;
}
.bl_richTxt strong {
  font-weight: 700;
}
.bl_richTxt i,
.bl_richTxt em {
  font-style: italic;
}
.bl_richTxt s {
  text-decoration: line-through;
}
.bl_richTxt a[href^="tel:"] {
  pointer-events: none;
  cursor: default;
}
@media (hover: none) and (pointer: coarse) {
  .bl_richTxt a[href^="tel:"] {
    pointer-events: auto;
    cursor: pointer;
  }
}
.bl_richTxt {
  /*----------------------------------------
    画像・キャプション
  ----------------------------------------*/
  /*----------------------------------------
    引用
  ----------------------------------------*/
  /*----------------------------------------
    リスト
  ----------------------------------------*/
}
.bl_richTxt ul {
  margin-top: 1.625em;
}
.bl_richTxt ul[class]:not(.el_ul) > li {
  margin-top: 0;
  padding-left: 0;
}
.bl_richTxt ul[class]:not(.el_ul) > li::before {
  content: none;
}
.bl_richTxt ol {
  margin-top: 1.625em;
}
.bl_richTxt {
  /*----------------------------------------
    テーブル
  ----------------------------------------*/
}
.bl_richTxt .bl_tableWrap,
.bl_richTxt .bl_tableWrap02 {
  margin-top: 1.625em;
}
.bl_richTxt .bl_tableWrap table,
.bl_richTxt .bl_tableWrap02 table {
  margin-top: 0;
}
.bl_richTxt {
  /*----------------------------------------
    ボックス
  ----------------------------------------*/
}
.bl_richTxt .bl_box h2, .bl_richTxt .bl_box h3, .bl_richTxt .bl_box h4, .bl_richTxt .bl_box h5 {
  margin-top: 0;
}
.bl_richTxt {
  /*----------------------------------------
    マージン調整
  ----------------------------------------*/
  /*----------------------------------------
    動画
  ----------------------------------------*/
}
.bl_richTxt iframe {
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
}
.bl_richTxt {
  /*----------------------------------------
    clearfix
  ----------------------------------------*/
}
.bl_richTxt .clearfix::after {
  content: "";
  display: block;
  clear: both;
}
.bl_richTxt {
  /*----------------------------------------
    水平線
  ----------------------------------------*/
}
.bl_richTxt hr {
  margin: 60px 0;
}

.bl_box {
  padding-block: 30px;
  border-radius: 10px;
  background-color: #f5f9fd;
}
@media screen and (min-width: 992px) {
  .bl_box {
    padding-block: 40px;
  }
}
.bl_box > :first-child {
  margin-top: 0;
}
.bl_box > :last-child {
  margin-bottom: 0;
}
.bl_box_inner {
  width: calc(100% - 60px);
  margin-inline: auto;
}
@media screen and (min-width: 992px) {
  .bl_box_inner {
    width: calc(100% - 80px);
  }
}
.bl_box_lv2Heading {
  margin-bottom: 20px;
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1.5;
}
.bl_box_txt {
  font-size: 1rem;
  line-height: 1.625;
}
.bl_box_txt + .bl_box_txt {
  margin-top: 1em;
}
.bl_box_ttl {
  margin-block: 30px 20px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
}
.bl_box_ttl02 {
  margin-bottom: 20px;
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5555555556;
}
.bl_box__scroll {
  overflow-y: scroll;
  max-height: 230px;
}
.bl_box__sm {
  padding-block: 26px;
}
.bl_box__sm .bl_box_inner {
  width: calc(100% - 52px);
}
.bl_box__sm .bl_box_ttl02 {
  margin-bottom: 12px;
}

.bl_boxTelBox {
  padding: 20px;
  background-color: var(--oct-white);
  border-radius: 10px;
}

.bl_boxTelBoxList {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
}
@media screen and (min-width: 992px) {
  .bl_boxTelBoxList {
    flex-direction: row;
    justify-content: center;
    gap: 0 80px;
  }
}

.bl_boxTelBoxItem {
  display: flex;
  flex-direction: column;
  gap: 4px 0;
  text-align: center;
}
@media screen and (min-width: 992px) {
  .bl_boxTelBoxItem {
    flex-direction: row;
    gap: 0 30px;
    text-align: left;
  }
}
.bl_boxTelBoxItem_ttl {
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.625;
}
.bl_boxTelBoxItem_num {
  color: var(--oct-blue);
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.625;
}

.bl_box02 {
  padding-block: 30px;
  border: 1px solid var(--oct-line);
  border-radius: 10px;
}
.bl_box02_inner {
  width: calc(100% - 60px);
  margin-inline: auto;
}
.bl_box02_head + .bl_box02_body {
  margin-top: 20px;
}
.bl_box02_ttl {
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5555555556;
}
@media screen and (min-width: 992px) {
  .bl_box02_ttl {
    font-size: 1.25rem;
    line-height: 1.6;
  }
}
.bl_box02_time {
  margin-top: 10px;
  color: var(--oct-blue);
  font-weight: 700;
  font-size: 0.8125rem;
  line-height: 1.5384615385;
}
.bl_box02 + .bl_box02 {
  margin-top: 30px;
}

.bl_boxList {
  padding: 30px;
  border: 1px solid var(--oct-line);
  border-radius: 10px;
}
@media screen and (min-width: 992px) {
  .bl_boxList {
    padding: 40px;
  }
}
.bl_boxList > li {
  border-bottom: 1px solid var(--oct-line);
}
.bl_boxList > li:last-child {
  border-bottom: none;
}
.bl_boxList > li:last-child > a {
  padding-bottom: 0;
}
.bl_boxList > li:first-child > a {
  padding-top: 0;
}
.bl_boxList > li > a {
  display: block;
  padding-block: 30px;
}
@media screen and (min-width: 992px) {
  .bl_boxList > li > a {
    padding-block: 40px;
  }
}

.bl_media {
  padding-block: 30px;
  border: 1px solid var(--oct-line);
  border-radius: 10px;
}
@media screen and (min-width: 992px) {
  .bl_media {
    padding-block: 40px;
  }
}
.bl_media_inner {
  width: calc(100% - 60px);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: 40px 0;
}
@media screen and (min-width: 992px) {
  .bl_media_inner {
    flex-direction: row;
    gap: 0 40px;
  }
}
.bl_media_imgWrap {
  width: 100%;
}
@media screen and (min-width: 992px) {
  .bl_media_imgWrap {
    width: 320px;
  }
}
.bl_media_imgWrap img {
  display: block;
  width: 100%;
}
@media screen and (min-width: 992px) {
  .bl_media_cont {
    flex: 1;
  }
}
.bl_media_txt {
  color: #4d5d71;
}
.bl_media .el_lv3Heading {
  margin-top: 0;
  font-weight: 700;
}
.bl_media .fileSize {
  display: none;
}
.bl_media + .bl_media {
  margin-top: 30px;
}
@media screen and (min-width: 992px) {
  .bl_media__rev {
    flex-direction: row-reverse;
  }
}

.bl_mediaLinkList {
  display: flex;
  flex-direction: column;
  gap: 16px 0;
  margin-top: 32px !important;
}
@media screen and (min-width: 992px) {
  .bl_mediaLinkList {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 16px 60px;
  }
}
@media screen and (min-width: 992px) {
  .bl_mediaLinkList > li {
    width: calc((100% - 60px) / 2);
  }
}
.bl_mediaLinkList > li > a {
  position: relative;
  display: block;
  padding-right: 28px;
  text-decoration: none;
  font-weight: 700;
  transition: color 0.2s ease;
}
.bl_mediaLinkList > li > a::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-black.svg") no-repeat center;
  background-size: 100% 100%;
}
@media (hover: hover) {
  .bl_mediaLinkList > li > a:hover {
    color: var(--oct-blue);
  }
}

.bl_contentBox {
  overflow: hidden;
  border-radius: 10px;
  border: 1px solid var(--color-accent);
  background-color: var(--color-accent);
}
.bl_contentBox + .bl_contentBox {
  margin-top: 30px;
}
.bl_contentBox_heading {
  font-weight: 400;
  border-bottom: 1px solid var(--color-accent);
  background-color: var(--color-background-secondary);
  padding: 7px 14px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .bl_contentBox_heading {
    padding: 7px 21px;
  }
}
.bl_contentBox_body {
  background-color: var(--color-background);
  padding: 15px 19px 26px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.02em;
}

.bl_contentBox02 {
  margin-top: 80px;
  color: var(--color-text-dg);
}
.bl_contentBox02 + .bl_contentBox02 {
  margin-top: 30px;
}
.bl_contentBox02_heading {
  font-weight: 500;
  border-bottom: 2px solid var(--dark-green);
  background-color: var(--color-background-secondary);
  padding: 7px 0;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
.bl_contentBox02_body {
  margin-top: 20px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.02em;
}
.bl_contentBox02_btnWrap {
  margin-top: 27px;
}
.bl_contentBox02_btnWrap .el_btn__02 {
  max-width: none !important;
  width: auto;
}
.bl_contentBox02 .hp_telRestricted.clrGreen {
  color: var(--color-accent);
}

.bl_bnrList {
  display: flex;
  flex-direction: column;
  gap: 30px 0;
}
@media screen and (min-width: 992px) {
  .bl_bnrList {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 30px;
  }
}
.bl_bnrList > li {
  width: 100%;
}
@media screen and (min-width: 992px) {
  .bl_bnrList > li {
    width: calc((100% - 60px) / 3);
  }
}
.bl_bnrList > li > a {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--oct-white);
  transition: opacity 0.2s ease;
}
@media (hover: hover) {
  .bl_bnrList > li > a:hover {
    opacity: 0.7;
  }
}
.bl_bnrList > li > a img {
  display: block;
  width: 100%;
}
@media screen and (min-width: 992px) {
  .bl_bnrList__1col {
    flex-direction: column;
    flex-wrap: nowrap;
  }
}
@media screen and (min-width: 992px) {
  .bl_bnrList__1col > li {
    width: 100%;
  }
}

.bl_searchbar {
  position: relative;
  display: flex;
  height: 50px;
  border-radius: 30px;
}
.bl_searchbar_input {
  position: relative;
  flex: 1;
}
.bl_searchbar_input::before {
  position: absolute;
  top: calc(50% - 10px);
  left: 15px;
  z-index: 1;
  display: block;
  content: "";
  width: 20px;
  height: 20px;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  background: url("/common/images/icons/icon-search-dark-green.svg") center no-repeat;
  background-size: 100% 100%;
}
@media screen and (min-width: 768px) {
  .bl_searchbar_input::before {
    left: 25px;
  }
}
.bl_searchbar_input input {
  position: absolute;
  inset: 0;
  border-radius: 30px 0 0 30px;
  background-color: var(--color-background);
  padding-inline: 41px 20px;
  font-size: 1rem;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .bl_searchbar_input input {
    padding-inline: 57px 20px;
  }
}
.bl_searchbar_input input::-moz-placeholder {
  color: #767676;
}
.bl_searchbar_input input::placeholder {
  color: #767676;
}
.bl_searchbar_input input:focus-visible {
  outline-offset: -3px;
}
.bl_searchbar_btn {
  position: relative;
  z-index: 1;
  width: 76px;
  font-weight: 800;
  color: var(--color-on-accent);
  border-radius: 0 30px 30px 0;
  background-color: #004098;
  transition: background-color 0.3s ease-out;
  font-size: 1.125rem;
  line-height: 1.4444444444;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .bl_searchbar_btn {
    width: 100px;
  }
}
.bl_searchbar_btn:focus-visible {
  outline-offset: -3px;
}
@media (hover: hover) {
  .bl_searchbar_btn:hover {
    background-color: var(--color-primary);
  }
}
.bl_searchbar__border .bl_searchbar_input input {
  border: 1px solid var(--color-accent);
  border-right: none;
}

.bl_searchbar02 {
  border-radius: 30px;
  display: flex;
  height: 50px;
  position: relative;
}
.bl_searchbar02_input {
  flex: 1;
  position: relative;
}
.bl_searchbar02_input:before {
  background: url(/common/img/icons/icon-search-dark-green.svg) 50% no-repeat;
  background-size: 100% 100%;
  content: "";
  display: block;
  height: 20px;
  left: 15px;
  position: absolute;
  top: calc(50% - 10px);
  width: 20px;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .bl_searchbar02_input:before {
    left: 25px;
  }
}
.bl_searchbar02_input input {
  background-color: var(--color-background);
  border-radius: 10px 0 0 10px;
  font-size: 1rem;
  inset: 0;
  letter-spacing: 0.05em;
  padding-inline: 41px 20px;
  position: absolute;
  border: 1px solid var(--dark-green);
}
@media screen and (min-width: 768px) {
  .bl_searchbar02_input input {
    padding-inline: 57px 20px;
  }
}
.bl_searchbar02_input input::-moz-placeholder {
  color: #767676;
}
.bl_searchbar02_input input::placeholder {
  color: #767676;
}
.bl_searchbar02_input input:focus-visible {
  outline-offset: -3px;
}
.bl_searchbar02_btn {
  background-color: #004098;
  border-radius: 0 10px 10px 0;
  color: var(--color-on-accent);
  font-size: 1.125rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  line-height: 1.4444444444;
  position: relative;
  transition: background-color 0.3s ease-out;
  width: 76px;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .bl_searchbar02_btn {
    width: 100px;
  }
}
.bl_searchbar02_btn:focus-visible {
  outline-offset: -3px;
}
@media (hover: hover) {
  .bl_searchbar02_btn:hover {
    background-color: var(--color-primary);
  }
}
.bl_searchbar02__border .bl_searchbar_input input {
  border: 1px solid var(--color-accent);
  border-right: none;
}

@media screen and (min-width: 992px) {
  .bl_tabContent {
    display: flex;
    align-items: flex-start;
    gap: 0 70px;
  }
}
.bl_tabContent_tabs {
  display: inline-flex;
  align-items: flex-end;
  gap: 0 8px;
}
@media screen and (min-width: 992px) {
  .bl_tabContent_tabs {
    min-width: 150px;
    flex-direction: column;
    align-items: flex-start;
    gap: 15px 0;
  }
}
.bl_tabContent_tab {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-grow: 1;
  min-height: 38px;
  text-align: center;
  border-radius: 10px;
  border: 2px solid var(--oct-line);
  background-color: var(--oct-white);
  padding: 8px 24px;
  font-weight: 700;
  cursor: pointer;
  transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
  font-size: 0.875rem;
  line-height: 1.4285714286;
}
@media screen and (min-width: 992px) {
  .bl_tabContent_tab {
    width: 100%;
    min-height: 46px;
    font-size: 1rem;
    line-height: 1.625;
  }
}
.bl_tabContent_tab__orange[aria-selected=true] {
  border-color: var(--oct-orange);
  background-color: var(--oct-orange);
  color: var(--oct-white);
}
@media (hover: hover) {
  .bl_tabContent_tab__orange:hover {
    border-color: var(--oct-orange);
    background-color: var(--oct-orange);
    color: var(--oct-white);
  }
}
.bl_tabContent_tab__blue[aria-selected=true] {
  border-color: var(--oct-blue);
  background-color: var(--oct-blue);
  color: var(--oct-white);
}
@media (hover: hover) {
  .bl_tabContent_tab__blue:hover {
    border-color: var(--oct-blue);
    background-color: var(--oct-blue);
    color: var(--oct-white);
  }
}
.bl_tabContent_panels {
  margin-top: 10px;
  background-color: var(--oct-white);
}
@media screen and (min-width: 992px) {
  .bl_tabContent_panels {
    margin-top: 0;
    flex: 1;
  }
}
@media screen and (min-width: 992px) {
  .bl_tabContent .el_btn02_wrap {
    width: calc(100% + 220px);
    transform: translateX(-220px);
  }
}

.bl_pageMv {
  padding-block: 15px 23px;
  background-color: var(--color-background-primary);
}
@media screen and (min-width: 768px) {
  .bl_pageMv {
    padding-block: 27px 40px;
  }
}
.bl_pageMv_centered {
  max-width: 1180px;
}
.bl_pageMv_bg img {
  display: block;
  width: 100%;
}

.bl_faq_item {
  padding: 20px;
  border: 1px solid #dae2eb;
  border-radius: 10px;
}
@media screen and (min-width: 992px) {
  .bl_faq_item {
    padding: 24px;
  }
}
.bl_faq_heading {
  display: flex;
  gap: 0 12px;
  margin-bottom: 20px;
}
@media screen and (min-width: 992px) {
  .bl_faq_heading {
    gap: 0 18px;
  }
}
.bl_faq_heading .label {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  min-width: 32px;
  padding-bottom: 4px;
  color: var(--oct-white);
  border-radius: 50%;
  background-color: #005cb9;
  font-weight: 700;
  font-size: 0.875rem;
  line-height: 1;
  letter-spacing: 0em;
}
.bl_faq_heading .ttl {
  flex: 1;
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
.bl_faq_body {
  width: 100%;
  display: flex;
  gap: 0 12px;
  border-radius: 10px;
  background-color: var(--oct-softBlue);
  padding: 20px;
}
@media screen and (min-width: 992px) {
  .bl_faq_body {
    width: calc(100% - 100px);
    margin-inline: auto;
    padding: 24px;
    gap: 0 18px;
  }
}
.bl_faq_body .label {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  min-width: 32px;
  padding-bottom: 4px;
  color: var(--oct-white);
  border-radius: 50%;
  background-color: var(--oct-orange);
  font-weight: 700;
  font-size: 0.875rem;
  line-height: 1;
  letter-spacing: 0em;
}
.bl_faq_body .content {
  flex: 1;
  padding-top: 2px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.bl_faq_body + .bl_faq_heading {
  margin-top: 30px;
}
.bl_faq__acc .bl_faq_heading {
  position: relative;
  z-index: 1;
  width: 100%;
  padding-right: 24px;
  margin-bottom: 0;
  text-align: left;
}
@media screen and (min-width: 992px) {
  .bl_faq__acc .bl_faq_heading {
    padding-right: 40px;
  }
}
.bl_faq__acc .bl_faq_heading::before, .bl_faq__acc .bl_faq_heading::after {
  content: "";
  display: block;
  position: absolute;
  border-radius: 2px;
  background-color: #005cb9;
}
.bl_faq__acc .bl_faq_heading::before {
  top: 10px;
  right: 6px;
  width: 2px;
  height: 14px;
  transition: transform 0.2s ease;
}
@media screen and (min-width: 992px) {
  .bl_faq__acc .bl_faq_heading::before {
    right: 19px;
  }
}
.bl_faq__acc .bl_faq_heading::after {
  top: 16px;
  right: 0;
  width: 14px;
  height: 2px;
}
@media screen and (min-width: 992px) {
  .bl_faq__acc .bl_faq_heading::after {
    right: 13px;
  }
}
.bl_faq__acc .bl_faq_body {
  margin-top: 20px;
}
.bl_faq__acc .bl_faq_body .content a {
  position: relative;
  display: inline-block;
  padding-right: 28px;
}
.bl_faq__acc .bl_faq_body .content a:not(.el_linkIcon)::after {
  content: "";
  display: block;
  position: absolute;
  top: 2px;
  right: 0;
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-black.svg") no-repeat center;
  background-size: 100% 100%;
}
.bl_faq__acc .bl_faq_item {
  position: relative;
}
.bl_faq__acc .bl_faq_item::after {
  content: "";
  display: block;
  position: absolute;
  top: 5px;
  right: 0;
  width: 52px;
  height: 28px;
  background-color: var(--oct-white);
  border-radius: 16px;
}
.bl_faq__acc .bl_faq_item + .bl_faq_item {
  margin-top: 12px;
}
.bl_faq__acc .bl_faq_item.is_open .bl_faq_heading::before {
  transform: rotate(-90deg);
}

.bl_allyInfo .el_img02 {
  margin-top: 20px;
}
.bl_allyInfo .el_txt__smail {
  margin-top: 8px;
}
@media screen and (min-width: 768px) {
  .bl_allyInfo .el_txt__smail {
    text-align: center;
  }
}

/* その他モーダル */
.bl_dialog {
  background-color: rgba(0, 0, 0, 0.3);
  display: flex;
  flex-direction: column;
  inset: 0;
  opacity: 0;
  overflow-y: auto;
  padding: 45px 15px;
  position: fixed;
  transition: visibility 0.3s ease-out, opacity 0.3s ease-out;
  visibility: hidden;
  z-index: 1002;
}
.bl_dialog.is_menuOpen {
  opacity: 1;
  visibility: visible;
  will-change: visibility, opacity;
}
.bl_dialog_container {
  background-color: var(--color-background);
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  margin: auto;
  max-width: 1000px;
  padding: 30px 15px;
  position: relative;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .bl_dialog_container {
    padding: 30px 50px;
  }
}
.bl_dialog_content {
  margin-bottom: auto;
}
.bl_dialog_heading {
  display: flex;
  align-items: center;
  gap: 0 8px;
  padding: 12px 25px;
  margin-bottom: 20px;
  background-color: var(--color-background-secondary);
  border-radius: 20px;
}
.bl_dialog_heading .icon {
  width: 20px;
}
.bl_dialog_heading .icon img {
  display: block;
  width: 100%;
}
.bl_dialog_heading .heading {
  color: var(--dark-green);
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.4166666667;
  letter-spacing: 0.05em;
}

/* CMSで画像を挿入した場合のモーダル */
.bl_modal {
  position: relative;
  width: 80vmin;
  aspect-ratio: 1/1;
  max-width: calc(100% - 40px);
  max-height: calc(100% - 40px);
  display: flex;
  flex-direction: column;
}
.bl_modal__w700 {
  max-width: 700px;
}
.bl_modal_wrap {
  position: fixed;
  inset: 0;
  z-index: 1001;
  display: grid;
  place-items: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease-out, visibility 0.3s ease-out;
}
.bl_modal_wrap.is_active {
  opacity: 1;
  visibility: visible;
}
.bl_modal_overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
}
.bl_modal_close {
  position: absolute;
  bottom: 100%;
  left: 100%;
  transform: translate(calc(-50% - 4px), 50%);
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .bl_modal_close {
    transform: translate(-50%, 50%);
  }
}
.bl_modal_close > button {
  position: relative;
  width: 36px;
  height: 36px;
  border: none;
  background-color: #333;
  border-radius: 50%;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .bl_modal_close > button {
    width: 40px;
    height: 40px;
  }
}
.bl_modal_close > button::before, .bl_modal_close > button::after {
  content: "";
  display: block;
  position: absolute;
  top: 17px;
  left: 8px;
  width: 19px;
  height: 2px;
  background-color: var(--white);
}
@media screen and (min-width: 768px) {
  .bl_modal_close > button::before, .bl_modal_close > button::after {
    top: 20px;
    left: 10px;
    width: 20px;
  }
}
.bl_modal_close > button::before {
  transform: rotate(-45deg);
}
.bl_modal_close > button::after {
  transform: rotate(45deg);
}
.bl_modal_inner {
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.bl_modal_cont {
  position: relative;
  padding: 24px;
  border-radius: 12px;
  background-color: var(--white);
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.bl_modal_cont img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
}

.bl_search {
  position: relative;
}
.bl_search_input {
  width: 100%;
  height: 60px;
  padding: 12px 50px 12px 20px;
  border: 1px solid transparent;
  border-radius: 10px;
  outline: none;
  background-color: var(--oct-white);
  color: var(--oct-black);
  transition: all 0.2s ease;
  cursor: pointer;
}
.bl_search_icon {
  position: absolute;
  top: 50%;
  right: 18px;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  cursor: pointer;
  transition: all 0.2s ease;
}
.bl_search_icon img {
  display: block;
  width: 100%;
}
.bl_search_icon::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-serch.svg") center no-repeat;
  background-size: 100% 100%;
}
.bl_search__w500 {
  max-width: 500px;
}

.bl_search02 {
  border-radius: 10px;
  display: flex;
  height: 50px;
  position: relative;
}
.bl_search02_input {
  flex: 1;
  position: relative;
}
.bl_search02_input:before {
  background: url(/common/images/icons/icon-serch.svg) 50% no-repeat;
  background-size: 100% 100%;
  content: "";
  display: block;
  height: 20px;
  left: 15px;
  position: absolute;
  top: calc(50% - 10px);
  width: 20px;
  z-index: 1;
}
.bl_search02_input input {
  position: absolute;
  inset: 0;
  background-color: var(--oct-white);
  border-radius: 10px 0 0 10px;
  padding-inline: 40px 20px;
  border: 1px solid var(--oct-blue);
  font-size: 1rem;
  letter-spacing: 0.05em;
}
.bl_search02_input input::-moz-placeholder {
  color: #767676;
}
.bl_search02_input input::placeholder {
  color: #767676;
}
.bl_search02_input input:focus-visible {
  outline-offset: -3px;
}
.bl_search02_btn {
  background-color: var(--oct-blue);
  border-radius: 0 10px 10px 0;
  color: var(--oct-white);
  font-weight: 700;
  position: relative;
  transition: background-color 0.2s ease;
  width: 76px;
  z-index: 1;
  font-size: 1.125rem;
  line-height: 1.4444444444;
}
.bl_search02_btn:focus-visible {
  outline-offset: -3px;
}
@media (hover: hover) {
  .bl_search02_btn:hover {
    background-color: var(--oct-cellularCyan);
  }
}

.bl_searchModal {
  position: fixed;
  inset: 0;
  z-index: 1002;
  display: flex;
  flex-direction: column;
  background-color: rgba(0, 0, 0, 0.3);
  padding: 45px 15px;
  overflow-y: auto;
  visibility: hidden;
  opacity: 0;
  transition: visibility 0.2s ease, opacity 0.2s ease;
}
.bl_searchModal.is_menuOpen {
  will-change: visibility, opacity;
  visibility: visible;
  opacity: 1;
}
.bl_searchModal_container {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 600px;
  border-radius: 10px;
  background-color: var(--oct-white);
  margin: auto;
}
.bl_searchModal_content {
  margin-bottom: auto;
}
.bl_searchModal_heading {
  display: flex;
  align-items: center;
  gap: 0 8px;
  padding: 12px 20px;
  background-color: var(--oct-cellularCyan);
  border-radius: 10px 10px 0 0;
}
.bl_searchModal_heading .icon {
  width: 30px;
}
.bl_searchModal_heading .icon img {
  display: block;
  width: 100%;
}
.bl_searchModal_heading .heading {
  color: var(--oct-white);
  font-weight: 500;
  font-size: 1.25rem;
  line-height: 1.5;
}
.bl_searchModal_section {
  padding: 30px;
}
.bl_searchModal_section + .bl_searchModal_section {
  margin-top: 30px;
}
.bl_searchModal .el_btn02 {
  max-width: 200px;
  min-height: 40px;
}
.bl_searchModal .el_btn02_wrap {
  margin-top: 30px;
}

.bl_searchList {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
  margin-top: 30px;
}

.bl_searchItem {
  border: 1px solid var(--oct-line);
  border-radius: 6px;
  padding: 15px;
  background-color: var(--oct-white);
}
.bl_searchItem_ttl {
  font-weight: 700;
  font-size: 1.125rem;
}
.bl_searchItem_ttl > a {
  color: var(--oct-blue);
}
@media (hover: hover) {
  .bl_searchItem_ttl > a:hover {
    text-decoration: underline;
  }
}
.bl_searchItem_url {
  color: #808080;
  font-size: 0.75rem;
  margin: 5px 0;
}
.bl_searchItem_txt {
  font-size: 1rem;
}

.bl_pager {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
}
.bl_pager_wrap {
  margin-top: 40px;
}
@media screen and (min-width: 992px) {
  .bl_pager_wrap {
    margin-top: 60px;
  }
}
.bl_pager_num > a,
.bl_pager_num > span {
  width: 40px;
  aspect-ratio: 1;
  background-color: var(--oct-white);
  border: 1px solid var(--oct-line);
  border-radius: 4px;
  color: inherit;
  text-decoration: none;
  display: grid;
  place-items: center;
  transition: color 0.2s ease, background-color 0.2s ease;
  font-size: 1rem;
  line-height: 1;
}
.bl_pager_num > a:hover {
  color: var(--oct-white);
  background-color: var(--oct-blue);
  border-color: var(--oct-blue);
}
.bl_pager_num.is_current span {
  background-color: var(--oct-blue);
  color: var(--oct-white);
  border-color: var(--oct-blue);
}
.bl_pager_prev > a,
.bl_pager_prev > span, .bl_pager_next > a,
.bl_pager_next > span {
  width: 40px;
  aspect-ratio: 1;
  background-color: var(--oct-white);
  border: 1px solid var(--oct-line);
  border-radius: 4px;
  color: inherit;
  text-decoration: none;
  display: grid;
  place-items: center;
  transition: background-color 0.2s ease;
}
.bl_pager_prev > a::before,
.bl_pager_prev > span::before, .bl_pager_next > a::before,
.bl_pager_next > span::before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-top: 2px solid var(--oct-black);
  border-right: 2px solid var(--oct-black);
  transform: rotate(45deg);
  transition: border 0.2s ease;
}
.bl_pager_prev > a:hover, .bl_pager_next > a:hover {
  background-color: var(--oct-blue);
  border-color: var(--oct-blue);
}
.bl_pager_prev > a:hover::before, .bl_pager_next > a:hover::before {
  border-color: var(--oct-white);
}
.bl_pager_prev > span, .bl_pager_next > span {
  background-color: #e9ebed;
  border-color: #e9ebed;
}
.bl_pager_prev > span::before, .bl_pager_next > span::before {
  opacity: 0.4;
}
.bl_pager_prev > a::before,
.bl_pager_prev > span::before {
  margin-left: 3px;
  transform: rotate(45deg) scale(-1);
}
.bl_pager_next > a::before,
.bl_pager_next > span::before {
  margin-right: 3px;
}

.bl_fileLinks {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
}
@media screen and (min-width: 768px) {
  .bl_fileLinks {
    flex-direction: row;
    gap: 20px 40px;
  }
}
@media screen and (min-width: 768px) {
  .bl_fileLinks__center {
    max-width: 950px;
    margin-inline: auto;
  }
}
.bl_fileLinks > li > a {
  display: block;
  background-color: #f5f5f5;
  padding: 15px 19px;
  color: var(--color-text);
  text-decoration: underline;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.02em;
}
.bl_fileLinks > li > a:hover {
  color: var(--color-primary);
}
.bl_fileLinks > li .el_linkIcon::before {
  display: inline-block;
  content: "";
  width: 24px;
  height: 24px;
  vertical-align: -6px;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  margin-right: 5px;
}
.bl_fileLinks > li .el_linkIcon__pdf::before {
  background-image: url("/common/images/icons/file/icon-pdf.svg");
}
.bl_fileLinks > li .el_linkIcon__word::before {
  background-image: url("/common/images/icons/file/icon-word.svg");
}
.bl_fileLinks > li .el_linkIcon__excel::before {
  background-image: url("/common/images/icons/file/icon-excel.svg");
}
.bl_fileLinks > li .el_linkIcon__powerpoint::before {
  background-image: url("/common/images/icons/file/icon-powerpoint.svg");
}
.bl_fileLinks > li .el_linkIcon__zip::before {
  background-image: url("/common/images/icons/file/icon-filelink.svg");
}
.bl_imgCards + .bl_fileLinks {
  margin-top: 44px;
}
@media screen and (min-width: 768px) {
  .bl_imgCards + .bl_fileLinks {
    margin-top: 55px;
  }
}

.bl_btnList {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
  margin-top: 20px;
}
@media screen and (min-width: 768px) {
  .bl_btnList {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 0 30px;
  }
}
@media screen and (min-width: 768px) {
  .bl_btnList__2col > li {
    width: calc((100% - 30px) / 2);
  }
}
@media screen and (min-width: 768px) {
  .bl_btnList__w660 {
    max-width: 660px;
    margin-inline: auto;
  }
}

.bl_prevNext {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
}
.bl_prevNext_wrap {
  margin-top: 30px;
}
@media screen and (min-width: 768px) {
  .bl_prevNext_wrap {
    margin-top: 60px;
  }
}
.bl_prevNext_prev > a,
.bl_prevNext_prev > span, .bl_prevNext_next > a,
.bl_prevNext_next > span {
  position: relative;
  display: inline-block;
  min-height: 40px;
  padding: 4px 22px 5px 36px;
  background-color: var(--white);
  border: 1px solid var(--color-accent);
  border-radius: 4px;
  color: var(--color-accent);
  display: grid;
  place-items: center;
  transition: color 0.3s ease-out, background 0.3s ease-out;
}
.bl_prevNext_prev > a::before,
.bl_prevNext_prev > span::before, .bl_prevNext_next > a::before,
.bl_prevNext_next > span::before {
  content: "";
  display: block;
  position: absolute;
  top: 16px;
  left: 16px;
  width: 8px;
  height: 8px;
  border-top: 2px solid var(--color-accent);
  border-right: 2px solid var(--color-accent);
  transform: rotate(45deg);
  transition: border 0.3s ease-out;
}
.bl_prevNext_prev > a:hover, .bl_prevNext_next > a:hover {
  color: var(--white);
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}
.bl_prevNext_prev > a:hover::before, .bl_prevNext_next > a:hover::before {
  border-color: var(--white);
}
.bl_prevNext_prev > a::before,
.bl_prevNext_prev > span::before {
  transform: rotate(45deg) scale(-1);
}
.bl_prevNext_next > a,
.bl_prevNext_next > span {
  padding: 4px 36px 5px 22px;
}
.bl_prevNext_next > a::before,
.bl_prevNext_next > span::before {
  left: calc(100% - 24px);
}

.bl_flowList {
  margin-bottom: 40px;
  display: flex;
  justify-content: center;
  gap: 0 30px;
}
@media screen and (min-width: 992px) {
  .bl_flowList {
    margin-bottom: 60px;
    gap: 0 140px;
  }
}
.bl_flowList > li {
  position: relative;
}
.bl_flowList > li:not(:first-child)::before {
  content: "";
  display: block;
  position: absolute;
  top: 20px;
  right: 100%;
  width: 30px;
  height: 2px;
  background-color: var(--oct-line);
}
@media screen and (min-width: 992px) {
  .bl_flowList > li:not(:first-child)::before {
    width: 100px;
    right: calc(100% + 20px);
  }
}
.bl_flowList > li.is_current::before {
  background-color: var(--oct-blue);
}
.bl_flowList > li.is_current .bl_flowItem_num {
  color: var(--oct-white);
  background-color: var(--oct-blue);
  font-weight: 700;
}
.bl_flowList > li.is_current .bl_flowItem_ttl {
  font-weight: 700;
}

.bl_flowItem {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px 0;
}
@media screen and (min-width: 992px) {
  .bl_flowItem {
    flex-direction: row;
    gap: 0 12px;
  }
}
.bl_flowItem_num {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  color: var(--oct-text);
  background-color: #dce3eb;
  border-radius: 50%;
  font-weight: 700;
  font-size: 0.9375rem;
  line-height: 1;
}
.bl_flowItem_ttl {
  text-align: center;
  font-size: 0.9375rem;
  line-height: 1.5333333333;
}

.bl_formMassage {
  padding: 10px 15px;
  color: var(--oct-red);
  border: 2px solid var(--oct-red);
  background-color: #fffaca;
  margin: 10px auto;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}

.bl_form_required {
  display: inline-block;
  min-width: 42px;
  padding: 4px 8px 5px;
  text-align: center;
  color: var(--oct-white);
  background-color: var(--oct-orange);
  border-radius: 4px;
  font-weight: 700;
  font-size: 0.75rem;
  line-height: 1;
  letter-spacing: 0.05em;
}
.bl_form_required[hidden] {
  display: none;
}
.bl_form_note {
  margin-top: 8px;
  font-size: 0.875rem;
  line-height: 1.5714285714;
  letter-spacing: 0.05em;
}
.bl_form_fieldset {
  border: none;
  padding: 0;
  margin: 0;
}
.bl_form_fieldset legend {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
.bl_form_privacy {
  width: calc(100% - 40px);
  max-width: 900px;
  margin: 40px auto 0;
  padding: 30px;
  background-color: #f5f9fd;
  border: 1px solid #f5f9fd;
  border-radius: 10px;
}
@media screen and (min-width: 992px) {
  .bl_form_privacy {
    width: calc(100% - 80px);
  }
}
.bl_form_privacy .ttl {
  display: flex;
  align-items: center;
  gap: 0 10px;
  margin-bottom: 13px;
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5555555556;
}
@media screen and (min-width: 992px) {
  .bl_form_privacy .ttl {
    flex: 1;
    font-size: 1.25rem;
    line-height: 1.5;
  }
}
.bl_form_privacy .txt {
  font-size: 0.9375rem;
  line-height: 1.7333333333;
}
.bl_form_privacy .content {
  margin-top: 30px;
}
.bl_form_fileList {
  display: flex;
  flex-direction: column;
  gap: 8px 0;
  margin: 8px 0;
}
.bl_form_fileList > li {
  display: flex;
  align-items: center;
  gap: 0 8px;
  font-size: 0.875rem;
  line-height: 1;
  letter-spacing: 0.05em;
}
.bl_form_fileList .remove-file {
  display: inline-block;
  padding: 8px;
  border: 1px solid var(--oct-orange);
  background-color: var(--oct-orange);
  color: var(--oct-orange);
  border-radius: 4px;
  font-size: 0.875rem;
  line-height: 1;
  letter-spacing: 0.05em;
}
.bl_form .error {
  display: inline-block;
  margin-top: 8px;
  color: var(--oct-red);
  font-weight: 700;
  font-size: 0.875rem;
  line-height: 1.5714285714;
  letter-spacing: 0.05em;
}

.bl_formList {
  width: calc(100% - 40px);
  max-width: 900px;
  margin-inline: auto;
}
@media screen and (min-width: 992px) {
  .bl_formList {
    width: calc(100% - 80px);
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 30px 20px;
  }
}
.bl_formList dt {
  display: flex;
  align-items: center;
  gap: 0 10px;
  margin: 40px 0 13px 0;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 992px) {
  .bl_formList dt {
    margin: 0;
    padding-top: 13px;
    width: calc(100% - 20px - 68.1818182%);
    min-height: 40px;
  }
}
.bl_formList dt:first-child {
  margin-top: 0;
}
.bl_formList dd {
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 992px) {
  .bl_formList dd {
    width: 68.1818182%;
    min-height: 40px;
  }
}
.bl_formList dd.bg_on {
  padding: 10px;
  border-radius: 10px;
  background-color: #f3f6f8;
  border: 2px solid #dfdfdf;
}
.bl_formList_wrap {
  margin-top: 50px;
  padding-block: 30px;
  border-radius: 10px;
  background-color: var(--oct-white);
  border: 1px solid var(--oct-line);
}
@media screen and (min-width: 992px) {
  .bl_formList_wrap {
    padding-block: 40px;
  }
}
.bl_formList__error {
  border-color: var(--oct-red);
  background-color: #fff7f7;
}
.bl_formList__error .bl_form_privacy {
  border: 2px solid var(--oct-red);
  background-color: #ffebeb;
}
.bl_formList__confirm dt {
  padding-top: 0;
}

.bl_formBtns {
  margin-top: 30px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px 0;
}

.bl_formBtn {
  position: relative;
  width: 100%;
  max-width: 260px;
  min-height: 60px;
  padding: 18px 52px 18px 34px;
  border-radius: 60px;
  background-color: var(--oct-blue);
  color: var(--oct-white);
  font-weight: 700;
  transition: opacity 0.2s ease;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.bl_formBtn::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 24px;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-white.svg") no-repeat center;
  background-size: 100% 100%;
}
@media (hover: hover) {
  .bl_formBtn:hover {
    opacity: 0.7;
  }
}
.bl_formBtn__back {
  padding-left: 52px;
  padding-right: 34px;
  background-color: var(--oct-muted);
}
.bl_formBtn__back::before {
  content: "";
  display: block;
  position: absolute;
  right: auto;
  left: 24px;
  transform: translateY(-50%) scale(-1, 1);
}

.bl_gradationBox {
  border-radius: 20px;
  background: var(--color-background);
  padding: 30px 15px;
}
@media screen and (min-width: 768px) {
  .bl_gradationBox {
    padding: 40px 50px 42px;
  }
}

.bl_irListBox {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  order: 2;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 30px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
}
@media (min-width: 768px) {
  .bl_irListBox {
    order: unset;
    gap: 25px;
  }
}
@media (min-width: 768px) {
  .bl_irListBox.compact {
    margin-top: -10px;
  }
}

.bl_topicGrid {
  width: 790px;
  max-width: 100%;
  display: flex;
  gap: 30px;
  flex-wrap: wrap;
  align-items: flex-start;
}

.bl_topicGrid {
  width: 100%;
  gap: 30px;
}

.bl_topicCard {
  flex-basis: 100%;
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
@media (min-width: 768px) {
  .bl_topicCard {
    flex: 0 0 380px;
    width: 380px;
  }
}
.bl_topicCard_image {
  position: relative;
  width: 100%;
  height: 212px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 10px;
  background: linear-gradient(90deg, #fbfbfb 0%, #f3f3f3 50%, #f2f2f2 100%);
}
@media (min-width: 768px) {
  .bl_topicCard_image {
    width: 380px;
    height: 240px;
  }
}
.bl_topicCard_image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.bl_topicCard_image__presentation img, .bl_topicCard_image__vision img {
  position: absolute;
  max-width: none;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.bl_topicCard_title {
  width: 100%;
  min-height: 28px;
  margin-top: 14px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 24px;
  gap: 10px;
  align-items: center;
}
@media (min-width: 768px) {
  .bl_topicCard_title {
    width: 380px;
    min-height: 68px;
    margin-top: 20px;
    grid-template-columns: 346px 24px;
  }
}
.bl_topicCard_title h3 {
  margin: 0;
  width: auto;
  font-size: 18px;
  font-weight: 800;
  line-height: 28px;
}
@media (min-width: 768px) {
  .bl_topicCard_title h3 {
    width: 346px;
    font-size: 24px;
    line-height: 34px;
  }
}
.bl_topicCard_title span {
  color: var(--blue);
  font-style: normal;
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  background: url("/common/images/home/icon-arrow-dark.svg") center/24px 24px no-repeat;
  font-size: 0;
  line-height: 24px;
}
.bl_topicCard p {
  width: 100%;
  margin: 5px 0 0;
  font-size: 16px;
  line-height: 26px;
}
@media (min-width: 768px) {
  .bl_topicCard p {
    width: 380px;
    margin: 10px 0 0;
    font-size: 18px;
    line-height: 28px;
  }
}

.bl_sustainabilityContent {
  width: calc(100% - 40px);
  margin: 70px auto 0;
  display: grid;
  gap: 80px;
}
@media (min-width: 768px) {
  .bl_sustainabilityContent {
    width: min(1200px, 100% - 80px);
    margin-top: 94px;
    gap: 120px;
  }
}

.bl_sustainabilitySection {
  display: grid;
  gap: 20px;
  width: 100%;
  min-width: 0;
}
@media (min-width: 768px) {
  .bl_sustainabilitySection {
    gap: 40px;
  }
}
.bl_sustainabilitySection h2 {
  margin: 0;
  font-size: 24px;
  font-weight: 800;
  line-height: 34px;
}
@media (min-width: 768px) {
  .bl_sustainabilitySection h2 {
    font-size: 32px;
    line-height: 42px;
  }
}

.bl_sustainabilityReport_grid {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px;
  align-items: start;
}
@media (min-width: 768px) {
  .bl_sustainabilityReport_grid {
    grid-template-columns: repeat(3, minmax(0, 380px));
  }
}
.bl_sustainabilityReport_card {
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  color: var(--text);
}
@media (min-width: 768px) {
  .bl_sustainabilityReport_card {
    width: 380px;
  }
}
.bl_sustainabilityReport_card_image {
  width: 100%;
  height: auto;
  aspect-ratio: 335/212;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 10px;
  background: linear-gradient(90deg, #fbfbfb 0%, #f3f3f3 51%, #f2f2f2 100%);
}
@media (min-width: 768px) {
  .bl_sustainabilityReport_card_image {
    height: 240px;
    aspect-ratio: auto;
  }
}
.bl_sustainabilityReport_card_image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.bl_sustainabilityReport_card_image__integrated img {
  height: auto;
  min-height: 240px;
}
.bl_sustainabilityReport_card_image__tnfd img {
  width: 596px;
  max-width: none;
}
.bl_sustainabilityReport_card_title {
  width: 100%;
  min-height: 28px;
  margin-top: 14px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 24px;
  gap: 10px;
  align-items: center;
  font-size: 18px;
  font-weight: 800;
  line-height: 28px;
}
@media (min-width: 768px) {
  .bl_sustainabilityReport_card_title {
    min-height: 68px;
    margin-top: 20px;
    font-size: 24px;
    line-height: 34px;
  }
}
.bl_sustainabilityReport_card_title i {
  width: 24px;
  height: 24px;
  display: block;
  background: url("/common/images/home/icon-arrow-dark.svg") center/24px 24px no-repeat;
}
.bl_sustainabilityReport_card_text {
  margin-top: 5px;
  color: #4d5d71;
  font-size: 16px;
  line-height: 26px;
}
@media (min-width: 768px) {
  .bl_sustainabilityReport_card_text {
    margin-top: 10px;
    line-height: 28px;
  }
}

.bl_sustainabilityInitiative_list {
  display: grid;
  gap: 20px;
}
@media (min-width: 768px) {
  .bl_sustainabilityInitiative_list {
    gap: 30px;
  }
}
.bl_sustainabilityInitiative_card {
  min-height: 0;
  padding: 30px 20px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  align-items: start;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
}
@media (min-width: 768px) {
  .bl_sustainabilityInitiative_card {
    min-height: 316px;
    padding: 40px;
    grid-template-columns: 320px minmax(0, 1fr);
    gap: 40px;
  }
}
.bl_sustainabilityInitiative_card_image {
  width: 100%;
  height: auto;
  aspect-ratio: 295/170;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 0;
}
@media (min-width: 768px) {
  .bl_sustainabilityInitiative_card_image {
    width: 320px;
    height: 216px;
    aspect-ratio: auto;
  }
}
.bl_sustainabilityInitiative_card_body {
  display: grid;
  gap: 0;
}
.bl_sustainabilityInitiative_card_body h3 {
  margin: 0;
  font-size: 20px;
  font-weight: 800;
  line-height: 30px;
}
@media (min-width: 768px) {
  .bl_sustainabilityInitiative_card_body h3 {
    font-size: 24px;
    line-height: 34px;
  }
}
.bl_sustainabilityInitiative_card_body p {
  margin: 8px 0 0;
  color: #4d5d71;
  font-size: 15px;
  line-height: 25px;
}
@media (min-width: 768px) {
  .bl_sustainabilityInitiative_card_body p {
    margin-top: 12px;
    font-size: 16px;
    line-height: 28px;
  }
}

.bl_sustainabilityLinkGrid {
  margin-top: 22px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 15px;
}
@media (min-width: 768px) {
  .bl_sustainabilityLinkGrid {
    margin-top: 28px;
    grid-template-columns: repeat(2, minmax(0, 350px));
    gap: 16px 60px;
  }
}
.bl_sustainabilityLinkGrid a {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 24px;
  gap: 10px;
  align-items: start;
  font-size: 15px;
  font-weight: 700;
  line-height: 25px;
}
@media (min-width: 768px) {
  .bl_sustainabilityLinkGrid a {
    font-size: 16px;
    line-height: 26px;
  }
}
.bl_sustainabilityLinkGrid i {
  width: 24px;
  height: 24px;
  display: block;
  background: url("/common/images/home/icon-arrow-dark.svg") center/24px 24px no-repeat;
  margin-top: 1px;
}

.bl_sustainabilityNewsList_button {
  width: 184px;
}
.bl_sustainabilityNewsList .bl_irNewsRow > span {
  max-width: none;
}

.bl_aboutContent {
  width: calc(100% - 40px);
  margin: 70px auto 0;
}
@media (min-width: 768px) {
  .bl_aboutContent {
    width: min(1280px, 100% - 80px);
    margin-top: 94px;
  }
}

.bl_aboutMenu {
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px;
  align-items: start;
}
@media (min-width: 768px) {
  .bl_aboutMenu {
    grid-template-columns: repeat(3, minmax(0, 400px));
    gap: 40px;
  }
}

.bl_aboutCard {
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  color: var(--text);
}
@media (min-width: 768px) {
  .bl_aboutCard {
    width: 400px;
  }
}
.bl_aboutCard_media {
  position: relative;
  width: 100%;
  height: auto;
  display: block;
  overflow: hidden;
  border-radius: 10px;
  background: #fff;
  aspect-ratio: 335/201;
}
@media (min-width: 768px) {
  .bl_aboutCard_media {
    height: 240px;
    aspect-ratio: auto;
  }
}
.bl_aboutCard_media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  max-width: none;
  -o-object-fit: cover;
     object-fit: cover;
}
.bl_aboutCard__family .bl_aboutCard_media {
  background: #c4c4c4;
}
.bl_aboutCard__family .bl_aboutCard_media img {
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (min-width: 768px) {
  .bl_aboutCard__family .bl_aboutCard_media img {
    left: -115px;
    top: -3px;
    width: 610px;
    height: 246px;
  }
}
.bl_aboutCard__brand .bl_aboutCard_media img {
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  padding: 20px;
  box-sizing: border-box;
}
@media (min-width: 768px) {
  .bl_aboutCard__brand .bl_aboutCard_media img {
    left: 15px;
    top: 45px;
    width: 370px;
    height: 147px;
    padding: 0;
  }
}
.bl_aboutCard__sdgs .bl_aboutCard_media {
  background: #79b33d;
}
.bl_aboutCard__sdgs .bl_aboutCard_media img {
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (min-width: 768px) {
  .bl_aboutCard__sdgs .bl_aboutCard_media img {
    left: -20px;
    top: 30px;
    width: 441px;
    height: 179px;
  }
}
.bl_aboutCard__history .bl_aboutCard_media {
  background: #c4c4c4;
}
.bl_aboutCard__history .bl_aboutCard_media img {
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (min-width: 768px) {
  .bl_aboutCard__history .bl_aboutCard_media img {
    left: -99px;
    top: -2px;
    width: 598px;
    height: 242px;
  }
}
.bl_aboutCard_title {
  width: 100%;
  min-height: 28px;
  margin-top: 14px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 24px;
  gap: 10px;
  align-items: center;
  font-size: 18px;
  font-weight: 800;
  line-height: 28px;
}
@media (min-width: 768px) {
  .bl_aboutCard_title {
    min-height: 68px;
    margin-top: 20px;
    font-size: 24px;
    line-height: 34px;
  }
}
.bl_aboutCard_title i {
  width: 24px;
  height: 24px;
  display: block;
  background: url("/common/images/home/icon-arrow-dark.svg") center/24px 24px no-repeat;
}
.bl_aboutCard_text {
  margin-top: 5px;
  font-size: 16px;
  line-height: 26px;
}
@media (min-width: 768px) {
  .bl_aboutCard_text {
    margin-top: 10px;
    font-size: 18px;
    line-height: 28px;
  }
}

.bl_scholarshipTable {
  width: 100%;
  margin-top: -40px;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
  font-size: 15px;
  line-height: 25px;
}
@media (min-width: 768px) {
  .bl_scholarshipTable {
    margin-top: -80px;
    font-size: 16px;
    line-height: 26px;
  }
}
.bl_scholarshipTable tr {
  display: block;
  width: 100%;
  box-sizing: border-box;
}
@media (min-width: 768px) {
  .bl_scholarshipTable tr {
    display: table-row;
    width: auto;
  }
}
.bl_scholarshipTable tr:not(:last-child) td {
  border-bottom: 1px solid var(--line);
}
.bl_scholarshipTable tr:last-child th,
.bl_scholarshipTable tr:last-child td {
  border-bottom: 0;
}
.bl_scholarshipTable th,
.bl_scholarshipTable td {
  vertical-align: top;
}
.bl_scholarshipTable th {
  display: block;
  width: 100%;
  box-sizing: border-box;
  padding: 20px 20px 10px;
  background: #f3f7fb;
  border-right: 0;
  border-bottom: 0;
  text-align: left;
  font-weight: 800;
}
@media (min-width: 768px) {
  .bl_scholarshipTable th {
    display: table-cell;
    width: 260px;
    padding: 30px;
    border-right: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }
}
.bl_scholarshipTable td {
  display: block;
  width: 100%;
  box-sizing: border-box;
  padding: 0 20px 20px;
  background: #f3f7fb;
}
@media (min-width: 768px) {
  .bl_scholarshipTable td {
    display: table-cell;
    padding: 30px 40px;
    background: transparent;
    border-bottom: 1px solid var(--line);
  }
}

.bl_scholarshipApply {
  display: grid;
  gap: 20px;
  margin-top: 0;
}
@media (min-width: 768px) {
  .bl_scholarshipApply {
    gap: 40px;
  }
}
.bl_scholarshipApply h2 {
  margin: 0;
  font-size: 24px;
  font-weight: 800;
  line-height: 34px;
}
@media (min-width: 768px) {
  .bl_scholarshipApply h2 {
    font-size: 32px;
    line-height: 42px;
  }
}
.bl_scholarshipApply_box {
  min-height: 0;
  padding: 30px 20px;
  box-sizing: border-box;
  display: grid;
  justify-items: center;
  align-content: start;
  gap: 20px;
  border-radius: 4px;
  background: #f3f7fb;
  text-align: center;
}
@media (min-width: 768px) {
  .bl_scholarshipApply_box {
    min-height: 224px;
    padding: 50px 40px;
    gap: 30px;
  }
}
.bl_scholarshipApply_box p {
  margin: 0;
  text-align: left;
  font-size: 15px;
  line-height: 25px;
}
@media (min-width: 768px) {
  .bl_scholarshipApply_box p {
    text-align: center;
    font-size: 16px;
    line-height: 26px;
  }
}
.bl_scholarshipApply_box a {
  width: 100%;
  min-height: 42px;
  display: grid;
  place-items: center;
  border-radius: 21px;
  background: var(--text);
  color: #fff;
  font-size: 14px;
  font-weight: 800;
  line-height: 22px;
}
@media (min-width: 768px) {
  .bl_scholarshipApply_box a {
    width: 240px;
  }
}

.bl_scholarshipNews {
  display: grid;
  gap: 20px;
}
@media (min-width: 768px) {
  .bl_scholarshipNews {
    gap: 40px;
  }
}
.bl_scholarshipNews h2 {
  margin: 0;
  font-size: 24px;
  font-weight: 800;
  line-height: 34px;
}
@media (min-width: 768px) {
  .bl_scholarshipNews h2 {
    font-size: 32px;
    line-height: 42px;
  }
}
.bl_scholarshipNews_list .bl_irNewsRow > span {
  max-width: none;
}

.bl_referenceSites {
  gap: 30px;
}
.bl_referenceSites p {
  margin: 0;
  font-size: 18px;
  font-weight: 800;
  line-height: 30px;
}

.bl_referenceGrid {
  width: 100%;
  min-width: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  align-items: center;
}
@media (min-width: 768px) {
  .bl_referenceGrid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 30px;
  }
}

.bl_referenceBanner {
  position: relative;
  width: 100%;
  height: 105px;
  max-width: 100%;
  overflow: hidden;
  background: #fff;
}
@media (min-width: 768px) {
  .bl_referenceBanner {
    width: 380px;
    height: 117px;
  }
}
.bl_referenceBanner img {
  position: absolute;
  display: block;
  max-width: none;
  max-height: none;
  -o-object-fit: fill;
     object-fit: fill;
}
.bl_referenceBanner__research img {
  left: 5px;
  top: 2px;
  width: 325px;
  height: 102px;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (min-width: 768px) {
  .bl_referenceBanner__research img {
    left: 6px;
    top: 1px;
    width: 368px;
    height: 115px;
  }
}
.bl_referenceBanner__astris img {
  left: -10px;
  top: -53px;
  width: 376px;
  height: 212px;
}
@media (min-width: 768px) {
  .bl_referenceBanner__astris img {
    left: -7px;
    top: -59px;
    width: 416px;
    height: 234px;
  }
}
.bl_referenceBanner__logmi {
  border: 1px solid #d9d9d9;
}
.bl_referenceBanner__logmi img {
  left: 1px;
  top: 17px;
  width: 334px;
  height: 73px;
}
@media (min-width: 768px) {
  .bl_referenceBanner__logmi img {
    left: -3px;
    top: 18px;
    width: 387px;
    height: 84px;
  }
}

.bl_serviceArea {
  padding-block: 30px;
  background-color: #d6e1ee;
}
@media screen and (min-width: 992px) {
  .bl_serviceArea {
    padding-block: 50px;
  }
}

.bl_serviceLinks {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
@media screen and (min-width: 992px) {
  .bl_serviceLinks {
    gap: 20px;
  }
}
.bl_serviceLinks > li {
  width: calc((100% - 16px) / 2);
  min-height: 70px;
}
@media screen and (min-width: 992px) {
  .bl_serviceLinks > li {
    width: calc((100% - 100px) / 6);
    min-height: 80px;
  }
}
.bl_serviceLinks > li > a {
  width: 100%;
  height: 100%;
  padding: 8px;
  display: grid;
  place-items: center;
  background-color: var(--oct-white);
  border-radius: 10px;
  border: 1px solid var(--oct-line);
  transition: border 0.2s ease;
}
@media (hover: hover) {
  .bl_serviceLinks > li > a:hover {
    border-color: var(--oct-orange);
  }
}
.bl_serviceLinks > li > a img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.bl_disasterAlert {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 101;
  width: 100%;
  background-color: var(--oct-white);
  overflow: hidden;
}
.bl_disasterAlert_head {
  display: flex;
  align-items: center;
  gap: 0 8px;
  background-color: #ac2014;
  color: var(--oct-white);
  padding: 8px 20px;
  cursor: pointer;
}
@media screen and (min-width: 992px) {
  .bl_disasterAlert_head {
    padding: 6px 40px;
    gap: 0 16px;
  }
}
.bl_disasterAlert_ttl > span {
  position: relative;
  display: inline-block;
  padding-left: 36px;
  font-weight: 700;
  font-size: 0.875rem;
  line-height: 1.5;
}
@media screen and (min-width: 992px) {
  .bl_disasterAlert_ttl > span {
    font-size: 1rem;
  }
}
.bl_disasterAlert_ttl > span::before {
  content: "";
  display: grid;
  place-items: center;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-exclamationmark-white.svg") no-repeat center;
  background-size: 100% 100%;
}
.bl_disasterAlert_toggle {
  position: relative;
  min-width: 96px;
  height: 32px;
  margin-left: auto;
  padding: 4px 24px 4px 12px;
  border: 1px solid var(--oct-white);
  color: var(--oct-white);
  border-radius: 4px;
  font-size: 0.75rem;
  line-height: 1;
}
@media (min-width: 768px) {
  .bl_disasterAlert_toggle {
    min-width: 124px;
    height: 36px;
    padding: 4px 10px;
    font-size: 0.8125rem;
  }
}
.bl_disasterAlert_toggle::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  background: url("/common/images/icons/icon-arrow-chevron-white.svg") no-repeat center;
  background-size: 100% 100%;
  transition: transform 0.3s ease;
}
.bl_disasterAlert_toggle.is_active::after {
  transform: translateY(-50%) rotate(180deg);
}
.bl_disasterAlert_panel {
  background-color: #fff6f7;
  padding: 0 16px;
  display: grid;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
}
@media screen and (min-width: 992px) {
  .bl_disasterAlert_panel {
    padding: 0 80px;
  }
}
.bl_disasterAlert_row {
  position: relative;
  min-height: 48px;
  display: flex;
  align-items: center;
  color: var(--oct-blue);
  text-decoration: underline;
  padding: 8px 28px 8px 0;
  border-bottom: 1px solid var(--oct-line);
  font-size: 0.875rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 992px) {
  .bl_disasterAlert_row {
    min-height: 60px;
    font-size: 1rem;
  }
}
.bl_disasterAlert_row:last-child {
  border-bottom: 0;
}
.bl_disasterAlert_row::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-red.svg") no-repeat center;
  background-size: 100% 100%;
}
@media (hover: hover) {
  .bl_disasterAlert_row:hover {
    text-decoration: none;
  }
}

/* 独立ルートクラス */
/* disaster bar 表示中の ly_header オフセット
   災害バーは sticky top:0 で画面上部固定、ヘッダーが fixed (SP 常時 / PC scroll 後 is_fixed) の
   時に完全重なるため下にずらす。災害バー height は panel 開閉で変動するため JS で
   --bl_disasterAlert-height を動的更新し calc() で追従させる。
   PC scroll 前 (position: absolute, top: var(--hero-header-top)) は hero 下部配置を維持。 */
.bl_listIndex {
  display: flex;
  flex-direction: column;
  gap: 30px 0;
}
@media screen and (min-width: 992px) {
  .bl_listIndex__3col {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 50px 30px;
  }
}
@media screen and (min-width: 992px) {
  .bl_listIndex__3col > li {
    width: calc((100% - 60px) / 3);
  }
}
@media screen and (min-width: 992px) {
  .bl_listIndex__simple {
    row-gap: 30px;
  }
}
.bl_listIndex__simple .bl_listIndexItem {
  padding: 24px 20px;
  border: 1px solid #dce3eb;
  border-radius: 10px;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}
@media screen and (min-width: 992px) {
  .bl_listIndex__simple .bl_listIndexItem {
    padding: 30px;
  }
}
@media (hover: hover) {
  .bl_listIndex__simple .bl_listIndexItem:hover {
    color: var(--oct-black);
    transform: translateY(0);
    border-color: #8fa7c1;
    background-color: #f8fbfe;
  }
  .bl_listIndex__simple .bl_listIndexItem:hover .bl_listIndexItem_imgWrap img {
    transform: scale(1);
  }
  .bl_listIndex__simple .bl_listIndexItem:hover .bl_listIndexItem_ttl::after {
    right: 0;
  }
}
.bl_listIndex__simple .bl_listIndexItem[target=_blank] .bl_listIndexItem_ttl::after {
  background-image: url("/common/images/icons/icon-blank.svg");
}
.bl_listIndex__simple .bl_listIndexItem[href$=".pdf"] .bl_listIndexItem_ttl::after {
  background-image: url("/common/images/icons/file/icon-pdf.svg");
}
.bl_listIndex__simple .bl_listIndexItem[href$=".docx"] .bl_listIndexItem_ttl::after {
  background-image: url("/common/images/icons/file/icon-word.svg");
}
.bl_listIndex__simple .bl_listIndexItem[href$=".xlsx"] .bl_listIndexItem_ttl::after {
  background-image: url("/common/images/icons/file/icon-excel.svg");
}
.bl_listIndex + .content1 { /* 本文が表示された場合 */
  margin-top: 40px;
}
@media screen and (min-width: 992px) {
  .bl_listIndex + .content1 {
    margin-top: 80px;
  }
}

.bl_listIndexItem {
  display: block;
  height: 100%;
  color: var(--oct-text);
  text-decoration: none;
  transition: color 0.2s ease, transform 0.2s ease;
}
@media (hover: hover) {
  .bl_listIndexItem:hover {
    color: var(--oct-blue);
    transform: translateY(-4px);
  }
  .bl_listIndexItem:hover .bl_listIndexItem_imgWrap img {
    transform: scale(1.05);
  }
  .bl_listIndexItem:hover .bl_listIndexItem_ttl::after {
    right: -4px;
  }
}
.bl_listIndexItem_imgWrap {
  margin-bottom: 14px;
  border-radius: 10px;
  overflow: hidden;
}
@media screen and (min-width: 992px) {
  .bl_listIndexItem_imgWrap {
    margin-bottom: 20px;
  }
}
.bl_listIndexItem_imgWrap img {
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: 335/130;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.2s ease;
}
@media screen and (min-width: 992px) {
  .bl_listIndexItem_imgWrap img {
    aspect-ratio: 380/150;
  }
}
.bl_listIndexItem_ttl {
  position: relative;
  width: 100%;
  padding-right: 34px;
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5555555556;
}
@media screen and (min-width: 992px) {
  .bl_listIndexItem_ttl {
    font-size: 1.25rem;
    line-height: 1.7;
  }
}
.bl_listIndexItem_ttl::after {
  content: "";
  display: block;
  position: absolute;
  top: 2px;
  right: 0;
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-black.svg") no-repeat center;
  background-size: 100% 100%;
  transition: right 0.2s ease;
}
@media screen and (min-width: 992px) {
  .bl_listIndexItem_ttl::after {
    top: 4px;
  }
}
.bl_listIndexItem_lead {
  margin-top: 5px;
  font-size: 1rem;
  line-height: 1.625;
}
@media screen and (min-width: 992px) {
  .bl_listIndexItem_lead {
    margin-top: 10px;
    font-size: 1.125rem;
    line-height: 1.5555555556;
  }
}
.bl_listIndexItem.is_current {
  border: 2px solid var(--oct-blue);
}

/* 本文が表示された場合 */
.content1 + .bl_listIndex {
  margin-top: 40px;
}
@media screen and (min-width: 992px) {
  .content1 + .bl_listIndex {
    margin-top: 80px;
  }
}

.bl_selectLink {
  background-color: var(--oct-white);
  border: 1px solid var(--oct-line);
  border-radius: 5px;
  height: 40px;
  position: relative;
  width: 100%;
  max-width: 160px;
  z-index: 1;
}
.bl_selectLink::after {
  content: "";
  position: absolute;
  right: 15px;
  top: calc(50% - 5px);
  width: 14px;
  display: block;
  width: 8px;
  height: 8px;
  border-right: 2px solid var(--oct-black);
  border-bottom: 2px solid var(--oct-black);
  transform: rotate(45deg);
  z-index: -1;
}
.bl_selectLink select {
  position: absolute;
  inset: 0;
  padding: 4px 40px 4px 12px;
  color: var(--oct-black);
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
}
.bl_selectLink_wrap {
  display: flex;
  margin-bottom: 30px;
}

.bl_relatedArea {
  padding-block: 30px;
  background-color: #f2f5f8;
}
@media screen and (min-width: 992px) {
  .bl_relatedArea {
    padding-block: 50px;
  }
}

.bl_relatedLinks {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
@media screen and (min-width: 992px) {
  .bl_relatedLinks {
    gap: 20px;
  }
}
.bl_relatedLinks > li {
  width: calc((100% - 16px) / 2);
}
@media screen and (min-width: 992px) {
  .bl_relatedLinks > li {
    width: calc((100% - 100px) / 6);
  }
}
.bl_relatedLinks > li > a {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--oct-white);
  border-radius: 10px;
  border: 1px solid var(--oct-line);
  transition: border 0.2s ease;
}
@media (hover: hover) {
  .bl_relatedLinks > li > a:hover {
    border-color: var(--oct-blue);
  }
}
.bl_relatedLinks > li > a img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 10px;
}

.bl_linkImgCardUnit {
  display: flex;
  flex-direction: column;
  gap: 80px 0;
}
@media screen and (min-width: 992px) {
  .bl_linkImgCardUnit {
    flex-direction: row;
    gap: 80px;
  }
}
@media screen and (min-width: 992px) {
  .bl_linkImgCardUnit__2col {
    flex-wrap: wrap;
  }
}
@media screen and (min-width: 992px) {
  .bl_linkImgCardUnit__2col .bl_linkImgCard {
    width: calc((100% - 80px) / 2);
  }
}

.bl_linkImgCard {
  width: 100%;
}
.bl_linkImgCard_cont {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-end;
  padding: 20px;
  width: 100%;
  height: 150px;
  color: var(--oct-white);
}
@media screen and (min-width: 992px) {
  .bl_linkImgCard_cont {
    padding: 20px;
    height: 360px;
  }
}
@media (hover: hover) {
  .bl_linkImgCard_cont:hover .bl_linkImgCard_imgWrap img {
    transform: scale(1.05);
  }
}
.bl_linkImgCard_imgWrap {
  position: absolute;
  inset: 0;
  width: 100%;
  z-index: -1;
  border-radius: 10px;
  overflow: hidden;
}
.bl_linkImgCard_imgWrap::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, transparent, rgba(26, 43, 67, 0.6));
  border-radius: 10px;
}
.bl_linkImgCard_imgWrap img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 335/150;
  border-radius: 10px;
  box-shadow: 2px 2px 10px rgba(26, 43, 67, 0.2);
  transition: transform 0.2s ease;
}
.bl_linkImgCard_body {
  margin-top: 20px;
}
@media screen and (min-width: 992px) {
  .bl_linkImgCard_body {
    margin-top: 40px;
  }
}
.bl_linkImgCard_ttlWrap {
  width: 100%;
}
.bl_linkImgCard_ttl {
  position: relative;
  width: 100%;
  padding-right: 44px;
  font-weight: 700;
  font-size: 1.25rem;
  line-height: 1.5;
}
@media screen and (min-width: 992px) {
  .bl_linkImgCard_ttl {
    font-size: 1.875rem;
    line-height: 1.3333333333;
  }
}
.bl_linkImgCard_ttl::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border: 1px solid var(--oct-pale);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.1) url("/common/images/icons/icon-arrow-white.svg") no-repeat center;
  background-size: 24px 24px;
  box-shadow: 2px 2px 8px rgba(26, 43, 67, 0.3);
}
@media screen and (min-width: 992px) {
  .bl_linkImgCard_ttl::after {
    width: 40px;
    height: 40px;
  }
}

.bl_acc {
  display: block;
  border-radius: 10px;
  overflow: hidden;
}
.bl_acc.is_open .bl_acc_header::after {
  transform: translateY(-50%) rotate(-90deg);
}
.bl_acc_header {
  position: relative;
  display: block;
  width: 100%;
  text-align: left;
  background-color: var(--oct-blue);
  color: var(--oct-white);
  border: 1px solid var(--oct-blue);
  padding: 20px 40px 20px 20px;
  border-radius: 10px 10px 0 0;
  font-weight: 500;
  font-size: 1rem;
  line-height: 1.625;
}
.bl_acc_header::before, .bl_acc_header::after {
  content: "";
  display: block;
  position: absolute;
  background-color: var(--oct-white);
}
.bl_acc_header::before {
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  width: 16px;
  height: 2px;
}
.bl_acc_header::after {
  top: 50%;
  right: 27px;
  transform: translateY(-50%);
  width: 2px;
  height: 16px;
  transition: transform 0.3s ease;
}
.bl_acc_body {
  padding: 20px;
  background-color: var(--oct-white);
  border-bottom: 1px solid var(--oct-blue);
  border-right: 1px solid var(--oct-blue);
  border-left: 1px solid var(--oct-blue);
  border-radius: 0 0 10px 10px;
  font-size: 1rem;
  line-height: 1.625;
}

.bl_borderList > li {
  border-bottom: 1px solid var(--oct-line);
}
.bl_borderList > li:first-child {
  border-top: 1px solid var(--oct-line);
}

.bl_borderItem {
  padding-block: 20px;
}
.bl_borderItem_label {
  color: #4d5d71;
}
@media screen and (min-width: 992px) {
  .bl_borderItem_label {
    min-width: 310px;
  }
}
.bl_borderItem_tel {
  position: relative;
  font-size: 1rem;
  line-height: 1.625;
}
@media screen and (min-width: 992px) {
  .bl_borderItem_tel {
    flex: 1;
  }
}
.bl_borderItem_tel.freeCall {
  padding-left: 28px;
}
.bl_borderItem_tel.freeCall::before {
  content: "";
  display: block;
  position: absolute;
  top: calc(50% + 2px);
  left: 0;
  transform: translateY(-50%);
  width: 20px;
  height: 15px;
  background: url("/common/images/icons/icon_freecall01.png") no-repeat center;
  background-size: 100% 100%;
}
.bl_borderItem__2col {
  display: flex;
  flex-direction: column;
  gap: 12px 0;
}
@media screen and (min-width: 992px) {
  .bl_borderItem__2col {
    flex-direction: row;
    align-items: center;
    gap: 0 28px;
  }
}

.el_btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 100%;
  min-height: 58px;
  padding: 12px 66px 16px 30px;
  border-radius: 58px;
  border: 2px solid var(--oct-black);
  background-color: var(--oct-white);
  font-weight: 700;
  text-decoration: none;
  transition: color 0.2s ease, background-color 0.2s ease;
  font-size: 1rem;
  line-height: 1.625;
}
@media screen and (min-width: 992px) {
  .el_btn {
    width: auto;
    min-width: 240px;
  }
}
.el_btn::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--oct-black) url("/common/images/icons/icon-arrow-white.svg") no-repeat center;
  background-size: 24px 24px;
}
@media (hover: hover) {
  .el_btn:hover {
    background-color: var(--oct-black);
    color: var(--oct-white);
  }
}
.el_btn_wrap {
  margin-top: 30px;
}
@media screen and (min-width: 992px) {
  .el_btn_wrap {
    margin-top: 40px;
  }
}
.el_btn_wrap__left {
  text-align: left;
}
.el_btn_wrap__center {
  text-align: center;
}
.el_btn_wrap__right {
  text-align: right;
}

.el_btn02 {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 420px;
  min-height: 58px;
  padding: 12px 40px 12px 30px;
  border-radius: 10px;
  border: 2px solid var(--oct-blue);
  background-color: var(--oct-white);
  font-weight: 700;
  text-decoration: none;
  transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
  font-size: 1rem;
  line-height: 1.625;
}
@media screen and (min-width: 992px) {
  .el_btn02 {
    min-height: 68px;
  }
}
.el_btn02::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-blue.svg") no-repeat center;
  background-size: 100% 100%;
  transition: background-image 0.2s ease;
}
@media (hover: hover) {
  .el_btn02:hover {
    background-color: var(--oct-blue);
    color: var(--oct-white);
  }
  .el_btn02:hover::after {
    background-image: url("/common/images/icons/icon-arrow-white.svg");
  }
}
.el_btn02[target=_blank]::after {
  background-image: url("/common/images/icons/icon-blank.svg");
}
@media (hover: hover) {
  .el_btn02[target=_blank]:hover::after {
    background-image: url("/common/images/icons/icon-blank-white.svg");
  }
}
.el_btn02_wrap {
  margin-top: 30px;
}
@media screen and (min-width: 992px) {
  .el_btn02_wrap {
    margin-top: 40px;
  }
}
.el_btn02_wrap__left {
  text-align: left;
}
.el_btn02_wrap__center {
  text-align: center;
}
.el_btn02_wrap__right {
  text-align: right;
}
.el_btn02__blue {
  background-color: var(--oct-blue);
  color: var(--oct-white);
  transition: opacity 0.2s ease;
}
.el_btn02__blue::after {
  background-image: url("/common/images/icons/icon-arrow-white.svg");
}
.el_btn02__blue[target=_blank]::after {
  background-image: url("/common/images/icons/icon-blank-white.svg");
}
@media (hover: hover) {
  .el_btn02__blue:hover {
    opacity: 0.7;
  }
}
.el_btn02__close {
  background-color: var(--oct-muted);
  border-color: var(--oct-muted);
  color: var(--oct-white);
}
.el_btn02__close::after {
  background-image: url("/common/images/icons/icon-close-white.svg");
}
@media (hover: hover) {
  .el_btn02__close:hover {
    background-color: var(--oct-black);
    border-color: var(--oct-black);
  }
  .el_btn02__close:hover::after {
    background-image: url("/common/images/icons/icon-close-white.svg");
  }
}

.el_rssBtn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 6px;
  font-family: var(--font-family-poppins);
  color: var(--color-accent);
  min-height: 56px;
  border-radius: 10px;
  border: 1px solid currentColor;
  background-color: var(--color-background);
  box-shadow: 0px 2px 0px var(--color-accent);
  padding: 19px 13px;
  transition: color 0.3s ease-out, border-color 0.3s ease-out, background-color 0.3s ease-out;
  font-size: 1.25rem;
  line-height: 1;
}
.el_rssBtn::before {
  display: block;
  content: "";
  width: 18px;
  min-width: 18px;
  height: 18px;
  background: url("/common/images/icons/icon-rss.svg") center no-repeat;
  background-size: 100% 100%;
  transition: background-image 0.3s ease-out;
}
@media (hover: hover) {
  .el_rssBtn:hover {
    background-color: var(--color-background-button-hover);
  }
}

.el_socialWrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 25px;
}
@media screen and (min-width: 768px) {
  .el_socialWrap {
    justify-content: flex-end;
  }
}
.el_socialWrap_heading {
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.05em;
}

.el_social {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 10px;
}
@media screen and (min-width: 768px) {
  .el_social {
    justify-content: flex-start;
  }
}
.el_social > li img {
  display: block;
  width: 30px;
  transition: opacity 0.3s ease-out;
}
.el_social > li a {
  display: block;
}
.el_social > li a:hover {
  text-decoration: underline;
}
@media (hover: hover) {
  .el_social > li a:hover img {
    will-change: opacity;
    opacity: 0.7;
  }
}
.el_social__right {
  justify-content: flex-end !important;
}

.el_imgWrap {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.el_imgWrap img {
  display: block;
}
.el_imgWrap__left {
  align-items: flex-start;
  text-align: left;
}
.el_imgWrap__center {
  align-items: center;
  text-align: center;
}
.el_imgWrap__right {
  align-items: flex-end;
  text-align: right;
}
.el_imgWrap__full img {
  width: 100%;
  text-align: left;
}
.el_imgWrap .caption {
  font-size: 14px;
}

.el_embed iframe {
  display: block;
  max-width: 100%;
  height: auto;
}
.el_embed__full iframe {
  width: 100%;
}
.el_embed__aspectRatio16-9 iframe {
  aspect-ratio: 16/9;
}
.el_embed__aspectRatio4-3 iframe {
  aspect-ratio: 4/3;
}
.el_embed__aspectRatio1-1 iframe {
  aspect-ratio: 1/1;
}
.el_embed__aspectRatio21-9 iframe {
  aspect-ratio: 21/9;
}

.el_fieldset {
  border: none;
  padding: 0;
  margin: 0;
}
.el_fieldset:not(:last-of-type) {
  margin-bottom: 20px;
}
.el_fieldset_heading {
  display: block;
  font-weight: 700;
  width: 100%;
  margin-bottom: 5px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}

.el_options {
  display: flex;
  flex-direction: column;
  gap: 5px 0;
}
@media screen and (min-width: 768px) {
  .el_options {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 5px 25px;
  }
}
@media screen and (min-width: 768px) {
  .el_options__column {
    flex-direction: column;
  }
}
.el_options[aria-describedby=ethna-error-title] .el_radioTxt_label::before {
  border-color: var(--oct-red);
  border-width: 2px;
}

.el_radioTxt {
  position: relative;
  display: flex;
  align-items: center;
  cursor: pointer;
}
.el_radioTxt_input {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  opacity: 0;
  overflow: hidden;
}
.el_radioTxt_input:focus-visible + label::before {
  outline: 3px solid var(--focus-outline-color);
  outline-offset: 3px;
}
.el_radioTxt_input:checked + label::before {
  border-color: var(--oct-blue);
  border-width: 2px;
}
.el_radioTxt_input:checked + label::after {
  content: "";
}
.el_radioTxt_input__error + label::before {
  border: 2px solid var(--oct-red);
}
.el_radioTxt_label {
  position: relative;
  display: flex;
  align-items: center;
  padding-left: 26px;
  cursor: pointer;
}
.el_radioTxt_label::before, .el_radioTxt_label::after {
  position: absolute;
  border-radius: 50%;
}
.el_radioTxt_label::before {
  content: "";
  top: 7px;
  left: 0;
  width: 18px;
  height: 18px;
  border: 1px solid var(--oct-line);
  background-color: var(--oct-white);
}
.el_radioTxt_label::after {
  content: none;
  top: 12px;
  left: 4px;
  width: 9px;
  height: 9px;
  background-color: var(--oct-blue);
}

.el_note {
  margin: 10px 0 0;
  font-size: 0.875rem;
  line-height: 1.5714285714;
  letter-spacing: 0.05em;
}
.bl_fileLinks + .el_note {
  margin-top: 15px;
}

.el_iconHeading {
  display: flex;
  align-items: center;
  gap: 0 10px;
  width: -moz-max-content;
  width: max-content;
  max-width: 100%;
  font-weight: 500;
  margin: 0 auto 30px;
  color: var(--color-text-dg);
  font-size: 1.75rem;
  line-height: 1;
  letter-spacing: 0.05em;
}
.el_iconHeading .icon {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.el_orderList {
  counter-reset: counter;
}
.el_orderList > li {
  position: relative;
  padding-left: 32px;
  font-size: 1.125rem;
  line-height: 1.6666666667;
  letter-spacing: 0.05em;
}
.el_orderList > li::before {
  position: absolute;
  top: 4px;
  left: 0;
  display: grid;
  place-content: center;
  content: counter(counter);
  counter-increment: counter;
  width: 22px;
  height: 22px;
  font-family: var(--font-family-poppins);
  font-size: 16px;
  font-weight: 900;
  color: var(--color-on-accent);
  line-height: 1;
  border-radius: 50%;
  background-color: var(--color-accent);
  padding: 2px 0 0 1px;
}

.el_noteDescription {
  display: flex;
  flex-direction: column;
  gap: 8px 0;
  margin-top: 20px;
}
@media screen and (min-width: 768px) {
  .el_noteDescription {
    flex-direction: row;
    gap: 0 40px;
    margin-top: 15px;
  }
}
.el_noteDescription dt {
  font-weight: 700;
  color: #007ccf;
  font-size: 0.875rem;
  line-height: 1.7142857143;
}
.el_noteDescription dd {
  font-size: 0.875rem;
  line-height: 1.7142857143;
}
@media screen and (min-width: 768px) {
  .el_noteDescription dd {
    flex: 1;
  }
}

.el_txt {
  font-size: 1rem;
  line-height: 1.625;
}
.el_txt__small {
  font-size: 0.875rem;
  line-height: 1.7142857143;
}

.el_img02 {
  padding: 6px;
  border: 2px solid var(--color-accent);
  border-radius: 10px;
}
@media screen and (min-width: 768px) {
  .el_img02 {
    padding: 10px;
  }
}
.el_img02 img {
  display: block;
  width: 100%;
}
.el_img02__w520 {
  max-width: 520px;
  margin-inline: auto;
}

.el_input {
  width: 100%;
  height: 48px;
  padding: 10px;
  border-radius: 10px;
  background-color: var(--oct-white);
  border: 1px solid var(--oct-line);
}
@media screen and (min-width: 992px) {
  .el_input {
    padding: 20px;
  }
}
.el_input__error {
  border: 2px solid var(--oct-red);
}

.el_textarea {
  width: 100%;
  height: 200px;
  padding: 10px;
  border-radius: 10px;
  background-color: var(--oct-white);
  border: 1px solid var(--oct-line);
}
@media screen and (min-width: 992px) {
  .el_textarea {
    padding: 16px;
  }
}
.el_textarea__error {
  border: 2px solid var(--oct-red);
}
.el_textarea__sm {
  height: 100px;
}

.el_checkbox {
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
  overflow: hidden;
  border: 0;
  padding: 0;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  margin: -1px;
}
.el_checkbox:checked + label::after {
  opacity: 1;
  visibility: visible;
}
.el_checkbox:focus-visible + label::before {
  outline: 3px solid var(--focus-outline-color);
  outline-offset: 3px;
}
.el_checkbox_label {
  position: relative;
  display: inline-block;
  padding-left: 30px;
  cursor: pointer;
}
.el_checkbox_label::before {
  content: "";
  display: block;
  position: absolute;
  top: 4px;
  left: 0;
  width: 20px;
  aspect-ratio: 1;
  border-radius: 2px;
  background-color: var(--oct-white);
  border: 1px solid var(--oct-line);
}
.el_checkbox_label::after {
  content: "";
  display: block;
  position: absolute;
  top: 9px;
  left: 5px;
  transform: rotate(-45deg);
  width: 10px;
  height: 6px;
  border-left: 2px solid var(--oct-blue);
  border-bottom: 2px solid var(--oct-blue);
  opacity: 0;
  visibility: hidden;
}
.el_checkbox_wrap {
  display: flex;
  align-items: flex-start;
  gap: 0 10px;
}
.el_checkbox_wrap label {
  flex: 1;
}
.el_checkbox__error + label::before {
  border: 2px solid var(--oct-red);
}

.el_select {
  width: 100%;
  height: 48px;
  padding: 10px;
  border-radius: 10px;
  background-color: var(--color-background);
  border: 1px solid var(--color-accent);
  cursor: pointer;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
.el_select_wrap {
  position: relative;
  width: 100%;
}
.el_select_wrap::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 16px;
  width: 8px;
  height: 8px;
  transform: translateY(-50%) rotate(45deg);
  border-bottom: 2px solid var(--color-text-dg);
  border-right: 2px solid var(--color-text-dg);
  pointer-events: none;
}
.el_select__error {
  border: 2px solid var(--red);
}

.el_fileUpload {
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
  overflow: hidden;
  border: 0;
  padding: 0;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  margin: -1px;
}
.el_fileUpload_label {
  position: relative;
  display: inline-block;
  width: auto;
  cursor: pointer;
  padding: 10px 20px;
  background-color: var(--color-background-primary);
  border-radius: 5px;
  border: 1px solid var(--color-accent);
  color: var(--color-accent);
  transition: color 0.3s ease-out, background-color 0.3s ease-out;
}
@media (hover: hover) {
  .el_fileUpload_label:hover {
    background-color: var(--color-background);
  }
}
.el_fileUpload__error + label {
  border: 2px solid var(--red);
}

.el_octTag {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 10px;
  border-radius: 6px;
  background: var(--oct-blue);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}

.js_accordionItem.is_open .js_accordionItem_content {
  visibility: visible;
}
.js_accordionItem_content {
  max-height: 0;
  overflow: hidden;
  visibility: hidden;
  transition: max-height 0.3s ease-out, visibility 0.3s ease-out;
}

.js_fadeUp {
  opacity: 0;
  transform: translate3d(0, 100px, 0);
  transition: opacity 1s ease-out, transform 1s ease-out;
}
.js_fadeUp.is_fadeUp {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.zoomimg {
  cursor: pointer;
}

.js_modal_img_cont img {
  display: block;
  width: 100%;
}

.js_hidden.is_hidden {
  display: none;
}

.js_target_input {
  display: none;
}
.js_target_input.is_active {
  display: block;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes headerDrop {
  from {
    transform: translate(-50%, -12px);
  }
  to {
    transform: translate(-50%, 0);
  }
}
@keyframes heroCarouselProgress {
  from {
    transform: scaleX(0);
  }
  to {
    transform: scaleX(1);
  }
}
@keyframes fv2ImageDrift {
  0% {
    transform: scale(1.12);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes fv2CircleWipe {
  0% {
    transform: translate(-50%, -50%) scale(0.015);
    opacity: 1;
  }
  50% {
    transform: translate(-50%, -50%) scale(1.08);
    opacity: 1;
  }
  100% {
    transform: translate(-50%, -50%) scale(0.015);
    opacity: 0;
  }
}
.un_notification {
  width: calc(100% - 20px);
  max-width: 1180px;
  border-radius: 10px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .un_notification {
    top: 143px;
    width: calc(100% - 40px);
    background-color: var(--color-background-notice);
    padding: 15px 20px;
  }
}
.un_notification_content {
  display: flex;
  flex-direction: column;
  border-radius: 10px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .un_notification_content {
    flex-direction: row;
  }
}
.un_notification_heading {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: var(--color-on-notice);
  background-color: #aa0808;
  padding: 4px 15px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_notification_heading {
    padding: 12px 15px;
  }
}
.un_notification_heading .inner {
  position: relative;
  padding-left: 29px;
}
.un_notification_heading .inner::before {
  position: absolute;
  top: calc(50% - 12px);
  left: 0;
  display: block;
  content: "";
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-notice02.svg") center no-repeat;
  background-size: 100% 100%;
}
.un_notification_body {
  font-weight: 700;
  background-color: var(--color-background);
  padding: 12px 15px;
  display: flex;
  flex-direction: column;
  gap: 10px 0;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_notification_body {
    flex: 1;
  }
}
@media screen and (min-width: 992px) {
  .un_notification_body {
    flex-direction: row;
    gap: 0 15px;
  }
}
@media screen and (min-width: 992px) {
  .un_notification_linkList {
    flex: 1;
  }
}
@media screen and (min-width: 992px) {
  .un_notification_linkList > li {
    flex: 1;
  }
}
.un_notification_linkList > li:not(:first-child) {
  margin-top: 10px;
}
.un_notification_item {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 992px) {
  .un_notification_item {
    flex-direction: row;
    gap: 0 15px;
  }
}
.un_notification_item .date {
  font-weight: 500;
  font-family: var(--font-family-poppins);
  flex-shrink: 0;
}
.un_notification_item .ttl {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  min-width: 0;
}
@media screen and (min-width: 992px) {
  .un_notification_item .ttl {
    flex: 1;
  }
}
@media (hover: hover) {
  .un_notification_item:hover .ttl {
    text-decoration: underline;
  }
}
.un_notification_linkWrap {
  padding: 10px 0 0 0;
  border-top: 1px dashed var(--color-border);
  text-align: center;
}
@media screen and (min-width: 992px) {
  .un_notification_linkWrap {
    padding: 0 0 0 15px;
    border-top: none;
    border-left: 1px dashed var(--color-border);
    display: grid;
    place-items: center;
  }
}
.un_notification_link {
  position: relative;
  display: inline-block;
  padding-right: 29px;
  color: #aa0808;
  font-weight: 400;
}
.un_notification_link::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background: url(/common/img/icons/icon-circle-arrow-red.svg) no-repeat center;
  background-size: 16px 16px;
}
@media (hover: hover) {
  .un_notification_link:hover {
    text-decoration: underline;
  }
}

.un_details_mv {
  width: 100%;
  margin-bottom: 40px;
}
@media screen and (min-width: 992px) {
  .un_details_mv {
    margin-bottom: 60px;
  }
}
.un_details_mv img {
  display: block;
  width: 100%;
}
.un_details_head {
  margin-bottom: 20px;
}
.un_details_date {
  text-align: right;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.02em;
}
.un_details_foot {
  margin-top: 30px;
}

.un_homeMv {
  padding-block: 10px 82px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .un_homeMv {
    padding-block: 25px 48px;
  }
}
.un_homeMv_wrap {
  background-color: var(--color-background-primary);
}

.un_homeTopics {
  padding-top: 21px;
  margin-top: 55px;
}
@media screen and (min-width: 768px) {
  .un_homeTopics {
    padding-top: 25px;
    margin-top: 18px;
  }
}
.un_homeTopics_content {
  position: relative;
  border-radius: 20px;
  background-color: var(--color-background);
  padding: 40px 15px 30px;
}
@media screen and (min-width: 768px) {
  .un_homeTopics_content {
    padding: 25px 100px 24px 100px;
  }
}
.un_homeTopics_heading {
  position: absolute;
  top: -21px;
  left: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 158px;
  height: 40px;
  font-weight: 800;
  color: var(--color-on-accent);
  border-radius: 20px;
  background-color: var(--color-accent);
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_homeTopics_heading {
    top: -25px;
    width: 175px;
  }
}
.un_homeTopics_heading::before {
  position: absolute;
  top: calc(100% - 1px);
  left: 23px;
  display: block;
  content: "";
  width: 24px;
  height: 13px;
  background: url("/common/images/balloon-tip.svg") center no-repeat;
  background-size: 100% 100%;
}

.un_homeArea01 {
  padding-block: 34px 84px;
}
@media screen and (min-width: 768px) {
  .un_homeArea01 {
    padding-block: 34px 104px;
  }
}

.un_homeArea02 {
  padding-block: 70px;
}
@media screen and (min-width: 768px) {
  .un_homeArea02 {
    padding-block: 80px 88px;
  }
}

.un_homeNav {
  position: relative;
  z-index: 1;
  padding-block: 56px 51px;
  background-color: var(--color-primary);
}
@media screen and (min-width: 768px) {
  .un_homeNav {
    padding-block: 39px 31px;
  }
}
.un_homeNav::before, .un_homeNav::after {
  position: absolute;
  left: 0;
  z-index: -1;
  display: block;
  content: "";
  width: 100%;
  height: 9px;
  background: none;
  background-size: auto 53px;
}
.un_homeNav::before {
  top: -9px;
}
.un_homeNav::after {
  bottom: -9px;
  background-position: bottom;
}
.un_homeNav_bgWrap {
  position: absolute;
  top: -80px;
  right: 0;
  z-index: -1;
  width: 241px;
}
@media screen and (min-width: 1280px) {
  .un_homeNav_bgWrap {
    width: 326px;
    top: -144px;
  }
}
.un_homeNav_bgWrap img {
  display: block;
  width: 100%;
}
.un_homeNav_panels {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
}
@media screen and (min-width: 992px) {
  .un_homeNav_panels {
    gap: 16px;
  }
}
.un_homeNav_panels > li {
  width: calc((100% - 15px) / 2);
}
@media screen and (min-width: 992px) {
  .un_homeNav_panels > li {
    width: calc((100% - 64px) / 5);
  }
}
.un_homeNav_panel {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: 20px;
  background-color: var(--color-background);
}
@media (hover: hover) {
  .un_homeNav_panel:hover {
    -webkit-text-decoration: var(--color-accent) underline;
            text-decoration: var(--color-accent) underline;
  }
}
.un_homeNav_panel .imgWrap img {
  display: block;
  width: 100%;
  aspect-ratio: 165/97;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 992px) {
  .un_homeNav_panel .imgWrap img {
    aspect-ratio: 200/97;
  }
}
.un_homeNav_panel .body {
  position: relative;
  padding: 0 20px 12px;
}
.un_homeNav_panel .body::before {
  display: block;
  content: "";
  margin-top: -1px;
  border-top: 2px dashed var(--color-accent);
}
.un_homeNav_panel .ttl {
  font-weight: 800;
  color: var(--color-accent);
  text-align: center;
  padding-top: 8px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
.un_homeNav_panel__sonchou .body::before {
  content: none;
}
.un_homeNav_items {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  margin-top: 40px;
}
@media screen and (min-width: 992px) {
  .un_homeNav_items {
    gap: 16px;
    margin-top: 30px;
  }
}
.un_homeNav_items > li {
  width: calc((100% - 15px) / 2);
}
@media screen and (min-width: 992px) {
  .un_homeNav_items > li {
    width: calc((100% - 48px) / 4);
  }
}
.un_homeNav_item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px 0;
  width: 100%;
  color: #fff;
  overflow: hidden;
  border-radius: 10px;
  background-color: #004098;
  padding: 12px 12px 14px;
}
@media screen and (min-width: 992px) {
  .un_homeNav_item {
    flex-direction: row;
    gap: 0 10px;
    padding: 15px 12px;
  }
}
@media (hover: hover) {
  .un_homeNav_item:hover {
    text-decoration: underline;
  }
}
.un_homeNav_item .icon {
  width: 30px;
  min-width: 30px;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.un_homeNav_item .icon img {
  display: block;
  width: 100%;
}
.un_homeNav_item .txt {
  font-weight: 800;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}

.un_homeOfficeInfo {
  padding-block: 35px 40px;
  overflow: hidden;
}
@media screen and (min-width: 992px) {
  .un_homeOfficeInfo {
    padding-block: 35px 50px;
  }
}
.un_homeOfficeInfo_content {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 40px 0;
}
@media screen and (min-width: 1280px) {
  .un_homeOfficeInfo_content {
    flex-direction: row;
    gap: 0 30px;
  }
}
@media screen and (min-width: 1280px) {
  .un_homeOfficeInfo_left {
    width: 680px;
  }
}
@media screen and (min-width: 1280px) {
  .un_homeOfficeInfo_right {
    width: 354px;
  }
}
@media screen and (min-width: 1280px) {
  .un_homeOfficeInfo_right .bl_tabContent_panels {
    min-height: 453px;
  }
}
.un_homeOfficeInfo_illustration, .un_homeOfficeInfo_illustration02 {
  position: absolute;
  z-index: 1;
}
.un_homeOfficeInfo_illustration a, .un_homeOfficeInfo_illustration02 a {
  display: block;
  transition: opacity 0.3s ease-out;
}
@media (hover: hover) {
  .un_homeOfficeInfo_illustration a:hover, .un_homeOfficeInfo_illustration02 a:hover {
    opacity: 0.7;
  }
}
.un_homeOfficeInfo_illustration img, .un_homeOfficeInfo_illustration02 img {
  display: block;
  width: 100%;
}
.un_homeOfficeInfo_illustration {
  bottom: -37px;
  left: -47px;
  width: 104px;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
@media screen and (min-width: 1280px) {
  .un_homeOfficeInfo_illustration {
    bottom: -25px;
    left: -57px;
  }
}
.un_homeOfficeInfo_illustration02 {
  right: -39px;
  bottom: -40px;
  width: 118px;
}
@media screen and (min-width: 1280px) {
  .un_homeOfficeInfo_illustration02 {
    width: 122px;
    right: -69px;
    bottom: -24px;
  }
}
.un_homeOfficeInfo_news {
  overflow-y: auto;
  max-height: 562px;
  padding: 6px 18px 6px 6px;
  margin-right: -10px;
}
@media screen and (min-width: 1280px) {
  .un_homeOfficeInfo_news {
    max-height: 285px;
    margin-right: 0;
  }
}
.un_homeOfficeInfo_news + .el_btn_wrap {
  margin-top: 30px;
}
@media screen and (min-width: 1280px) {
  .un_homeOfficeInfo_news + .el_btn_wrap {
    margin-top: 40px;
  }
}

.un_homeOfficeInfo02 {
  padding-inline: 15px;
  margin-bottom: 30px;
}
@media screen and (min-width: 992px) {
  .un_homeOfficeInfo02 {
    padding-inline: 0;
    margin-bottom: 40px;
  }
}
.un_homeOfficeInfo02_content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px 0;
}
@media screen and (min-width: 1280px) {
  .un_homeOfficeInfo02_content {
    flex-direction: row;
    align-items: stretch;
    gap: 0 23px;
  }
}
.un_homeOfficeInfo02_calendar {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px 0;
  border-radius: 20px;
  background-color: var(--color-background);
  padding: 25px 50px;
  width: 100%;
}
@media screen and (min-width: 1280px) {
  .un_homeOfficeInfo02_calendar {
    flex-direction: row;
    justify-content: space-between;
    gap: 0 25px;
    width: 687px;
    border-radius: 30px;
  }
}
.un_homeOfficeInfo02_calendarHeading {
  width: 223px;
}
.un_homeOfficeInfo02_calendarBody .el_btn {
  width: 275px;
}
@media screen and (min-width: 1280px) {
  .un_homeOfficeInfo02_calendarBody .el_btn {
    width: 294px;
  }
}
.un_homeOfficeInfo02_line {
  max-width: 354px;
  width: 100%;
}
.un_homeOfficeInfo02_banner a {
  transition: opacity 0.3s ease-out;
}
@media (hover: hover) {
  .un_homeOfficeInfo02_banner a:hover {
    opacity: 0.7;
  }
}

.un_homePublic {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: calc(100% - 30px);
  border-radius: 30px;
  background: #fff;
  padding: 35px 44px 30px;
  margin-inline: auto;
}
@media screen and (min-width: 992px) {
  .un_homePublic {
    width: 100%;
    min-height: 509px;
    padding: 30px 20px 30px;
  }
}
.un_homePublic_heading {
  width: 100%;
  max-width: 266px;
  margin: 0 auto 19px;
}
.un_homePublic_heading img {
  display: block;
  width: 100%;
}
.un_homePublic_content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px 0;
}
@media screen and (min-width: 992px) {
  .un_homePublic_content {
    gap: 12px 0;
  }
}
.un_homePublic_imgWrap {
  display: block;
  width: 142px;
  border-radius: 6px;
  border: 6px solid #fff;
}
@media screen and (min-width: 992px) {
  .un_homePublic_imgWrap {
    width: 184px;
  }
}
.un_homePublic_imgWrap img {
  display: block;
  width: 100%;
}
.un_homePublic_links {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 20px;
}
.un_homePublic_links > li > a {
  position: relative;
  display: inline-block;
  font-weight: 800;
  color: var(--color-accent);
  padding-right: 27px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
.un_homePublic_links > li > a::after {
  position: absolute;
  top: calc(50% - 8px);
  right: 0;
  display: block;
  content: "";
  width: 17px;
  height: 17px;
  background: url("/common/images/icons/icon-arrow02.svg") center no-repeat;
  background-size: 100% 100%;
}
@media (hover: hover) {
  .un_homePublic_links > li > a:hover {
    text-decoration: underline;
  }
}
.un_homePublic_btnWrap {
  margin-top: 21px;
}

.un_homeMainNav {
  padding-block: 30px 0;
}
@media screen and (min-width: 992px) {
  .un_homeMainNav {
    padding-block: 40px 0;
  }
}
.un_homeMainNav_content {
  display: flex;
  flex-direction: column;
  gap: 50px 0;
  padding-block: 35px;
}
@media screen and (min-width: 992px) {
  .un_homeMainNav_content {
    flex-direction: row;
    gap: 0 59px;
    padding-block: 80px 43px;
  }
}
@media screen and (min-width: 992px) {
  .un_homeMainNav_scene {
    width: 525px;
  }
}
@media screen and (min-width: 992px) {
  .un_homeMainNav_search {
    width: 480px;
  }
}

.un_homeMainNavPurpose_list {
  display: flex;
  flex-direction: column;
  gap: 10px 14px;
}
@media screen and (min-width: 768px) {
  .un_homeMainNavPurpose_list {
    flex-direction: row;
    flex-wrap: wrap;
  }
}
@media screen and (min-width: 768px) {
  .un_homeMainNavPurpose_list > li {
    width: calc((100% - 14px) / 2);
  }
}
@media screen and (min-width: 1280px) {
  .un_homeMainNavPurpose_list > li {
    width: calc((100% - 42px) / 4);
  }
}
.un_homeMainNavPurpose_list > li > a {
  display: flex;
  align-items: center;
  gap: 0 8px;
  width: 100%;
  height: 100%;
  font-weight: 500;
  border-radius: 15px;
  background-color: var(--color-background);
  padding: 16px 16px 16px 30px;
  border: 1px solid var(--color-background);
  transition: border-color 0.3s ease-out;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
@media (hover: hover) {
  .un_homeMainNavPurpose_list > li > a:hover {
    border-color: var(--color-accent);
    text-decoration: underline;
  }
}
.un_homeMainNavPurpose_list > li > a .icon {
  width: 24px;
  min-width: 24px;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.un_homeMainNavPurpose_list > li > a .icon img {
  display: block;
  width: 100%;
}

.un_homeMainNavScene_list {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
}
.un_homeMainNavScene_list > li {
  width: calc((100% - 15px) / 2);
  min-height: 140px;
}
@media screen and (min-width: 768px) {
  .un_homeMainNavScene_list > li {
    width: calc((100% - 45px) / 4);
  }
}
@media screen and (min-width: 992px) {
  .un_homeMainNavScene_list > li {
    width: calc((100% - 15px) / 2);
  }
}
@media screen and (min-width: 1280px) {
  .un_homeMainNavScene_list > li {
    width: calc((100% - 45px) / 4);
  }
}
.un_homeMainNavScene_list > li > a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 11px 0;
  width: 100%;
  height: 100%;
  border-radius: 15px;
  border: 2px solid var(--color-background);
  background-color: var(--color-background);
  padding: 18px 9px 23px;
  transition: border-color 0.3s ease-out, background-color 0.3s ease-out;
}
.un_homeMainNavScene_list > li > a .icon {
  width: 60px;
  min-width: 60px;
  min-height: 60px;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.un_homeMainNavScene_list > li > a .icon img {
  display: block;
  width: 100%;
}
.un_homeMainNavScene_list > li > a .ttl {
  text-align: center;
  font-size: 1rem;
  line-height: 1.75;
  letter-spacing: 0.05em;
}
@media (hover: hover) {
  .un_homeMainNavScene_list > li > a:hover {
    text-decoration: underline;
    border-color: var(--color-accent);
  }
}

.un_homeMainNavSearch {
  border-radius: 20px;
  background-color: #b0ecb2;
  padding: 30px 15px;
  margin-inline: -15px;
}
@media screen and (min-width: 768px) {
  .un_homeMainNavSearch {
    min-width: 480px;
    padding: 30px;
    margin-inline: 0;
  }
}
.un_homeMainNavSearch_section02 {
  margin-top: 15px;
}
@media screen and (min-width: 768px) {
  .un_homeMainNavSearch_section02 {
    margin-top: 17px;
  }
}
.un_homeMainNavSearch_heading {
  font-weight: 500;
  margin-bottom: 8px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
.un_homeMainNavSearch_heading02 {
  margin-bottom: 5px;
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.05em;
}
.un_homeMainNavSearch_keywords {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.un_homeMainNavSearch_keywords > li > a {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-accent);
  border-radius: 4px;
  background-color: var(--color-background);
  padding-inline: 6px;
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.05em;
}
.un_homeMainNavSearch_links {
  display: flex;
  gap: 0 25px;
  margin-top: 20px;
}
@media screen and (min-width: 768px) {
  .un_homeMainNavSearch_links {
    gap: 0 16px;
    margin-top: 42px;
  }
}
.un_homeMainNavSearch_links > li {
  width: calc((100% - 25px) / 2);
}
@media screen and (min-width: 768px) {
  .un_homeMainNavSearch_links > li {
    width: calc((100% - 16px) / 2);
  }
}
.un_homeMainNavSearch_links > li > a {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px 0;
  width: 100%;
  min-height: 72px;
  height: 100%;
  text-align: center;
  border-radius: 20px;
  border: 1px solid var(--color-background);
  background-color: var(--color-background);
  padding: 13px 13px 11px;
  transition: border-color 0.3s ease-out;
  font-size: 1rem;
  line-height: 1.1875;
  letter-spacing: 0em;
}
@media screen and (min-width: 768px) {
  .un_homeMainNavSearch_links > li > a {
    padding: 23px 13px 21px;
  }
}
.un_homeMainNavSearch_links > li > a .icon {
  width: 52px;
  min-width: 52px;
  height: 52px;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.un_homeMainNavSearch_links > li > a .icon img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.un_homeMainNavSearch_links > li > a .ttl {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 1.1875em;
}
@media (hover: hover) {
  .un_homeMainNavSearch_links > li > a:hover {
    text-decoration: underline;
    border-color: var(--color-primary);
  }
}

.el_linkList {
  display: flex;
  flex-direction: column;
  gap: 10px 0;
}
.el_linkList > li > a {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: var(--color-accent);
  background-color: var(--color-background);
  border-radius: 10px;
  border: 1px solid var(--color-accent);
  padding: 11px;
  text-align: center;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}

.un_homeMainNavEmergency {
  padding-block: 35px 0;
}
@media screen and (min-width: 768px) {
  .un_homeMainNavEmergency {
    padding-block: 44px 0;
  }
}
.un_homeMainNavEmergency_heading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 8px;
  margin-bottom: 30px;
}
@media screen and (min-width: 768px) {
  .un_homeMainNavEmergency_heading {
    gap: 0 35px;
  }
}
.un_homeMainNavEmergency_heading .ttl {
  font-family: var(--font-family-zenmaru);
  font-weight: 700;
  text-align: center;
  font-size: 1.5rem;
  line-height: 1.4166666667;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) {
  .un_homeMainNavEmergency_heading .ttl {
    font-size: 1.875rem;
    line-height: 1.3333333333;
  }
}
.un_homeMainNavEmergency_heading::before, .un_homeMainNavEmergency_heading::after {
  flex: 1;
  display: block;
  content: "";
  height: 4px;
  background-color: var(--color-background-secondary);
}
.un_homeMainNavEmergency_heading::before {
  border-radius: 4px 0 0 4px;
}
.un_homeMainNavEmergency_heading::after {
  border-radius: 0 4px 4px 0;
}
.un_homeMainNavEmergency_nav {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
@media screen and (min-width: 1280px) {
  .un_homeMainNavEmergency_nav {
    display: flex;
    gap: 0 15px;
    flex-direction: row;
  }
}
.un_homeMainNavEmergency_navContent {
  display: flex;
  flex-direction: column;
  gap: 14px 0;
}
.un_homeMainNavEmergency_primary {
  flex: 1;
}
.un_homeMainNavEmergency_links {
  display: flex;
  gap: 14px 11px;
}
.un_homeMainNavEmergency_links > li.link01 {
  width: 100%;
  margin-bottom: 10px;
}
@media screen and (min-width: 992px) {
  .un_homeMainNavEmergency_links > li.link01 {
    margin-bottom: 14px;
  }
}
.un_homeMainNavEmergency_links > li.link01 > a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  font-weight: 500;
  color: #004098;
  background-color: #ffd900;
  border-radius: 40px;
  border: 1px solid #004098;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_homeMainNavEmergency_links > li.link01 > a::after {
  position: absolute;
  top: calc(50% - 11px);
  right: 19px;
  display: block;
  content: "";
  width: 22px;
  height: 22px;
  background: url("/common/images/icons/icon-circle-arrow-dark-green.svg") center no-repeat;
  background-size: 100% 100%;
  border-radius: 50%;
}
@media (hover: hover) {
  .un_homeMainNavEmergency_links > li.link01 > a:hover {
    text-decoration: underline;
  }
}
.un_homeMainNavEmergency_links > li.link01 > a .illustration {
  position: absolute;
  bottom: -3px;
  left: -23px;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
@media screen and (min-width: 992px) {
  .un_homeMainNavEmergency_links > li.link01 > a .illustration {
    left: 30px;
  }
}
.un_homeMainNavEmergency_links > li.link01 > a .inline {
  display: flex;
  align-items: baseline;
}
.un_homeMainNavEmergency_links > li.link01 > a .large {
  margin-inline: 2px;
  font-size: 1.5rem;
  line-height: 1.4166666667;
  letter-spacing: 0.05em;
}
.un_homeMainNavEmergency_links > li.link02 > a, .un_homeMainNavEmergency_links > li.link03 > a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  font-weight: 700;
  color: var(--color-accent);
  background-color: var(--color-background);
  border-radius: 10px;
  border: 1px solid var(--color-accent);
  padding: 8px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_homeMainNavEmergency_links > li.link02 {
  width: 130px;
}
@media (hover: hover) {
  .un_homeMainNavEmergency_links > li.link02 > a:hover {
    text-decoration: underline;
  }
}
.un_homeMainNavEmergency_links > li.link03 {
  width: 338px;
}
.un_homeMainNavEmergency_links02 {
  display: flex;
  gap: 0 11px;
}
.un_homeMainNavEmergency_links02 > li > a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  font-weight: 700;
  color: var(--color-accent);
  text-align: center;
  background-color: var(--color-background);
  border-radius: 10px;
  border: 1px solid var(--color-accent);
  padding: 16px 8px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_homeMainNavEmergency_links02 > li.link02 {
  width: 27.1398747%;
}
.un_homeMainNavEmergency_links02 > li.link03 {
  width: 70.5636743%;
}
.un_homeMainNavEmergency_list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 13px;
}
@media screen and (min-width: 992px) {
  .un_homeMainNavEmergency_list {
    gap: 12px 15px;
    min-width: 570px;
  }
}
.un_homeMainNavEmergency_list > li {
  width: calc((100% - 13px) / 2);
  min-height: 60px;
}
@media screen and (min-width: 992px) {
  .un_homeMainNavEmergency_list > li {
    width: calc((100% - 30px) / 3);
  }
}
.un_homeMainNavEmergency_list > li > a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 13px 0;
  width: 100%;
  height: 100%;
  border-radius: 10px;
  border: 1px solid var(--color-primary);
  padding: 26px 8px 21px;
}
.un_homeMainNavEmergency_list > li > a .icon {
  width: 45px;
  min-width: 45px;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.un_homeMainNavEmergency_list > li > a .icon img {
  display: block;
  width: 100%;
}
.un_homeMainNavEmergency_list > li > a .ttl {
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
@media (hover: hover) {
  .un_homeMainNavEmergency_list > li > a:hover {
    text-decoration: underline;
  }
}
.un_homeMainNavEmergency_list > li > a.link01 {
  background-color: #fff;
  border-color: #00a0e9;
}
.un_homeMainNavEmergency_list > li > a.link02 {
  color: #fff;
  border-color: #004098;
  background-color: #004098;
}
.un_homeMainNavEmergency_list > li > a.link03 {
  color: #fff;
  border-color: #ca4922;
  background-color: #ca4922;
}

.un_homeAbout {
  position: relative;
  color: var(--dark-green);
  background-color: var(--color-primary);
  padding-block: 140px 70px;
}
.un_homeAbout::before, .un_homeAbout::after {
  position: absolute;
  left: 0;
  display: block;
  content: "";
  width: 100%;
  background-position: top;
  background-repeat: repeat-x;
}
.un_homeAbout::before {
  top: 0;
  height: 65px;
  background-image: url("/common/images/bg-ishigaki.png");
  background-size: auto 65px;
}
.un_homeAbout::after {
  top: 63px;
  height: 9px;
  background-image: none;
  background-size: auto 53px;
}
.un_homeAbout_centered {
  position: relative;
}
.un_homeAbout_illustration {
  position: absolute;
  top: -167px;
  right: 6px;
  width: 147px;
  z-index: 1;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
@media screen and (min-width: 768px) {
  .un_homeAbout_illustration {
    right: -35px;
  }
}
.un_homeAbout_links {
  display: flex;
  flex-wrap: wrap;
  gap: 13px 14px;
}
@media screen and (min-width: 992px) {
  .un_homeAbout_links {
    gap: 15px;
  }
}
.un_homeAbout_links > li {
  width: calc((100% - 14px) / 2);
}
@media screen and (min-width: 992px) {
  .un_homeAbout_links > li {
    width: calc((100% - 45px) / 4);
  }
}
.un_homeAbout_link {
  display: block;
  color: var(--color-text);
  border-radius: 20px;
  background: var(--color-background);
  overflow: hidden;
}
@media screen and (min-width: 992px) {
  .un_homeAbout_link {
    border-radius: 30px;
  }
}
@media (hover: hover) {
  .un_homeAbout_link:hover {
    text-decoration: underline;
  }
}
.un_homeAbout_link .imgWrap img {
  display: block;
  width: 100%;
  aspect-ratio: 166/110;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 992px) {
  .un_homeAbout_link .imgWrap img {
    aspect-ratio: 255/110;
  }
}
.un_homeAbout_link .ttl {
  font-weight: 500;
  text-align: center;
  padding: 10px 10px 14px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_homeAbout_bottom {
  margin-top: 40px;
}
.un_homeAbout_heading {
  color: var(--dark-green);
}
.un_homeAbout_heading02 {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-weight: 500;
  margin-bottom: 12px;
  font-size: 1.25rem;
  line-height: 1.5;
}
@media screen and (min-width: 992px) {
  .un_homeAbout_heading02 {
    flex-direction: row;
    font-size: 1.5rem;
    line-height: 1.4166666667;
  }
}
.un_homeAbout_heading02 .note {
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_homeAbout_box {
  display: flex;
  flex-direction: column;
  width: -moz-max-content;
  width: max-content;
  max-width: 100%;
  border-radius: 26px;
  background-color: rgba(1, 40, 18, 0.3);
  padding: 30px;
  color: var(--color-on-accent);
  margin-inline: auto;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 992px) {
  .un_homeAbout_box {
    width: 100%;
    max-width: none;
    border-radius: 6px;
    padding: 20px 20px 15px;
  }
}
.un_homeAbout_boxList {
  display: flex;
  flex-direction: column;
  gap: 15px 0;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 992px) {
  .un_homeAbout_boxList {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: baseline;
    gap: 15px 40px;
    font-size: 1.125rem;
    line-height: 1.875;
  }
}
.un_homeAbout_boxList > li > dl {
  display: flex;
  align-items: baseline;
}
@media screen and (min-width: 992px) {
  .un_homeAbout_boxList > li > dl {
    flex-direction: column;
  }
}
@media screen and (min-width: 1280px) {
  .un_homeAbout_boxList > li > dl {
    flex-direction: row;
  }
}
.un_homeAbout_boxList > li > dl > dt {
  width: 55px;
  margin-right: 15px;
}
@media screen and (min-width: 992px) {
  .un_homeAbout_boxList > li > dl > dt {
    width: auto;
  }
}
.un_homeAbout_boxList > li > dl > dd {
  display: flex;
  flex: 1;
  justify-content: flex-end;
}
.un_homeAbout_boxList > li > dl > dd .num {
  font-family: var(--font-family-poppins);
  font-weight: 700;
  font-size: 2.125rem;
  line-height: 0.8823529412;
}
.un_homeAbout_boxList > li > dl > dd .unit {
  margin-left: 6px;
}
@media screen and (min-width: 992px) {
  .un_homeAbout_boxList > li > dl > dd .unit {
    margin-left: 8px;
  }
}

.un_homeOtherSites {
  padding-block: 0 30px;
}
@media screen and (min-width: 768px) {
  .un_homeOtherSites {
    padding-block: 0 40px;
  }
}

.un_homeRelatedSites {
  padding-block: 30px 30px;
}
@media screen and (min-width: 768px) {
  .un_homeRelatedSites {
    padding-block: 40px 40px;
  }
}

.un_homeBanner {
  padding-block: 30px 0;
}
@media screen and (min-width: 768px) {
  .un_homeBanner {
    padding-block: 40px 0;
  }
}

.un_furusato .ly_mainContent {
  position: relative;
  padding-block: 90px 100px;
  background-color: #feffef;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .un_furusato .ly_mainContent {
    padding-block: 70px 100px;
  }
}
.un_furusato .ly_mainContent::before {
  content: "";
  display: block;
  position: absolute;
  top: 39px;
  left: calc(50% - 246px);
  width: 172px;
  height: 138px;
  background: url("/common/images/furusato/bg-deco-left.svg") no-repeat center;
  background-size: 100% 100%;
}
@media screen and (min-width: 768px) {
  .un_furusato .ly_mainContent::before {
    width: 344px;
    height: 276px;
    top: 78px;
    left: calc(50% - 690px);
  }
}
.un_furusato .ly_mainContent::after {
  content: "";
  display: block;
  position: absolute;
  top: 19px;
  right: calc(50% - 235px);
  width: 174px;
  height: 124px;
  background: url("/common/images/furusato/bg-deco-right.svg") no-repeat center;
  background-size: 100% 100%;
}
@media screen and (min-width: 768px) {
  .un_furusato .ly_mainContent::after {
    width: 348px;
    height: 248px;
    top: 51px;
    right: calc(50% - 680px);
  }
}

.un_furusatoTax_intro {
  padding-bottom: 80px;
}
.un_furusatoTax_intro .un_furusatoTax_txt {
  margin: 28px auto 0;
  max-width: 800px;
}
@media screen and (min-width: 768px) {
  .un_furusatoTax_intro .un_furusatoTax_txt {
    margin-top: 20px;
    max-width: 800px;
  }
}
.un_furusatoTax_lv1Heading {
  max-width: 144px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .un_furusatoTax_lv1Heading {
    max-width: 180px;
  }
}
.un_furusatoTax_lv1Heading img {
  display: block;
  width: 100%;
}
.un_furusatoTax_ttl {
  margin-top: 60px;
  text-align: center;
  font-family: "Zen Old Mincho", serif;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.4166666667;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) {
  .un_furusatoTax_ttl {
    font-size: 1.75rem;
    line-height: 1.3571428571;
  }
}
.un_furusatoTax_ttl .clrBrown {
  color: #745810;
}
.un_furusatoTax_txt {
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_furusatoTax_lv2Heading {
  position: relative;
  margin-bottom: 20px;
  padding-left: 50px;
  color: #745810;
  font-family: "Zen Old Mincho", serif;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.4166666667;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) {
  .un_furusatoTax_lv2Heading {
    font-size: 1.75rem;
    line-height: 1.3571428571;
  }
}
.un_furusatoTax_lv2Heading::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 40px;
  height: 40px;
  background: url("/common/images/furusato/heading-deco01.svg") no-repeat center;
  background-size: 40px 40px;
}

.un_furusatoTaxBox {
  position: relative;
  margin-top: 60px;
  padding-block: 30px;
  border: 1px solid #745810;
  background-color: var(--color-background);
}
@media screen and (min-width: 768px) {
  .un_furusatoTaxBox {
    padding-block: 40px;
  }
}
.un_furusatoTaxBox::before, .un_furusatoTaxBox::after {
  content: "";
  display: block;
  position: absolute;
  width: 20px;
  height: 20px;
  background: url("/common/images/furusato/deco01.svg") no-repeat center;
  background-size: 20px 20px;
}
.un_furusatoTaxBox::before {
  top: -1px;
  left: -1px;
}
.un_furusatoTaxBox::after {
  bottom: -1px;
  right: -1px;
}
.un_furusatoTaxBox_inner {
  width: calc(100% - 30px);
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .un_furusatoTaxBox_inner {
    width: calc(100% - 80px);
  }
}
.un_furusatoTaxBox_ttl {
  padding-bottom: 30px;
  border-bottom: 1px solid #745810;
  color: #745810;
  font-family: "Zen Old Mincho", serif;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.4166666667;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) {
  .un_furusatoTaxBox_ttl {
    padding-bottom: 20px;
    font-size: 1.75rem;
    line-height: 1.3571428571;
  }
}
.un_furusatoTaxBox_txt {
  margin-top: 20px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}

.un_furusatoTaxSection + .un_furusatoTaxSection {
  padding-top: 80px;
}

.un_ftCardUnit {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
  margin-top: 20px;
}
@media screen and (min-width: 768px) {
  .un_ftCardUnit {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 20px;
  }
}
@media screen and (min-width: 768px) {
  .un_ftCardUnit__3col .un_ftCard {
    width: calc((100% - 40px) / 3);
  }
}

.un_ftCard {
  padding-block: 40px 30px;
  background-color: var(--color-background);
  border: 1px solid #745810;
}
.un_ftCard_inner {
  width: calc(100% - 20px);
  margin-inline: auto;
}
.un_ftCard_imgWrap {
  max-width: 240px;
  margin-inline: auto;
}
.un_ftCard_imgWrap img {
  display: block;
  width: 100%;
}
.un_ftCard_ttl {
  margin-top: 16px;
  text-align: center;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_ftCard_ttl {
    min-height: 52px;
    display: grid;
    place-items: center;
  }
}

.un_ftSiteCardUnit {
  display: flex;
  flex-direction: column;
  gap: 10px 0;
  margin-top: 20px;
}
@media screen and (min-width: 768px) {
  .un_ftSiteCardUnit {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 20px;
  }
}
@media screen and (min-width: 768px) {
  .un_ftSiteCardUnit__3col .un_ftSiteCard {
    width: calc((100% - 40px) / 3);
  }
}

.un_ftSiteCard {
  padding-block: 30px 15px;
  background-color: var(--color-background);
  border: 1px solid #745810;
}
.un_ftSiteCard_inner {
  width: calc(100% - 40px);
  margin-inline: auto;
}
.un_ftSiteCard_imgWrap {
  max-width: 264px;
  margin-inline: auto;
}
.un_ftSiteCard_imgWrap img {
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: 264/66;
  -o-object-fit: contain;
     object-fit: contain;
}
.un_ftSiteCard_linkWrap {
  margin-top: 20px;
}
.un_ftSiteCard_link {
  display: block;
  padding: 7px;
  background-color: #f2edcf;
  text-align: center;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media (hover: hover) {
  .un_ftSiteCard_link:hover {
    text-decoration: underline;
  }
}

.un_furusatoTaxContact .ttl {
  margin-bottom: 11px;
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.2222222222;
  letter-spacing: 0.05em;
}
.un_furusatoTaxContact .info {
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_furusatoTaxContact .address {
  margin-bottom: 4px;
}
.un_furusatoTaxContact .mailWrap > a {
  color: var(--color-accent);
}
@media (hover: hover) {
  .un_furusatoTaxContact .mailWrap > a:hover {
    text-decoration: underline;
  }
}

.un_ftLinklist {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 15px;
}
@media screen and (min-width: 768px) {
  .un_ftLinklist {
    gap: 20px;
  }
}
.un_ftLinklist > li {
  width: calc((100% - 15px) / 2);
}
@media screen and (min-width: 768px) {
  .un_ftLinklist > li {
    width: calc((100% - 40px) / 3);
  }
}
.un_ftLinklist > li > a {
  display: block;
  padding: 6px 15px;
  border: 1px solid #745810;
  background-color: var(--color-background);
}
@media (hover: hover) {
  .un_ftLinklist > li > a:hover .ttl {
    text-decoration: underline;
  }
}
.un_ftLinklist > li > a .ttl {
  position: relative;
  display: inline-block;
  padding-right: 30px;
  color: #745810;
  font-weight: 500;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_ftLinklist > li > a .ttl::after {
  content: "";
  display: block;
  position: absolute;
  top: 1px;
  right: 0;
  width: 24px;
  height: 24px;
  background: url("/common/images/furusato/icon-pdf.svg") no-repeat center;
  background-size: 24px 24px;
}

.un_fTContentBox {
  border-color: #745810;
}
.un_fTContentBox .bl_contentBox_heading {
  border-color: #745810;
  background-color: #f2edcf;
}

.un_furusatoTaxBiz {
  position: relative;
  padding-block: 60px 100px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .un_furusatoTaxBiz {
    padding-block: 40px 100px;
  }
}
.un_furusatoTaxBiz_lv2Heading {
  position: relative;
  margin-bottom: 36px;
  text-align: center;
  color: var(--color-text-dg);
}
@media screen and (min-width: 768px) {
  .un_furusatoTaxBiz_lv2Heading {
    margin-bottom: 40px;
  }
}
.un_furusatoTaxBiz_lv2Heading > span {
  position: relative;
  display: inline-block;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--color-accent);
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1.4166666667;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_furusatoTaxBiz_lv2Heading > span {
    font-size: 1.75rem;
    line-height: 1.3571428571;
  }
}
.un_furusatoTaxBiz_lv2Heading > span::before, .un_furusatoTaxBiz_lv2Heading > span::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: var(--color-accent);
}
.un_furusatoTaxBiz_lv2Heading > span::before {
  bottom: -3px;
}
.un_furusatoTaxBiz_lv2Heading > span::after {
  bottom: -5px;
}
.un_furusatoTaxBiz_lv3Heading {
  display: flex;
  align-items: flex-start;
  gap: 0 14px;
  margin: 80px 0 15px 0;
  padding-bottom: 10px;
  color: var(--color-text-dg);
  border-bottom: 2px solid var(--color-text-dg);
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_furusatoTaxBiz_lv3Heading {
    margin: 40px 0 20px 0;
  }
}
.un_furusatoTaxBiz_lv3Heading .num {
  min-width: 26px;
  font-weight: 700;
}
.un_furusatoTaxBiz_lv3Heading .heading {
  font-weight: 500;
  flex: 1;
}
.un_furusatoTaxBiz_txt {
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_furusatoTaxBiz_figure {
  max-width: 840px;
  margin-inline: auto;
}
.un_furusatoTaxBiz_figure img {
  display: block;
  width: 100%;
}
.un_furusatoTaxBiz_btnWrap {
  margin-top: 30px;
  text-align: center;
}
.un_furusatoTaxBiz_btn {
  position: relative;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 479px;
  min-height: 60px;
  font-weight: 500;
  text-align: center;
  color: var(--color-text-dg);
  background-color: var(--yellow);
  border-radius: 80px;
  border: 1px solid var(--color-text-dg);
  padding: 9px 40px 7px 40px;
  transition: background-color 0.3s ease-out;
  font-size: 1.125rem;
  line-height: 1.2222222222;
  letter-spacing: 0.05em;
}
.un_furusatoTaxBiz_btn::after {
  position: absolute;
  top: calc(50% - 11px);
  right: 15px;
  display: block;
  content: "";
  width: 22px;
  height: 22px;
  background: url("/common/images/icons/icon-circle-arrow-dark-green.svg") center no-repeat;
  background-size: 100% 100%;
  border-radius: 50%;
}
@media (hover: hover) {
  .un_furusatoTaxBiz_btn:hover {
    text-decoration: underline;
  }
}
.un_furusatoTaxBiz_note {
  margin-top: 15px;
  color: var(--color-notice);
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.05em;
}
.un_furusatoTaxBiz_note + .un_furusatoTaxBiz_note {
  margin-top: 0;
}

.un_furusatoTaxBizAbout_note {
  margin-top: 10px;
  text-align: center;
  color: var(--color-text-dg);
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_furusatoTaxBizAbout .un_furusatoTaxBiz_figure {
  margin-top: 40px;
}
@media screen and (min-width: 768px) {
  .un_furusatoTaxBizAbout .un_furusatoTaxBiz_figure {
    margin-top: 50px;
  }
}

.un_furusatoTaxBizSection + .un_furusatoTaxBizSection {
  padding-top: 80px;
}
@media screen and (min-width: 768px) {
  .un_furusatoTaxBizSection + .un_furusatoTaxBizSection {
    padding-top: 100px;
  }
}

.un_ftbAttemptList {
  display: flex;
  flex-direction: column;
  gap: 30px 0;
}

.un_ftbAttemptItem {
  padding-block: 30px;
  background-color: var(--color-on-primary);
}
@media screen and (min-width: 768px) {
  .un_ftbAttemptItem {
    padding-block: 40px;
  }
}
.un_ftbAttemptItem_inner {
  width: calc(100% - 30px);
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .un_ftbAttemptItem_inner {
    width: calc(100% - 80px);
  }
}
.un_ftbAttemptItem_ttl {
  display: flex;
  align-items: flex-start;
  gap: 0 15px;
}
.un_ftbAttemptItem_ttl .num {
  min-width: 46px;
  min-height: 37px;
  padding: 2px 2px 1px;
  display: grid;
  place-items: center;
  border-radius: 6px;
  background-color: var(--color-accent);
  color: var(--color-on-primary);
  font-family: var(--font-family-poppins);
  font-size: 1.5rem;
  line-height: 1.4166666667;
  letter-spacing: 0.1em;
}
.un_ftbAttemptItem_ttl .ttl {
  color: var(--color-accent);
  font-weight: 500;
  font-size: 1.25rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_ftbAttemptItem_ttl .ttl {
    font-size: 1.5rem;
    line-height: 1.4166666667;
  }
}
.un_ftbAttemptItem_content {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 25px 0;
}
.un_ftbAttemptItem_txt {
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_ftbAttemptItem_txt + .un_ftbAttemptItem_txt {
  margin-top: 20px;
}
.un_ftbAttemptItem_imgWrap {
  display: flex;
  flex-direction: column;
  gap: 30px 0;
  padding: 20px;
  background-color: #cfecd4;
  border-radius: 10px;
}
@media screen and (min-width: 768px) {
  .un_ftbAttemptItem_imgWrap {
    flex-direction: row;
    gap: 0 18px;
    padding: 25px;
  }
}
@media screen and (min-width: 768px) {
  .un_ftbAttemptItem_imgWrap .un_ftbAttemptItemFigure {
    flex: 1;
  }
}

.un_ftbAttemptItemFigure_img {
  aspect-ratio: 275/223;
}
@media screen and (min-width: 768px) {
  .un_ftbAttemptItemFigure_img {
    aspect-ratio: 185/150;
  }
}
.un_ftbAttemptItemFigure_img img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.un_ftbAttemptItemFigure_caption {
  margin-top: 10px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}

.un_ftbLinkList {
  display: flex;
  flex-direction: column;
  gap: 8px 0;
}

.un_ftbLink {
  color: var(--color-accent);
}
@media (hover: hover) {
  .un_ftbLink:hover {
    text-decoration: underline;
  }
}
.un_ftbLink[href$=".pdf"]::after, .un_ftbLink[href$=".xlsx"]::after {
  content: "";
  display: inline-block;
  width: 24px;
  height: 24px;
  margin-left: 4px;
  transform: translateY(-2px);
  vertical-align: middle;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
.un_ftbLink[href$=".pdf"]::after {
  background-image: url("/common/images/furusato_biz/icon-pdf.svg");
}
.un_ftbLink[href$=".xlsx"]::after {
  background-image: url("/common/images/furusato_biz/icon-excel.svg");
}

.un_furusatoTaxBizFlow {
  padding-block: 20px 30px;
  background-color: var(--color-on-primary);
}
@media screen and (min-width: 768px) {
  .un_furusatoTaxBizFlow {
    padding-block: 40px 50px;
  }
}
.un_furusatoTaxBizFlow_inner {
  width: calc(100% - 30px);
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .un_furusatoTaxBizFlow_inner {
    width: calc(100% - 80px);
  }
}
.un_furusatoTaxBizFlow_imgWrap {
  width: 95.2380952%;
  max-width: 780px;
  margin-inline: auto;
}
.un_furusatoTaxBizFlow_imgWrap img {
  display: block;
  width: 100%;
}

.un_ftbFlowList {
  margin-top: 50px;
  display: flex;
  flex-direction: column;
  gap: 50px 0;
}
@media screen and (min-width: 768px) {
  .un_ftbFlowList {
    margin-top: 40px;
  }
}

.un_ftbFlowItem {
  background-color: var(--color-on-primary);
}
.un_ftbFlowItem_ttl {
  display: flex;
  align-items: flex-start;
  gap: 0 15px;
}
.un_ftbFlowItem_ttl .num {
  min-width: 46px;
  min-height: 37px;
  padding: 2px 2px 1px;
  display: grid;
  place-items: center;
  border-radius: 6px;
  background-color: var(--color-accent);
  color: var(--color-on-primary);
  font-family: var(--font-family-poppins);
  font-size: 1.5rem;
  line-height: 1.4166666667;
  letter-spacing: 0.1em;
}
.un_ftbFlowItem_ttl .ttl {
  color: var(--color-accent);
  font-weight: 500;
  font-size: 1.25rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_ftbFlowItem_ttl .ttl {
    font-size: 1.5rem;
    line-height: 1.4166666667;
  }
}
.un_ftbFlowItem_content {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 768px) {
  .un_ftbFlowItem_content {
    margin-top: 15px;
  }
}
.un_ftbFlowItem_txt {
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_ftbFlowItem_txt + .un_ftbAttemptItem_txt {
  margin-top: 20px;
}
.un_ftbFlowItem_attention {
  margin-top: 50px;
  margin: 50px 0 9px 0;
  color: var(--color-notice);
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_ftbFlowItem .un_ftbLinkList {
  margin-top: 14px;
}
.un_ftbFlowItem .un_ftbFlowBox {
  margin-top: 15px;
}
@media screen and (min-width: 768px) {
  .un_ftbFlowItem .un_ftbFlowBox {
    margin-top: 20px;
  }
}

.un_ftbFlowBox {
  padding-block: 20px;
  border-radius: 10px;
  background-color: #ebf0f6;
}
@media screen and (min-width: 768px) {
  .un_ftbFlowBox {
    padding-block: 30px;
  }
}
.un_ftbFlowBox_inner {
  width: calc(100% - 40px);
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .un_ftbFlowBox_inner {
    width: calc(100% - 60px);
  }
}
.un_ftbFlowBox_txt {
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_ftbFlowBox_txt + .un_ftbFlowBox_txt {
  margin-top: 20px;
}
@media screen and (min-width: 768px) {
  .un_ftbFlowBox_txt + .un_ftbFlowBox_txt {
    margin-top: 15px;
  }
}

.un_ftbFlowItemList > li {
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_ftbFlowItemList > li::before {
  content: "・";
}

.un_ftbMelitList {
  display: flex;
  flex-direction: column;
  gap: 10px 0;
}
@media screen and (min-width: 768px) {
  .un_ftbMelitList {
    max-width: 700px;
    margin-inline: auto;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
  }
}
@media screen and (min-width: 768px) {
  .un_ftbMelitList > li {
    width: calc((100% - 40px) / 3);
  }
}

.un_ftbMelitItem {
  padding-block: 14px;
  background-color: var(--color-on-primary);
  border-radius: 10px;
}
@media screen and (min-width: 768px) {
  .un_ftbMelitItem {
    height: 100%;
    padding-block: 25px 20px;
  }
}
.un_ftbMelitItem_inner {
  width: calc(100% - 60px);
  margin-inline: auto;
  display: flex;
  align-items: center;
  gap: 0 15px;
}
@media screen and (min-width: 768px) {
  .un_ftbMelitItem_inner {
    width: calc(100% - 30px);
    flex-direction: column;
    gap: 15px 0;
  }
}
.un_ftbMelitItem_imgWrap {
  max-width: 68px;
}
.un_ftbMelitItem_imgWrap img {
  display: block;
  width: 100%;
}
.un_ftbMelitItem_ttl {
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_ftbMelitItem_ttl {
    text-align: center;
  }
}
.un_ftbMelitItem_ttl .sm {
  font-weight: 400;
  font-size: 0.875rem;
  line-height: 1.7142857143;
}

.un_ftbTable {
  width: 100%;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_ftbTable thead th {
  padding: 6px 20px;
  text-align: center;
  background-color: var(--color-accent);
  color: var(--color-on-primary);
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.2222222222;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_ftbTable thead th {
    padding: 15px 20px;
  }
}
.un_ftbTable thead th:not(:last-child) {
  border-right: 4px solid var(--light-green);
}
@media screen and (min-width: 768px) {
  .un_ftbTable thead th:not(:last-child) {
    width: 29.887218%;
  }
}
.un_ftbTable tbody td {
  position: relative;
  padding: 20px 10px;
  background-color: var(--color-on-primary);
  border-top: 4px solid var(--light-green);
}
@media screen and (min-width: 768px) {
  .un_ftbTable tbody td {
    padding: 16px 22px 18px;
    border-top-width: 6px;
  }
}
.un_ftbTable tbody td:not(:last-child)::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 1px;
  height: 69.2307692%;
  border: 1px dashed #bfbfbf;
}
.un_ftbTable tbody td .price {
  text-align: center;
  font-weight: 700;
}
.un_ftbTable_list {
  display: flex;
  flex-direction: column;
  gap: 15px 0;
}
@media screen and (min-width: 768px) {
  .un_ftbTable_list {
    gap: 12px 0;
  }
}
.un_ftbTable_list > li {
  position: relative;
  padding-left: 16px;
}
.un_ftbTable_list > li::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #bfbfbf;
}

.un_ftbBox {
  margin-top: 20px;
  padding-block: 20px;
  background-color: var(--color-on-primary);
}
.un_ftbBox_inner {
  width: calc(100% - 30px);
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .un_ftbBox_inner {
    width: calc(100% - 60px);
  }
}
.un_ftbBox_ttl {
  margin-bottom: 10px;
  color: var(--color-accent);
  font-weight: 800;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
.un_ftbBox_txt {
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}

.un_assemblyTopics {
  padding-block: 60px 80px;
}
.un_assemblyTopics_content {
  display: flex;
  flex-direction: column;
  gap: 72px 0;
}
@media screen and (min-width: 1280px) {
  .un_assemblyTopics_content {
    flex-direction: row;
    gap: 0 30px;
  }
}
@media screen and (min-width: 1280px) {
  .un_assemblyTopics_left {
    width: 710px;
  }
}
@media screen and (min-width: 1280px) {
  .un_assemblyTopics_right {
    flex: 1;
  }
}

.un_assemblyNews_listWrap {
  border-radius: 30px;
  background-color: var(--color-background);
  padding: 40px 15px;
}
@media screen and (min-width: 768px) {
  .un_assemblyNews_listWrap {
    padding: 40px;
  }
}

.un_assemblyPublic {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: calc(100% - 20px);
  border-radius: 30px;
  background-color: var(--color-background);
  padding: 40px;
  margin-inline: auto;
}
@media screen and (min-width: 992px) {
  .un_assemblyPublic {
    width: 100%;
  }
}
.un_assemblyPublic_mediaImgWrap {
  width: 100%;
}
.un_assemblyPublic_mediaImgWrap img {
  display: block;
  width: 100%;
  border-radius: 8px;
}
.un_assemblyPublic_mediaBody {
  margin-top: 10px;
}
.un_assemblyPublic_links {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 20px;
}
.un_assemblyPublic_links > li > a {
  position: relative;
  display: inline-block;
  font-weight: 800;
  color: var(--color-accent);
  padding-right: 27px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
.un_assemblyPublic_links > li > a::after {
  position: absolute;
  top: calc(50% - 8px);
  right: 0;
  display: block;
  content: "";
  width: 17px;
  height: 17px;
  background: url("/common/images/icons/icon-arrow02.svg") center no-repeat;
  background-size: 100% 100%;
}
.un_assemblyPublic_btnWrap {
  margin-top: 21px;
}
.un_assemblyPublic_btnWrap .el_btn {
  min-width: 100%;
}

.un_library {
  color: var(--color-text-dg);
}
.un_library_info {
  padding-bottom: 80px;
}
.un_library_lv2Heading {
  display: flex;
  gap: 0 10px;
  margin-bottom: 15px;
  padding: 0 10px 10px 10px;
  border-bottom: 2px solid var(--color-accent);
}
.un_library_lv2Heading .icon {
  width: 20px;
  padding-top: 2px;
}
@media screen and (min-width: 768px) {
  .un_library_lv2Heading .icon {
    padding-top: 5px;
  }
}
.un_library_lv2Heading .icon img {
  display: block;
  width: 100%;
}
.un_library_lv2Heading .heading {
  flex: 1;
  font-weight: 500;
  font-size: 1.375rem;
  line-height: 1.2727272727;
  letter-spacing: 0.05em;
}
.un_library_lv3Heading {
  position: relative;
  margin-bottom: 8px;
  padding-left: 7px;
  font-weight: 400;
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.05em;
}
.un_library_lv3Heading::before {
  content: "";
  display: block;
  position: absolute;
  top: 4px;
  left: 0;
  width: 3px;
  height: 16px;
  border-radius: 3px;
  background-color: var(--color-accent);
}
.un_library_txt {
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_library_txt .el_link {
  color: var(--color-accent);
}

.un_libraryDl {
  display: flex;
  flex-direction: column;
  gap: 8px 0;
  margin-bottom: 10px;
  padding: 30px 15px;
  background-color: var(--color-background);
  border-radius: 30px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_libraryDl {
    flex-direction: row;
    gap: 0 30px;
    padding: 15px 40px;
  }
}
.un_libraryDl .ttlWrap {
  display: flex;
  align-items: center;
  gap: 0 5px;
}
.un_libraryDl .ttlWrap .icon {
  width: 24px;
}
.un_libraryDl .ttlWrap .icon img {
  display: block;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .un_libraryDl dd {
    flex: 1;
  }
}

.un_libLinkList {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 40px;
}
@media screen and (min-width: 768px) {
  .un_libLinkList {
    flex-direction: row;
    gap: 14px;
  }
}
@media screen and (min-width: 768px) {
  .un_libLinkList > li {
    width: calc((100% - 42px) / 4);
  }
}

.un_libLinkItem {
  display: block;
  height: 100%;
  border-radius: 15px;
  background-color: var(--color-background);
  padding: 16px;
  border: 1px solid var(--color-primary);
}
@media (hover: hover) {
  .un_libLinkItem:hover {
    text-decoration: underline;
  }
}
.un_libLinkItem_icon {
  max-width: 40px;
  margin-inline: auto;
}
.un_libLinkItem_icon img {
  display: block;
  width: 100%;
}
.un_libLinkItem_ttl {
  text-align: center;
  margin-top: 10px;
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}

.un_libLending_ttl {
  margin-bottom: 30px;
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1.2727272727;
  letter-spacing: 0.05em;
}

.un_libLendingList {
  display: flex;
  flex-direction: column;
  gap: 30px 0;
}
@media screen and (min-width: 768px) {
  .un_libLendingList {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 30px;
  }
}
@media screen and (min-width: 768px) {
  .un_libLendingList > li {
    width: calc((100% - 60px) / 3);
  }
}

.un_libLendingItem_imgWrap {
  max-width: 64px;
  margin-inline: auto;
}
.un_libLendingItem_imgWrap img {
  display: block;
  width: 100%;
}
.un_libLendingItem_category {
  max-width: 120px;
  min-height: 27px;
  margin-top: 10px;
  display: grid;
  place-items: center;
  padding: 4px;
  margin-inline: auto;
  border-radius: 10px;
  border: 1px solid transparent;
  background-color: var(--color-background);
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1;
  letter-spacing: 0.05em;
}
.un_libLendingItem_category.red {
  border-color: #dd2e44;
  background-color: #feedef;
}
.un_libLendingItem_category.yellow {
  border-color: #f3b400;
  background-color: #fff6db;
}
.un_libLendingItem_category.blue {
  border-color: #00a6ed;
  background-color: #ebf9ff;
}
.un_libLendingItem_quantity {
  text-align: center;
  margin-top: 21px;
  font-weight: 500;
  font-size: 1.375rem;
  line-height: 1.2727272727;
  letter-spacing: 0.05em;
}

.un_libService_ttl {
  display: flex;
  gap: 0 14px;
}
.un_libService_ttl .icon {
  width: 50px;
}
.un_libService_ttl .icon img {
  display: block;
  width: 100%;
}
.un_libService_ttl .ttl {
  flex: 1;
  font-weight: 500;
  font-size: 1.375rem;
  line-height: 1.2727272727;
  letter-spacing: 0.05em;
}
.un_libService_ttl .ttl .bold {
  font-weight: 900;
}
.un_libService_ttl .ttl .sm {
  font-size: 1rem;
  line-height: 1.625;
}
.un_libService_cont {
  margin-top: 20px;
}
.un_libService_txt {
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.05em;
}
.un_libService_txt + .un_libService_txt {
  margin-top: 10px;
}

.un_libUl > li {
  position: relative;
  padding-left: 25px;
}
.un_libUl > li::before {
  position: absolute;
  top: 8px;
  left: 5px;
  display: block;
  content: "";
  width: 12px;
  height: 12px;
  border-radius: 4px;
  background-color: var(--color-accent);
}
.un_libUl > li > a {
  position: relative;
  transition: color 0.3s ease-out;
}

.un_libNoteList {
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.05em;
}

.un_sitemap > *:first-child {
  margin-top: 0 !important;
}
.un_sitemap_lv1 {
  margin-bottom: 20px;
}
@media screen and (min-width: 992px) {
  .un_sitemap_lv1 {
    margin-top: 60px;
  }
}
.un_sitemap_lv1 > a {
  position: relative;
  display: block;
  background-color: var(--oct-blue);
  border-radius: 10px;
  color: var(--oct-white);
  padding: 15px 15px 15px 42px;
  font-weight: 700;
  transition: background 0.2s ease;
  font-size: 1.5rem;
  line-height: 1.4166666667;
}
@media screen and (min-width: 992px) {
  .un_sitemap_lv1 > a {
    padding: 15px 24px 15px 42px;
    font-size: 1.75rem;
  }
}
.un_sitemap_lv1 > a::before {
  content: "";
  display: block;
  position: absolute;
  top: 24px;
  left: 14px;
  width: 20px;
  height: 20px;
  transform: rotate(-90deg);
  background: var(--oct-white) url(/common/images/icons/icon-chevron-blue.svg) 50% no-repeat;
  background-size: 12px 12px;
  border-radius: 50%;
  transition: background 0.2s ease;
}
@media (hover: hover) {
  .un_sitemap_lv1 > a:hover {
    background-color: var(--oct-cellularCyan);
  }
}
.un_sitemap_lv2 {
  display: flex;
  flex-direction: column;
  gap: 10px 0;
}
@media screen and (min-width: 992px) {
  .un_sitemap_lv2 {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 20px;
  }
}
@media screen and (min-width: 992px) {
  .un_sitemap_lv2 > li {
    width: calc((100% - 20px) / 2);
  }
}
.un_sitemap_lv2 > li > a {
  position: relative;
  display: block;
  background-color: var(--oct-softBlue);
  border-radius: 10px 10px 0 0;
  padding: 10px 15px 10px 40px;
  margin-bottom: 20px;
  border-bottom: 2px solid var(--oct-blue);
  color: var(--oct-blue);
  font-weight: 700;
  transition: color 0.2s ease;
  font-size: 1.375rem;
  line-height: 1.4545454545;
}
@media screen and (min-width: 992px) {
  .un_sitemap_lv2 > li > a {
    padding: 10px 24px 10px 40px;
    font-size: 1.5rem;
  }
}
.un_sitemap_lv2 > li > a::before {
  content: "";
  display: block;
  position: absolute;
  top: 18px;
  left: 12px;
  width: 20px;
  height: 20px;
  transform: rotate(-90deg);
  background: var(--oct-white) url(/common/images/icons/icon-chevron-blue.svg) 50% no-repeat;
  background-size: 12px 12px;
  border-radius: 50%;
  transition: background 0.2s ease;
}
@media (hover: hover) {
  .un_sitemap_lv2 > li > a:hover {
    color: var(--oct-cellularCyan);
  }
}
.un_sitemap_lv3, .un_sitemap_lv4, .un_sitemap_lv5 {
  margin: 10px 0;
  padding-left: 1em;
}
.un_sitemap_lv3 > li > a, .un_sitemap_lv4 > li > a, .un_sitemap_lv5 > li > a {
  position: relative;
  display: inline-block;
  padding-left: 15px;
  color: var(--oct-black);
}
.un_sitemap_lv3 > li > a::before, .un_sitemap_lv4 > li > a::before, .un_sitemap_lv5 > li > a::before {
  content: "";
  display: block;
  position: absolute;
  top: 7px;
  left: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: var(--oct-blue);
}
@media (hover: hover) {
  .un_sitemap_lv3 > li > a:hover, .un_sitemap_lv4 > li > a:hover, .un_sitemap_lv5 > li > a:hover {
    text-decoration: underline;
  }
}
.un_sitemap_lv3 li + li {
  margin-top: 5px;
}

.un_newsletter_heading {
  margin-bottom: 20px;
  padding: 20px 23px 21px 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: var(--color-background);
  border: 4px solid var(--color-accent);
  border-radius: 20px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
@media screen and (min-width: 768px) {
  .un_newsletter_heading {
    padding: 15px 23px 16px 16px;
  }
}
.un_newsletter_heading .heading {
  color: var(--color-accent);
  font-weight: 700;
  font-size: 1.75rem;
  line-height: 1.3571428571;
  letter-spacing: 0.05em;
}
.un_newsletter_heading .heading img {
  display: block;
  width: 140px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .un_newsletter_heading .heading img {
    width: 192px;
  }
}
.un_newsletter_document {
  width: calc(100% - 40px);
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .un_newsletter_document {
    width: 100%;
  }
}
.un_newsletter_document .caption {
  margin-top: 15px;
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.05em;
}

.un_newsletterCont {
  margin-top: 50px;
  padding-block: 40px;
  background-color: var(--color-background-primary);
  border-radius: 20px;
}
@media screen and (min-width: 768px) {
  .un_newsletterCont {
    padding-block: 50px;
  }
}
.un_newsletterCont_inner {
  width: calc(100% - 50px);
  max-width: 880px;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: 40px 0;
}
@media screen and (min-width: 768px) {
  .un_newsletterCont_inner {
    width: 81.4814815%;
    flex-direction: row;
    gap: 0 10.7954545%;
  }
}
@media screen and (min-width: 768px) {
  .un_newsletterCont_left {
    flex: 1;
    min-width: 0;
  }
}
@media screen and (min-width: 768px) {
  .un_newsletterCont_right {
    width: 50.1136364%;
  }
}

.un_newsletterCont02 {
  margin-top: 50px;
}
.un_newsletterCont02_inner {
  display: flex;
  flex-direction: column;
  gap: 30px 0;
}
@media screen and (min-width: 768px) {
  .un_newsletterCont02_inner {
    flex-direction: row;
    gap: 0 4.62962963%;
  }
}
@media screen and (min-width: 768px) {
  .un_newsletterCont02_left {
    flex: 1;
  }
}
@media screen and (min-width: 768px) {
  .un_newsletterCont02_right {
    width: 63.4259259%;
  }
}

.un_newsletterBox .el_ul__files > li > a {
  display: block;
  padding: 20px 15px;
  background-color: var(--white);
  border: 2px solid #cdcdcd;
  border-radius: 20px;
  font-weight: 700;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_newsletterBox .el_ul__files > li > a {
    padding: 30px;
  }
}
.un_newsletterBox .el_ul__files > li > a:hover {
  text-decoration: underline;
}

.un_newsletterIndex {
  margin-top: 20px;
  border: 2px solid var(--color-accent);
  border-radius: 10px;
}
.un_newsletterIndex_ttl {
  padding: 8px 20px;
  border-radius: 7px 7px 0 0;
  color: var(--white);
  background-color: var(--color-accent);
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .un_newsletterIndex_ttl {
    padding: 8px 30px;
  }
}
.un_newsletterIndex_cont {
  padding: 20px 20px 30px;
}
@media screen and (min-width: 768px) {
  .un_newsletterIndex_cont {
    padding: 30px;
  }
}
.un_newsletterIndex .el_ul__files > li > a:hover {
  text-decoration: underline;
}

.un_newsletterSlider .splide__slide > a {
  display: block;
}
.un_newsletterSlider .splide__slide > a .ttl {
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 8px;
  font-weight: 700;
  font-size: 1.3125rem;
  line-height: 1.4761904762;
  letter-spacing: 0.1em;
}
.un_newsletterSlider .splide__slide > a .ttl .tag {
  display: inline-block;
  min-width: 70px;
  padding: 2px 6px 2px 11px;
  color: var(--white);
  background-color: var(--color-primary);
  border-radius: 10px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.1em;
}
.un_newsletterSlider .splide__slide > a .document {
  max-width: 344px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .un_newsletterSlider .splide__slide > a .document {
    max-width: 100%;
  }
}
.un_newsletterSlider .splide__slide > a .document img {
  display: block;
  width: 100%;
}
.un_newsletterSlider .splide__controller {
  width: 100%;
  height: 34px;
  margin-top: 20px;
}
.un_newsletterSlider .splide__controller__custom {
  position: relative;
  max-width: 190px;
  height: 100%;
  margin-inline: auto;
}
.un_newsletterSlider .splide__arrow {
  width: 34px;
  height: 34px;
  background: url(/common/img/icons/icon-circle-arrow-white.svg) no-repeat center;
  background-size: 34px 34px;
  opacity: 1;
  transition: background 0.3s ease-out;
}
.un_newsletterSlider .splide__arrow--prev {
  left: 0;
  transform: translateY(-50%) scale(-1, 1);
}
.un_newsletterSlider .splide__arrow--next {
  right: 0;
}
.un_newsletterSlider .splide__arrow:hover:not(:disabled) {
  opacity: 1;
  background-image: url(/common/img/icons/icon-circle-arrow.svg);
}
.un_newsletterSlider .sliderPager {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 4px;
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1;
  letter-spacing: 0.1em;
}

.un_bnrArea {
  width: calc(100% - 20px);
  margin-inline: auto;
  padding-block: 30px;
  border-radius: 20px;
  background-color: var(--color-background-secondary);
}
@media screen and (min-width: 768px) {
  .un_bnrArea {
    width: calc(100% - 40px);
    padding-block: 30px;
    border-radius: 20px;
  }
}
.un_bnrArea_centered {
  width: calc(100% - 40px);
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .un_bnrArea_centered {
    width: calc(100% - 80px);
  }
}
@media screen and (min-width: 768px) {
  .un_bnrArea.is_fixed {
    position: fixed;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1001;
    width: 100%;
    padding-block: 20px;
    border-radius: 0;
  }
}
.un_bnrArea .el_note {
  margin-top: 20px;
}

#top .un_bnrArea {
  margin-bottom: 100px;
}
@media screen and (min-width: 768px) {
  #top .un_bnrArea.is_fixed {
    margin-bottom: 0;
  }
}

.un_bnrAreaLinks {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) {
  .un_bnrAreaLinks {
    justify-content: space-between;
  }
}

.un_bnrAreaLink {
  position: relative;
  display: inline-block;
  padding: 0 28px 4px 0;
  border-bottom: 1px dashed var(--color-accent);
  color: #004098;
  font-family: var(--font-family-zenmaru);
  font-weight: 700;
  transition: opacity 0.3s ease-out;
  font-size: 1.125rem;
  line-height: 1.1111111111;
  letter-spacing: 0.1em;
}
.un_bnrAreaLink::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 20px;
  height: 20px;
  background: url("/common/img/icons/icon-circle-arrow.svg") no-repeat center;
  background-size: 20px 20px;
}
.un_bnrAreaLink:hover {
  opacity: 0.7;
}
.un_bnrAreaLink_wrap {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .un_bnrAreaLink_wrap {
    text-align: left;
  }
}

.un_bnrAreaHiddenLink {
  position: relative;
  display: inline-block;
  padding-left: 26px;
  font-family: var(--font-family-zenmaru);
  transition: opacity 0.3s ease-out;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.1em;
}
.un_bnrAreaHiddenLink::before {
  content: "";
  display: block;
  position: absolute;
  top: 4px;
  left: 8px;
  transform: rotate(45deg);
  width: 2px;
  height: 18px;
  background-color: var(--color-accent);
}
.un_bnrAreaHiddenLink::after {
  content: "";
  display: block;
  position: absolute;
  top: 12px;
  left: 0;
  transform: rotate(45deg);
  width: 18px;
  height: 2px;
  background-color: var(--color-accent);
}
.un_bnrAreaHiddenLink:hover {
  opacity: 0.7;
}
.un_bnrAreaHiddenLink_wrap {
  display: none;
}
@media screen and (min-width: 768px) {
  .un_bnrAreaHiddenLink_wrap {
    display: block;
    text-align: right;
  }
}

.un_contactFormArea .el_lv3Heading {
  margin-bottom: 30px;
}
.un_contactFormArea .el_ul > li::before {
  width: 6px;
  height: 6px;
  top: 0.7em;
}

.un_disaster {
  background-color: var(--color-background-secondary);
}
@media screen and (min-width: 992px) {
  .un_disaster_notification {
    flex: 1;
  }
}
.un_disaster_notification .un_notification {
  position: static;
  transform: translateX(0);
  width: 100%;
}
@media screen and (min-width: 768px) {
  .un_disaster_notification .un_notification {
    padding: 0;
  }
}

.un_disasterMain {
  padding-block: 20px 30px;
  background-color: var(--color-background-primary);
}
.un_disasterMain_bottom {
  display: flex;
  flex-direction: column;
  gap: 30px 0;
}
@media screen and (min-width: 992px) {
  .un_disasterMain_bottom {
    flex-direction: row;
    align-items: flex-start;
    gap: 0 30px;
  }
}

.un_disasterSecondary {
  position: relative;
  padding-block: 40px 100px;
  background-color: var(--color-background-secondary);
}
@media screen and (min-width: 992px) {
  .un_disasterSecondary {
    padding-block: 60px 100px;
  }
}
.un_disasterSecondary::after {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  content: "";
  width: 100%;
  height: 10px;
  background: none;
  background-size: auto 60px;
}

.un_disasterHeader {
  padding-block: 20px;
  background-color: #aa0808;
  color: var(--color-on-primary);
}
.un_disasterHeader_inner {
  width: calc(100% - 30px);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: 16px 0;
}
@media screen and (min-width: 992px) {
  .un_disasterHeader_inner {
    width: calc(100% - 80px);
    flex-direction: row;
    gap: 0 30px;
  }
}
.un_disasterHeader_head {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.un_disasterHeader_logo {
  display: flex;
  align-items: center;
  max-width: 154px;
  background-color: var(--color-background);
  padding: 10px;
  border-radius: 8px;
}
.un_disasterHeader_logo a {
  display: block;
}
.un_disasterHeader_logo img {
  display: block;
  width: 100%;
}
.un_disasterHeader_heading {
  margin-bottom: 10px;
  text-align: center;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.4166666667;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 992px) {
  .un_disasterHeader_heading {
    text-align: left;
  }
}
.un_disasterHeader_body {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
}
@media screen and (min-width: 992px) {
  .un_disasterHeader_body {
    flex: 1;
    flex-direction: row;
    align-items: center;
    gap: 0 30px;
  }
}
@media screen and (min-width: 992px) {
  .un_disasterHeader_content {
    flex: 1;
  }
}
.un_disasterHeader_txt {
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 992px) {
  .un_disasterHeader_txt {
    flex: 1;
  }
}
@media screen and (min-width: 992px) {
  .un_disasterHeader_btnWrap {
    min-width: 194px;
  }
}
.un_disasterHeader_btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0 6px;
  width: 100%;
  min-height: 58px;
  padding: 4px 12px;
  border-radius: 10px;
  background-color: var(--color-on-primary);
  color: var(--color-text);
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
.un_disasterHeader_btn::before {
  content: "";
  display: block;
  width: 28px;
  height: 28px;
  background-image: url("/common/images/icons/icon-pc.svg");
  background-size: 100% 100%;
}
@media (hover: hover) {
  .un_disasterHeader_btn:hover {
    text-decoration: underline;
  }
}

.un_disasterInfo {
  margin-bottom: 30px;
  padding-block: 25px 30px;
  border-radius: 10px;
  border: 3px solid #aa0808;
  background-color: var(--color-background);
}
@media screen and (min-width: 992px) {
  .un_disasterInfo {
    padding-block: 30px;
  }
}
.un_disasterInfo_inner {
  width: calc(100% - 30px);
  margin-inline: auto;
}
@media screen and (min-width: 992px) {
  .un_disasterInfo_inner {
    width: calc(100% - 60px);
  }
}
.un_disasterInfo_heading {
  margin-bottom: 15px;
  text-align: center;
  color: #aa0808;
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 992px) {
  .un_disasterInfo_heading {
    text-align: left;
  }
}
.un_disasterInfo_content {
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}

.un_disasterBnr {
  display: block;
  transition: opacity 0.3s ease-out;
}
@media (hover: hover) {
  .un_disasterBnr:hover {
    opacity: 0.7;
  }
}
.un_disasterBnr > img {
  display: block;
  width: 100%;
}
.un_disasterBnr_wrap {
  max-width: 320px;
  margin-inline: auto;
}
@media screen and (min-width: 992px) {
  .un_disasterBnr_wrap {
    width: 29.6296296296%;
    margin: 0;
  }
}

.un_disasterList {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
}
@media screen and (min-width: 992px) {
  .un_disasterList {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 0 15px;
  }
}
@media screen and (min-width: 992px) {
  .un_disasterList > li {
    width: calc((100% - 45px) / 4);
  }
}

.un_disasterItem {
  height: 100%;
  background-color: var(--color-background);
  display: flex;
  flex-direction: column;
}
.un_disasterItem_head {
  padding: 15px 20px;
  border-radius: 10px 10px 0 0;
  border: 3px solid var(--color-text);
}
.un_disasterItem_heading {
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
.un_disasterItem_body {
  height: 100%;
  padding: 20px;
  border: 3px solid var(--color-text);
  border-top: none;
  border-radius: 0 0 10px 10px;
}
.un_disasterItem_list {
  display: flex;
  flex-direction: column;
  gap: 10px 0;
}
.un_disasterItem_list > li > a {
  position: relative;
  display: block;
  padding-left: 16px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.05em;
}
.un_disasterItem_list > li > a::before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  width: 8px;
  height: 8px;
  background-color: #d9d9d9;
  border-radius: 2px;
}
@media (hover: hover) {
  .un_disasterItem_list > li > a:hover {
    text-decoration: underline;
  }
}
.un_disasterItem__blue .un_disasterItem_head,
.un_disasterItem__blue .un_disasterItem_body {
  border-color: var(--color-accent);
}
.un_disasterItem__blue .un_disasterItem_heading {
  color: var(--color-accent);
}
.un_disasterItem__green .un_disasterItem_head,
.un_disasterItem__green .un_disasterItem_body {
  border-color: #00a0e9;
}
.un_disasterItem__green .un_disasterItem_heading {
  color: #004098;
}
.un_disasterItem__yellow .un_disasterItem_head,
.un_disasterItem__yellow .un_disasterItem_body {
  border-color: #e1a777;
}
.un_disasterItem__yellow .un_disasterItem_heading {
  color: #4a2200;
}
.un_disasterItem__red .un_disasterItem_head,
.un_disasterItem__red .un_disasterItem_body {
  border-color: #ba3c3c;
}
.un_disasterItem__red .un_disasterItem_heading {
  color: #5a0000;
}

.un_division_head {
  position: relative;
  margin-bottom: 30px;
}
.un_division_head::before {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  right: 0;
  width: calc(100% - 4px);
  height: 4px;
  border-radius: 4px;
  background-color: var(--color-accent);
}
.un_division_heading {
  position: relative;
  padding-bottom: 26px;
  font-weight: 700;
  font-size: 1.75rem;
  line-height: 1.3571428571;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 992px) {
  .un_division_heading {
    font-size: 2.375rem;
    line-height: 1.2631578947;
  }
}
.un_division_heading::before, .un_division_heading::after {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  left: 0;
  width: 50px;
  height: 4px;
}
@media screen and (min-width: 992px) {
  .un_division_heading::before, .un_division_heading::after {
    width: 80px;
  }
}
.un_division_heading::before {
  bottom: 4px;
  border-radius: 4px 4px 0 0;
  background-color: var(--color-primary);
}
.un_division_heading::after {
  bottom: 0;
  border-radius: 0 0 4px 4px;
  background-color: var(--color-accent);
}
.un_division_body {
  display: flex;
  flex-direction: column;
  gap: 80px 0;
}
.un_division_lv2Heading {
  margin-bottom: 30px;
  padding: 10px 15px;
  border-radius: 4px;
  background-color: var(--color-background-primary);
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1.4545454545;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 992px) {
  .un_division_lv2Heading {
    padding: 4px 20px 5px 20px;
    font-size: 1.5rem;
    line-height: 1.4166666667;
  }
}
.un_division_contact {
  margin-top: 80px;
}
.un_division .bl_newsList {
  gap: 20px 0;
}

.un_homeHero {
  position: relative;
  width: 100%;
  height: calc(var(--vh) - var(--alert-head-height, 0px));
  min-height: calc(var(--vh) - var(--alert-height, 0px));
  border-radius: 0 0 36px 0;
  overflow: hidden;
}
.un_homeHero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  border-radius: 0 0 36px 0;
  background: linear-gradient(180deg, rgba(26, 43, 67, 0) 52%, rgba(26, 43, 67, 0.5) 100%), rgba(26, 43, 67, 0.36);
}
.un_homeHero_wrap {
  background-color: #7fcff3;
}
.un_homeHero_cont {
  position: relative;
  z-index: 1;
  width: calc(100% - 40px);
  height: 100%;
  margin-inline: auto;
  padding-block: 20px 100px;
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 992px) {
  .un_homeHero_cont {
    width: calc(100% - 120px);
    padding-block: 32px 80px;
  }
}
.un_homeHero_head {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.un_homeHero_body {
  margin-top: auto;
  display: flex;
  justify-content: center;
}
@media screen and (min-width: 992px) {
  .un_homeHero_body {
    align-items: flex-end;
    justify-content: space-between;
  }
}
.un_homeHero_logo {
  display: block;
  width: 136px;
}
@media screen and (min-width: 992px) {
  .un_homeHero_logo {
    width: 160px;
  }
}
.un_homeHero_logo img {
  display: block;
  width: 100%;
}
.un_homeHero_brandPageLink {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4px 0;
  padding: 12px 14px;
  border-radius: var(--oct-radiusMd);
  background-image: linear-gradient(70deg, #ffebe0, #ffffff 50%, #dbe7f5);
  box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
}
@media screen and (min-width: 992px) {
  .un_homeHero_brandPageLink {
    flex-direction: row;
    align-items: center;
    gap: 0 12px;
    min-height: 60px;
    padding: 12px;
  }
}
.un_homeHero_brandPageLink::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  background-color: var(--oct-white);
  border-radius: var(--oct-radiusMd);
  opacity: 0;
  transition: opacity 0.2s ease;
}
@media (hover: hover) {
  .un_homeHero_brandPageLink:hover::before {
    opacity: 1;
  }
}
.un_homeHero_brandPageLink .icon {
  width: 24px;
}
.un_homeHero_brandPageLink .icon img {
  display: block;
  width: 100%;
}
.un_homeHero_brandPageLink .ttl {
  font-weight: 800;
  font-size: 12px;
  line-height: 1.4;
}
@media screen and (min-width: 992px) {
  .un_homeHero_brandPageLink .ttl {
    font-size: 15px;
  }
}
.un_homeHero_menu {
  display: none;
}
@media screen and (min-width: 992px) {
  .un_homeHero_menu {
    display: flex;
    flex-direction: column;
    gap: 12px 0;
    color: var(--oct-white);
    font-size: 16px;
    line-height: 1.65;
    font-weight: 800;
  }
}
.un_homeHero_menu > a {
  position: relative;
  display: inline-block;
}
.un_homeHero_menu > a[target=_blank]::after {
  display: inline-block;
  content: "";
  width: 20px;
  height: 20px;
  margin-left: 4px;
  vertical-align: -3px;
  background-image: url("/common/images/icons/icon-blank-white.svg");
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
@media (hover: hover) {
  .un_homeHero_menu > a:hover {
    text-decoration: underline;
  }
}
.un_homeHero_copy {
  width: 100%;
  max-width: 309px;
}
@media screen and (min-width: 992px) {
  .un_homeHero_copy {
    width: 53%;
    max-width: 700px;
  }
}
.un_homeHero_copy img {
  display: block;
  width: 100%;
}
.un_homeHero {
  /* FV ヒーロー独自スライドアニメーション */
}
.un_homeHero_images {
  position: absolute;
  inset: 0;
  overflow: hidden;
  z-index: 0;
  border-radius: 0 0 36px 0;
}
.un_homeHero_imageWrap {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.8s ease;
}
.un_homeHero_imageWrap.is_active {
  opacity: 1;
  z-index: 2;
}
.un_homeHero_imageWrap.is_leaving {
  z-index: 1;
}
.un_homeHero_imageWrap.is_active .un_homeHero_image, .un_homeHero_imageWrap.is_leaving .un_homeHero_image {
  animation: fv2ImageDrift 7100ms ease-out forwards;
}
.un_homeHero_imageWrap .un_homeHero_image {
  position: static;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 58% center;
     object-position: 58% center;
  inset: auto;
  transform: scale(1.5);
}
@media screen and (min-width: 992px) {
  .un_homeHero_imageWrap .un_homeHero_image {
    -o-object-position: center;
       object-position: center;
  }
}
.un_homeHero_image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 58% center;
     object-position: 58% center;
}
@media screen and (min-width: 992px) {
  .un_homeHero_image {
    -o-object-position: center center;
       object-position: center center;
  }
}
.un_homeHero_controlsWrap {
  position: absolute;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  width: calc(100% - 175px);
  max-width: 200px;
}
@media screen and (min-width: 992px) {
  .un_homeHero_controlsWrap {
    bottom: 10px;
    width: calc(100% - 120px);
    max-width: 100%;
  }
}
.un_homeHero_controls {
  position: relative;
  width: 100%;
  height: 48px;
  color: var(--oct-white);
}
@media screen and (min-width: 992px) {
  .un_homeHero_controls {
    height: 56px;
    margin-left: auto;
    display: flex;
    align-items: center;
  }
}
.un_homeHero_pager {
  width: 100%;
  height: 100%;
  color: var(--oct-white);
  text-shadow: 0 2px 8px rgba(26, 43, 67, 0.42);
}
.un_homeHero_current, .un_homeHero_total {
  display: none !important;
}
.un_homeHero_current {
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 22px;
  font-size: 16px;
  line-height: 26px;
}
@media screen and (min-width: 992px) {
  .un_homeHero_current {
    font-size: 18px;
  }
}
.un_homeHero_total {
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 16px;
  font-size: 12px;
  line-height: 20px;
  opacity: 0.72;
}
@media screen and (min-width: 992px) {
  .un_homeHero_total {
    font-size: 13px;
  }
}
.un_homeHero_separator {
  display: none;
}
.un_homeHero_toggle {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 50%;
  background: rgba(26, 43, 67, 0.72);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.78) inset;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  transition: background-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}
.un_homeHero_toggle::before, .un_homeHero_toggle::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 24px;
  height: 24px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
.un_homeHero_toggle::before {
  background-image: url(/common/images/controller/controller-stop-white.svg);
}
.un_homeHero_toggle::after {
  background-image: url(/common/images/controller/controller-play-white.svg);
  opacity: 0;
}
.un_homeHero_toggle.is_paused::before {
  opacity: 0;
}
.un_homeHero_toggle.is_paused::after {
  opacity: 1;
}
@media (hover: hover) {
  .un_homeHero_toggle:hover {
    background-color: var(--oct-white);
  }
  .un_homeHero_toggle:hover::before {
    background-image: url(/common/images/controller/controller-stop-black.svg);
  }
  .un_homeHero_toggle:hover::after {
    background-image: url(/common/images/controller/controller-play-black.svg);
  }
}
.un_homeHero_dots {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  gap: 0 8px;
  width: 100%;
  height: 12px;
}
@media screen and (min-width: 992px) {
  .un_homeHero_dots {
    width: calc(100% - 50px);
    height: 44px;
    gap: 0 12px;
    justify-content: flex-end;
  }
}
.un_homeHero_dotBtn {
  display: block;
  width: 12px;
  height: 12px;
  padding: 0;
  border: 1px solid var(--oct-white);
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.2s ease;
}
.un_homeHero_dotBtn.is_active {
  background-color: var(--oct-white);
}
@media (hover: hover) {
  .un_homeHero_dotBtn:hover {
    background-color: var(--oct-white);
  }
}

/* アクセシビリティ: prefers-reduced-motion 時はアニメ無効 */
@media (prefers-reduced-motion: reduce) {
  .un_homeHero_imageWrap {
    transition: none;
  }
  .un_homeHero_imageWrap.is_active .un_homeHero_image {
    animation: none;
    transform: scale(1);
  }
}
.un_homePickup {
  overflow: hidden;
}
.un_homePickup_slider {
  margin-right: calc(50% - 50vw);
}
.un_homePickup_slider .splide__slide > a {
  display: block;
  transition: color 0.2s ease;
}
@media (hover: hover) {
  .un_homePickup_slider .splide__slide > a:hover {
    color: var(--oct-blue);
  }
  .un_homePickup_slider .splide__slide > a:hover .imgWrap img {
    transform: scale(1.05);
  }
}
.un_homePickup_slider .splide__slide > a .imgWrap {
  width: 100%;
  border-radius: 10px;
  overflow: hidden;
}
.un_homePickup_slider .splide__slide > a .imgWrap img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 10px;
  aspect-ratio: 248/96;
  transition: transform 0.2s ease;
}
@media screen and (min-width: 992px) {
  .un_homePickup_slider .splide__slide > a .imgWrap img {
    aspect-ratio: 558/216;
  }
}
.un_homePickup_slider .splide__slide > a .ttl {
  position: relative;
  margin-top: 16px;
  padding-right: 30px;
  font-weight: 700;
  font-size: 0.9375rem;
  line-height: 1.6;
}
@media screen and (min-width: 992px) {
  .un_homePickup_slider .splide__slide > a .ttl {
    margin-top: 24px;
    font-size: 1.25rem;
    line-height: 1.5;
  }
}
.un_homePickup_slider .splide__slide > a .ttl::after {
  content: "";
  display: block;
  position: absolute;
  top: 2px;
  right: 0;
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-blue.svg") no-repeat center;
  background-size: 100% 100%;
}
@media screen and (min-width: 992px) {
  .un_homePickup_slider .splide__slide > a .ttl::after {
    top: 4px;
  }
}
.un_homePickup_slider .splide__slide > a .caption {
  margin-top: 12px;
  padding-right: 30px;
  font-size: 0.9375rem;
  line-height: 1.6;
}
.un_homePickup_slider .splide__controller {
  margin-top: 30px;
}
.un_homePickup_slider .splide__controller__custom {
  display: flex;
  align-items: center;
  gap: 16px;
}
.un_homePickup_slider .splide__pagination {
  position: static;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0;
  gap: 8px;
}
.un_homePickup_slider .splide__pagination__page {
  position: relative;
  display: block;
  width: 4px;
  height: 4px;
  margin: 0;
  border-radius: 4px;
  opacity: 1;
  background-color: rgba(26, 43, 67, 0.4);
  overflow: hidden;
  transition: width 0.2s ease;
}
.un_homePickup_slider .splide__pagination__page.is-active {
  width: 70px;
  background-color: var(--oct-blue);
  transform: scale(1);
}
.un_homePickup_slider .splide__toggle {
  display: block;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}
.un_homePickup_slider .splide__toggle__play, .un_homePickup_slider .splide__toggle__pause {
  position: relative;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--oct-blue);
}
.un_homePickup_slider .splide__toggle__play::before, .un_homePickup_slider .splide__toggle__pause::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  width: 24px;
  height: 24px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
.un_homePickup_slider .splide__toggle__play {
  display: none;
}
.un_homePickup_slider .splide__toggle__play::before {
  background-image: url("/common/images/controller/controller-play-blue.svg");
}
.un_homePickup_slider .splide__toggle__pause {
  display: block;
}
.un_homePickup_slider .splide__toggle__pause::before {
  background-image: url("/common/images/controller/controller-stop-blue.svg");
}
.un_homePickup_slider .splide__toggle.is-active .splide__toggle__play {
  display: none;
}
.un_homePickup_slider .splide__toggle.is-active .splide__toggle__pause {
  display: block;
}
.un_homePickup_slider .splide__toggle:not(.is-active) .splide__toggle__play {
  display: block;
}
.un_homePickup_slider .splide__toggle:not(.is-active) .splide__toggle__pause {
  display: none;
}

.un_homeImportant {
  padding-top: 40px;
}

.un_homeImpNewsUnit {
  display: flex;
  flex-direction: column;
  gap: 30px 0;
}
@media screen and (min-width: 992px) {
  .un_homeImpNewsUnit {
    flex-direction: row;
    gap: 0 30px;
  }
}

.un_homeImpNews {
  width: 100%;
  padding: 30px;
  border-radius: 10px;
  border: 1px solid var(--oct-line);
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 992px) {
  .un_homeImpNews {
    padding: 40px;
  }
}
.un_homeImpNews_head {
  margin-bottom: 30px;
}
@media screen and (min-width: 992px) {
  .un_homeImpNews_head {
    display: flex;
    align-items: center;
    gap: 0 20px;
  }
}
.un_homeImpNews_heading {
  color: var(--oct-text);
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.4166666667;
}
.un_homeImpNews_tag {
  display: inline-block;
  margin-top: 8px;
  padding: 5px 10px;
  border-radius: 6px;
  color: var(--oct-white);
  background-color: var(--oct-black);
  font-weight: 700;
  font-size: 0.75rem;
  line-height: 1;
}
@media screen and (min-width: 992px) {
  .un_homeImpNews_tag {
    margin-top: 0;
    font-size: 1.125rem;
    line-height: 1;
  }
}
@media screen and (min-width: 992px) {
  .un_homeImpNews_body {
    height: 100%;
    display: flex;
    flex-direction: column;
  }
}
.un_homeImpNews__red .un_homeImpNews_heading {
  color: var(--oct-red);
}
.un_homeImpNews__red .un_homeImpNews_tag {
  background-color: var(--oct-red);
}
.un_homeImpNews__blue .un_homeImpNews_heading {
  color: var(--oct-blue);
}
.un_homeImpNews__blue .un_homeImpNews_tag {
  background-color: var(--oct-blue);
}
.un_homeImpNews .el_btn02 {
  max-width: 100%;
}

@media screen and (min-width: 992px) {
  .un_homeImpNewsList {
    height: 100%;
  }
}
.un_homeImpNewsList > li {
  border-bottom: 1px solid var(--oct-line);
}
.un_homeImpNewsList > li:first-of-type .un_homeImpNewsItem {
  padding-top: 0;
}
.un_homeImpNewsList > li:last-of-type {
  border-bottom: none;
}
.un_homeImpNewsList > li:last-of-type .un_homeImpNewsItem {
  padding-bottom: 0;
}
.un_homeImpNewsList__arrow .un_homeImpNewsItem_ttl {
  padding-right: 28px;
}
.un_homeImpNewsList__arrow .un_homeImpNewsItem_ttl::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-blue.svg") no-repeat center;
  background-size: 100% 100%;
}

.un_homeImpNewsItem {
  display: flex;
  flex-direction: column;
  gap: 12px 0;
  padding-block: 24px;
}
@media screen and (min-width: 992px) {
  .un_homeImpNewsItem {
    flex-direction: row;
    align-items: center;
    gap: 0;
  }
}
.un_homeImpNewsItem_head {
  display: flex;
  align-items: center;
  gap: 0 15px;
}
@media screen and (min-width: 992px) {
  .un_homeImpNewsItem_head {
    padding-right: 20px;
    border-right: 1px solid var(--oct-line);
  }
}
.un_homeImpNewsItem_date {
  display: inline-block;
  min-width: 113px;
  font-size: 0.875rem;
  line-height: 1.5;
}
@media screen and (min-width: 992px) {
  .un_homeImpNewsItem_date {
    min-width: 90px;
    display: flex;
    flex-direction: column;
  }
}
@media screen and (min-width: 992px) {
  .un_homeImpNewsItem_date .lg {
    font-weight: 700;
    font-size: 1.125rem;
  }
}
.un_homeImpNewsItem_ttl {
  position: relative;
  font-size: 1rem;
  line-height: 1.625;
}
@media screen and (min-width: 992px) {
  .un_homeImpNewsItem_ttl {
    flex: 1;
    padding-left: 20px;
  }
}
.un_homeImpNewsItem_ttl > a {
  display: inline-block;
  transition: color 0.2s ease;
  text-decoration: underline;
}
@media (hover: hover) {
  .un_homeImpNewsItem_ttl > a:hover {
    color: var(--oct-blue);
    text-decoration: none;
  }
}

.un_homeNewsList {
  display: flex;
  flex-direction: column;
}
.un_homeNewsList > li {
  border-bottom: 1px solid var(--oct-line);
}
.un_homeNewsList > li:first-of-type .un_homeNewsItem {
  border-top: 1px solid var(--oct-line);
}
.un_homeNewsList__arrow .un_homeNewsItem_ttl {
  padding-right: 28px;
}
.un_homeNewsList__arrow .un_homeNewsItem_ttl::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-blue.svg") no-repeat center;
  background-size: 100% 100%;
}

.un_homeNewsItem {
  display: flex;
  flex-direction: column;
  gap: 12px 0;
  padding-block: 30px;
}
@media screen and (min-width: 992px) {
  .un_homeNewsItem {
    flex-direction: row;
    align-items: center;
    gap: 0;
    padding-block: 38px;
  }
}
.un_homeNewsItem_head {
  display: flex;
  align-items: center;
  gap: 0 15px;
}
@media screen and (min-width: 992px) {
  .un_homeNewsItem_head {
    padding-right: 20px;
    border-right: 1px solid var(--oct-line);
  }
}
.un_homeNewsItem_date {
  display: inline-block;
  min-width: 113px;
  font-size: 0.875rem;
  line-height: 1.5;
}
@media screen and (min-width: 992px) {
  .un_homeNewsItem_date {
    min-width: 90px;
    display: flex;
    flex-direction: column;
  }
}
@media screen and (min-width: 992px) {
  .un_homeNewsItem_date .lg {
    font-weight: 700;
    font-size: 1.125rem;
  }
}
.un_homeNewsItem_category {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px 12px;
  border-radius: 8px;
  background-color: var(--oct-white);
  border: 1px solid var(--oct-line);
  font-size: 0.8125rem;
  line-height: 1.5384615385;
}
@media screen and (min-width: 992px) {
  .un_homeNewsItem_category {
    padding: 4px 20px 6px;
    font-size: 1rem;
    line-height: 1.625;
  }
}
.un_homeNewsItem_ttl {
  position: relative;
  font-size: 1rem;
  line-height: 1.625;
}
@media screen and (min-width: 992px) {
  .un_homeNewsItem_ttl {
    flex: 1;
    padding-left: 20px;
  }
}
.un_homeNewsItem_ttl > a {
  display: inline-block;
  transition: color 0.2s ease;
  text-decoration: underline;
}
@media (hover: hover) {
  .un_homeNewsItem_ttl > a:hover {
    color: var(--oct-blue);
    text-decoration: none;
  }
}

.un_homeVision {
  margin-top: 80px;
  padding-block: 40px 140px;
  background-color: var(--oct-blue);
  color: var(--oct-white);
  border-radius: 20px 0 0 0;
}
@media screen and (min-width: 992px) {
  .un_homeVision {
    margin-top: 140px;
    padding-block: 80px 340px;
    border-radius: 40px 0 0 0;
  }
}
.un_homeVision_centered {
  position: relative;
  z-index: 1;
}
.un_homeVision_deco {
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
  width: 102px;
}
@media screen and (min-width: 992px) {
  .un_homeVision_deco {
    width: 202px;
  }
}
.un_homeVision_lv2Heading {
  display: flex;
  flex-direction: column;
  gap: 12px 0;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.4166666667;
}
@media screen and (min-width: 992px) {
  .un_homeVision_lv2Heading {
    font-size: 2.625rem;
    line-height: 1.2380952381;
  }
}
.un_homeVision_lv2Heading::before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  background: url("/common/images/home/vision-heading-deco01.svg") no-repeat center;
  background-size: 100% 100%;
}
@media screen and (min-width: 992px) {
  .un_homeVision_lv2Heading::before {
    width: 18px;
    height: 18px;
  }
}

.un_homeVisionBnrList {
  margin-top: 30px;
  display: flex;
  flex-direction: column;
  gap: 24px 0;
}
@media screen and (min-width: 992px) {
  .un_homeVisionBnrList {
    margin-top: 40px;
    gap: 48px 0;
  }
}
.un_homeVisionBnrList > li {
  width: 100%;
}
.un_homeVisionBnrList > li > a {
  position: relative;
  display: block;
}
.un_homeVisionBnrList > li > a::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(to bottom, transparent, rgba(26, 43, 67, 0.2));
  border-radius: 10px;
  opacity: 0;
  transition: opacity 0.2s ease;
}
@media (hover: hover) {
  .un_homeVisionBnrList > li > a:hover::before {
    opacity: 1;
  }
}
.un_homeVisionBnrList > li > a img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 10px;
  aspect-ratio: 335/105;
}
@media screen and (min-width: 992px) {
  .un_homeVisionBnrList > li > a img {
    aspect-ratio: 1200/420;
  }
}
@media screen and (min-width: 992px) {
  .un_homeVisionBnrList__2col {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 48px;
  }
}
@media screen and (min-width: 992px) {
  .un_homeVisionBnrList__2col > li {
    width: calc((100% - 48px) / 2);
  }
}
@media screen and (min-width: 992px) {
  .un_homeVisionBnrList__2col > li > a img {
    aspect-ratio: 576/182;
  }
}

.un_homeVisionHead {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
  margin-bottom: 40px;
}
@media screen and (min-width: 992px) {
  .un_homeVisionHead {
    margin-bottom: 50px;
  }
}
.un_homeVisionHead_lead {
  font-size: 0.875rem;
  line-height: 1.5714285714;
}
@media screen and (min-width: 992px) {
  .un_homeVisionHead_lead {
    font-size: 1.125rem;
    line-height: 1.5555555556;
  }
}

.un_homeHumCap {
  position: relative;
  z-index: 2;
  margin: -74px auto 0 0;
  padding-block: 110px 160px;
}
@media screen and (min-width: 992px) {
  .un_homeHumCap {
    margin-top: -250px;
    padding-block: 140px 230px;
  }
}
.un_homeHumCap::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  z-index: -1;
  width: calc(100% - 20px);
  height: 100%;
  background-color: var(--oct-white);
  border-radius: 0 20px 0 0;
}
@media screen and (min-width: 992px) {
  .un_homeHumCap::before {
    width: calc(100% - 40px);
  }
}
@media screen and (min-width: 992px) {
  .un_homeHumCap_centered {
    display: flex;
    gap: 0 40px;
  }
}
.un_homeHumCap_imgWrap {
  position: absolute;
  inset: 0;
  z-index: -1;
}
.un_homeHumCap_img {
  display: block;
  width: 100%;
}
.un_homeHumCap_img__01, .un_homeHumCap_img__02, .un_homeHumCap_img__03 {
  position: absolute;
}
.un_homeHumCap_img__01 img, .un_homeHumCap_img__02 img, .un_homeHumCap_img__03 img {
  display: block;
  width: 100%;
}
.un_homeHumCap_img__01 {
  top: 36px;
  right: 20px;
  width: 230px;
}
@media screen and (min-width: 992px) {
  .un_homeHumCap_img__01 {
    top: 60px;
    right: 40px;
    width: 480px;
  }
}
.un_homeHumCap_img__02 {
  bottom: 30px;
  left: 0;
  width: 330px;
}
@media screen and (min-width: 992px) {
  .un_homeHumCap_img__02 {
    width: 720px;
  }
}
.un_homeHumCap_img__03 {
  z-index: -1;
  bottom: 0;
  right: 20px;
  width: 300px;
}
@media screen and (min-width: 992px) {
  .un_homeHumCap_img__03 {
    right: 40px;
    width: 760px;
  }
}
.un_homeHumCap_lv2Heading {
  width: 260px;
}
@media screen and (min-width: 992px) {
  .un_homeHumCap_lv2Heading {
    width: 360px;
  }
}
@media screen and (min-width: 1280px) {
  .un_homeHumCap_lv2Heading {
    width: 470px;
  }
}
.un_homeHumCap_lv2Heading img {
  display: block;
  width: 100%;
}
@media screen and (min-width: 992px) {
  .un_homeHumCap .el_btn02 {
    max-width: 300px;
  }
}

@media screen and (min-width: 992px) {
  .un_homeHumCapCont {
    flex: 1;
    max-width: 640px;
    padding-top: 120px;
    margin-left: auto;
  }
}

.un_homeHumCapList > li:not(:first-child) {
  margin-top: 16px;
}
@media screen and (min-width: 992px) {
  .un_homeHumCapList > li:not(:first-child) {
    margin-top: 20px;
  }
}

.un_homeHumCapItem {
  display: flex;
  align-items: center;
  gap: 0 16px;
}
@media screen and (min-width: 992px) {
  .un_homeHumCapItem {
    gap: 0 20px;
  }
}
.un_homeHumCapItem_head .heading {
  font-size: 0.8125rem;
  line-height: 1.6923076923;
}
@media screen and (min-width: 992px) {
  .un_homeHumCapItem_head .heading {
    font-size: 1.25rem;
    line-height: 1.5;
  }
}
.un_homeHumCapItem_body {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 0 15px;
}
@media screen and (min-width: 992px) {
  .un_homeHumCapItem_body {
    gap: 0 20px;
  }
}
.un_homeHumCapItem_body::before {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  border-top: 2px dotted var(--oct-line);
  flex: 1;
}
@media screen and (min-width: 992px) {
  .un_homeHumCapItem_body::before {
    min-width: 40px;
    height: 4px;
    border-top-width: 4px;
  }
}
.un_homeHumCapItem_body .txt {
  font-size: 0.8125rem;
  line-height: 1.6923076923;
}
@media screen and (min-width: 992px) {
  .un_homeHumCapItem_body .txt {
    text-align: right;
    font-size: 1.25rem;
    line-height: 1.5;
  }
}
.un_homeHumCapItem_body .txt .lg {
  display: inline-block;
  margin-right: 4px;
  font-weight: 700;
  color: var(--oct-blue);
  font-size: 1.125rem;
  line-height: 1.3333333333;
}
@media screen and (min-width: 992px) {
  .un_homeHumCapItem_body .txt .lg {
    margin-right: 8px;
    font-size: 1.875rem;
  }
}

.un_homeHumCapHead {
  margin-bottom: 24px;
}
@media screen and (min-width: 992px) {
  .un_homeHumCapHead {
    margin-bottom: 0;
  }
}

.un_homeHumCapBox {
  padding-block: 24px;
  background-color: #ddf5fd;
}
@media screen and (min-width: 992px) {
  .un_homeHumCapBox {
    padding-block: 40px;
  }
}
.un_homeHumCapBox_inner {
  width: calc(100% - 40px);
  margin-inline: auto;
}
@media screen and (min-width: 992px) {
  .un_homeHumCapBox_inner {
    width: calc(100% - 80px);
  }
}
.un_homeHumCapBox_note {
  text-align: right;
  margin-top: 20px;
  font-size: 0.625rem;
  line-height: 1.8;
}
@media screen and (min-width: 992px) {
  .un_homeHumCapBox_note {
    font-size: 1rem;
  }
}

.un_homeService {
  overflow: hidden;
}
.un_homeService_sectIn + .un_homeService_sectIn {
  padding-top: 60px;
}
@media screen and (min-width: 992px) {
  .un_homeService_sectIn + .un_homeService_sectIn {
    padding-top: 120px;
  }
}
.un_homeService_lv3Heading {
  display: flex;
  align-items: center;
  gap: 0 16px;
  margin-bottom: 20px;
}
@media screen and (min-width: 992px) {
  .un_homeService_lv3Heading {
    margin-bottom: 30px;
  }
}
.un_homeService_lv3Heading .icon {
  width: 28px;
}
@media screen and (min-width: 992px) {
  .un_homeService_lv3Heading .icon {
    width: 36px;
  }
}
.un_homeService_lv3Heading .icon img {
  display: block;
  width: 100%;
}
.un_homeService_lv3Heading .heading {
  flex: 1;
  font-weight: 700;
  font-size: 1.25rem;
  line-height: 1.5;
}
@media screen and (min-width: 992px) {
  .un_homeService_lv3Heading .heading {
    font-size: 1.875rem;
    line-height: 1.3333333333;
  }
}

.un_homeHistory_panel {
  position: relative;
  overflow: hidden;
  min-height: 395px;
  padding: 32px 24px;
  border-radius: 24px;
  background: linear-gradient(163deg, #f3f4f6 0%, #e5e7eb 100%);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
}
@media screen and (min-width: 992px) {
  .un_homeHistory_panel {
    padding: 50px;
  }
}
.un_homeHistory_panel::before, .un_homeHistory_panel::after {
  content: "";
  position: absolute;
  width: 384px;
  height: 384px;
  border-radius: 50%;
  filter: blur(64px);
}
.un_homeHistory_panel::before {
  right: -192px;
  top: -192px;
  background: rgba(0, 64, 152, 0.1);
}
.un_homeHistory_panel::after {
  left: -192px;
  bottom: -192px;
  background: rgba(234, 85, 4, 0.1);
}
.un_homeHistory_panel h2 {
  position: relative;
  z-index: 1;
  margin: 0 0 36px;
  font-size: 32px;
  line-height: 1.24;
  font-weight: 700;
}
@media screen and (min-width: 992px) {
  .un_homeHistory_panel h2 {
    font-size: 42px;
  }
}
.un_homeHistory_card {
  position: relative;
  z-index: 1;
  padding: 28px 22px;
  border-radius: 14px;
  background: #fff;
}
@media screen and (min-width: 992px) {
  .un_homeHistory_card {
    padding: 40px;
  }
}
.un_homeHistory_card h3 {
  margin: 0 0 18px;
  font-size: 20px;
  font-weight: 700;
}
.un_homeHistory_card p {
  margin: 0;
  color: var(--oct-muted);
  line-height: 1.65;
}
.un_homeHistory_arrow {
  position: absolute;
  top: 32px;
  right: 24px;
  z-index: 2;
  background: rgba(255, 255, 255, 0.7);
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border: 1px solid var(--oct-pale);
  border-radius: var(--oct-radiusMd);
  background: rgba(255, 255, 255, 0.1);
  box-shadow: 2px 2px 8px rgba(26, 43, 67, 0.22);
}
@media screen and (min-width: 992px) {
  .un_homeHistory_arrow {
    top: 50px;
    right: 50px;
  }
}

.un_homeHistory {
  margin-top: 80px;
}
@media screen and (min-width: 992px) {
  .un_homeHistory {
    margin-top: 140px;
  }
}

.un_homeHistoryPanel {
  position: relative;
  overflow: hidden;
  display: block;
  padding-block: 30px;
  border-radius: 20px;
  background: linear-gradient(163deg, #f3f4f6 0%, #e5e7eb 100%);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
  transition: opacity 0.2s ease;
}
@media screen and (min-width: 992px) {
  .un_homeHistoryPanel {
    padding-block: 50px;
  }
}
@media (hover: hover) {
  .un_homeHistoryPanel:hover {
    opacity: 0.7;
  }
}
.un_homeHistoryPanel::before, .un_homeHistoryPanel::after {
  content: "";
  position: absolute;
  width: 384px;
  height: 384px;
  border-radius: 50%;
  filter: blur(64px);
}
.un_homeHistoryPanel::before {
  right: -192px;
  top: -192px;
  background: rgba(0, 64, 152, 0.1);
}
.un_homeHistoryPanel::after {
  left: -192px;
  bottom: -192px;
  background: rgba(234, 85, 4, 0.1);
}
@media screen and (min-width: 992px) {
  .un_homeHistoryPanel_centered {
    width: calc(100% - 100px);
  }
}
.un_homeHistoryPanel_head {
  position: relative;
  padding-right: 40px;
}
@media screen and (min-width: 992px) {
  .un_homeHistoryPanel_head {
    padding-right: 44px;
  }
}
.un_homeHistoryPanel_head::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border: 1px solid var(--oct-pale);
  border-radius: var(--oct-radiusMd);
  box-shadow: 2px 2px 8px rgba(26, 43, 67, 0.22);
  background: rgba(255, 255, 255, 0.1) url("/common/images/icons/icon-arrow-black.svg") no-repeat center;
  background-size: 24px 24px;
}
@media screen and (min-width: 992px) {
  .un_homeHistoryPanel_head::after {
    width: 40px;
    height: 40px;
  }
}
.un_homeHistoryPanel_lv2Heading {
  font-weight: 700;
  font-size: 2rem;
  line-height: 1.3125;
}
@media screen and (min-width: 992px) {
  .un_homeHistoryPanel_lv2Heading {
    font-size: 2.625rem;
    line-height: 1.2380952381;
  }
}
.un_homeHistoryPanel_lv3Heading {
  margin-bottom: 18px;
  font-weight: 700;
  font-size: 1.25rem;
  line-height: 1.5;
}
.un_homeHistoryPanel_body {
  position: relative;
  z-index: 1;
  margin-top: 30px;
  padding: 24px;
  background-color: var(--oct-white);
  border-radius: 10px;
}
@media screen and (min-width: 992px) {
  .un_homeHistoryPanel_body {
    margin-top: 40px;
    padding: 50px;
  }
}
.un_homeHistoryPanel_txt {
  font-size: 1rem;
  line-height: 1.625;
}

.un_homeMedia {
  padding-block: 80px;
}
@media screen and (min-width: 992px) {
  .un_homeMedia {
    padding-block: 140px;
  }
}
.un_homeMedia_centered {
  display: flex;
  flex-direction: column;
  gap: 80px 0;
}
@media screen and (min-width: 992px) {
  .un_homeMedia_centered {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 100px;
  }
}
@media screen and (min-width: 992px) {
  .un_homeMedia_centered .un_homeMediaSect {
    width: calc((100% - 100px) / 2);
  }
}
.un_homeMedia .un_homeHead {
  margin-bottom: 26px;
}
@media screen and (min-width: 992px) {
  .un_homeMedia .el_homeLv2Heading {
    font-size: 1.875rem;
    line-height: 1.3333333333;
  }
}

@media screen and (min-width: 992px) {
  .un_homeMediaSect {
    display: flex;
    flex-direction: column;
  }
}

@media screen and (min-width: 992px) {
  .un_homeMediaCard {
    height: 100%;
  }
}
@media screen and (min-width: 992px) {
  .un_homeMediaCard_inner {
    height: 100%;
    display: flex;
    flex-direction: column;
  }
}
.un_homeMediaCard_imgWrap {
  width: 100%;
  height: 170px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  border: 1px solid var(--oct-line);
  border-radius: 20px;
}
@media screen and (min-width: 992px) {
  .un_homeMediaCard_imgWrap {
    min-height: 250px;
  }
}
.un_homeMediaCard_imgWrap img {
  display: block;
  max-width: 86.9565217%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.un_homeMediaCard_body {
  margin-top: 20px;
}
@media screen and (min-width: 992px) {
  .un_homeMediaCard_body {
    height: 100%;
    display: flex;
    flex-direction: column;
    margin-top: 30px;
  }
}
.un_homeMediaCard_ttl {
  margin-bottom: 20px;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.625;
}
@media screen and (min-width: 992px) {
  .un_homeMediaCard_ttl {
    font-size: 1.25rem;
    line-height: 1.5;
  }
}
.un_homeMediaCard_txt {
  font-size: 0.9375rem;
  line-height: 1.6;
}
@media screen and (min-width: 992px) {
  .un_homeMediaCard_txt {
    height: 100%;
    font-size: 1.25rem;
    line-height: 1.5;
  }
}
@media screen and (min-width: 992px) {
  .un_homeMediaCard .el_btn02 {
    max-width: 380px;
  }
}
@media screen and (min-width: 992px) {
  .un_homeMediaCard .el_btn02_wrap {
    margin-top: 50px;
  }
}

.un_homeAttention {
  padding-block: 30px 40px;
  background-color: #7fcff3;
}
@media screen and (min-width: 992px) {
  .un_homeAttention {
    padding-block: 30px 60px;
  }
}
.un_homeAttention_slider {
  position: relative;
  margin-top: 30px;
}
@media screen and (min-width: 992px) {
  .un_homeAttention_slider {
    margin-top: 60px;
  }
}
.un_homeAttention_slider .splide__arrows {
  display: flex;
  align-items: center;
  gap: 8px;
}
.un_homeAttention_slider .splide__arrow {
  position: static;
  transform: translateY(0);
  width: 36px;
  height: 36px;
  background-color: var(--oct-blue);
  border: 1px solid var(--oct-blue);
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 1;
}
.un_homeAttention_slider .splide__arrow::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 24px;
  height: 24px;
  background: url("/common/images/icons/icon-arrow-white.svg") no-repeat center;
  background-size: 100% 100%;
}
.un_homeAttention_slider .splide__arrow--prev::before {
  transform: translate(-50%, -50%) scaleX(-1);
}
@media (hover: hover) {
  .un_homeAttention_slider .splide__arrow:hover {
    opacity: 1;
  }
}
.un_homeAttention_slider .splide__slide > a {
  position: relative;
  display: block;
  width: 100%;
}
.un_homeAttention_slider .splide__slide > a::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(to bottom, transparent, rgba(26, 43, 67, 0.2));
  border-radius: 10px;
  opacity: 0;
  transition: opacity 0.2s ease;
}
@media (hover: hover) {
  .un_homeAttention_slider .splide__slide > a:hover::before {
    opacity: 1;
  }
}
.un_homeAttention_slider .splide__slide > a img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 315/193;
  border-radius: 10px;
}
@media screen and (min-width: 992px) {
  .un_homeAttention_slider .splide__slide > a img {
    aspect-ratio: 880/538;
  }
}
.un_homeAttention_slider .splide__slide > a .ttl {
  position: relative;
  margin-top: 10px;
  padding: 4px 34px 4px 12px;
  background-color: var(--oct-white);
  border-radius: 4px;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 0.875rem;
  line-height: 1.4285714286;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 992px) {
  .un_homeAttention_slider .splide__slide > a .ttl {
    position: absolute;
    bottom: 15px;
    left: 50%;
    transform: translateX(-50%);
    width: calc(100% - 30px);
    margin-top: 0;
    padding: 14px 54px 14px 20px;
    border-radius: 10px;
    font-size: 1.25rem;
    line-height: 1.5;
  }
}
.un_homeAttention_slider .splide__slide > a .ttl::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--oct-black) url("/common/images/icons/icon-arrow-white.svg") no-repeat center;
  background-size: 12px 12px;
  display: grid;
  place-items: center;
}
@media screen and (min-width: 992px) {
  .un_homeAttention_slider .splide__slide > a .ttl::after {
    width: 34px;
    height: 34px;
    background-size: 24px 24px;
  }
}
.un_homeAttention_slider .splide__controller {
  margin-top: 30px;
}
.un_homeAttention_slider .splide__controller__custom {
  display: flex;
  align-items: center;
  justify-content: center;
}
.un_homeAttention_slider .splide__controller__btns {
  min-width: 124px;
  position: relative;
  display: flex;
}
.un_homeAttention_slider .splide__controller__btns .splide__toggle__wrap {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.un_homeAttention_slider .splide__controller__btns .splide__arrows {
  width: 100%;
  justify-content: space-between;
}
.un_homeAttention_slider .splide__toggle {
  display: block;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}
.un_homeAttention_slider .splide__toggle__play, .un_homeAttention_slider .splide__toggle__pause {
  position: relative;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--oct-blue);
  background-color: var(--oct-blue);
}
.un_homeAttention_slider .splide__toggle__play::before, .un_homeAttention_slider .splide__toggle__pause::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  width: 24px;
  height: 24px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
.un_homeAttention_slider .splide__toggle__play {
  display: none;
}
.un_homeAttention_slider .splide__toggle__play::before {
  background-image: url("/common/images/controller/controller-play-white.svg");
}
.un_homeAttention_slider .splide__toggle__pause {
  display: block;
}
.un_homeAttention_slider .splide__toggle__pause::before {
  background-image: url("/common/images/controller/controller-stop-white.svg");
}
.un_homeAttention_slider .splide__toggle.is-active .splide__toggle__play {
  display: none;
}
.un_homeAttention_slider .splide__toggle.is-active .splide__toggle__pause {
  display: block;
}
.un_homeAttention_slider .splide__toggle:not(.is-active) .splide__toggle__play {
  display: block;
}
.un_homeAttention_slider .splide__toggle:not(.is-active) .splide__toggle__pause {
  display: none;
}
.un_homeAttention_slider .splide__custom-fraction {
  display: inline-block;
  padding: 4px 8px;
  margin-left: 20px;
  background-color: var(--oct-blue);
  border: 1px solid var(--oct-blue);
  border-radius: 4px;
  font-weight: 700;
  color: var(--oct-white);
  white-space: nowrap;
  font-size: 0.875rem;
}

.un_homeHead {
  display: flex;
  flex-direction: column;
  gap: 8px 0;
  margin-bottom: 40px;
}
@media screen and (min-width: 992px) {
  .un_homeHead {
    flex-direction: row;
    align-items: flex-end;
    gap: 0 30px;
    margin-bottom: 50px;
  }
}
.un_homeHead_lead {
  font-size: 0.875rem;
  line-height: 1.5714285714;
}
@media screen and (min-width: 992px) {
  .un_homeHead_lead {
    padding-bottom: 3px;
    font-size: 1.125rem;
    line-height: 1.5555555556;
  }
}
@media screen and (min-width: 992px) {
  .un_homeHead__vertical {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px 0;
  }
}

.un_homeCorpInfo {
  padding-top: 80px;
}
@media screen and (min-width: 992px) {
  .un_homeCorpInfo {
    padding-top: 140px;
  }
}
.un_homeCorpInfo_centered {
  display: flex;
  flex-direction: column;
  gap: 80px 0;
}
@media screen and (min-width: 992px) {
  .un_homeCorpInfo_centered {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 80px;
  }
}
@media screen and (min-width: 992px) {
  .un_homeCorpInfo_centered .un_homeCorpInfoSect {
    width: calc((100% - 80px) / 2);
  }
}
.un_homeCorpInfo .bl_linkList {
  margin-top: 20px;
}
@media screen and (min-width: 992px) {
  .un_homeCorpInfo .bl_linkList {
    margin-top: 40px;
  }
}

.un_homeCorpInfoCard_cont {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-end;
  padding: 20px;
  width: 100%;
  height: 150px;
  color: var(--oct-white);
}
@media screen and (min-width: 992px) {
  .un_homeCorpInfoCard_cont {
    padding: 20px;
    height: 270px;
  }
}
@media (hover: hover) {
  .un_homeCorpInfoCard_cont:hover .un_homeCorpInfoCard_imgWrap img {
    transform: scale(1.05);
  }
}
.un_homeCorpInfoCard_imgWrap {
  position: absolute;
  inset: 0;
  width: 100%;
  z-index: -1;
  border-radius: 10px;
  overflow: hidden;
}
.un_homeCorpInfoCard_imgWrap::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, transparent, rgba(26, 43, 67, 0.6));
  border-radius: 10px;
}
.un_homeCorpInfoCard_imgWrap img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 335/150;
  border-radius: 10px;
  box-shadow: 2px 2px 10px rgba(26, 43, 67, 0.2);
  transition: transform 0.2s ease;
}
.un_homeCorpInfoCard_ttlWrap {
  width: 100%;
}
.un_homeCorpInfoCard_ttl {
  position: relative;
  width: 100%;
  padding-right: 44px;
  font-weight: 700;
  font-size: 1.25rem;
  line-height: 1.5;
}
@media screen and (min-width: 992px) {
  .un_homeCorpInfoCard_ttl {
    font-size: 1.875rem;
    line-height: 1.3333333333;
  }
}
.un_homeCorpInfoCard_ttl::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border: 1px solid var(--oct-pale);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.1) url("/common/images/icons/icon-arrow-white.svg") no-repeat center;
  background-size: 24px 24px;
  box-shadow: 2px 2px 8px rgba(26, 43, 67, 0.3);
}
@media screen and (min-width: 992px) {
  .un_homeCorpInfoCard_ttl::after {
    width: 40px;
    height: 40px;
  }
}

.un_homeIndividual_slider {
  margin-top: -12px;
  margin-right: calc(50% - 50vw);
}
.un_homeIndividual_slider .splide__slide {
  padding-top: 12px;
  padding-bottom: 12px;
}
.un_homeIndividual_slider .splide__slide > a {
  width: 150px;
  height: 120px;
  display: grid;
  place-items: center;
  padding: 8px;
  border: 1px solid var(--oct-line);
  border-radius: var(--oct-radiusLg);
  background-color: var(--oct-white);
  box-shadow: var(--oct-shadow);
  transition: border 0.2s ease;
}
@media screen and (min-width: 992px) {
  .un_homeIndividual_slider .splide__slide > a {
    width: 250px;
    height: 150px;
    aspect-ratio: 186/150;
  }
}
@media (hover: hover) {
  .un_homeIndividual_slider .splide__slide > a:hover {
    border-color: var(--oct-blue);
  }
}
.un_homeIndividual_slider .splide__slide > a img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  border-radius: var(--oct-radiusLg);
}
.un_homeIndividual_slider .splide__controller {
  margin-top: 18px;
}
.un_homeIndividual_slider .splide__controller__custom {
  display: flex;
  align-items: center;
  gap: 16px;
}
.un_homeIndividual_slider .splide__pagination {
  position: static;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0;
  gap: 8px;
}
.un_homeIndividual_slider .splide__pagination__page {
  position: relative;
  display: block;
  width: 4px;
  height: 4px;
  margin: 0;
  border-radius: 4px;
  opacity: 1;
  background-color: rgba(26, 43, 67, 0.4);
  overflow: hidden;
  transition: width 0.2s ease;
}
.un_homeIndividual_slider .splide__pagination__page.is-active {
  width: 70px;
  background-color: var(--oct-blue);
  transform: scale(1);
}
.un_homeIndividual_slider .splide__toggle {
  display: block;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}
.un_homeIndividual_slider .splide__toggle__play, .un_homeIndividual_slider .splide__toggle__pause {
  position: relative;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--oct-blue);
}
.un_homeIndividual_slider .splide__toggle__play::before, .un_homeIndividual_slider .splide__toggle__pause::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  width: 24px;
  height: 24px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
.un_homeIndividual_slider .splide__toggle__play {
  display: none;
}
.un_homeIndividual_slider .splide__toggle__play::before {
  background-image: url("/common/images/controller/controller-play-blue.svg");
}
.un_homeIndividual_slider .splide__toggle__pause {
  display: block;
}
.un_homeIndividual_slider .splide__toggle__pause::before {
  background-image: url("/common/images/controller/controller-stop-blue.svg");
}
.un_homeIndividual_slider .splide__toggle.is-active .splide__toggle__play {
  display: none;
}
.un_homeIndividual_slider .splide__toggle.is-active .splide__toggle__pause {
  display: block;
}
.un_homeIndividual_slider .splide__toggle:not(.is-active) .splide__toggle__play {
  display: block;
}
.un_homeIndividual_slider .splide__toggle:not(.is-active) .splide__toggle__pause {
  display: none;
}

.un_homeCorporation_slider {
  margin-right: calc(50% - 50vw);
}
.un_homeCorporation_slider .splide__slide > a {
  position: relative;
  width: 240px;
  height: 150px;
  padding: 16px;
  display: flex;
  align-items: flex-end;
  border-radius: var(--oct-radiusLg);
  overflow: hidden;
}
@media screen and (min-width: 992px) {
  .un_homeCorporation_slider .splide__slide > a {
    width: 360px;
    height: 220px;
  }
}
@media (hover: hover) {
  .un_homeCorporation_slider .splide__slide > a:hover img {
    transform: scale(1.05);
  }
}
.un_homeCorporation_slider .splide__slide > a::after {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  border-radius: var(--oct-radiusLg);
  background: linear-gradient(180deg, rgba(26, 43, 67, 0) 35%, rgba(26, 43, 67, 0.66) 100%);
}
.un_homeCorporation_slider .splide__slide > a img {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: var(--oct-radiusLg);
  transition: transform 0.2s ease;
}
.un_homeCorporation_slider .splide__slide > a span {
  position: relative;
  display: block;
  width: 100%;
  z-index: 2;
  color: var(--oct-white);
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.625;
}
@media screen and (min-width: 992px) {
  .un_homeCorporation_slider .splide__slide > a span {
    font-size: 1.25rem;
    line-height: 1.5;
  }
}
.un_homeCorporation_slider .splide__controller {
  margin-top: 30px;
}
.un_homeCorporation_slider .splide__controller__custom {
  display: flex;
  align-items: center;
  gap: 16px;
}
.un_homeCorporation_slider .splide__pagination {
  position: static;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0;
  gap: 8px;
}
.un_homeCorporation_slider .splide__pagination__page {
  position: relative;
  display: block;
  width: 4px;
  height: 4px;
  margin: 0;
  border-radius: 4px;
  opacity: 1;
  background-color: rgba(26, 43, 67, 0.4);
  overflow: hidden;
  transition: width 0.2s ease;
}
.un_homeCorporation_slider .splide__pagination__page.is-active {
  width: 70px;
  background-color: var(--oct-blue);
  transform: scale(1);
}
.un_homeCorporation_slider .splide__toggle {
  display: block;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}
.un_homeCorporation_slider .splide__toggle__play, .un_homeCorporation_slider .splide__toggle__pause {
  position: relative;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--oct-blue);
}
.un_homeCorporation_slider .splide__toggle__play::before, .un_homeCorporation_slider .splide__toggle__pause::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  width: 24px;
  height: 24px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
.un_homeCorporation_slider .splide__toggle__play {
  display: none;
}
.un_homeCorporation_slider .splide__toggle__play::before {
  background-image: url("/common/images/controller/controller-play-blue.svg");
}
.un_homeCorporation_slider .splide__toggle__pause {
  display: block;
}
.un_homeCorporation_slider .splide__toggle__pause::before {
  background-image: url("/common/images/controller/controller-stop-blue.svg");
}
.un_homeCorporation_slider .splide__toggle.is-active .splide__toggle__play {
  display: none;
}
.un_homeCorporation_slider .splide__toggle.is-active .splide__toggle__pause {
  display: block;
}
.un_homeCorporation_slider .splide__toggle:not(.is-active) .splide__toggle__play {
  display: block;
}
.un_homeCorporation_slider .splide__toggle:not(.is-active) .splide__toggle__pause {
  display: none;
}

.un_homeEnMv {
  position: relative;
  width: 100%;
  height: 380px;
  padding: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 992px) {
  .un_homeEnMv {
    height: 560px;
  }
}
.un_homeEnMv_bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.un_homeEnMv_bg::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, rgba(26, 43, 67, 0) 30%, rgba(26, 43, 67, 0.65) 100%), rgba(26, 43, 67, 0.36);
  border-radius: 0 0 24px 24px;
}
@media screen and (min-width: 992px) {
  .un_homeEnMv_bg::before {
    border-radius: 0 0 36px 36px;
  }
}
.un_homeEnMv_bg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 0 0 24px 24px;
}
@media screen and (min-width: 992px) {
  .un_homeEnMv_bg img {
    border-radius: 0 0 36px 36px;
  }
}
.un_homeEnMv_cont {
  position: relative;
  z-index: 1;
  color: var(--oct-white);
  display: flex;
  flex-direction: column;
  gap: 16px 0;
  text-align: center;
}
.un_homeEnMv_company {
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.6875rem;
  line-height: 1.6363636364;
  letter-spacing: 0.15em;
}
@media screen and (min-width: 992px) {
  .un_homeEnMv_company {
    font-size: 0.875rem;
  }
}
.un_homeEnMv_heading {
  font-weight: 900;
  font-size: 1.75rem;
  line-height: 1.5;
}
@media screen and (min-width: 992px) {
  .un_homeEnMv_heading {
    font-size: 4rem;
  }
}

.un_homeEnIntro_txt {
  max-width: 800px;
  margin-inline: auto;
  font-size: 0.875rem;
  line-height: 1.7857142857;
}
@media screen and (min-width: 992px) {
  .un_homeEnIntro_txt {
    font-size: 1rem;
    line-height: 1.625;
  }
}
.un_homeEnIntro .un_homeHead {
  text-align: center;
}
@media screen and (min-width: 992px) {
  .un_homeEnIntro .un_homeHead {
    align-items: center;
  }
}
.un_homeEnIntro .un_homeHead_lead {
  font-size: 1rem;
  line-height: 1.625;
}
@media screen and (min-width: 992px) {
  .un_homeEnIntro .un_homeHead_lead {
    font-size: 1.125rem;
    line-height: 1.5555555556;
  }
}
.un_homeEnIntro .el_homeLv2Heading {
  font-size: 2rem;
  line-height: 1.25;
}
@media screen and (min-width: 992px) {
  .un_homeEnIntro .el_homeLv2Heading {
    font-size: 2.625rem;
    line-height: 1.2380952381;
  }
}

.un_homeEnSust {
  padding-bottom: 80px;
}
@media screen and (min-width: 992px) {
  .un_homeEnSust {
    padding-bottom: 140px;
  }
}

/* 既存のcss（一部抜粋）※デザインによって調整、削除する */
/* float */
.bl_imgFloat {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
}
@media screen and (min-width: 992px) {
  .bl_imgFloat {
    display: flow-root;
  }
}
@media screen and (min-width: 992px) {
  .bl_imgFloat_imgWrap {
    max-width: 45%;
    float: left;
    margin-right: 40px;
  }
}
.bl_imgFloat_imgWrap img {
  display: block;
  width: 100%;
}
@media screen and (min-width: 992px) {
  .bl_imgFloat_body {
    width: 100%;
  }
}
@media screen and (min-width: 992px) {
  .bl_imgFloat__rev .bl_imgFloat_imgWrap {
    float: right;
    margin-right: auto;
    margin-left: 40px;
  }
}

/* imglist */
.bl_imgList {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
}
@media screen and (min-width: 992px) {
  .bl_imgList {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 20px;
  }
}
@media screen and (min-width: 992px) {
  .bl_imgList .item {
    width: 100%;
  }
}
.bl_imgList .item a, .bl_imgList .item img {
  display: block;
  width: 100%;
}
.bl_imgList .item .caption {
  margin-top: 8px;
  text-align: center;
  font-size: 14px;
}
@media screen and (min-width: 992px) {
  .bl_imgList__2col .item {
    width: calc((100% - 20px) / 2);
  }
}
@media screen and (min-width: 992px) {
  .bl_imgList__3col .item {
    width: calc((100% - 40px) / 3);
  }
}
@media screen and (min-width: 992px) {
  .bl_imgList__4col .item {
    width: calc((100% - 60px) / 4);
  }
}

/* CMS独自のスタイルやクラスにあてる */
/* colorbox */
#cboxOverlay, #cboxWrapper, #colorbox {
  z-index: 10 !important;
}

/* ============================================================ */
/*  下層レイアウト (about/corporate/scholarship/ir/sustainability) */
/* グローバルセレクタは . スコープ化済み (site-wide 副作用なし) */
/* ============================================================ */
:root {
  --blue: #004098;
  --cellular-cyan: #00a0e9;
  --orange: #ea5504;
  --red: #a91017;
  --text: #1a2b43;
  --muted: #58595a;
  --line: #b7c2cf;
  --pale: #ebf0f6;
  --soft-blue: #f0f9ff;
  --white: #ffffff;
  --shadow: 2px 2px 10px rgba(26, 43, 67, 0.14);
  --radius-lg: 20px;
  --radius-md: 10px;
  --container: 1280px;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

.site-header {
  position: absolute;
  top: 1042px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
  width: calc(100% - 40px);
  max-width: 1400px;
  height: 86px;
  margin: 0 auto;
  padding: 0 30px;
  display: flex;
  align-items: center;
  gap: 32px;
  background: rgba(255, 255, 255, 0.94);
  border-radius: 10px;
  box-shadow: 0 10px 28px rgba(26, 43, 67, 0.12);
  backdrop-filter: blur(10px);
}

.site-header::before {
  content: "";
  position: fixed;
  left: 0;
  right: 0;
  top: 886px;
  height: 960px;
  z-index: -1;
  background: var(--cellular-cyan);
  pointer-events: none;
}

.site-header.is-fixed::before {
  display: none;
}

.site-header.is-fixed {
  position: fixed;
  top: 10px;
  animation: headerDrop 0.2s ease-out;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.brand-mark,
.mini-mark,
.pixel-icon {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  width: 42px;
  height: 32px;
}

.brand-mark span,
.mini-mark span,
.pixel-icon::before,
.pixel-icon::after,
.pixel-icon span {
  display: block;
}

.brand-mark span:nth-child(1),
.brand-mark span:nth-child(2),
.brand-mark span:nth-child(4),
.brand-mark span:nth-child(5),
.brand-mark span:nth-child(8),
.brand-mark span:nth-child(9),
.brand-mark span:nth-child(10),
.brand-mark span:nth-child(11),
.mini-mark span:nth-child(1),
.mini-mark span:nth-child(2),
.mini-mark span:nth-child(4),
.mini-mark span:nth-child(5),
.mini-mark span:nth-child(8),
.mini-mark span:nth-child(9),
.mini-mark span:nth-child(10),
.mini-mark span:nth-child(11) {
  background: var(--orange);
}

.brand-mark span:nth-child(3),
.brand-mark span:nth-child(6),
.brand-mark span:nth-child(12),
.mini-mark span:nth-child(3),
.mini-mark span:nth-child(6),
.mini-mark span:nth-child(12) {
  background: var(--blue);
}

.brand-mark span:nth-child(7),
.mini-mark span:nth-child(7) {
  background: #d2d2d2;
}

.brand-text {
  font-size: 20px;
}

.global-nav {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 30px;
  font-size: 15px;
  font-weight: 700;
}

.global-nav a,
.footer-nav a,
.hero-menu a,
.drawer-nav a {
  transition: color 0.2s ease;
}

.global-nav a:hover,
.footer-nav a:hover,
.hero-menu a:hover,
.drawer-nav a:hover {
  color: var(--orange);
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 14px;
}

.icon-link,
.lang-link {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border: 0;
  border-radius: 50%;
  background: transparent;
  color: var(--text);
  font-weight: 800;
  cursor: pointer;
}

.lang-link {
  border: 1px solid var(--line);
}

.menu-button {
  display: none;
  width: 44px;
  height: 44px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
}

.menu-button span {
  display: block;
  height: 2px;
  margin: 5px 0;
  background: var(--text);
}

.drawer-nav {
  display: none;
}

.hero {
  position: relative;
  height: 1024px;
  min-height: 1024px;
  overflow: hidden;
  border-radius: 0 0 36px 0;
  background: var(--text);
}

.hero-image,
.hero-shade {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.hero-image {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}

.hero-shade {
  background: linear-gradient(180deg, rgba(26, 43, 67, 0) 52%, rgba(26, 43, 67, 0.5) 100%), rgba(26, 43, 67, 0.36);
}

.fv-logo {
  position: absolute;
  top: 32px;
  left: 60px;
  width: 190px;
  height: 66px;
  display: block;
}

.fv-logo img {
  position: absolute;
  max-width: none;
}

.fv-logo-symbol {
  left: 49.6px;
  top: 1.5px;
  width: 81.1px;
  height: 14.9px;
}

.fv-logo-mark {
  left: 131.9px;
  top: 0;
  width: 8.3px;
  height: 16.4px;
}

.fv-logo-text {
  left: 0;
  bottom: 0;
  width: 190px;
  height: 39.3px;
}

.brand-page-link {
  position: absolute;
  top: 30px;
  right: 30px;
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 258px;
  height: 86px;
  padding: 18px 24px 18px 30px;
  border-radius: var(--radius-md);
  background: linear-gradient(163deg, #fff6f6 5%, #fff 51%, #ebf1f9 96%);
  box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
  font-size: 18px;
  font-weight: 800;
}

.mini-mark {
  width: 56px;
  height: 42px;
}

.hero-menu {
  position: absolute;
  left: 60px;
  bottom: 64px;
  display: grid;
  gap: 16px;
  color: #fff;
  font-size: 16px;
  font-weight: 800;
  line-height: 1.65;
}

.hero-copy {
  position: absolute;
  right: 50px;
  bottom: 70px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  width: min(100% - 120px, 793px);
}

.hero-copy img:first-child {
  width: calc(100% - 84px);
}

.hero-copy-mark {
  width: 72px;
}

.section-pad {
  width: min(var(--container), 100% - 80px);
  margin: 0 auto;
  padding: 100px 0;
}

.section-heading {
  margin-bottom: 44px;
}

.section-heading h2 {
  margin: 0 0 20px;
  font-size: 42px;
  line-height: 1.24;
  letter-spacing: 0.05em;
}

.section-heading p {
  margin: 0;
  font-size: 18px;
  line-height: 1.55;
}

.pickup-slider {
  position: relative;
  width: 100%;
  margin: 178px auto 60px;
  overflow: hidden;
  padding-bottom: 4px;
  background: var(--cellular-cyan);
}

.pickup-card {
  position: relative;
  width: 880px;
  max-width: calc(100% - 80px);
  margin: 0 auto;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: #fff;
  box-shadow: var(--shadow);
}

.pickup-card.is-side {
  display: block;
  position: absolute;
  top: 0;
  margin: 0;
  opacity: 1;
}

.pickup-card.is-side:nth-of-type(2) {
  left: calc(50% - 1380px);
}

.pickup-card.is-side:nth-of-type(3) {
  left: calc(50% + 500px);
}

.pickup-visual {
  height: 538px;
  position: relative;
  display: block;
  background: #eaf2f8;
}

.pickup-visual img {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  -o-object-fit: cover;
     object-fit: cover;
}

.pickup-title {
  position: absolute;
  left: 15px;
  right: 15px;
  bottom: 15px;
  margin: 0;
  min-height: 58px;
  padding: 14px 12px 14px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: 0 0 16px 16px;
  background: #fff;
  font-size: 18px;
  font-weight: 800;
  line-height: 1.6;
}

.pickup-title span,
.image-link-card i,
.floating-arrow {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border: 1px solid var(--pale);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.1);
  box-shadow: 2px 2px 8px rgba(26, 43, 67, 0.22);
}

.slider-control {
  display: flex;
  align-items: center;
  gap: 26px;
  width: -moz-max-content;
  width: max-content;
  margin: 30px auto 0;
}

.pause {
  width: 14px;
  height: 16px;
  border-left: 4px solid var(--text);
  border-right: 4px solid var(--text);
}

.bar {
  position: relative;
  width: 120px;
  height: 4px;
  border-radius: 3px;
  background: var(--line);
}

.bar i {
  position: absolute;
  inset: 0 auto 0 0;
  width: 75%;
  border-radius: inherit;
  background: var(--blue);
}

.important {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 620px));
  gap: 40px;
  justify-content: center;
  padding: 40px 40px;
  background: #fff;
}

.important-card {
  padding: 34px 40px 30px;
  border: 1px solid #d2d2d2;
  border-radius: var(--radius-md);
  background: #fff;
}

.important-heading {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 28px;
}

.important-heading h3 {
  margin: 0;
  font-size: 24px;
  line-height: 1.42;
}

.important-heading span,
.tag {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 10px;
  border-radius: 6px;
  background: var(--blue);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}

.important-card.is-red h3,
.important-card.is-red .important-heading span {
  color: var(--red);
}

.important-card.is-red .important-heading span {
  color: #fff;
  background: var(--red);
}

.important-card.is-blue h3 {
  color: var(--blue);
}

.notice-row {
  display: grid;
  grid-template-columns: 118px 1fr;
  gap: 22px;
  align-items: center;
  margin-bottom: 40px;
}

.notice-row time {
  display: grid;
  gap: 2px;
  border-right: 2px solid var(--line);
  font-size: 18px;
  font-weight: 800;
}

.notice-row small {
  font-size: 14px;
  font-weight: 400;
}

.notice-row p {
  margin: 0;
  font-size: 16px;
  line-height: 1.65;
}

.outline-button {
  min-height: 60px;
  padding: 16px 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  border: 2px solid var(--blue);
  border-radius: var(--radius-md);
  background: #fff;
  font-weight: 800;
  transition: background 0.2s ease, color 0.2s ease;
}

.outline-button:hover {
  background: var(--blue);
  color: #fff;
}

.campaign-pickup {
  width: 100%;
  margin: 96px 0 0;
  overflow: hidden;
  padding-left: max(80px, (100% - var(--container)) / 2);
  padding-bottom: 2px;
}

.campaign-pickup-heading {
  display: flex;
  align-items: flex-end;
  gap: 80px;
  margin-bottom: 50px;
}

.campaign-pickup-heading h2 {
  margin: 0;
  font-size: 42px;
  font-weight: 800;
  line-height: 52px;
  letter-spacing: 0.05em;
}

.campaign-pickup-heading p {
  margin: 0 0 8px;
  font-size: 18px;
  line-height: 28px;
}

.campaign-pickup-track {
  display: flex;
  gap: 40px;
  overflow-x: auto;
  padding-right: 80px;
  scrollbar-width: none;
}

.campaign-pickup-track::-webkit-scrollbar {
  display: none;
}

.campaign-card {
  position: relative;
  flex: 0 0 558px;
  padding-bottom: 63px;
}

.campaign-card img {
  width: 558px;
  height: 216px;
  border-radius: 10px;
  -o-object-fit: cover;
     object-fit: cover;
}

.campaign-card span {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 468px;
  color: var(--text);
  font-size: 20px;
  font-weight: 800;
  line-height: 30px;
  letter-spacing: 0.05em;
}

.campaign-card i {
  position: absolute;
  right: 0;
  bottom: 6px;
  color: var(--blue);
  font-size: 24px;
  font-style: normal;
  line-height: 1;
}

.campaign-scroll {
  position: relative;
  width: min(1280px, 100vw - 160px);
  height: 2px;
  margin-top: 63px;
  background: var(--line);
  border-radius: 3px;
}

.campaign-scroll span {
  position: absolute;
  left: 0;
  top: 0;
  width: 431px;
  height: 2px;
  background: var(--blue);
  border-radius: 3px;
}

.news-section {
  padding-top: 100px;
}

.news-heading {
  display: flex;
  align-items: flex-end;
  gap: 78px;
  margin-bottom: 50px;
}

.news-heading h2 {
  margin: 0;
  color: var(--text);
  font-size: 42px;
  font-weight: 900;
  line-height: 52px;
  letter-spacing: 0.05em;
}

.news-heading p {
  margin: 0 0 8px;
  font-size: 18px;
  line-height: 28px;
}

.news-layout {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 70px;
}

.news-tabs {
  display: grid;
  gap: 15px;
  align-content: start;
}

.news-tabs button {
  width: 150px;
  height: 46px;
  border: 2px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  font-size: 16px;
  font-weight: 800;
  letter-spacing: 0.05em;
  cursor: pointer;
}

.news-tabs button.active {
  border-color: var(--orange);
  background: var(--orange);
  color: #fff;
}

.news-content {
  display: grid;
  justify-items: center;
}

.news-list {
  width: 100%;
  display: grid;
  border-top: 2px solid var(--line);
}

.news-item {
  min-height: 103px;
  display: grid;
  grid-template-columns: 134px 107px 1fr 24px;
  gap: 20px;
  align-items: center;
  border-bottom: 2px solid var(--line);
  font-size: 16px;
}

.news-item time {
  min-height: 52px;
  display: grid;
  align-content: center;
  border-right: 1px solid var(--line);
  color: var(--text);
}

.news-item time small {
  display: block;
  margin-bottom: 2px;
  font-size: 14px;
  font-weight: 400;
  line-height: 14px;
}

.news-item time strong {
  font-size: 18px;
  line-height: 28px;
}

.news-category {
  width: 107px;
  min-height: 35px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.news-title-text {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.news-item i {
  color: var(--blue);
  font-size: 24px;
  font-style: normal;
}

.news-more {
  width: 420px;
  min-height: 68px;
  margin-top: 40px;
}

.vision-section {
  position: relative;
  overflow: hidden;
  margin-top: 140px;
  background: var(--blue);
  color: #fff;
}

.au-shika-silhouette {
  position: absolute;
  top: 80px;
  right: max(96px, (100% - 1200px) / 2 + 18px);
  z-index: 1;
  width: 205px;
  height: auto;
  opacity: 1;
  pointer-events: none;
}

.vision-inner {
  position: relative;
  z-index: 1;
  width: min(1200px, 100% - 80px);
  margin: 0 auto;
  padding: 80px 0 96px;
}

.vision-heading {
  margin-bottom: 58px;
}

.vision-dots {
  display: block;
  width: 18px;
  height: 18px;
  margin-bottom: 16px;
  background: linear-gradient(var(--orange) 0 0) right top/9px 9px no-repeat, linear-gradient(#d2d2d2 0 0) left bottom/9px 9px no-repeat;
}

.vision-heading h2 {
  margin: 0 0 18px;
  font-size: 42px;
  line-height: 52px;
  letter-spacing: 0.05em;
}

.vision-heading p {
  margin: 0;
  font-size: 18px;
  line-height: 28px;
}

.vision-family-frame {
  width: 100%;
  height: 420px;
  overflow: hidden;
  border-radius: 10px;
  background: #fff;
}

.vision-family {
  display: block;
  width: 103.28%;
  max-width: none;
  height: 180.06%;
  -o-object-fit: fill;
     object-fit: fill;
  transform: translate(-1.64%, -22.29%);
}

.vision-card-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 48px;
  margin-top: 36px;
}

.vision-plan-card,
.vision-health-card {
  position: relative;
  min-height: 182px;
  height: 182px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 10px;
  box-shadow: var(--shadow);
}

.vision-plan-card {
  background: var(--text);
}

.vision-plan-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  opacity: 0.42;
}

.vision-plan-card span {
  position: relative;
  z-index: 1;
  font-size: 42px;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: 0.07em;
}

.vision-plan-card small {
  position: relative;
  z-index: 1;
  margin-top: -36px;
  color: rgba(255, 255, 255, 0.72);
  font-size: 20px;
  font-weight: 800;
  letter-spacing: 0.42em;
}

.vision-health-card {
  background: linear-gradient(180deg, #f97316 0%, var(--orange) 100%);
  font-size: 38px;
  font-weight: 800;
  line-height: 1.45;
  text-align: center;
}

.human-capital {
  position: relative;
  min-height: 631px;
  margin-top: 0;
  padding: 80px max(40px, (100% - 1200px) / 2) 0;
  overflow: hidden;
  border-radius: 0 36px 0 0;
  background: #fff;
  color: var(--text);
  isolation: isolate;
}

.human-copy {
  position: relative;
  z-index: 2;
  width: 470px;
  max-width: 48%;
}

.human-copy img {
  width: 470px;
}

.human-button {
  width: 300px;
  min-height: 68px;
  margin-top: 50px;
  color: var(--blue);
}

.human-bridge {
  position: absolute;
  right: 40px;
  top: 0;
  width: 478px;
  height: 147px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 70px 0 0 70px;
}

.human-cellular-stroke {
  position: absolute;
  right: 40px;
  top: 488px;
  z-index: 0;
  width: 761px;
  height: 143px;
  pointer-events: none;
}

.human-data {
  position: absolute;
  right: max(40px, (100% - 1200px) / 2);
  top: 197px;
  z-index: 2;
  width: 540px;
  min-height: 306px;
  padding: 40px 60px 26px;
  background: #e2f6ff;
}

.human-data dl {
  margin: 0;
  display: grid;
  gap: 14px;
}

.human-data dl div {
  display: grid;
  grid-template-columns: max-content 1fr max-content;
  align-items: baseline;
  gap: 14px;
}

.human-data dl div::before {
  content: "";
  grid-column: 2;
  height: 4px;
  border-bottom: 3px dotted rgba(26, 43, 67, 0.25);
}

.human-data dt {
  grid-column: 1;
  grid-row: 1;
  font-size: 20px;
}

.human-data dd {
  grid-column: 3;
  grid-row: 1;
  margin: 0;
  font-size: 20px;
}

.human-data strong {
  color: var(--blue);
  font-size: 30px;
  line-height: 1;
}

.human-data p {
  margin: 28px 0 0;
  text-align: right;
  font-size: 16px;
}

.human-people {
  position: absolute;
  left: 0;
  top: 411px;
  z-index: 1;
  width: 717px;
  height: 193px;
  -o-object-fit: cover;
     object-fit: cover;
}

.feature-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 80px;
}

.image-link-card {
  position: relative;
  display: block;
  height: 268px;
  overflow: hidden;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
}

.image-link-card::after,
.corp-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(26, 43, 67, 0) 35%, rgba(26, 43, 67, 0.66) 100%);
}

.image-link-card img,
.corp-card img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.image-link-card span {
  position: absolute;
  left: 30px;
  bottom: 30px;
  z-index: 1;
  color: #fff;
  font-size: 30px;
  font-weight: 800;
  line-height: 1.3;
}

.image-link-card i {
  position: absolute;
  right: 30px;
  bottom: 30px;
  z-index: 1;
  color: #fff;
  font-style: normal;
}

.link-list {
  display: grid;
  gap: 15px;
  margin-top: 40px;
}

.link-row {
  min-height: 65px;
  padding: 18px 29px;
  display: flex;
  align-items: center;
  gap: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: #fff;
  font-size: 15px;
  font-weight: 700;
}

.link-row.featured {
  border-color: rgba(0, 64, 152, 0.1);
  background: var(--soft-blue);
}

.link-row i {
  margin-left: auto;
  color: var(--blue);
  font-style: normal;
  font-size: 24px;
}

.services {
  width: 100%;
  max-width: none;
  padding-left: max(40px, (100% - var(--container)) / 2);
  overflow: hidden;
}

.services .section-heading {
  width: min(var(--container), 100vw - 80px);
}

.service-block {
  margin-top: 64px;
}

.service-block h3 {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 0 0 30px;
  font-size: 30px;
  line-height: 1;
}

.pixel-icon {
  position: relative;
  flex: 0 0 auto;
  width: 36px;
  height: 36px;
  background: linear-gradient(90deg, var(--orange) 0 33%, transparent 33% 100%), linear-gradient(var(--orange) 0 33%, var(--blue) 33% 66%, var(--orange) 66%);
  background-size: 36px 36px;
}

.pixel-icon.alt {
  background: linear-gradient(90deg, var(--orange) 0 33%, transparent 33% 100%), linear-gradient(var(--orange) 0 33%, var(--blue) 33% 66%, var(--blue) 66%);
}

.personal-services,
.corporate-services {
  display: flex;
  gap: 30px;
  overflow-x: auto;
  padding: 0 40px 4px 0;
  scrollbar-width: none;
}

.personal-services::-webkit-scrollbar,
.corporate-services::-webkit-scrollbar {
  display: none;
}

.logo-card {
  flex: 0 0 186px;
  height: 150px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: #fff;
}

.featured-logo {
  flex-basis: 250px;
  box-shadow: var(--shadow);
}

.logo-card img {
  width: 70%;
  max-height: 70px;
  -o-object-fit: contain;
     object-fit: contain;
}

.mini-scroll {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-top: 24px;
}

.mini-scroll span {
  width: 150px;
  height: 6px;
  border-radius: 6px;
  background: var(--blue);
}

.mini-scroll i {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--line);
}

.corporate-services {
  gap: 30px;
}

.corp-card {
  position: relative;
  flex: 0 0 360px;
  height: 220px;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: #dfecfd;
  box-shadow: 2px 2px 10px rgba(26, 43, 67, 0.2);
}

.corp-card span {
  position: absolute;
  left: 25px;
  bottom: 20px;
  z-index: 1;
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  line-height: 1.5;
}

.corp-first {
  background: #dfecfd;
}

.corp-first .corp-photo {
  position: absolute;
  right: -35px;
  width: 64%;
}

.corp-first .corp-logo {
  position: absolute;
  left: 10px;
  top: 62px;
  width: 64%;
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
}

.history-panel {
  position: relative;
  overflow: hidden;
  min-height: 395px;
  padding: 50px;
  border-radius: 24px;
  background: linear-gradient(163deg, #f3f4f6 0%, #e5e7eb 100%);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
}

.history-panel::before,
.history-panel::after {
  content: "";
  position: absolute;
  width: 384px;
  height: 384px;
  border-radius: 50%;
  filter: blur(64px);
}

.history-panel::before {
  right: -192px;
  top: -192px;
  background: rgba(0, 64, 152, 0.1);
}

.history-panel::after {
  left: -192px;
  bottom: -192px;
  background: rgba(234, 85, 4, 0.1);
}

.history-panel h2 {
  position: relative;
  z-index: 1;
  margin: 0 0 36px;
  font-size: 42px;
  line-height: 1.24;
}

.history-card {
  position: relative;
  z-index: 1;
  padding: 40px;
  border-radius: 14px;
  background: #fff;
}

.history-card h3 {
  margin: 0 0 18px;
  font-size: 20px;
}

.history-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.floating-arrow {
  position: absolute;
  top: 50px;
  right: 50px;
  z-index: 2;
  background: rgba(255, 255, 255, 0.7);
}

.media-section {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 500px));
  justify-content: center;
  gap: 100px;
}

.media-card h2 {
  margin: 0 0 26px;
  font-size: 30px;
  line-height: 1.35;
}

.media-card h3 {
  margin: 32px 0 20px;
  font-size: 20px;
  line-height: 1.5;
}

.media-card p {
  margin: 0 0 46px;
  font-size: 20px;
  line-height: 1.5;
}

.media-visual {
  position: relative;
  height: 250px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: linear-gradient(138deg, #fff6f2 10%, #f5fcff 92%);
}

.media-visual img {
  max-width: 82%;
  max-height: 78%;
  -o-object-fit: contain;
     object-fit: contain;
}

.media-visual span {
  position: absolute;
  right: 20px;
  bottom: 20px;
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-md);
  background: #fff;
  box-shadow: var(--shadow);
}

.outline-button.wide {
  width: min(380px, 100%);
  margin: 0 auto;
}

.related-links {
  padding: 60px 80px 70px;
  background: var(--pale);
}

.related-grid,
.personal-link-grid {
  width: min(1280px, 100%);
  margin: 0 auto;
  display: grid;
  gap: 20px;
}

.related-grid {
  grid-template-columns: repeat(6, 1fr);
  margin-bottom: 20px;
}

.personal-link-grid {
  grid-template-columns: repeat(6, 1fr);
}

.related-grid a,
.personal-link-grid a {
  min-height: 80px;
  display: grid;
  place-items: center;
  padding: 16px;
  border-radius: 4px;
  background: #fff;
  font-weight: 800;
  text-align: center;
}

.site-footer {
  position: relative;
  padding-top: 60px;
  background: #fff;
}

.footer-inner {
  width: min(1200px, 100% - 80px);
  margin: 0 auto 56px;
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 80px;
}

.footer-brand .brand-text {
  font-size: 22px;
}

.sns-links {
  display: flex;
  gap: 10px;
  margin-top: 34px;
}

.sns-links a {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--blue);
  color: #fff;
  font-weight: 800;
}

.footer-nav {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 28px 38px;
  font-weight: 800;
}

.legal-nav {
  width: min(900px, 100% - 80px);
  margin: 0 auto 46px;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 24px 36px;
  color: var(--muted);
  font-size: 14px;
}

.page-top {
  position: absolute;
  right: 80px;
  bottom: 88px;
  width: 60px;
  height: 60px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-md);
  background: var(--blue);
  color: #fff;
  font-size: 24px;
  font-weight: 800;
}

.copyright {
  margin: 0;
  padding: 18px 24px;
  background: var(--blue);
  color: #fff;
  text-align: center;
  font-size: 14px;
}

@media (max-width: 768px) {
  .site-header {
    top: 776px;
    width: calc(100% - 20px);
    height: 70px;
    padding: 0 16px;
    border-radius: 10px;
  }
  .brand-mark {
    width: 34px;
    height: 26px;
  }
  .brand-text {
    font-size: 16px;
  }
  .hero {
    height: 760px;
    min-height: 760px;
    border-radius: 0 0 28px 0;
  }
  .hero-image {
    -o-object-position: 58% center;
       object-position: 58% center;
  }
  .brand-page-link {
    top: 24px;
    right: 16px;
    min-width: 0;
    height: 58px;
    padding: 12px 14px;
    font-size: 13px;
  }
  .fv-logo {
    top: 24px;
    left: 20px;
    width: 150px;
    height: 52px;
  }
  .fv-logo-symbol {
    left: 39.2px;
    top: 1.2px;
    width: 64px;
    height: 11.8px;
  }
  .fv-logo-mark {
    left: 104.1px;
    width: 6.6px;
    height: 13px;
  }
  .fv-logo-text {
    width: 150px;
    height: 31px;
  }
  .mini-mark {
    width: 34px;
    height: 26px;
  }
  .hero-menu {
    left: 24px;
    bottom: 176px;
    gap: 8px;
    font-size: 14px;
  }
  .hero-copy {
    right: 20px;
    bottom: 40px;
    width: calc(100% - 40px);
  }
  .hero-copy img:first-child {
    width: calc(100% - 44px);
  }
  .hero-copy-mark {
    width: 38px;
  }
  .section-pad,
  .pickup-slider {
    width: calc(100% - 32px);
    margin-top: 70px;
  }
  .section-pad {
    padding: 70px 0;
  }
  .section-heading {
    margin-bottom: 30px;
  }
  .section-heading h2 {
    font-size: 32px;
  }
  .section-heading p {
    font-size: 16px;
  }
  .pickup-visual {
    height: 280px;
  }
  .slider-control {
    gap: 14px;
  }
  .bar {
    width: 70px;
  }
  .important {
    padding: 40px 16px;
    gap: 24px;
  }
  .important-card {
    padding: 26px 22px 24px;
  }
  .important-heading {
    align-items: flex-start;
    flex-direction: column;
    gap: 10px;
  }
  .notice-row {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .notice-row time {
    border-right: 0;
    border-bottom: 1px solid var(--line);
    padding-bottom: 10px;
  }
  .news-layout {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .news-heading {
    display: block;
    margin-bottom: 30px;
  }
  .news-heading h2 {
    font-size: 32px;
    line-height: 1.25;
  }
  .news-heading p {
    margin-top: 12px;
    font-size: 16px;
  }
  .campaign-pickup {
    margin-top: 70px;
    padding-left: 16px;
  }
  .campaign-pickup-heading {
    display: block;
    margin-bottom: 30px;
  }
  .campaign-pickup-heading h2 {
    font-size: 32px;
    line-height: 1.25;
  }
  .campaign-pickup-heading p {
    margin-top: 12px;
    font-size: 16px;
  }
  .campaign-pickup-track {
    gap: 20px;
    padding-right: 16px;
  }
  .campaign-card {
    flex-basis: min(558px, 100vw - 48px);
    padding-bottom: 76px;
  }
  .campaign-card img {
    width: 100%;
    height: auto;
    aspect-ratio: 558/216;
  }
  .campaign-card span {
    width: calc(100% - 38px);
    font-size: 16px;
    line-height: 1.6;
  }
  .campaign-scroll {
    width: calc(100vw - 32px);
    margin-top: 36px;
  }
  .campaign-scroll span {
    width: 34%;
  }
  .news-tabs {
    display: flex;
    overflow-x: auto;
  }
  .news-tabs button {
    flex: 0 0 auto;
    padding: 0 18px;
  }
  .news-item {
    grid-template-columns: 1fr 24px;
    gap: 12px 16px;
    padding: 20px 0;
  }
  .news-item time {
    min-height: 0;
    border-right: 0;
  }
  .news-category,
  .news-title-text {
    grid-column: 1/2;
  }
  .news-item i {
    grid-column: 2;
    grid-row: 1/4;
    align-self: center;
  }
  .news-more {
    width: 100%;
    margin-top: 30px;
  }
  .vision-section {
    margin-top: 80px;
  }
  .au-shika-silhouette {
    top: 42px;
    right: 18px;
    width: 138px;
  }
  .vision-inner {
    width: calc(100% - 32px);
    padding: 64px 0 40px;
  }
  .vision-heading h2 {
    font-size: 32px;
    line-height: 1.25;
  }
  .vision-heading p {
    font-size: 16px;
  }
  .vision-family-frame {
    height: auto;
    aspect-ratio: 1200/420;
  }
  .vision-card-row {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .vision-plan-card,
  .vision-health-card {
    min-height: 142px;
  }
  .vision-plan-card span {
    font-size: 28px;
  }
  .vision-plan-card small {
    margin-top: -28px;
    font-size: 14px;
  }
  .vision-health-card {
    font-size: 28px;
  }
  .human-capital {
    min-height: 760px;
    padding: 56px 16px 0;
    border-radius: 0 28px 0 0;
  }
  .human-copy {
    max-width: none;
    width: 100%;
  }
  .human-copy img {
    width: min(420px, 100%);
  }
  .human-button {
    width: 100%;
    margin-top: 32px;
  }
  .human-bridge {
    position: relative;
    right: auto;
    top: auto;
    width: 100%;
    height: auto;
    margin: 40px 0 24px;
    aspect-ratio: 478/147;
  }
  .human-cellular-stroke {
    display: none;
  }
  .human-data {
    position: relative;
    right: auto;
    top: auto;
    width: 100%;
    padding: 28px 22px;
  }
  .human-data dt,
  .human-data dd {
    font-size: 15px;
  }
  .human-data strong {
    font-size: 24px;
  }
  .human-people {
    position: relative;
    width: calc(100% + 32px);
    height: auto;
    margin: 36px 0 0 -16px;
  }
  .image-link-card {
    height: 220px;
  }
  .image-link-card span {
    left: 22px;
    bottom: 22px;
    font-size: 24px;
  }
  .image-link-card i {
    right: 22px;
    bottom: 22px;
  }
  .services {
    padding-left: 16px;
  }
  .services .section-heading {
    width: calc(100vw - 32px);
  }
  .service-block h3 {
    font-size: 24px;
  }
  .personal-services,
  .corporate-services {
    gap: 16px;
    padding-right: 16px;
  }
  .logo-card {
    flex-basis: 170px;
    height: 120px;
  }
  .featured-logo {
    flex-basis: 190px;
  }
  .corp-card {
    flex-basis: 280px;
    height: 180px;
  }
  .history-panel {
    padding: 32px 24px;
  }
  .history-panel h2 {
    font-size: 32px;
  }
  .history-card {
    padding: 28px 22px;
  }
  .floating-arrow {
    top: 32px;
    right: 24px;
  }
  .media-card h2 {
    font-size: 26px;
  }
  .media-card p {
    font-size: 16px;
  }
  .media-visual {
    height: 210px;
  }
  .related-links {
    padding: 46px 16px;
  }
  .related-grid,
  .personal-link-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
  .footer-inner {
    width: calc(100% - 32px);
    grid-template-columns: 1fr;
    gap: 34px;
  }
  .footer-nav {
    justify-content: flex-start;
    gap: 18px 24px;
  }
  .legal-nav {
    width: calc(100% - 32px);
    justify-content: flex-start;
  }
  .sub-header {
    height: 80px;
    padding: 15px 20px;
    gap: 0;
    border-bottom: 1px solid var(--line);
  }
  .sub-logo {
    width: 140px;
    min-width: 140px;
  }
  .sub-header .sub-logo {
    height: 49px;
    background-size: 140px 49px;
  }
  .sub-logo-copy {
    margin-left: 26px;
    font-size: 10px;
  }
  .sub-logo-main {
    font-size: 22px;
  }
  .sub-logo-en {
    font-size: 6px;
  }
  .sub-nav {
    display: none;
  }
  .sub-actions {
    margin-left: auto;
    gap: 20px;
  }
  .sub-actions .sub-icon:first-child,
  .sub-lang {
    display: none;
  }
  .sub-actions::after {
    content: "";
    width: 35px;
    height: 35px;
    display: block;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: linear-gradient(var(--text), var(--text)) center 10px/15px 1px no-repeat, linear-gradient(var(--text), var(--text)) center 16px/15px 1px no-repeat, linear-gradient(var(--text), var(--text)) center 22px/15px 1px no-repeat, #fff;
  }
  .sub-footer {
    min-height: 620px;
    padding: 32px 20px 42px;
  }
  .sub-footer-inner {
    min-height: 0;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 22px;
  }
  .sub-footer-inner::after {
    right: auto;
    top: 141px;
    left: 50%;
    width: 63px;
    height: 9px;
    transform: translateX(-50%);
    background-image: url("/image/common/footer-line-sp.png");
  }
  .sub-footer-brand {
    position: static;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .sub-footer-brand .sub-logo {
    width: 180.6px;
    min-width: 180.6px;
    height: 63.21px;
    background-image: url("/image/common/footer-logo-sp.png");
    background-size: 180.6px 63.21px;
  }
  .sub-sns {
    width: 166px;
    height: 34px;
    margin-top: 22px;
    background-image: url("/image/common/footer-sns-sp.png");
  }
  .sub-footer-menu {
    position: static;
    width: 335px;
    margin-top: 31px;
    display: grid;
    grid-template-columns: repeat(2, 160px);
    justify-content: center;
    gap: 12px 15px;
    text-align: center;
    font-size: 14px;
    line-height: 24px;
  }
  .sub-legal {
    position: static;
    width: 280px;
    display: grid;
    justify-content: center;
    gap: 10px;
    text-align: center;
    font-size: 12px;
    line-height: 20px;
  }
  .-top {
    position: absolute;
    right: 20px;
    bottom: 82px;
    align-self: flex-end;
    width: 48px;
    height: 48px;
    margin-left: 0;
    border-width: 1.5px;
  }
  .-top::before {
    font-size: 20px;
  }
  .sub-copyright {
    left: 0;
    bottom: 0;
    width: 100%;
    height: 42px;
    margin: 0;
    padding: 12px 20px;
    font-size: 10px;
    line-height: 18px;
  }
  .page-top {
    right: 16px;
    bottom: 72px;
    width: 48px;
    height: 48px;
  }
}
@media (max-width: 1180px) {
  .global-nav,
  .header-actions {
    display: none;
  }
  .menu-button {
    display: block;
    margin-left: auto;
  }
  .drawer-nav {
    position: fixed;
    top: 96px;
    right: 20px;
    z-index: 30;
    width: min(320px, 100% - 40px);
    padding: 18px;
    display: none;
    grid-template-columns: 1fr;
    gap: 6px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: #fff;
    box-shadow: var(--shadow);
  }
  .drawer-nav.is-open {
    display: grid;
  }
  .drawer-nav a {
    padding: 14px;
    border-radius: 10px;
    font-weight: 800;
  }
  .feature-grid,
  .media-section,
  .important {
    grid-template-columns: 1fr;
  }
  .media-section {
    gap: 70px;
  }
  .related-grid,
  .personal-link-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 1240px) {
  .sub-header {
    height: 80px;
    padding: 15px 20px;
    align-items: center;
  }
  .sub-header .sub-logo {
    width: 140px;
    min-width: 140px;
    height: 49px;
    background-size: 140px 49px;
  }
  .sub-nav {
    display: none;
  }
  .sub-actions {
    margin-left: auto;
    gap: 20px;
    padding-top: 0;
  }
  .sub-actions .sub-icon:first-child,
  .sub-lang {
    display: none;
  }
  .sub-actions .sub-icon:nth-child(2) {
    margin-top: 0;
  }
  .sub-actions::after {
    content: "";
    width: 35px;
    height: 35px;
    display: block;
    border: 1px solid var(--line);
    border-radius: 4px;
    background: linear-gradient(var(--text), var(--text)) center 10px/15px 1px no-repeat, linear-gradient(var(--text), var(--text)) center 16px/15px 1px no-repeat, linear-gradient(var(--text), var(--text)) center 22px/15px 1px no-repeat, #fff;
  }
}/*# sourceMappingURL=common.css.map */