@charset "UTF-8";

/* ---------------------------------------------------------------------------
  ★共通
--------------------------------------------------------------------------- */
html {
  font-size: 62.5%;
}

body {
  font-size: clamp(1rem, 3.8vw, 1.6rem);
  -webkit-text-size-adjust: 100%;
}

object {
  pointer-events: none;
}

.sp {
  display: block !important;
}

.pc {
  display: none !important;
}

a {
  text-decoration: none;
  transition: 0.3s;
}

.sp-left {
  text-align: left !important;
}

.sp-center {
  text-align: center !important;
  justify-content: center !important;
}

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

.sp-column li {
  width: 100% !important;
}

.sp-reverse {
  flex-direction: column-reverse !important;
}

.f10 {
  font-size: clamp(0.8rem, 3.2vw, 1rem) !important;
}

.f11 {
  font-size: clamp(0.8rem, 3.3vw, 1.1rem) !important;
}

ul.pankuzu,
.news_set .o_02 .tag,
.f12 {
  font-size: clamp(0.8rem, 3.4vw, 1.2rem) !important;
}

.f13 {
  font-size: clamp(0.8rem, 3.5vw, 1.3rem) !important;
}

.news_set .o_02 .da,
.f14 {
  font-size: clamp(1rem, 3.6vw, 1.4rem) !important;
}

.f15 {
  font-size: clamp(1rem, 3.7vw, 1.5rem) !important;
}

.f16 {
  font-size: clamp(1rem, 3.8vw, 1.6rem) !important;
}

.f17 {
  font-size: clamp(1rem, 3.9vw, 1.7rem) !important;
}

.n_subTit,
.news_set .btn_02 a,
.f18 {
  font-size: clamp(1rem, 4vw, 1.8rem) !important;
}

.f19 {
  font-size: clamp(1rem, 4.1vw, 1.9rem) !important;
}

.f20 {
  font-size: clamp(1.2rem, 4.2vw, 2rem) !important;
}

.f21 {
  font-size: clamp(1.2rem, 4.3vw, 2.1rem) !important;
}

.f22 {
  font-size: clamp(1.2rem, 4.3vw, 2.2rem) !important;
}

.f23 {
  font-size: clamp(1.2rem, 4.5vw, 2.3rem) !important;
}

.f24 {
  font-size: clamp(1.2rem, 4.6vw, 2.4rem) !important;
}

.f25 {
  font-size: clamp(1.2rem, 4.7vw, 2.5rem) !important;
}

.f26 {
  font-size: clamp(1.2rem, 4.8vw, 2.6rem) !important;
}

.f27 {
  font-size: clamp(1.2rem, 4.9vw, 2.7rem) !important;
}

.f28 {
  font-size: clamp(1.4rem, 5vw, 2.8rem) !important;
}

.f29 {
  font-size: clamp(1.4rem, 5.1vw, 2.9rem) !important;
}

.f30 {
  font-size: clamp(1.6rem, 5.2vw, 3rem) !important;
}

/* ---------------------------------------------------------------------------
  ★ハンバーガーメニュー
--------------------------------------------------------------------------- */
.hamburger {
  position: fixed;
  right: 0;
  top: 0;
  width: 58px;
  height: 56px;
  cursor: pointer;
  z-index: 100;
  background: #00359b;
}

.hamburger__line {
  position: absolute;
  left: 11px;
  width: 34px;
  height: 2px;
  background-color: #fff;
  transition: all 0.6s;
}

.hamburger__line--1 {
  top: 14px;
}

.hamburger__line--2 {
  top: 26px;
}

.hamburger__line--3 {
  top: 38px;
}

/* グローバルナビゲーション・クリック後の表示 */
.black-bg01 {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  z-index: 100;
  background-color: #000;
  opacity: 0;
  visibility: hidden;
  transition: all 0.6s;
  cursor: pointer;
}

.global-nav {
  position: fixed;
  right: -301px;
  top: 0px;
  height: 100vh;
  transition: all 0.6s ease 0s;
  z-index: 999999;
  overflow-y: auto;
  background: #e9f2ff;
  width: 300px;
}

.nav-open .global-nav {
  right: 0;
}

.nav-open .black-bg01 {
  opacity: 0.8;
  visibility: visible;
}

.nav-open .hamburger__line--1 {
  transform: rotate(45deg);
  top: 20px;
}

.nav-open .hamburger__line--2 {
  width: 0;
  left: 50%;
}

.nav-open .hamburger__line--3 {
  transform: rotate(-45deg);
  top: 20px;
}

.global-nav_Box {
  width: 238px;
  margin: auto;
  background: #e9f2ff;
  padding: 0px 0%;
  position: relative;
}

.global-nav_title,
.accordion_title a,
.accordion_content li a {
  color: #11217a;
}

.global-nav_title {
  position: relative;
  border-bottom: 1px solid rgb(255 255 255);
  padding: 0.8em;
  cursor: pointer;
  font-weight: bold;
  background: #e9f2ff;
  display: block;
}

.accordion_title {
  cursor: pointer;
  position: relative;
  border-bottom: 1px solid rgb(221, 228, 225);
  padding: 0.8em;
  font-weight: bold;
}

.accordion_title::after {
  position: absolute;
  display: block;
  content: "";
  top: 41%;
  right: 18px;
  width: 5px;
  height: 5px;
  border-top: 2px solid #11217a;
  border-right: 2px solid #11217a;
  transform: rotate(135deg);
  transition: all 0.4s ease-in-out 0s;
}

.accordion_title.open::after {
  transform: rotate(-45deg);
  top: 45%;
}

.accordion_content li {
  padding: 0.3em 0.3em 0.3em 1.25em;
  font-size: 14px;
}

/* ---------------------------------------------------------------------------
  ★header・home・footer
--------------------------------------------------------------------------- */

.header01 .logo img:nth-child(1) {
  width: 45px;
}

.header01 .logo img:nth-child(2) {
  width: 215px;
}

.h_btnArea {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin: 16px;
}

.h_btnArea .btn01 {
  width: 100%;
  text-align: center;
  background-position: top 50% left 3em;
}

.global-nav .snsArea {
  justify-content: flex-end;
  margin-bottom: 16px;
}

.global-nav .snsArea li {
  width: 32px;
}

.home01 .h_h2Tit {
  font-size: 1.8rem;
}

.home01 .cl50 {
  padding: 16px 10px 40px;
  margin-bottom: 9px;
}

.home01 .news_set_aqua::after {
  width: 150px;
  height: 166px;
  position: absolute;
  bottom: -65px;
  right: -12px;
}

.home01 .o_02.home01Box {
  padding: 18px 22px 30px 30px;
}

.home_bg {
  background-position: right 58% bottom 22%;
  padding: 26px 0 0;
}

.footer01 {
  flex-direction: column;
  gap: 20px;
}

.footer01 .f_btnArea {
  flex-wrap: wrap;
  justify-content: center;
}

.footer02 {
  flex-direction: column;
  align-items: flex-end;
}

/* ---------------------------------------------------------------------------
  ★news
--------------------------------------------------------------------------- */
.h1Tit {
  font-size: clamp(2rem, 6vw, 3.8rem) !important;
}

.subh2Tit {
  font-size: clamp(1.2rem, 4.6vw, 2.4rem) !important;
}
