@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Buenard:wght@400..700&family=Noto+Sans+JP:wght@400..900&family=Zen+Old+Mincho:wght@400;500;600;700&display=swa");
@import url("https://cdn.jsdelivr.net/npm/yakuhanjp@4.1.1/dist/css/yakuhanmp.css");
@import url("lib/remodal.css");
@import url("lib/simplebar.min.css");
/* ------------------------------------------------
 vars
------------------------------------------------ */
:root {
  --font-base: "Noto Sans JP", sans-serif;
  --font-serif: YakuHanMP, "Zen Old Mincho", serif;
  --font-num: "Buenard", serif;
  --color-black: #303030;
  --color-gray: #A1A1A1;
  --color-gray2: #979797;
  --color-lgray: #F9F6F6;
  --color-red: #BC2238;
  --color-red-a05: rgba(188, 34, 56, 0.5);
  --color-pink: #FFF3F5;
  --color-pink-bg: rgba(255, 243, 245, 0.8);
  --color-blue: #006BAD;
  --color-green: #0A7900;
  --color-gray-bg: rgba(221, 221, 221, 0.15);
  --color-gray-a03: rgba(161, 161, 161, 0.3);
  --color-beige: #fffaee;
  --grade-blue: linear-gradient(0deg, rgba(0, 101, 164, 0.98) 0%, rgba(0, 127, 206, 0.98) 100%);
  --grade-lblue: linear-gradient(134deg, rgba(226, 250, 255, 0.70) 10.38%, rgba(199, 236, 245, 0.70) 82.2%);
  --grade-green: linear-gradient(125deg, rgba(239, 255, 186, 0.70) 12.05%, rgba(189, 238, 99, 0.70) 88.64%);
  --grade-green-blue: linear-gradient(180deg, #A3E97D 0%, #50D0FF 100%);
  --grade-gray: linear-gradient(180deg, #C5C3C3 -1.03%, #B8B8B8 106.82%);
  --grade-lgray: linear-gradient(157deg, #F4F4F4 3.62%, #DDD 98.03%);
  --grade-lgray-hover: linear-gradient(157deg, #E7E7E7 3.62%, #BDBDBD 98.03%);
  --grade-dgray: linear-gradient(0deg, #535460 0%, #646573 100%);
  --shadow-white: 0 0.4444444444em 1.1111111111em 0 rgba(14, 19, 33, 0.18);
  --shadow-black: 0 0.4444444444em 1.1111111111em 0 rgba(0, 0, 0, 0.4);
  --shadow-lgray: 0 0.4444444444em 1.1111111111em 0 #C1C2C7;
  --shadow-red: 0 0.4444444444em 1.1111111111em 0 #C9A2A2;
  --drop-shadow-white: drop-shadow(0 0.4444444444em 0.5555555556em rgba(14, 19, 33, 0.18));
  --drop-shadow-gray: drop-shadow(0 0.4444444444em 0.5555555556em #C1C2C7);
  --easeOutCubic: cubic-bezier(0.33, 1, 0.68, 1);
  --easeOutExpo: cubic-bezier(0.16, 1, 0.3, 1);
  --easeOutBack: cubic-bezier(0.34, 1.56, 0.64, 1);
}
@media screen and (max-width: 767px) {
  :root {
    --shadow-white: 0 0.4666666667em 0.9333333333em 0 rgba(14, 19, 33, 0.18);
    --shadow-black: 0 0.4666666667em 0.9333333333em 0 rgba(0, 0, 0, 0.4);
    --shadow-red: 0 0.4666666667em 0.9333333333em 0 #C9A2A2;
  }
}
:root {
  --nvw: 1vw;
}

/* ------------------------------------------------
  reset
------------------------------------------------ */
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strong, sub, var, b, u, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}

sup {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 60%;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, nav, section {
  display: block;
}

ol, ul {
  list-style: none;
}

caption, th {
  text-align: left;
  font-weight: 500;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
}

area {
  border: none;
  outline: none;
}

blockquote::before, blockquote::after,
q::before, q::after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

fieldset, img {
  border: 0;
  vertical-align: bottom;
}

/* ------------------------------------------------
 reeset
------------------------------------------------ */
button {
  font-family: inherit;
  font-size: 1em;
  border: none;
  cursor: pointer;
  font-feature-settings: "palt";
}

a {
  color: #000;
}
@media screen and (any-hover: hover) {
  a {
    transition: opacity 0.4s ease;
  }
  a:hover {
    opacity: 0.3;
  }
}

/* ------------------------------------------------
  common
------------------------------------------------ */
html {
  scroll-behavior: smooth;
}

body {
  color: #000;
  font-family: var(--font-base);
  line-height: 1.6;
  letter-spacing: 0.04em;
  background-color: #FFF;
  font-feature-settings: "palt";
}

.ff-mincho, .ff_h {
  font-family: var(--font-serif);
}

.ff_num {
  font-family: var(--font-num);
}

.h, .ff_h {
  font-weight: 500;
}

h1.breakn, h2.breakn, h3.breakn {
  word-break: normal;
}

img.liquid {
  width: 100%;
  height: auto;
}

.wb_auto {
  word-break: auto-phrase;
}

.note {
  font-size: 0.6666666667em;
}
.note li {
  text-indent: -1em;
  padding-left: 1em;
}
.note.num li {
  text-indent: -2em;
  padding-left: 2em;
}
.note.num2 li {
  text-indent: -1.8em;
  padding-left: 1.8em;
}
.note.bulet li {
  text-indent: -1.4em;
  padding-left: 1.4em;
}

@media screen and (min-width: 780.1px) {
  .sp_disp {
    display: none;
  }
}
@media screen and (max-width: 780px) {
  .pc_disp {
    display: none;
  }
  img {
    width: 100%;
    height: auto;
  }
  button {
    color: inherit;
  }
}
/* ------------------------------------------------
 font-size
------------------------------------------------ */
@media screen and (min-width: 1920.1px) {
  html {
    font-size: 0.9375vw;
  }
}
@media screen and (max-width: 1920px) {
  html {
    font-size: 18px;
  }
}
@media screen and (max-width: 780px) {
  html {
    font-size: 3.8461538462vw;
  }
}

/* ------------------------------------------------
 basic_btn
------------------------------------------------ */
button.basic_btn {
  cursor: pointer;
}

.basic_btn {
  font-size: 1em;
  text-decoration: none;
  border-radius: 100px;
  align-content: center;
  padding: 0;
  height: 5em;
  width: 20.5555555556em;
  display: inline-block;
  position: relative;
  overflow: hidden;
  box-sizing: border-box;
}
.basic_btn .txt {
  font-weight: bold;
  font-weight: 500;
  letter-spacing: 0.05em;
  display: inline-block;
  vertical-align: 0.2em;
}
.basic_btn > * {
  position: relative;
}
.basic_btn.disabled {
  filter: grayscale(100%);
  opacity: 0.4 !important;
  cursor: default;
}
@media screen and (any-hover: hover) {
  .basic_btn::before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0;
    transition: opacity 0.4s ease;
  }
  .basic_btn:hover {
    opacity: 1;
  }
}
.basic_btn.arrow {
  padding-right: 0.5555555556em;
}
.basic_btn.arrow::after {
  content: "";
  background: url(../images/common/arrow_bk.svg) 0 0/contain no-repeat;
  width: 0.4444444444em;
  aspect-ratio: 8/14;
  display: block;
  position: absolute;
  right: 1.1111111111em;
  top: 50%;
  transform: translateY(-50%);
}
.basic_btn.arrow.primary::after, .basic_btn.arrow.secondary::after, .basic_btn.arrow.third::after {
  background-image: url(../images/common/arrow_wh.svg);
}
@media screen and (max-width: 780px) {
  .basic_btn.arrow::after {
    width: 0.4666666667em;
  }
}
.basic_btn.icon::before {
  content: "";
  width: auto;
  height: auto;
  position: static;
}
.basic_btn.primary {
  text-align: center;
  background: linear-gradient(180deg, #CF344A 0%, #BE162E 100%);
  box-shadow: var(--shadow-red);
}
.basic_btn.primary .txt {
  color: #fff;
}
.basic_btn.primary::before {
  background-color: #000;
}
@media screen and (any-hover: hover) {
  .basic_btn.primary:hover::before {
    opacity: 0.2;
  }
}
.basic_btn.secondary {
  background: var(--grade-blue);
  box-shadow: var(--shadow-white);
}
.basic_btn.secondary .txt {
  color: #fff;
}
.basic_btn.secondary .txt b {
  color: #AEF0FF;
}
.basic_btn.secondary::before {
  background-color: #000;
}
@media screen and (any-hover: hover) {
  .basic_btn.secondary:hover::before {
    opacity: 0.3;
  }
}
.basic_btn.third {
  background: var(--grade-dgray);
  box-shadow: var(--shadow-white);
}
.basic_btn.third .txt {
  color: #fff;
}
.basic_btn.third .txt b {
  color: #AEF0FF;
}
.basic_btn.third::before {
  background-color: #000;
}
@media screen and (any-hover: hover) {
  .basic_btn.third:hover::before {
    opacity: 0.3;
  }
}
.basic_btn.fourth {
  background: var(--grade-lgray);
  box-shadow: var(--shadow-lgray);
}
.basic_btn.fourth::before {
  background: var(--grade-lgray-hover);
  opacity: 0;
}
@media screen and (any-hover: hover) {
  .basic_btn.fourth:hover::before {
    opacity: 1;
  }
}
.basic_btn.fifth {
  background-color: #fff;
  box-shadow: var(--shadow-white);
}
@media screen and (any-hover: hover) {
  .basic_btn.fifth {
    transition: background-color 0.4s ease;
  }
  .basic_btn.fifth:hover {
    background-color: var(--color-lgray);
  }
}
@media screen and (max-width: 780px) {
  .basic_btn {
    width: 21.3333333333em;
    height: 4.3333333333em;
  }
  .basic_btn.arrow {
    padding-right: 0;
  }
}

/* ----------------------------
 basic_btn.download
------------------------------*/
.basic_btn.download {
  color: #000;
  border-radius: 6px;
  border: 1px solid var(--color-gray);
  background-color: #fff;
  padding: 0.5555555556em 1em;
  height: auto;
  display: flex;
  justify-content: space-between;
  -moz-column-gap: 0.5555555556em;
       column-gap: 0.5555555556em;
  align-items: center;
  width: 100%;
}
.basic_btn.download .txt {
  font-size: 0.7777777778em;
  line-height: 1.3;
  margin-right: auto;
}
.basic_btn.download::before {
  opacity: 1;
  display: block;
}
.basic_btn.download.arrow::after {
  width: 0.3333333333em;
  right: 0.6666666667em;
}
.basic_btn.download.l {
  width: 17.7777777778em;
  min-height: 4.8888888889em;
  -moz-column-gap: 0.8888888889em;
       column-gap: 0.8888888889em;
}
.basic_btn.download.l .txt {
  font-size: 1em;
}
.basic_btn.download.l.arrow::after {
  width: 0.4444444444em;
  right: 0.8888888889em;
}
@media screen and (any-hover: hover) {
  .basic_btn.download {
    transition: background-color 0.4s ease;
  }
  .basic_btn.download:hover {
    background-color: #ececec;
  }
  .basic_btn.download.disabled:hover {
    background-color: #fff;
  }
}
.basic_btn.download[class*=file_]::before {
  content: "";
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  width: 1.1111111111em;
  aspect-ratio: 5/6;
  display: block;
  position: static;
}
.basic_btn.download.file_pdf {
  font-size: 1em;
}
.basic_btn.download.file_pdf::before {
  background-image: url(../images/common/icon_pdf.svg);
}
.basic_btn.download.file_pdf.l::before {
  width: 1.6666666667em;
}
.basic_btn.download.file_word::before {
  background-image: url(../images/common/icon_word.svg);
}
.basic_btn.download.file_excel::before {
  background-image: url(../images/common/icon_excel.svg);
}
@media screen and (max-width: 780px) {
  .basic_btn.download {
    padding: 0.6666666667em 1.3333333333em;
  }
  .basic_btn.download.arrow::after {
    width: 0.4666666667em;
    right: 0.8em;
  }
  .basic_btn.download .txt {
    font-size: 0.8em;
  }
}

/* ------------------------------------------------
 float_btn
------------------------------------------------ */
@media screen and (min-width: 780.1px) {
  #float_btn {
    display: none;
  }
}
@media screen and (max-width: 780px) {
  #float_btn {
    width: 100%;
    text-align: center;
    position: fixed;
    left: 0;
    bottom: 1em;
    z-index: 10;
    opacity: 1;
    visibility: visible;
    transform: translateY(0%);
    transition: all 0.4s ease;
  }
  #float_btn .basic_btn {
    margin: 0 auto;
    box-shadow: var(--shadow-black);
  }
  #float_btn .basic_btn .txt {
    font-size: 1.0666666667em;
  }
  #float_btn .basic_btn::after {
    right: 1.3333333333em;
  }
  #float_btn.hide {
    opacity: 0;
    visibility: hidden;
    transform: translateY(100%);
  }
}

/* ------------------------------------------------
 simplebar
------------------------------------------------ */
@media screen and (max-width: 780px) {
  .section .scroll[data-simplebar] {
    margin-left: -1.3333333333em !important;
    margin-right: -1.3333333333em !important;
  }
  .section .scroll[data-simplebar] .scroll_inner {
    padding-left: 1.3333333333em !important;
    padding-right: 1.3333333333em !important;
    width: -moz-fit-content;
    width: fit-content;
  }
  .section .scroll[data-simplebar] .simplebar-horizontal,
  .section .scroll[data-simplebar] .simplebar-scrollbar {
    position: static;
    overflow: visible;
  }
  .section .scroll[data-simplebar] .simplebar-horizontal {
    margin: 1.6666666667em 1.3333333333em 0;
    background-color: var(--color-gray);
    height: 1px;
    position: relative;
  }
  .section .scroll[data-simplebar] .simplebar-scrollbar {
    background-color: var(--color-gray);
    border-radius: 0.8333333333em;
    height: 0.3888888889em;
    position: relative;
    top: -0.1666666667em;
    display: block;
    opacity: 0.3;
    transition: width 0.6s ease;
  }
}

/* ------------------------------------------------
 navi
------------------------------------------------ */
#navi {
  padding-top: 6.6666666667em;
  padding-bottom: 1.6666666667em;
  width: 21.1111111111em;
  max-height: 100vh;
  position: fixed;
  right: 0;
  top: 0;
  z-index: 20;
  scrollbar-width: none;
  box-sizing: border-box;
  overscroll-behavior-y: contain;
  overflow-y: auto;
  overflow-x: clip;
  transition: all 0.4s var(--easeOutExpo);
  transform: translateX(117%);
  pointer-events: none;
}
#navi::-webkit-scrollbar {
  display: none;
}
#navi > .inner {
  margin-left: auto;
  width: 17.7777777778em;
  pointer-events: all;
}
#navi .logo {
  display: none;
}
#navi .menu,
#navi .links {
  border-radius: 2.2222222222em 0 0 2.2222222222em;
  filter: var(--drop-shadow-white);
}
#navi .entry {
  margin-top: 1.1111111111em;
}
#navi .entry .basic_btn {
  text-align: center;
  padding-left: 0;
  padding-right: 0.2222222222em;
  width: 100%;
}
@media screen and (min-width: 780.1px) {
  #navi .entry .basic_btn {
    height: 3.3333333333em;
  }
}
#navi .entry .basic_btn {
  box-shadow: var(--shadow-black);
}
#navi .entry .basic_btn .txt {
  font-size: 0.8888888889em;
}
#navi .links {
  background-color: #fff;
  margin-top: 0.5555555556em;
  padding: 0.8333333333em 2.7777777778em;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 18px;
}
#navi .links a {
  display: block;
  align-content: center;
}
#navi .links a img {
  width: 100%;
  height: auto;
}
#navi .links a:first-child {
  width: 10.6666666667em;
}
#navi .links a:last-child {
  width: 7.3333333333em;
}
@media screen and (max-width: 1440px) {
  #navi {
    top: 0 !important;
  }
}
@media screen and (max-width: 780px) {
  #navi {
    padding-top: 2em;
    padding-bottom: 2em;
    width: 100vw;
    pointer-events: all;
  }
  #navi > .inner {
    width: 22em;
  }
  #navi .menu,
  #navi .links {
    border-radius: 2em 0 0 2em;
  }
  #navi .entry {
    margin-top: 1.6666666667em;
  }
  #navi .entry .basic_btn .txt {
    font-size: 1.0666666667em;
  }
  #navi .links {
    margin-top: 0.6666666667em;
    padding: 1em 3.3333333333em;
    width: 100%;
  }
  #navi .links a:first-child {
    width: 12.8em;
  }
  #navi .links a:last-child {
    width: 8.8em;
  }
}

#btn_menu_close {
  border-radius: 1.1111111111em 0 0 1.1111111111em;
  background: rgba(100, 101, 115, 0.98);
  width: 2.2222222222em;
  height: auto;
  aspect-ratio: 4/5;
  display: block;
  position: absolute;
  right: 17.7777777778em;
  top: 2.2222222222em;
}
#btn_menu_close .txt {
  background: url(../images/common/icon_close.svg) 0 0/contain no-repeat;
  background-size: contain;
  margin-left: 1em;
  width: 0.7777777778em;
  aspect-ratio: 1/1;
  display: block;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
#btn_menu_close::before {
  content: none;
}
@media screen and (any-hover: hover) {
  #btn_menu_close::before {
    transition: opacity 0.4s ease;
  }
  #btn_menu_close:hover::before {
    opacity: 0.3;
  }
}
@media screen and (max-width: 780px) {
  #btn_menu_close {
    border-radius: 1.4666666667em 0 0 1.4666666667em;
    width: 2.6666666667em;
    right: 22em;
    top: 2em;
  }
  #btn_menu_close .txt {
    font-size: 1em;
    width: 0.9333333333em;
    margin-left: 1.2em;
  }
  #btn_menu_close::before {
    content: "";
    width: 4em;
    height: max(100dvh, 48.0666666667em);
    position: fixed;
    right: 100%;
    top: 0;
  }
}

.overlay {
  background: rgba(0, 0, 255, 0.2);
  background-color: transparent;
  width: 100vw;
  height: 100vh;
  position: fixed;
  left: 100%;
  top: 0;
  z-index: 2;
}

/* ----------------------------
 navu show
------------------------------*/
#navi:not(.show).absolute {
  position: absolute;
}
#navi.show {
  transform: translateX(0%);
  opacity: 1;
}
#navi.show + #btn_menu {
  transform: translateX(100%);
  transition-delay: 0;
}
#navi.show + #btn_menu + #menu_overlay {
  left: 0;
}

/* ----------------------------
 メニュー展開中背面ロック
------------------------------*/
/* ----------------------------
 navi > menu
------------------------------*/
#navi .menu {
  background: linear-gradient(0deg, rgba(83, 84, 96, 0.98) 0%, rgba(100, 101, 115, 0.98) 100%);
  padding: 1.6666666667em 1.9444444444em 1.9444444444em;
  position: relative;
}
#navi .menu ul {
  display: flex;
  flex-direction: column;
}
#navi .menu .list {
  line-height: 1.5;
  margin: 0 0.2222222222em;
  row-gap: 0.7777777778em;
}
#navi .menu .list a {
  color: #fff;
  text-decoration: none;
  opacity: 1 !important;
}
#navi .menu .list a.current .txt {
  opacity: 0.3;
}
@media screen and (any-hover: hover) {
  #navi .menu .list a > .txt {
    transition: opacity 0.4s ease;
  }
  #navi .menu .list a:hover > .txt {
    opacity: 0.3;
  }
}
#navi .menu .list > li.home {
  display: none;
}
#navi .menu .list > li.qa {
  display: none;
}
#navi .menu .list > li > a {
  display: flex;
  align-items: center;
}
#navi .menu .list > li > a::before {
  content: "";
  border-radius: 0.1666666667em;
  background-color: #D4E978;
  margin-top: 0.4em;
  margin-right: 0.5555555556em;
  width: 0.7777777778em;
  height: 0.7777777778em;
  transform: rotate(45deg);
  display: block;
  align-self: start;
}
#navi .menu .list > li > a::after {
  content: "";
  background: url(../images/common/arrow_wh.svg) no-repeat;
  background-size: contain;
  margin-left: auto;
  width: 0.3888888889em;
  aspect-ratio: 7/12;
}
#navi .menu .list > li > a .txt {
  margin-right: 1em;
  flex: 1;
}
#navi .menu .list > li:nth-child(even) a::before {
  background-color: #C1EAF3;
}
#navi .menu .list .s {
  line-height: 1.8;
  margin-top: 0.3333333333em;
  margin-left: 1.7777777778em;
}
#navi .menu .list .s a {
  font-size: 0.7777777778em;
  display: flex;
  -moz-column-gap: 0.7142857143em;
       column-gap: 0.7142857143em;
  align-items: center;
}
#navi .menu .list .s a::before {
  content: "";
  border-top-width: 1px;
  border-top-style: solid;
  width: 0.4285714286em;
  display: block;
}
@media screen and (max-width: 780px) {
  #navi .menu {
    padding: 2.6666666667em 2em;
  }
  #navi .menu .list {
    margin: 0;
    row-gap: 0.9333333333em;
  }
  #navi .menu .list > li > a {
    display: flex;
    align-items: center;
  }
  #navi .menu .list > li > a::before {
    border-radius: 0.2em;
    margin-right: 0.8em;
    margin-top: 0.6em;
    width: 0.9333333333em;
    height: 0.9333333333em;
  }
  #navi .menu .list > li > a::after {
    width: 0.4em;
  }
  #navi .menu .list > li > a > .txt {
    font-size: 1.3333333333em;
  }
  #navi .menu .list .s {
    margin-top: 0.4666666667em;
    margin-left: 2.5333333333em;
  }
  #navi .menu .list .s li + li {
    margin-top: 0.1333333333em;
  }
  #navi .menu .list .s a {
    font-size: 1.0666666667em;
    -moz-column-gap: 0.75em;
         column-gap: 0.75em;
  }
  #navi .menu .list .s a::before {
    width: 0.375em;
  }
}

/* ----------------------------
 btn_menu
------------------------------*/
#btn_menu {
  font-size: 1em;
  border: none;
  border-radius: 2.2222222222em 0 0 2.2222222222em;
  padding: 0;
  width: 6.6666666667em;
  height: auto;
  aspect-ratio: 1/1;
  position: fixed;
  right: 0;
  top: 6.6666666667em;
  cursor: pointer;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  z-index: 10;
  transition: transform 0.2s ease;
  transition-delay: 0.1s;
  transform: translateX(0);
}
#btn_menu::after {
  content: "";
  background: transparent url(../images/common/btn_menu.svg) 50% 50% no-repeat;
  background-size: 2.1111111111em auto;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}
@media screen and (max-width: 780px) {
  #btn_menu {
    border-radius: 1.4666666667em 0 0 1.4666666667em;
    width: 4.6666666667em;
    top: 2em;
  }
  #btn_menu::after {
    background-size: 1.6em auto;
  }
}

/* ------------------------------------------------
 footer common
------------------------------------------------ */
#aside {
  margin-top: 8.3333333333em;
}
@media screen and (max-width: 780px) {
  #aside {
    margin-top: 6.6666666667em;
  }
}

@media screen and (min-width: 780.1px) {
  #aside .section > .inner {
    margin-left: auto;
    margin-right: auto;
    width: 68.8888888889em;
    box-sizing: border-box;
  }
}
@media screen and (max-width: 780px) {
  #aside .section > .inner {
    padding-left: 1.3333333333em;
    padding-right: 1.3333333333em;
  }
}

/* ------------------------------------------------
 font-size
------------------------------------------------ */
@media screen and (min-width: 780.1px) and (max-width: 1255.9px) {
  #aside, #footer {
    font-size: 1.4332351302vw;
  }
}

/* ------------------------------------------------
 banner_check
------------------------------------------------ */
#banner_check {
  margin-top: 8.3333333333em;
}
#banner_check a {
  margin: 0 auto;
  width: 55.5555555556em;
  display: block;
  overflow: hidden;
}
#banner_check a img {
  max-width: 100%;
}
@media screen and (max-width: 780px) {
  #banner_check {
    margin-top: 6.6666666667em;
  }
  #banner_check a {
    width: 23.3333333333em;
  }
}

/* ------------------------------------------------
 bottom_entry
------------------------------------------------ */
#bottom_entry {
  background: linear-gradient(276deg, #F2F2F2 0%, #F8F8F8 100%);
  margin-top: 8.3333333333em;
}
#bottom_entry > .inner {
  padding-top: 4.4444444444em;
  padding-bottom: 4.4444444444em;
}
#bottom_entry .frame {
  text-align: center;
  position: relative;
}
#bottom_entry .frame::before, #bottom_entry .frame::after {
  content: "";
  border-left: 1px solid #000;
  border-right: 1px solid #000;
  width: calc(100% - 1.3333333333em);
  height: 3.6666666667em;
  box-sizing: border-box;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  pointer-events: none;
}
#bottom_entry .frame::before {
  top: 0;
}
#bottom_entry .frame::after {
  bottom: 0;
}
#bottom_entry .frame_inner {
  padding-top: 3.3333333333em;
  padding-bottom: 4.4444444444em;
  position: relative;
}
#bottom_entry .frame_inner::before, #bottom_entry .frame_inner::after {
  content: "";
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  width: 5em;
  height: calc(100% - 0.8888888889em);
  box-sizing: border-box;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
}
#bottom_entry .frame_inner::before {
  left: 0;
}
#bottom_entry .frame_inner::after {
  right: 0;
}
#bottom_entry .heading {
  font-size: 2.6666666667em;
  font-weight: 500;
}
#bottom_entry .important {
  border-radius: 0.3333333333em;
  background-color: #FFF3F5;
  background-color: #fff;
  margin-top: 2.2222222222em;
  padding: 2.2222222222em 2.7777777778em;
}
#bottom_entry .important > * + * {
  margin-top: 0.5555555556em;
}
#bottom_entry .important .heading {
  font-size: 1.1111111111em;
}
#bottom_entry .important .heading b {
  color: var(--color-red);
  font-weight: bold;
}
#bottom_entry .important .links {
  margin-left: 1.3888888889em;
}
#bottom_entry .important .links li + li {
  margin-top: 0.2222222222em;
}
#bottom_entry .important .links li a {
  color: var(--color-blue);
  width: -moz-fit-content;
  width: fit-content;
  display: inline-flex;
  align-items: center;
}
#bottom_entry .important .links li a::before {
  content: "";
  border-radius: 0.1666666667em;
  background-color: var(--color-blue);
  margin-right: 0.5555555556em;
  width: 0.7777777778em;
  height: 0.7777777778em;
  transform: rotate(45deg);
  display: block;
}
#bottom_entry .important .links + .note {
  margin-top: 1.4285714286em;
}
#bottom_entry .note {
  font-size: 0.7777777778em;
  margin-top: 2.1428571429em;
}
@media screen and (max-width: 780px) {
  #bottom_entry {
    margin-top: 6.6666666667em;
  }
  #bottom_entry > .inner {
    padding: 1.3333333333em 0.6666666667em !important;
  }
  #bottom_entry .frame::before, #bottom_entry .frame::after {
    width: calc(100% - 0.9333333333em);
    height: 2.4666666667em;
  }
  #bottom_entry .frame_inner {
    padding-top: 4.6666666667em;
    padding-bottom: 5.3333333333em;
  }
  #bottom_entry .frame_inner::before, #bottom_entry .frame_inner::after {
    width: 3.3333333333em;
    height: calc(100% - 0.6666666667em);
  }
  #bottom_entry .heading {
    font-size: 2em;
    font-weight: bold;
    letter-spacing: 0.05em;
  }
  #bottom_entry .important {
    margin-top: 2em;
    padding: 1.3333333333em 1.6666666667em;
  }
  #bottom_entry .note {
    font-size: 0.8em;
    margin: 0.8333333333em 0.8333333333em 0;
  }
}

/* ------------------------------------------------
 contact
------------------------------------------------ */
#contact {
  color: #fff;
  background: var(--grade-dgray);
  position: relative;
  overflow: hidden;
}
#contact::before {
  content: "";
  border-radius: 17.8666666667em;
  border: 3em solid rgba(104, 104, 120, 0.8);
  width: 55em;
  aspect-ratio: 3/2;
  transform: rotate(-45deg);
  transform-origin: 100% 0;
  position: absolute;
  right: calc(50% + 40em);
  top: 1.3888888889em;
  box-sizing: border-box;
}
#contact > .inner {
  padding: 6.6666666667em 4.7222222222em;
  position: relative;
}
#contact a {
  color: #fff;
}
#contact .logo {
  width: 29.4444444444em;
}
#contact .txt .title {
  font-size: 2.6666666667em;
}
#contact .txt .name {
  font-weight: bold;
  margin-top: 1.6666666667em;
}
#contact .txt .address {
  font-size: 0.7777777778em;
  margin-top: 1.1428571429em;
}
#contact .txt .contact {
  border-top: 1px solid rgba(255, 255, 255, 0.5);
  margin-top: 1.6666666667em;
  padding-top: 1.6666666667em;
}
#contact .txt .contact .tel {
  font-size: 1.6666666667em;
  text-decoration: none;
}
#contact .txt .contact .time {
  font-size: 0.6666666667em;
}
#contact .txt .contact .time b {
  font-size: 1.5em;
}
@media screen and (min-width: 780.1px) {
  #contact > .inner {
    display: flex;
    align-items: center;
    -moz-column-gap: 4.7222222222em;
         column-gap: 4.7222222222em;
  }
  #contact > .inner .txt {
    flex: 1;
  }
}
@media screen and (max-width: 780px) {
  #contact::before {
    border-radius: 14.9333333333em;
    right: 100%;
    top: 7.7777777778em;
  }
  #contact > .inner {
    padding-top: 4.6666666667em;
    padding-bottom: 4em;
  }
  #contact .logo {
    width: 23.3333333333em;
  }
  #contact .txt {
    margin-top: 4em;
  }
  #contact .txt .title {
    font-size: 2em;
  }
  #contact .txt .address {
    font-size: 0.8em;
    margin-top: 1em;
  }
  #contact .txt .contact {
    margin-top: 2em;
    padding-top: 1em;
  }
  #contact .txt .contact .tel {
    font-size: 2em;
  }
}

/* ------------------------------------------------
 banners
------------------------------------------------ */
#banners {
  background-color: #5C5D6C;
}
#banners > .inner {
  padding: 3.3333333333em 0;
}
#banners .list {
  display: grid;
  grid-template-columns: repeat(4, 10.5555555556em);
  justify-content: center;
  gap: 0.8888888889em 1.1111111111em;
}
#banners .list li {
  background-color: #fff;
}
#banners .list a {
  display: block;
}
@media screen and (max-width: 780px) {
  #banners > .inner {
    padding-top: 2.6666666667em;
    padding-bottom: 2.6666666667em;
  }
  #banners .list {
    grid-template-columns: repeat(2, 11.3333333333em);
    gap: 0.6666666667em;
  }
}

/* ------------------------------------------------
 footer
------------------------------------------------ */
#footer {
  background-color: #fff;
}
#footer > .inner {
  line-height: 1.4;
  padding: 0.8888888889em 1.6666666667em;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#footer a, #footer .copy {
  font-size: 0.5555555556em;
  display: block;
  text-decoration: none;
}
#footer .list {
  display: flex;
}
#footer .list li + li {
  border-left: 1px solid #a1a1a1;
  margin-left: 1.6666666667em;
  padding-left: 1.6666666667em;
}
@media screen and (max-width: 780px) {
  #footer > .inner {
    text-align: center;
    padding: 1.0666666667em 0;
    flex-direction: column;
    row-gap: 0.6666666667em;
  }
  #footer a, #footer .copy {
    font-size: 0.6666666667em;
  }
  #footer .copy {
    letter-spacing: normal;
  }
  #footer .list li + li {
    margin-left: 0.8333333333em;
    padding-left: 0.8333333333em;
  }
}

/* ------------------------------------------------
 wrapper coverimage
------------------------------------------------ */
#wrapper {
  position: relative;
  overflow: hidden;
}
#wrapper .background {
  position: absolute;
  z-index: -1;
}
#wrapper .background.illust {
  background: transparent no-repeat;
  background-size: contain;
  display: block;
  position: absolute;
}
#wrapper .background.illust.r {
  background-image: url(../images/coverimage/r_blank.webp);
  width: max((100% - 1600px) / 320px * 268px + 874px, 48.5555555556em);
  aspect-ratio: 1142/1242;
  left: calc(50% + 260px);
  top: -9.7222222222em;
}
@media screen and (min-width: 1600px) {
  #wrapper .background.illust {
    top: -11.6666666667em;
  }
  #wrapper .background.illust.r1 {
    background-image: url(../images/coverimage/r_1.webp?2);
  }
  #wrapper .background.illust.r2 {
    background-image: url(../images/coverimage/r_2.webp?2);
  }
  #wrapper .background.illust.r3 {
    background-image: url(../images/coverimage/r_3.webp?2);
  }
  #wrapper .background.illust.r4 {
    background-image: url(../images/coverimage/r_4.webp?2);
  }
  #wrapper .background.illust.r5 {
    background-image: url(../images/coverimage/r_5.webp?2);
  }
  #wrapper .background.illust.r6 {
    background-image: url(../images/coverimage/r_6.webp?2);
  }
  #wrapper .background.illust.r7 {
    background-image: url(../images/coverimage/r_7.webp?2);
  }
}
@media screen and (min-width: 1920.1px) {
  #wrapper .background.illust.r {
    width: 63.4444444444em;
    left: calc(50% + 14.4444444444em);
  }
}
@media screen and (min-width: 780.1px) {
  #wrapper .background.block {
    border-radius: 38.8888888889em;
    background: linear-gradient(59deg, #F8F8F8 9.97%, #F2F2F2 84.36%);
    width: 116.1111111111em;
    aspect-ratio: 65/85;
    left: calc(50% - 58.3333333333em);
    transform: rotate(-45deg);
    transform-origin: top left;
  }
}
@media screen and (max-width: 780px) {
  #wrapper .background.illust.r {
    background-image: url(../images/coverimage/r_blank-sp.webp);
    width: 31.2em;
    aspect-ratio: 520/200;
    left: -3.3333333333em;
    top: -4.4em;
  }
  #wrapper .background.illust.r.top, #wrapper .background.illust.r.r1 {
    background-image: url(../images/coverimage/r_1-sp.webp?2);
  }
  #wrapper .background.illust.r.r2 {
    background-image: url(../images/coverimage/r_2-sp.webp?2);
  }
  #wrapper .background.illust.r.r3 {
    background-image: url(../images/coverimage/r_3-sp.webp?2);
  }
  #wrapper .background.illust.r.r4 {
    background-image: url(../images/coverimage/r_4-sp.webp?2);
  }
  #wrapper .background.illust.r.r5 {
    background-image: url(../images/coverimage/r_5-sp.webp?2);
  }
  #wrapper .background.illust.r.r6 {
    background-image: url(../images/coverimage/r_6-sp.webp?2);
  }
  #wrapper .background.illust.r.r7 {
    background-image: url(../images/coverimage/r_7-sp.webp?2);
  }
  #wrapper .background.illust.r.blank {
    background-image: url(../images/coverimage/r_blank2-sp.webp);
    width: 28.6666666667em;
    aspect-ratio: 430/392;
    left: 12.9333333333em;
    top: -6em;
  }
  #wrapper .background.block {
    display: none;
  }
}

/* ------------------------------------------------
 section 本文
------------------------------------------------ */
.section.basic_style {
  margin-top: 8.3333333333em;
}
.section.basic_style .sheader .title {
  font-size: 2.6666666667em;
}
.section.basic_style .sheader .note {
  font-size: 0.6666666667em;
  margin-top: 0.8333333333em;
}
.section.basic_style .sheader.center {
  text-align: center;
}
.section.basic_style .sheader.h_marker {
  position: relative;
}
.section.basic_style .sheader.h_marker::before {
  background-color: #F8F8F8;
  left: -4.1666666667em;
  top: -4.7777777778em;
}
.section.basic_style .sheader.h_marker.center::before {
  content: "";
  left: 50%;
  top: -4.4444444444em;
  transform: translateX(-50%);
}
.section.basic_style .sbody {
  margin-top: 3.3333333333em;
}
.section.basic_style .sbody b {
  color: var(--color-red);
  font-weight: inherit;
}
.section.basic_style .sbody a:not(.basic_btn) {
  color: var(--color-blue);
}
.section.basic_style .sbody .center {
  text-align: center;
}
.section.basic_style .sbody .lead {
  line-height: 2;
}
.section.basic_style .sbody .scroll + .note {
  margin-top: 1.6666666667em;
}
@media screen and (min-width: 780.1px) {
  .section.basic_style .pc_center {
    text-align: center;
  }
}
@media screen and (max-width: 780px) {
  .section.basic_style {
    margin-top: 6.6666666667em;
  }
  .section.basic_style > .inner {
    margin-left: 1.3333333333em;
    margin-right: 1.3333333333em;
  }
  .section.basic_style .sheader .title {
    font-size: 2em;
    padding: 0 0.3333333333em;
  }
  .section.basic_style .sheader .note {
    font-size: 0.8em;
    margin-top: 0.8333333333em;
  }
  .section.basic_style .sheader.h_marker::before {
    left: -4em;
    top: -3.7333333333em;
  }
  .section.basic_style .sheader.h_marker.center::before {
    top: -4em;
  }
  .section.basic_style .sbody {
    margin-top: 2em;
  }
  .section.basic_style .sbody b {
    color: var(--color-red);
    font-weight: inherit;
  }
  .section.basic_style .sbody .scroll + .note {
    margin-top: 1.6666666667em;
  }
}

/* ------------------------------------------------
 装飾
------------------------------------------------ */
.section .h_marker {
  position: relative;
}
.section .h_marker::before {
  content: "";
  background-color: #F8F8F8;
  -webkit-mask: url(../images/common/heading_marker.svg) 0 0/contain no-repeat;
          mask: url(../images/common/heading_marker.svg) 0 0/contain no-repeat;
  width: 14.3333333333em;
  aspect-ratio: 1/1;
  position: absolute;
  z-index: -1;
}
@media screen and (max-width: 780px) {
  .section .h_marker::before {
    width: 13.6em;
  }
}

/* ----------------------------
 banzai
------------------------------*/
.entry_content .banzai, .requirement_block .banzai {
  display: flex;
  align-items: center;
  justify-content: center;
  -moz-column-gap: 0.8333333333em;
       column-gap: 0.8333333333em;
}
.entry_content .banzai::before, .entry_content .banzai::after, .requirement_block .banzai::before, .requirement_block .banzai::after {
  content: "";
  background-color: #000;
  width: 1px;
  height: 1.3333333333em;
  display: block;
  align-self: flex-end;
}
.entry_content .banzai::before, .requirement_block .banzai::before {
  transform: rotate(-20deg);
}
.entry_content .banzai::after, .requirement_block .banzai::after {
  transform: rotate(20deg);
}
.entry_content .banzai .txt, .requirement_block .banzai .txt {
  font-size: 1.1111111111em;
  font-weight: bold;
}
.entry_content .banzai .txt b, .requirement_block .banzai .txt b {
  color: var(--color-red);
}
@media screen and (max-width: 780px) {
  .entry_content .banzai, .requirement_block .banzai {
    -moz-column-gap: 0.5333333333em;
         column-gap: 0.5333333333em;
  }
  .entry_content .banzai::before, .entry_content .banzai::after, .requirement_block .banzai::before, .requirement_block .banzai::after {
    height: 1.6em;
  }
  .entry_content .banzai .txt, .requirement_block .banzai .txt {
    font-size: 1.0666666667em;
    letter-spacing: normal;
  }
}

/* ------------------------------------------------
 entryパーツ
------------------------------------------------ */
.entry_content {
  text-align: center;
}
.entry_content .banzai {
  margin-top: 2.7777777778em;
}
.entry_content .btns {
  margin-top: 0.6666666667em;
  display: flex;
  justify-content: center;
  -moz-column-gap: 1.1111111111em;
       column-gap: 1.1111111111em;
}
.entry_content .btns .basic_btn {
  display: block;
}
.entry_content .btns .basic_btn .txt {
  font-size: 1.1111111111em;
}
.entry_content .btns .basic_btn:last-child {
  width: 15.5555555556em;
}
@media screen and (max-width: 780px) {
  .entry_content .banzai {
    margin-top: 2.6666666667em;
  }
  .entry_content .btns {
    margin-top: 0.6666666667em;
    flex-direction: column;
    align-items: center;
    row-gap: 1em;
  }
  .entry_content .btns .basic_btn .txt {
    font-size: 1.0666666667em;
  }
  .entry_content .btns .basic_btn:last-child {
    width: 16em;
  }
}

/* ------------------------------------------------
 slider
------------------------------------------------ */
/* ----------------------------
 slider 遷移エフェクト
------------------------------*/
.slider.clip.swiper-initialized .swiper-slide {
  transition: all 0.8s ease;
  transform-origin: left center;
  opacity: 0;
}
.slider.clip.swiper-initialized .swiper-slide-prev {
  opacity: 0;
  transform: translate3D(100%, 0, 0) scale(0.9) !important;
}
.slider.clip.swiper-initialized .swiper-slide-active, .slider.clip.swiper-initialized .swiper-slide-next, .slider.clip.swiper-initialized .swiper-slide-next ~ li {
  opacity: 1;
}

/* ----------------------------
 scrollbar
------------------------------*/
.slider + .scrollbar {
  background-color: var(--color-gray);
  width: 100%;
  height: 1px;
  position: relative;
}
.slider + .scrollbar .drag {
  background-color: var(--color-gray);
  border-radius: 0.8333333333em;
  width: 33.3333%;
  height: 0.3888888889em;
  position: relative;
  top: -0.1666666667em;
  display: block;
  opacity: 0.3;
  transition: width 0.6s ease;
}

/* ------------------------------------------------
 remodal common
------------------------------------------------ */
.remodal-overlay {
  background: rgba(0, 0, 0, 0.8);
}
.remodal-overlay.remodal-is-opening, .remodal-overlay.remodal-is-closing {
  animation-duration: 0.3s;
  animation-fill-mode: forwards;
}
.remodal-overlay.remodal-is-opening {
  animation-name: remodal-overlay-opening-keyframes;
}
.remodal-overlay.remodal-is-closing {
  animation-name: remodal-overlay-closing-keyframes;
}

body:has(.remodal-is-opened) {
  overflow: hidden;
}

/* Default theme styles of the wrapper */
.remodal-wrapper {
  scrollbar-width: none;
  box-sizing: border-box;
  overscroll-behavior-y: contain;
  overflow-y: auto;
  overflow-x: clip;
}
/* Default theme styles of the modal dialog */
.remodal {
  overscroll-behavior-y: contain;
}
.remodal.remodal-is-opening, .remodal.remodal-is-closing {
  animation-duration: 0.3s;
  animation-fill-mode: forwards;
}
.remodal.remodal-is-opening {
  animation-name: remodal-opening-keyframes;
}
.remodal.remodal-is-closing {
  animation-name: remodal-closing-keyframes;
}

/* ----------------------------
 Keyframes
------------------------------*/
@keyframes remodal-opening-keyframes {
  from {
    transform: scale(1.05);
    opacity: 0;
  }
  to {
    transform: none;
    opacity: 1;
    filter: blur(0);
  }
}
@keyframes remodal-closing-keyframes {
  from {
    transform: scale(1);
    opacity: 1;
  }
  to {
    transform: scale(0.95);
    opacity: 0;
    filter: blur(0);
  }
}
@keyframes remodal-overlay-opening-keyframes {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes remodal-overlay-closing-keyframes {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
/* ------------------------------------------------
 remodal
------------------------------------------------ */
.remodal {
  text-align: left;
  margin: 0 auto;
  padding: 3.3333333333em 0;
  width: -moz-fit-content;
  width: fit-content;
  pointer-events: none;
}
.remodal > .inner {
  background-color: #fff;
  box-sizing: border-box;
  pointer-events: all;
}
@media screen and (min-width: 780.1px) {
  .remodal > .inner {
    border-radius: 2.2222222222em;
    padding: 3.3333333333em;
    width: 55.5555555556em;
  }
}
@media screen and (max-width: 780px) {
  .remodal {
    padding: 3.3333333333em 0;
  }
  .remodal > .inner {
    border-radius: 2em;
    padding: 2.6666666667em 1.6666666667em;
    width: 23.3333333333em;
  }
}

/* ----------------------------
 remodal_close
------------------------------*/
@media screen and (min-width: 780.1px) {
  .remodal_close {
    display: none;
  }
}
@media screen and (max-width: 780px) {
  .remodal_close {
    color: #fff;
    border-radius: 0;
    background-color: transparent;
    margin-top: 1em;
    width: 100%;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    -moz-column-gap: 0.5333333333em;
         column-gap: 0.5333333333em;
    pointer-events: all;
  }
  .remodal_close::before {
    content: "";
    background: url(../images/common/icon_close.svg) 0 0/contain no-repeat;
    margin-top: 0.2666666667em;
    width: 0.5333333333em;
    aspect-ratio: 1/1;
    display: block;
  }
  .remodal_close.stickey {
    border: 1px solid #E3E3E3;
    border-radius: 2em;
    background-color: #fff;
    margin-top: -1em;
    margin-right: -0.5333333333em;
    width: 2em;
    aspect-ratio: 1/1;
    justify-content: center;
    position: sticky;
    left: 100%;
    top: 0;
    top: 3.3333333333em;
  }
  .remodal_close.stickey::before {
    background-image: url(../images/common/icon_close_bk.svg);
    margin-top: 0;
  }
  .remodal_close.stickey .txt {
    display: none;
  }
}

/* ----------------------------
swiper-button
------------------------------*/
.remodal .swiper-button-prev, .remodal .swiper-button-next {
  color: #fff;
  padding: 3.8888888889em;
  width: 1.3888888889em;
  margin: 0;
  top: 50%;
  pointer-events: all;
}
.remodal .swiper-button-prev {
  left: 50%;
  transform: translate(-50vw, -50%);
}
.remodal .swiper-button-next {
  right: 50%;
  transform: translate(50vw, -50%);
}
@media screen and (max-width: 780px) {
  .remodal .swiper-button-prev, .remodal .swiper-button-next {
    padding: 0 0.8em;
    width: 0.8666666667em;
    height: 50%;
    margin: 0;
    top: 50%;
  }
  .remodal .swiper-button-prev {
    left: 50%;
    transform: translate(-50vw, -50%);
  }
  .remodal .swiper-button-next {
    right: 50%;
    transform: translate(50vw, -50%);
  }
}

/* ------------------------------------------------
 dialog
------------------------------------------------ */
.remodal.daialog {
  text-align: center;
}
.remodal.daialog .heading {
  font-size: 1.7777777778em;
}
.remodal.daialog .heading.attention::before {
  content: "";
  background: url(../images/common/icon_attention.svg) no-repeat;
  background-size: contain;
  margin: 0 auto 0.3125em;
  width: 1.40625em;
  aspect-ratio: 45/40;
  display: block;
}
.remodal.daialog .heading b {
  color: var(--color-red);
  font-weight: inherit;
}
.remodal.daialog .heading + .summary {
  margin-top: 2.2222222222em;
}
.remodal.daialog .btns {
  margin-top: 2.2222222222em;
  display: flex;
  align-items: center;
  flex-direction: column;
  row-gap: 1.6666666667em;
}
@media screen and (max-width: 780px) {
  .remodal.daialog .heading {
    font-size: 1.6em;
  }
  .remodal.daialog .heading.attention {
    font-size: 1.4666666667em;
    line-height: 1.4;
  }
  .remodal.daialog .heading.attention::before {
    margin-bottom: 0.4545454545em;
    width: 1.6363636364em;
  }
  .remodal.daialog .heading.attention + .summary {
    font-size: 0.9333333333em;
  }
  .remodal.daialog .heading + .summary {
    text-align: left;
    margin-top: 1.3333333333em;
  }
  .remodal.daialog .btns {
    margin-top: 1.3333333333em;
    row-gap: 1.6666666667em;
  }
  .remodal.daialog .btns .basic_btn {
    width: 100%;
  }
  .remodal.daialog .btns .basic_btn .txt {
    font-size: 1.0666666667em;
  }
}

/* ------------------------------------------------
 modal_efforts
------------------------------------------------ */
.remodal.torikumi > .inner {
  background: transparent;
  padding: 0;
}
.remodal.torikumi .slide .heading {
  color: #fff;
}
.remodal.torikumi .slide .heading .detail {
  line-height: 1;
}
.remodal.torikumi .slide .heading::after {
  content: none;
}
.remodal.torikumi .slide .body {
  border-radius: 2.2222222222em;
  background-color: #fff;
  margin-top: 2.2222222222em;
  padding: 2.7777777778em 3.3333333333em;
  align-content: center;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  -moz-column-gap: 2.2222222222em;
       column-gap: 2.2222222222em;
}
.remodal.torikumi .slide .img {
  position: relative;
}
.remodal.torikumi .slide .img .num {
  font-family: var(--font-num);
  font-size: 2.7777777778em;
  line-height: 1;
  position: absolute;
  left: -0.2em;
  top: -0.6em;
  z-index: 1;
}
.remodal.torikumi .slide .img .icon {
  margin-left: 0.5555555556em;
  width: 8.8888888889em;
}
.remodal.torikumi .slide .img .icon::before {
  content: none;
}
.remodal.torikumi .slide .txt .name {
  font-size: 1.5555555556em;
}
.remodal.torikumi .slide .txt .summary {
  margin-top: 1.1111111111em;
  border-radius: 1.1111111111em;
  background: linear-gradient(236deg, #F2F2F2 11.68%, #F8F8F8 92.02%);
  padding: 1.1111111111em 1.6666666667em;
}
.remodal.torikumi .swiper-wrapper {
  height: auto;
  align-content: center;
  align-content: start;
}
.remodal.torikumi .swiper-slide {
  -moz-text-align-last: left;
       text-align-last: left;
  height: auto;
}
@media screen and (min-width: 780.1px) {
  .remodal.torikumi .slider {
    width: 55.5555555556em;
  }
}
@media screen and (max-width: 780px) {
  .remodal.torikumi .slide .heading {
    margin: 0 1em;
    row-gap: 0.6666666667em;
  }
  .remodal.torikumi .slide .body {
    border-radius: 2em;
    margin: 1.6666666667em 1em 0;
    padding: 1.3333333333em;
    flex-direction: column;
    row-gap: 1.3333333333em;
  }
  .remodal.torikumi .slide .img {
    padding-top: 2em;
  }
  .remodal.torikumi .slide .img .num {
    font-size: 2.5333333333em;
    left: -0.5263157895em;
    top: 0;
  }
  .remodal.torikumi .slide .img .icon {
    width: 7.3333333333em;
  }
  .remodal.torikumi .slide .txt .name {
    font-size: 1.3333333333em;
    text-align: left;
    margin: 0 auto;
    width: -moz-fit-content;
    width: fit-content;
  }
  .remodal.torikumi .slide .txt .summary {
    line-height: 2;
    margin-top: 1.3333333333em;
    border-radius: 1.3333333333em;
    padding: 1.3333333333em 1.3333333333em;
  }
}