@charset "UTF-8";

/*====================================

  ----------------------------------
  Color
  ----------------------------------

    Blue        : #004C8F
    Light       : #E8F3FA
    Yellow      : #D8C700
    Orange      : #CA4B02
    Green       : #006F47

    border      : #CCDBE9
    text        : #3E475B

  ----------------------------------
  font
  ----------------------------------

    JP  : Noto Sans JP
    EN  : None

  ----------------------------------
    Structure
  ----------------------------------

    1. General
      1.1 Print
      1.2 Utility
      1.3 Parts
    2. PageTop
    3. Municipality
    4. Header
      4.1 Navigation
      4.2 Open Menu
      4.3 Utility
    5. Footer
    6. EasySearch
    7. News

====================================*/

:root {
  --blue: #004c8f;
  --light: #e8f3fa;
  --yellow: #d8c700;
  --orange: #ca4b02;
  --green: #006f47;

  --border: #ccdbe9;
  --text: #3e475b;
}

/*==================================
  1. General - サイト共通
==================================*/
body {
  background-color: #fff;
  color: #3e475b;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  letter-spacing: 0.25em;
}

button {
  letter-spacing: 0.1em;
}

.l-wrapper {
  width: 100%;
  text-align: left;
  overflow: hidden;
  font-size: 1.8rem;
}

@media only screen and (max-width: 767px) {
  .l-wrapper {
    font-size: 1.6rem;
  }
}

.l-wrapper.is-fixed {
  position: fixed;
}

.l-wrap {
  max-width: 1200px;
  padding-left: 20px;
  padding-right: 20px;
  margin-left: auto;
  margin-right: auto;
}

/* @media only screen and (max-width: 767px) {
  .l-wrap {
    padding-left: 10px;
    padding-right: 10px;
  }
} */

/* header-up*/
.l-header_info.hide {
  transform: translateY(-100%);
  transition: 0.8s;
}

.l-header_info.show {
  transform: translateY(0%);
  transition: 0.8s;
}

/*
 	1.1 Print
====================================*/
@media print {
  body {
    padding-top: 0 !important;
  }
  header {
    display: none !important;
  }
  footer {
    display: none !important;
  }
  .l-header_info {
    display: none !important;
  }
  .l-2col_side {
    display: none !important;
  }
  .l-2col_main {
    width: 100% !important;
  }
  .l-wrapper {
    -webkit-print-color-adjust: exact;
  }
  #page_top {
    display: none !important;
  }

  /* adjustment */
  .p-subVisual {
    display: none !important;
  }
  .c-gallery .c-gallery_list figure {
    padding: 0 !important;
  }
  .c-gallery .slick-arrow {
    display: none !important;
  }
}

/*
 	1.2 Utility
====================================*/
.u-strong {
  font-weight: 700;
}

.u-error {
  color: #b60000;
}

.u-small {
  font-size: 90%;
}

.u-smaller {
  font-size: 60%;
}

.u-big {
  font-size: 110%;
}

.u-bigger {
  font-size: 140%;
}

.u-biggest {
  font-size: 170%;
}

.u-colon {
  position: relative;
}

.u-colon::after {
  content: "\ff1a";
  padding: 0 0.25em;
}

.u-sup {
  font-size: 1.2rem;
  letter-spacing: 0;
}

.align-center {
  text-align: center;
}

.align-right {
  text-align: right;
}

/* adjustment */
.pc_none {
  display: none;
}
.pc_space {
  margin-left: 1em;
}

@media only screen and (max-width: 767px) {
  .pc_none {
    display: block;
  }
  .pc_space {
    margin: auto;
  }
}

/* Margin */
.u-mt0 {
  margin-top: 0 !important;
}
.u-mt20 {
  margin-top: 20px;
}
.u-mt40 {
  margin-top: 40px;
}
.u-mt60 {
  margin-top: 60px;
}
.u-mt80 {
  margin-top: 80px;
}
.u-mt100 {
  margin-top: 100px;
}
.u-mt120 {
  margin-top: 120px;
}
.u-mt160 {
  margin-top: 160px;
}

@media only screen and (max-width: 767px) {
  .u-mt20 {
    margin-top: 10px;
  }
  .u-mt40 {
    margin-top: 20px;
  }
  .u-mt60 {
    margin-top: 30px;
  }
  .u-mt80 {
    margin-top: 40px;
  }
  .u-mt100 {
    margin-top: 50px;
  }
  .u-mt120 {
    margin-top: 60px;
  }
  .u-mt160 {
    margin-top: 80px;
  }
}

/* Padding */
.u-pd80 {
  padding: 80px 0;
}
.u-pd120 {
  padding: 120px 0;
}
.u-pd160 {
  padding: 160px 0;
}
.u-pt80 {
  padding-top: 80px;
}
.u-pt120 {
  padding-top: 120px;
}
.u-pb120 {
  padding-bottom: 120px;
}

@media only screen and (max-width: 767px) {
  .u-pd80 {
    padding: 40px 0;
  }
  .u-pd120 {
    padding: 60px 0;
  }
  .u-pd160 {
    padding: 80px 0;
  }
  .u-pt80 {
    padding-top: 40px;
  }
  .u-pt120 {
    padding-top: 60px;
  }
  .u-pb120 {
    padding-bottom: 60px;
  }
}

/*
 	1.3 Parts
====================================*/

/*== Slick =======================*/
/* Arrows */
.slick-prev,
.slick-next {
  z-index: 2;
  top: calc(50% - (30px / 2));
  width: 5rem;
  height: 5rem;
}

.slick-prev:before,
.slick-next:before {
  font-family: initial; /* slick */
  font-size: initial; /* 20px */
  opacity: 1;
  color: #004c8f; /* Color */

  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  transition: 0.3s;

  width: 2rem;
  height: 2rem;
  border-top: 4px solid;
  border-right: 4px solid;
}

.slick-prev {
  left: 6px;
}
[dir="rtl"] .slick-prev {
  right: 6px;
  left: auto;
}
.slick-prev:before {
  transform: rotate(225deg);
}
[dir="rtl"] .slick-prev:before {
  transform: rotate(45deg);
}

.slick-next {
  right: 6px;
}
[dir="rtl"] .slick-next {
  right: auto;
  left: 6px;
}
.slick-next:before {
  transform: rotate(45deg);
}
[dir="rtl"] .slick-next:before {
  transform: rotate(225deg);
}

/* Dots */
.slick-dots li button:before {
  opacity: 0.7;
  color: #fff;
  font-size: 8px;
  text-shadow: 0 0 8px rgba(61, 61, 61, 0.7);
}
.slick-dots li.slick-active button:before {
  opacity: 1;
  color: #004c8f;
}

/*== Button =======================*/
.c-btn {
  display: inline-block;
  text-decoration: none;
  font-weight: 700;
  text-align: center;
  width: 100%;
  max-width: 320px;
  padding: 10px 30px;
  border-radius: 9999px;
  border: 1px solid #004c8f;

  background: #fff;
  color: #004c8f;
}

/* reverse */
.c-btn__rev {
  background: #004c8f;
  color: #fff;
}

.c-btn:hover,
.c-btn:focus {
  opacity: 0.8;
}

/*== Arrow =======================*/
.arrow {
  position: relative;
}
.arrow::before,
.arrow::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
}

/* Kunoji */
.s5-2::before {
  width: 0.75em;
  height: 0.75em;
  border-top: 4px solid;
  border-right: 4px solid;
  transform: rotate(45deg);
}

/*== Card =======================*/
[class^="card"] figure img {
  width: 100%;
  aspect-ratio: 3 / 2;
  object-fit: cover;
  border-radius: 1rem;
}

[class^="info"] {
  margin-top: 10px;
}

[class^="info"] > time {
  font-size: 90%;
  font-weight: 700;
}

/*
 	1.4 skipnav
====================================*/
#skiptocontent a {
  font-size: 1.4rem;
  padding: 4px 1em;
  position: absolute;
  top: -40px;
  left: 0px;
  border-bottom-right-radius: 8px;
  background: #d8c700;
  color: #3e475b;
  z-index: 9999;
}

#skiptocontent a:focus {
  position: absolute;
  top: 0px;
  left: 0px;
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  #skiptocontent a {
    transition-duration: 0.001ms !important;
  }
}

/*==================================
  2. PageTop- ページトップ
==================================*/
#page_top {
  position: fixed;
  right: 40px;
  bottom: 40px;
  z-index: 10;
  display: none;
}
#page_top a {
  display: block;
  width: 80px;
  aspect-ratio: 40 / 63;
}
#page_top img {
  filter: drop-shadow(0px 2px 3px rgba(91, 91, 91, 0.5));
}

@media only screen and (max-width: 767px) {
  #page_top {
    right: 20px;
    bottom: 20px;
  }
  #page_top a {
    width: 60px;
  }
}

/*==================================
  3. Municipality- 緊急情報
==================================*/
.l-header_info {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 990;
  width: 100%;
  background: #de0000;
  color: #fff;
  padding: 10px 30px;
  font-size: 1.6rem;
  font-weight: 700;
  text-align: left;
}
.l-header_info_txt {
  width: 1170px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}
.l-header_info_date {
  padding-right: 0.5em;
  margin-right: 0.5em;
  border-right: 1px solid #fff;
}
.l-header_info a {
  display: inline-block;
  color: #fff;
  flex: 1;
}

/* Adjustment　*/
.l-header_info.hide {
  transform: translateY(-100%);
  transition: 0.8s;
}

.l-header_info.show {
  transform: translateY(0%);
  transition: 0.8s;
}

@media only screen and (max-width: 767px) {
  .l-header_info {
    font-size: 1.2rem;
    padding: 10px 15px;
  }
  .l-header_info_txt {
    width: 100%;
    padding-left: 0;
    padding-right: 55px;
    flex-direction: column;
  }
  .l-header_info_date {
    display: block;
    padding-right: 0;
    margin-right: 0;
    border: none;
  }
}

/*==================================
  4. Header - ヘッダー
==================================*/
.l-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 9990;
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 0 10px #d0d0d0;
}

.l-header_inr {
  position: relative;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 0 40px;

  display: flex;
  justify-content: space-between;
  align-items: center;
}

.l-header_logo > a {
  display: inline-block;
}

.l-header_logo > a img {
  width: 220px;
  aspect-ratio: 16 / 5;
}

@media only screen and (min-width: 1200px) {
  /* 上下逆転 */
  nav {
    order: 2;
  }
  .l-header_utility_sub {
    order: 1;
  }
  #nav-toggle,
  #nav-toggle .on,
  #nav-toggle .off {
    display: none;
  }
}

@media only screen and (max-width: 1199px) {
  .l-header_inr {
    padding: 10px 20px;
  }
  .l-header_logo > a img {
    width: auto;
    height: 46px;
  }
}

/*
 	4.1 Utility
====================================*/
.l-header_utility {
  flex-shrink: 0;
}

.l-header_utility_inr {
  display: flex;
  flex-direction: column;
}

.l-header_utility_sub {
  display: flex;
  justify-content: flex-end;
  gap: 0 2em;
  font-size: 1.6rem;
}

.l-header_utility_sub_inr {
  display: flex;
  gap: 0 20px;
  padding: 8px 1em;
  background: #004c8f;
  border-radius: 0 0 0.4em 0.4em;
}

.l-header_utility_sub_inr > * {
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Search */
.l-header_utility_sub_form form {
  width: 100%;
  height: 100%;
  position: relative;
}
.l-header_utility_sub_form form input {
  width: calc(100% - 4em);
  height: 100%;
  padding: 0 1em;
  text-align: left;
  background: #fff;
  margin-right: 4em;

  border: 1px solid transparent;
  border-radius: 0.4em 0 0 0.4em;
}
.l-header_utility_sub_form form button {
  width: 4em;
  height: 100%;
  text-align: center;
  font-weight: 700;
  position: absolute;
  top: 0;
  right: 0;

  background: #ca4b02;
  border: 1px solid #ca4b02;
  border-radius: 0 0.4em 0.4em 0;
  color: #fff;
}

/* textLink */
.l-header_utility_sub_inr a {
  display: block;
  height: 100%;
  padding: 3px 10px;

  color: #fff;
  letter-spacing: 0.1em;
}

/*
 	4.2 Navigation
====================================*/
.l-header_nav {
  display: flex;
  justify-content: flex-end;
  gap: 0 1em;
  padding: 12px 0 5px;
}

.l-header_nav_item {
  padding-left: 1em;
  border-left: 1px solid #ccdbe9;
}

.l-header_nav_item:first-child {
  border-left: none;
}

a.l-header_nav_item_label {
  display: block;
  color: inherit;
  text-decoration: none;

  font-weight: 700;
  font-size: 1.7rem;
  text-align: center;

  opacity: 1;
  position: relative;
  z-index: 2;
}

/* 展開部分 */
.l-header_nav_item_child {
  visibility: hidden;
  transform: translateY(-10px);
  opacity: 0;
  position: absolute;
  width: calc(100% - 80px);
  top: 100%;
  left: 40px;
  padding: 40px 10vw;
  transition: 0.2s;

  background: #004c8f;
  border-radius: 1em;
  color: #fff;
  box-shadow: 0 5px 5px rgba(102, 102, 102, 0.1);
}

.l-header_nav_item_child_list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px 40px;
}

.l-header_nav_item_child_list li {
  padding-left: 1.2em;
  position: relative;
}

.l-header_nav_item_child_list li::before {
  content: "";
  position: absolute;
  top: calc(1em / 2 + 4px);
  left: 0;

  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #d8c700;
}

.l-header_nav_item_child_list li > a {
  text-decoration: none;
  color: inherit;
}

.l-header_nav_item_child_list li > a:hover,
.l-header_nav_item_child_list li > a:focus {
  color: #d8c700;
  text-decoration: underline;
}

@media only screen and (min-width: 1200px) {
  /* アクション時 */
  .l-header_nav_item_label:focus::before,
  .l-header_nav_item:hover .l-header_nav_item_label::before,
  .l-header_nav_item.actived .l-header_nav_item_label::before {
    content: "";
    position: absolute;
    top: calc(100% - 6px);
    left: 50%;
    transform: translateX(-50%);
    width: 60px;
    padding-top: calc(60px / 5 * 2);
    /* aspect-ratio: 5 / 2; */
    background: url(/assets/images/common/speech_wh.svg) no-repeat;
  }

  .l-header_nav_item:hover > .l-header_nav_item_child,
  .l-header_nav_item .l-header_nav_item_child.focused {
    visibility: visible;
    opacity: 1;
    transform: translateY(0);
  }
}

/*
 	4.3 SmartPhone
====================================*/
@media only screen and (max-width: 1199px) {
  .l-header_utility {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: #e8f3fa;
    overflow: scroll;
    padding: 60px 40px 40px;
  }
  .l-header_utility_inr {
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
  }
  .l-header_utility_sub {
    position: relative;
    flex-direction: column;
    align-items: center;
    margin-top: 40px;
  }
  .l-header_utility_sub_inr {
    flex-direction: column;
    align-items: center;
    gap: 20px 0;
    padding: 1em;
    border-radius: 0.4em;
    width: 100%;
  }
  .l-header_nav {
    flex-direction: column;
    align-items: center;
    gap: 20px;
    padding: 0;
  }
  .l-header_nav_item {
    width: 100%;
    border: none;
    padding-left: 0;
  }
  a.l-header_nav_item_label {
    padding: 8px;
    background: #fff;
    border-radius: 0.4em;
  }
  .l-header_nav_item_child {
    display: none;
  }
}

/*
 	4.4 Hamburger
====================================*/

@media only screen and (max-width: 1199px) {
  #nav-toggle .hamburger {
    position: absolute;
    right: 10px;
    top: 10px;
    width: 48px;
    height: 48px;
    cursor: pointer;
    z-index: 999;
  }
  #nav-toggle .on,
  #nav-toggle .off {
    display: inline-block;
    text-align: center;
    padding-top: 24px;
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: 0;
  }
  #nav-toggle span.line {
    display: block;
    height: 5px;
    width: 40px;
    background: #004c8f;
    /* box-shadow: 0 0 1px #f0f0f0; */
    position: absolute;
    top: 0;
    left: 4px;
    transition: 0.35s ease-in-out;
  }
  #nav-toggle span.line:nth-child(1) {
    top: 2px;
  }
  #nav-toggle span.line:nth-child(2) {
    top: 14px;
  }
  #nav-toggle .off {
    display: none;
  }

  .open #nav-toggle .on {
    display: none;
  }
  .open #nav-toggle .off {
    display: block;
    font-weight: 400;
  }
  .open #nav-toggle span.line {
    top: 11px;
  }
  .open #nav-toggle span.line:nth-child(1) {
    transform: rotate(330deg);
  }
  .open #nav-toggle span.line:nth-child(2) {
    transform: rotate(-150deg);
  }

  #global-nav {
    z-index: 998;

    visibility: hidden;
    opacity: 0;
    transition: opacity 0.5s ease, visibility 0.5s ease;
  }

  .open {
    overflow: hidden;
  }
  .open #global-nav {
    visibility: visible;
    opacity: 1;
  }
  .open #global-nav li {
    opacity: 1;
    transform: translateX(0);
    transition: transform 1s ease, opacity 0.9s ease;
  }
}

/*==================================
  5. Footer - フッター
==================================*/
.l-footer {
  margin-top: 160px;
}

@media only screen and (max-width: 767px) {
  .l-footer {
    margin-top: 80px;
  }
}

.l-footer_inr {
  padding-top: calc((100vw / 16 * 3) - 5%);
  background: #004c8f;
  color: #fff;
  position: relative;
}

.l-footer_inr::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(100vw / 16 * 3);
  /* aspect-ratio: 16 / 3; */
  background: #fff url(/assets/images/common/footer1.svg) no-repeat bottom center/cover;
}

.l-footer_inr::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 224px;
  background: url(/assets/images/common/footer2.svg) no-repeat bottom left, url(/assets/images/common/footer3.svg) no-repeat bottom right;
}

@media only screen and (max-width: 1199px) {
  .l-footer_inr {
    padding-top: calc((100vw / 16 * 3) - 0%);
  }
  .l-footer_inr::after {
    background-size: 20%, 40%;
  }
}

@media only screen and (max-width: 767px) {
  .l-footer_inr {
    padding-top: calc((100vw / 16 * 3) - -5%);
  }
}

.l-footer_info {
  position: relative;
  padding-bottom: 60px;
  z-index: 2;
}

.l-footer_logo > a {
  display: inline-block;
  width: 200px;
}

.l-footer_logo > a img {
  width: 100%;
  aspect-ratio: 16 / 5;
}

address a {
  color: inherit;
}

.l-footer_nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
}

.l-footer_nav li > a {
  color: #fff;
}

@media only screen and (min-width: 768px) {
  /* スマホ以外 */
  address a {
    text-decoration: none;
  }
}

@media only screen and (max-width: 1199px) {
}

@media only screen and (max-width: 767px) {
  .l-footer_nav {
    display: block;
    text-align: center;
  }
}

/*==================================
  6. EasySearch - かんたん検索
==================================*/
[class^="es"] {
  position: relative;
  display: inline-block;
}

/* アイコン */
.es01::after {
  background: url(/assets/images/common/es01.svg) no-repeat center/cover;
}
.es02::after {
  background: url(/assets/images/common/es02.svg) no-repeat center/cover;
}
.es03::after {
  background: url(/assets/images/common/es03.svg) no-repeat center/cover;
}
.es04::after {
  background: url(/assets/images/common/es04.svg) no-repeat center/cover;
}
.es05::after {
  background: url(/assets/images/common/es05.svg) no-repeat center/cover;
}
.es06::after {
  background: url(/assets/images/common/es06.svg) no-repeat center/cover;
}
.es07::after {
  background: url(/assets/images/common/es07.svg) no-repeat center/cover;
}
.es08::after {
  background: url(/assets/images/common/es08.svg) no-repeat center/cover;
}
.es09::after {
  background: url(/assets/images/common/es09.svg) no-repeat center/cover;
}
.es10::after {
  background: url(/assets/images/common/es10.svg) no-repeat center/cover;
}
.es11::after {
  background: url(/assets/images/common/es11.svg) no-repeat center/cover;
}
.es12::after {
  background: url(/assets/images/common/es12.svg) no-repeat center/cover;
}

/* searchList - 本体共通 */
.c-searchList {
  display: grid;
  gap: 10px;
}

.c-searchList li > a {
  text-decoration: none;
  display: block;
  width: 100%;
  background: #e8f3fa;
  border-radius: 1rem;
  color: #004c8f;
  font-weight: 700;
  box-shadow: 0 2px 6px #e0e0e0;
}

.c-searchList li > a span::after {
  content: "";
  position: absolute;
}

@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .c-searchList {
    grid-template-columns: repeat(2, 1fr);
  }
}

/*==================================
  7. News - 新着情報
==================================*/
/* tab */
.c-tablist {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  width: 100%;
}

.c-tablist_item,
.c-tablist_item:focus,
.c-tablist_item:hover {
  display: inline-block;
  overflow: hidden;
  padding: 0.5em 1em;
  text-align: center;
  font-weight: 700;
  border-radius: 1rem 1rem 0 0;
  background: #004c8f;
  color: #fff;
}

.c-tablist_item[aria-selected="true"] {
  background: #d8c700;
  color: inherit;
}

@media only screen and (max-width: 767px) {
  .c-tablist {
    gap: 4px;
  }
  .c-tablist_item,
  .c-tablist_item:focus,
  .c-tablist_item:hover {
    padding: 0.5em;
  }
}

[role="tabpanel"].is-hidden {
  display: none;
}

/* newsBody - 本体 */
.c-newsList {
  border-top: 1px solid #ccdbe9;
  border-bottom: 1px solid #ccdbe9;
}
.c-newsList_item {
  padding: 20px 0;
}
.c-newsList_item:not(:first-of-type) {
  border-top: 1px solid #ccdbe9;
}
.c-newsList_item_head {
  display: flex;
  align-items: center;
  gap: 1em;
}
.c-newsList_item_date {
  font-size: 1.6rem;
}
.c-newsList_item_body {
  margin-top: 12px;
}
.c-newsList_item_dept {
  margin-left: 0.5em;
}

@media only screen and (max-width: 767px) {
  /* .c-newsList_item {
    padding: 16px 0;
  } */
  .c-newsList_item_date {
    font-size: 1.4rem;
    /* adjustment */
    letter-spacing: 0.15em;
  }
}

/* ラベルアイコン共通 */
[class^="c-label"] {
  font-size: 1.6rem;
  display: inline-block;
}

@media only screen and (max-width: 767px) {
  [class^="c-label"] {
    font-size: 1.4rem;
  }
}

/* カテゴリアイコン */
.c-label {
  font-weight: 400;
  background: #006f47;
  border-radius: 6px;
  color: #fff;
  width: 10em;
  text-align: center;
  line-height: 1;
  padding: 4px 0;
}

/* NEWアイコン */
.c-label01 {
  font-weight: 700;
  background: #d8c700;
  padding-left: 0.5em;
  position: relative;
  line-height: 1;
  padding: 4px 0 4px 0.5em;
  margin-left: 0.5em;
  letter-spacing: 0.1em;
}

.c-label01::before {
  content: "";
  position: absolute;
  top: 0;
  right: -0.8em;
  width: 0.8em;
  height: auto;
  border-top: 0.8em solid #d8c700;
  border-right: 0.5em solid transparent;
  border-bottom: 0.8em solid #d8c700;
}

/* カレンダーのカテゴリアイコン */
.c-label02 {
  font-weight: 400;
  background: #ca4b02;
  border-radius: 6px;
  color: #fff;
  width: 10em;
  text-align: center;
}

/*==================================
  8. Calendar - カレンダー
==================================*/
.c-eventlist_item:not(:first-child) {
  margin-top: 10px;
}

.c-eventlist_item_txt {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.c-eventlist_item_txt a {
  text-decoration: underline;
}

.c-eventlist_item_txt a:hover {
  text-decoration: none;
}

@media only screen and (min-width: 768px) {
  .c-eventlist_item {
    display: flex;
  }
  .c-eventlist_item_txt {
    margin-left: 40px;
  }
}

@media only screen and (max-width: 767px) {
  .c-eventlist_item_txt {
    margin-top: 10px;
  }
  .c-eventlist_item:not(:first-child) {
    margin-top: 20px;
  }
}


/*==================================
  9. Adsence - バナー広告
==================================*/
/* 外枠 */
.l-wide {
  margin: 0 40px;
}

@media only screen and (max-width: 1199px) {
  .l-wide {
    margin: 0 20px;
  }
}

@media only screen and (max-width: 767px) {
  .l-wide {
    margin: 0 auto;
  }
}

/* 内枠 */
.l-inner {
  padding: 0 20px;
  margin: 0 auto;
}

.l-inner__mid {
  max-width: 1160px;
}

.l-inner__lar {
  max-width: 1540px;
}

/* 共通 */
.u-radius {
  border-radius: 3rem;
}

.u-bgLight {
  background: #e8f3fa;
}

.u-bgBlue {
  background: #004c8f;
}

.u-bgYellow {
  background: #d8c700;
}

/*
 	9.1 Link - リンク系
====================================*/
.c-bnrTtl02 {
  font-size: 3rem;
  font-weight: 700;
  color: #004c8f;
}
@media only screen and (max-width: 767px) {
  .c-bnrTtl02 {
    font-size: 2.4rem;
  }
}

.c-bnrList {
  display: grid;
  gap: 40px;
}

.c-bnrList:not(:first-of-type) {
  margin-top: 40px;
}

.c-bnrList a {
  display: block;
  width: 100%;

  text-decoration: none;
  color: inherit;
}

.c-bnrList figure img {
  width: 100%;
  height: auto;
  object-fit: cover;
  /* 角丸 */
  border-radius: 1rem;
}

.c-bnrList.c-bnrList__col2 {
  grid-template-columns: repeat(2, 1fr);
}

.c-bnrList.c-bnrList__col3 {
  grid-template-columns: repeat(3, 1fr);
}

.c-bnrList.c-bnrList__col4 {
  grid-template-columns: repeat(4, 1fr);
}

.c-bnrList.c-bnrList__col5 {
  grid-template-columns: repeat(5, 1fr);
}

@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .c-bnrList.c-bnrList__col3.type-l {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
  .c-bnrList.c-bnrList__col5 {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media only screen and (max-width: 767px) {
  .c-bnrList {
    gap: 20px;
  }
  .c-bnrList:not(:first-of-type) {
    margin-top: 20px;
  }
  .c-bnrList.c-bnrList__col2,
  .c-bnrList.c-bnrList__col3 {
    grid-template-columns: repeat(1, 1fr);
  }
  .c-bnrList.c-bnrList__col4,
  .c-bnrList.c-bnrList__col5 {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* figcaption */
.c-bnrList figcaption {
  font-weight: 700;
  margin-top: 10px;
}

/* 掲載について */
.p-Social_link {
  font-weight: 700;
  text-align: right;
  font-size: 90%;
}