@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Template:   cocoon-master
Version:    1.1.3
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
body {
  overflow-x: hidden;
  color: #1A1919;
  background: #fff;
  letter-spacing: 0.5px;
}
#container {
  overflow-x: hidden;
}
*:focus {
  outline: none;
}
input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0px 1000px #fff inset;
}
.posts-not-found h2 {
  display: none;
}
img {
  vertical-align: bottom;
}
.header-in.wrap {
  width: 100%;
  margin: auto;
}
.tagline {
  display: none;
}
.institute-tagline {
  border-top: 5px solid #BB1B8D;
  border-bottom: 1px solid #ddd;
  line-height: 1;
  padding: 14px 0;
  text-align: center;
}
.institute-title {
  font-size: 14px;
}
.institute-title-en {
  display: inline-block;
  font-size: 12px;
  margin-left: 5px;
}
.logo-image {
  padding: 10px 0;
}
.logo-image a {
  padding: 0;
  transition: all 0.3s;
}
.logo-image a:hover {
  opacity: 0.6;
}
.logo-image a img {
  width: auto;
  max-height: 90px;
}
#navi {
  background: #BB1B8D;
  padding: 0;
}
.navi-in > ul li {
  width: auto;
  height: auto;
  line-height: normal;
}
.navi-in a {
  color: #fff;
  padding: 20px 25px;
}
.menu-wrap {
  line-height: 1;
}
.menu-sub {
  font-size: 16px;
  margin-bottom: 8px;
}
.menu-title {
  font-size: 12px;
}

/* mv */
.mv-wrap {
  height: 440px;
  background-image: url('../../../wp-content/uploads/2024/05/mv_bg.jpg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
.mv-inner {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mv-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(255,255,255,0.4);
  padding: 50px 60px;
}
.mv-content-left {
  width: 17%;
}
.mv-content-right {
  width: 79%;
  line-height: 1;
}
.mv-catch {
  font-size: 22px;
}
.mv-title {
  font-size: 30px;
  line-height: 1.55;
  margin: 18px 0 10px;
}
.mv-catch,
.mv-title {
  font-weight: 700;
  font-family: "Noto Serif JP", serif;
  letter-spacing: 1px;
}
.mv-text {
  font-size: 15px;
  line-height: 1.75;
}
a.top-service-title h2,
h2.footer-cta-title,
.header-text-wrap h1.entry-title,
h2.h-title,
h3.h-title,
h4.h-title {
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  font-size: 16px;
  font-weight: 400;
  line-height: 1;
}
body.front-top-page header.article-header {
  display: none;
}
.top-service-list {
  display: grid;
  -ms-grid-columns: 1fr 1fr 1fr;
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 3.5vw 3vw;
  margin: 52px 0 50px;
}
.top-service a {
  transition: all 0.3s;
}
.top-service a:hover {
  opacity: 0.6;
}
a.top-service-title {
  text-decoration: none;
  color: #1A1919;
}
a.top-service-title h2 {
  text-align: center;
  border-bottom: 3px solid #1A1919;
  font-size: 22px;
  padding-bottom: 10px;
  margin-bottom: 15px;
  font-weight: 500;
}
span.top-service-title-span {
  display: inline-block;
  font-size: 15px;
  margin-left: 5px;
}
ul.top-service-index {
  padding: 0;
  margin: 0;
  list-style: none;
  margin-top: 5px;
}
ul.top-service-index li {
  margin: 0;
}
ul.top-service-index li a {
  display: block;
  text-decoration: none;
  color: #1A1919;
  font-size: 16px;
  padding: 6px 0;
  border-bottom: 2px dotted #1A1919;
  position: relative;
  padding-left: 20px;
}
ul.top-service-index li a::before {
  content: '';
  display: block;
  width: 15px;
  height: 15px;
  border-radius: 2px;
  background: #1A1919;
  position: absolute;
  top: 13px;
  left: 0;
}
.top-service p {
  margin: 0;
}
.top-service img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}
.top-banner-wrap {
  margin: 0;
  margin-top: 60px;
  text-align: center;
}
.top-banner-header {
  font-weight: 500;
  font-size: 24px;
  margin-bottom: 20px;
}
a.top-banner-link {
  display: inline-block;
  border: 3px solid #ddd;
  padding: 8px;
  transition: all 0.3s;
  background: #fff;
}
a.top-banner-link img {
  width: 350px;
  height: auto;
  object-fit: cover;
}
h2.h-title {
  font-size: 25px;
  font-weight: 500;
  text-align: center;
  margin-bottom: 1.4em;
  line-height: 1.8;
  margin-top: 70px;
}
h3.h-title {
  border: 0;
  padding: 0;
  color: #BB1B8D;
  font-size: 24px;
  font-weight: 500;
  margin-bottom: 0.9em;
  margin-top: 1.8em;
  line-height: 1.4;
}
h4.h-title {
  padding: 0;
  border: 0;
  font-weight: 500;
  font-size: 20px;
  position: relative;
  padding-left: 26px;
  margin-bottom: 1.0em;
  margin-top: 1.8em;
}
h4.h-title::before {
  content: '';
  display: block;
  position: absolute;
  top: 0.5px;
  left: 0;
  width: 20px;
  height: 20px;
  border-radius: 4px;
  background: #1A1919;
}
.header-bg-wrap {
  background: #CDCDD4;
  height: 140px;
}
.header-bg-wrap header.article-header {
  width: 100%;
  height: 100%;
}
.header-text-wrap {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.header-text-wrap h1.entry-title {
  font-size: 26px;
  color: #fff;
  letter-spacing: 2px;
}
.header-bg-wrap .date-tags {
  display: none;
}
.red {
  color: #BB1B8D;
}
.flex-style-02 {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
}
.flex-style-02-left {
  padding-right: 15px;
}
.flex-style-02-right {

}
.flex-style-02-right img {
  width: 100px;
  height: 116px;
  object-fit: cover;
  object-position: top;
}
.signature-text {
  text-align: right;
  font-weight: 500;
  font-family: "Noto Serif JP", serif;
}
.signature-name {
  font-size: 20px;
}
.signature-pos {
  font-size: 16px;
}
.signature-text-02 {
  text-align: right;
}
.photo-style-01 {
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
}
.photo-style-02 {
  width: 100%;
  max-width: 320px;
  margin: 0 auto;
}
.photo-style-03 {
  border: 1px solid #1A1919;
  display: inline-block;
  margin-bottom: 10px;
}
.photo-style-03 img {
  width: auto;
  height: 200px;
}
.photo-style-04 {
  text-align: center;
  margin: 0;
  margin-top: 40px;
}
.photo-style-04 img {
  width: auto;
  height: 100px;
}
.photo-style-05 {
  width: 100%;
  max-width: 650px;
  margin: 0 auto;
}
.photo-style-06 {
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
}

.page-title-01 {
  display: flex;
  align-items: center;
}
.page-title-01-left {
  width: 100px;
}
.page-title-01-title {
  font-size: 24px;
}
.page-title-01-sub {
  font-size: 18px;
}
.page-title-01-right {
  width: calc(100% - 100px);
  padding-left: 15px;
}
.support-box {
  display: flex;
  align-items: center;
  margin-bottom: 20px;
}
.support-box-item {
  font-size: 20px;
  font-weight: 500;
  background: #ddd;
  padding: 24px 0;
  min-width: 250px;
  text-align: center;
  line-height: 1.6;
  color: #fff;
}
.support-box-img {
  padding: 0 10px;
}
.support-box-img img {
  width: auto;
  height: 50px;
}
.text-style-01 {
  font-size: 18px;
  font-weight: 500;
}
.text-style-02 {
  text-align: center;
  padding: 50px;
  font-size: 24px;
  font-weight: 500;
  margin: 30px 0 0;
  border: 5px double #BB1B8D;
  background: #fef6fc;
}
.text-style-02.text-style-02-1 {
  margin-bottom: 30px;
  font-weight: 400;
  font-size: 20px;
}
.text-style-03 {

}
.text-style-03 a {
  color: #1A1919;
  font-size: 12px;
}
.flex-style-01 {
  display: flex;
  justify-content: space-between;
  margin-top: 56px;
}
.flex-style-left {
  width: 79%;
}
.flex-style-right {
  width: 18%;
}
.table-style-01 table tr th {
  background: #f5f5f5;
  font-weight: 500;
  width: 180px;
  text-align: left;
  vertical-align: top;
}
.table-style-01 table tr td {
  width: calc(100% - 180px);
}
.table-style-01 table tr th,
.table-style-01 table tr td {
  border: 0;
  padding: 24px;
  font-size: 16px;
  border-top: 1px solid #E0E0E0;
}
.table-style-01 table tr:last-child {
  border-bottom: 1px solid #E0E0E0;
}
.table-style-01 table tr:nth-of-type(2n+1) {
  background: transparent;
}
a.contact-mail {
  font-size: 32px;
  font-weight: 500;
  text-decoration: none;
  color: #1A1919;
}

.bg-style-01 {
  background: #007CC3;
}
.bg-style-02 {
  background: #BB1B8D;
}
#breadcrumb {
  padding: 0 10px;
  background: transparent;
  margin-bottom: 4px;
}
.breadcrumb {
  margin: 1em 0em 3em;
}
span.fa-home,
span.fa-file,
span.fa-folder {
  display: none;
}
.sp-b {
  margin: 0 10px 0 7px!important;
}
.sp .fa-angle-right {
  color: #b3b3b3;
}
.list-breadcrumb-category span.sp {
  margin-left: 8px;
}
body.archive.category #breadcrumb .breadcrumb-item {
  margin-left: 5px;
}
.breadcrumb-caption {
  margin: 0;
}
.breadcrumb-style .sp {
  margin: 0 10px 0 7px;
}
.footer-cta-inner {
  border-top: 1px solid #eee;
  text-align: center;
  padding: 70px 0;
}
h2.footer-cta-title {
  font-size: 22px;
  font-weight: 500;
  margin-bottom: 30px;
}
a.footer-cta-link,
a.license-cta {
  display: inline-block;
  background: #555;
  color: #fff;
  padding: 30px 60px;
  font-size: 16px;
  line-height: 1;
  text-decoration: none;
  box-shadow: 2px 2px 4px rgb(0 0 0 / 20%);
  margin-top: 30px;
  transition: all 0.3s;
}
a.footer-cta-link:hover,
a.license-cta:hover {
  opacity: 0.6;
}
a.footer-cta-link i,
a.license-cta i {
  margin-right: 5px;
}
a.license-cta {
  background: #BB1B8D;
  margin-top: 0;
  margin: 10px 0;
  font-size: 20px;
  line-height: 1.5;
  font-weight: 500;
}
.license-cta-wrap {
  text-align: center;
}
#footer {
  background: #f5f5f5;
  margin-top: 0;
}
.footer-info-wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 35px;
  padding-top: 10px;
}
.footer-menu-wrap {
  display: flex;
}
.footer-bottom-logo img {
  height: 64px;
}
ul.footer-menu-list {
  margin: 0;
  padding: 0;
  list-style: none;

  margin-right: 60px;
}
ul.footer-menu-list:nth-last-of-type(1) {
  margin-right: 0px;
}
ul.footer-menu-list li {
  margin: 0;
  margin-bottom: 15px;
}
ul.footer-menu-list li a {
  font-size: 14px;
  text-decoration: none;
  color: #1A1919;
}
ul.footer-menu-list li a:hover {
  text-decoration: underline;
}
.footer-bottom {
  position: static;
}
.footer-bottom-logo {
  position: static;
  float: none;
}
.footer-bottom-content {
  float: none;
  text-align: center;
}
.top-banner-img img {
  width: auto;
  height: 80px;
}
@media screen and (max-width: 1023px){
  .mblt-header-mobile-buttons {
    margin-top: 0px;
  }
  .mobile-header-menu-buttons {
    width: 35px;
    left: unset;
    min-width: unset;
    min-height: unset;
    top: 72px;
    right: 15px;
    box-shadow: unset;
    background: transparent;
    position: absolute;
  }
  .mobile-menu-buttons .menu-caption {
    display: none;
  }
  .mobile-menu-buttons > li {
    padding-top: 0;
  }
  .mobile-menu-buttons .menu-button span.fa-bars {
    font-size: 26px;
    color: #000;
  }
  .menu-drawer a {
    padding: 15px 10px;
    border-bottom: 1px solid #ddd;
  }
  #navi-menu-content {
    padding-top: 15px;
  }
  .logo-image a img {
    width: auto;
    max-height: 42px;
  }
  .institute-title {
    font-size: 13px;
  }
  .mv-wrap {
    height: auto;
  }
  .mv-content {
    padding: 20px 15px;
    display: block;
  }
  .mv-content-left {
    width: 100%;
    text-align: center;
    margin-bottom: 20px;
  }
  .mv-content-left img {
    width: auto;
    max-height: 200px;
  }
  .mv-content-right {
    width: 100%;
    text-align: center;
  }
  .mv-inner {
    padding: 20px 15px;
  }
  .mv-catch {
    font-size: 17px;
    text-align: center;
  }
  .mv-title {
    font-size: 17px;
    text-align: center;
    line-height: 1.6;
  }
  .mv-catch, .mv-title {
    letter-spacing: 0;
  }
  .mv-text {
    font-size: 14px;
  }
  .top-service-list {
    display: block;
  }
  .top-service {
    margin-bottom: 25px;
  }
  a.top-service-title h2 {
    font-size: 20px;
  }
  h2.footer-cta-title {
    font-size: 20px;
  }
  .footer-cta-inner {
    padding: 70px 15px;
  }
  a.footer-cta-link, a.license-cta {
    padding: 25px 15px;
    width: 100%;
  }
  .footer-info-wrap {
    display: block;
  }
  .footer-bottom-logo {
    text-align: center;
  }
  .footer-menu-wrap {
    display: block;
    margin-top: 30px;
  }
  ul.footer-menu-list {
    margin: 0;
  }
  ul.footer-menu-list li {
    text-align: center;
  }
  ul.footer-menu-list li a {
    font-size: 16px;
  }
  .footer-bottom-logo img {
    max-height: 46px;
  }
  .header-bg-wrap {
    height: 106px;
  }
  .header-text-wrap h1.entry-title {
    font-size: 24px;
  }
  h2.h-title {
    font-size: 20px;
  }
  h3.h-title {
    font-size: 20px;
    line-height: 1.55;
    margin-top: 0.8em;
  }
  h4.h-title {
    line-height: 1.55;
    font-size: 18px;
    padding-left: 24px;
  }
  h4.h-title::before {
    top: 5px;
    left: 0;
    width: 18px;
    height: 18px;
  }
  .signature-name {
    font-size: 18px;
  }
  .support-box-item {
    min-width: unset;
    font-size: 16px;
  }
  .support-box-img img {
    height: 30px;
  }
  .support-box.support-box-01 .support-box-item {
    padding: 15px 30px;
    min-width: 126px;
  }
  .support-box.support-box-02 .support-box-item {
    padding: 15px 15px;
  }
  .page-title-01-title {
    font-size: 20px;
  }
  .page-title-01-sub {
    font-size: 16px;
  }
  .page-title-01-left {
    width: 80px;
  }
  .page-title-01-right {
    width: calc(100% - 80px);
    padding-left: 12px;
  }
  .text-style-02 {
    padding: 30px 15px;
    font-size: 18px;
  }
  .photo-style-04 img {
    height: 60px;
  }
  .flex-style-01 {
    display: block;
    margin-top: 0;
  }
  .flex-style-left {
    width: 100%;
  }
  .flex-style-right {
    width: 100%;
    text-align: center;
  }
  .flex-style-right img {
    width: auto;
    height: 250px;
  }
  .table-style-01 table tr th,
  .table-style-01 table tr td {
    padding: 15px 15px;
  }
  .table-style-01 table tr th {
    width: 100px;
  }
  .table-style-01 table tr td {
    width: calc(100% - 100px);
  }
  a.contact-mail {
    font-size: 24px;
  }
  .photo-style-02 {
    max-width: 260px;
  }

  .flex-style-02-right img {
    width: 80px;
    height: 100px;
  }
  .signature-pos {
    font-size: 14.5px;
    letter-spacing: 0;
  }
  .flex-style-02-left {
    padding-right: 10px;
  }

  .top-banner-header {
    font-size: 20px;
  }
  .top-banner-img img {
    width: auto;
    height: 60px;
  }
}
@media screen and (max-width: 834px){
  main.main, div.sidebar {
    padding: 32px 15px;
  }
}
@media screen and (max-width: 390px){
  .logo-image {
    padding: 10px 15px;
    text-align: left;
  }
  .logo-image a img {
    max-height: 55px;
  }
  .institute-title {
    font-size: 12px;
    letter-spacing: 0;
    line-height: 1.4;
  }
  .institute-tagline {
    padding: 5px 0;
  }
  .mobile-header-menu-buttons {
    top: 55px;
  }
}
@media screen and (device-aspect-ratio: 40/71) {
  .mobile-header-menu-buttons {
    top: 70px;
  }
}
