﻿@charset "UTF-8";

/* ########### 心身統一合氣道会 ########### */
/*
 * "ZenKakuGothicNew" is lisenced under the SIL Open Font License 1.1
 * http://fonts.googleapis.com
 * https://www.google.com/fonts/attribution
 * http://scripts.sil.org/OFL
 */
/*
/* Copyright (c) 2025 心身統一合氣道会
 Released under the MIT license
 https://opensource.org/licenses/mit-license.php */

:root,
[data-bs-theme=light] {
  --bs-green-rgb: #1c7a6b;
}

.border-green {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-green-rgb), var(--bs-border-opacity)) !important;
}

.btn-green {
  width: 170px;
  --bs-btn-color: #fff;
  --bs-btn-bg: #1c7a6b;
  --bs-btn-border-color: #1c7a6b;
  --bs-btn-hover-color: #1c7a6b;
  --bs-btn-hover-bg: #fff;
  --bs-btn-hover-border-color: #146c43;
  --bs-btn-focus-shadow-rgb: 60, 153, 110;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #11603c;
  --bs-btn-active-border-color: #13653f;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #165b50;
  --bs-btn-disabled-border-color: #165b50;
}

.arrow-icon {
  top: 50%;
  right: 1rem;
  transform: translateY(-50%);
}

.text-green {
  color: #1c7a6b;
}

.btn-success {
  --bs-btn-color: #fff;
  --bs-btn-bg: #1c7a6b;
  --bs-btn-border-color: #1c7a6b;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #157347;
  --bs-btn-hover-border-color: #146c43;
  --bs-btn-focus-shadow-rgb: 60, 153, 110;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #146c43;
  --bs-btn-active-border-color: #13653f;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #1c7a6b;
  --bs-btn-disabled-border-color: #1c7a6b;
}

@font-face {
  font-family: "ZenKakuGothicNew";
  font-style: normal;
  font-weight: 500;
  src: url("../font/ZenKakuGothicNew-Medium.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "ZenKakuGothicNew";
  font-style: normal;
  font-weight: 700;
  src: url("../font/ZenKakuGothicNew-Bold.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "ZenKakuGothicNew";
  font-style: normal;
  font-weight: 900;
  src: url("../font/ZenKakuGothicNew-Black.woff") format("woff");
  font-display: swap;
}

label,
td,
th,
p,
div,
dd,
dt,
li,
a,
input,
textarea,
select,
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "ZenKakuGothicNew", "メイリオ", "Meiryo", "HiraKakuProN-W3", "Hiragino Kaku Gothic Pro", sans-serif;
}

a {
  color: #000;
  text-decoration: none;
}

@media (max-width: 576px) {

  html {
    font-size: 0.875rem;
  }

  .btn-green {
    width: 150px;
  }
}

/**************** ヘッダー ***************/
.navbar-toggler {
  background-color: #1c7a6b;
  border: none;
  padding: 0.5rem 0.6rem;
  border-radius: 6px;
  position: absolute;
  top: 1.2rem;
  right: 1rem;
}

.navbar-toggler:focus {
  box-shadow: none;
  outline: none;
}

/* 三本線 */
.navbar-toggler .navbar-toggler-icon {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='white' stroke-width='2' stroke-linecap='round' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
  transition: all 0.3s ease;
}

/* 開いた時は ×（バツ） に */
.navbar-toggler[aria-expanded="true"] .navbar-toggler-icon {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='white' stroke-width='2' stroke-linecap='round' d='M6 6 L24 24 M24 6 L6 24'/%3E%3C/svg%3E");
}

/* カスタムスライド・フェードアニメーション */
.navbar-collapse.collapse {
  display: block;
  height: 0;
  overflow: hidden;
  opacity: 0;
  transition: height 0.4s ease, opacity 0.4s ease;
}

/* 開いたとき */
.navbar-collapse.collapse.show {
  height: auto !important;
  opacity: 1;
  transition: height 0.4s ease, opacity 0.4s ease;
}

.tel-number {
  color: #218e78;
  font-size: 2rem;
  font-weight: 900 !important;
}

.tel-number::before {
  content: "";
  display: inline-block;
  width: 25px;
  height: 25px;
  background-image: url('../image/icon-tel.svg');
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
  margin-bottom: 0.5rem;
}

.address {
  font-size: 0.8125rem;
}

.honbu {
  font-size: 0.95rem;
  font-weight: 700;
  vertical-align: middle;
  padding-left: 0.25rem;
}

.small-text {
  font-size: 0.6875rem;
  padding-left: 0.25rem;
}

.logo-image {
  display: inline-block;
  width: 244px;
  height: 40px;
  background-image: url('../image/logo.png');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  vertical-align: middle;
}

.nav-item,.footer-link li a,#news li a{
  transition: color 0.3s ease;
}

.nav-item:hover,.footer-link li a:hover,#news li a:hover{
  color: #1c7a6b;
  text-decoration: underline;
  transition: width 0.4s ease;
}


@media (max-width: 576px) {

  .tel-number {
    font-size: 1.65rem;
  }

  .logo-image {
    width: 180px;
    height: 29px;
  }
}

@media (min-width: 576.1px) {

  .logo-address {
    max-width: 360px;
    width: 100%;
  }

}

@media (max-width: 767px) {
  header .container {
    max-width: 100%;
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 0 !important;
  }

  /* メニュー全体（#navbarMenu）の背景は白に */
  #navbarMenu {
    background-color: #ffffff;
  }

  /* ナビメニュー（ul）の背景だけ緑にする */
  #navbarMenu ul.navbar-nav {
    background-color: #1c7a6b;
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
  }

  /* ホバー効果 */
  #navbarMenu .navbar-nav .nav-link:hover {
    background-color: rgba(255, 255, 255, 0.1);
  }

  /* 左寄せ */
  #navbarMenu .navbar-nav .nav-link {
    color: #ffffff;
    border-top: 1px solid #ffffff;
    border-bottom: 1px solid #ffffff;
    padding: 0.75rem 1rem;
    text-align: left;
  }

  #navbarMenu .tel-number,
  #navbarMenu .small-text {
    text-align: left;
  }
}

@media (min-width: 768.1px) {
  .nav-link {
    font-size: 0.875rem;
    margin-left: 1rem !important;
    margin-bottom: 0.25rem !important;
    padding-inline: 0rem !important;
    padding-block: 0rem !important;
  }

}

/**************** メインビジュアル カルーセル1 ****************/
#videoCarousel {
  position: relative;
  height: 100vh;
  overflow: hidden;
}

.bg-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: auto;
  height: 100%;
  min-width: 100%;
  min-height: 100%;
  transform: translate(-50%, -50%);
  object-fit: cover;
  z-index: 0;
}

.carousel-item,
.carousel-inner {
  height: 100vh;
}

.overlay {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.3);
  /* 黒30%オーバーレイ */
  z-index: 1;
}

.carousel-caption {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  padding-left: 1rem;
  padding-right: 1rem;
  transform: translate(0%, -50%);
  z-index: 2;
  text-align: left;
}

.main-text {
  font-size: 3rem !important;
  font-weight: 700;
  line-height: 1.55;
}

.logo-image2 {
  display: inline-block;
  width: 244px;
  height: 40px;
  background-image: url('../image/logo-white.png');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  vertical-align: middle;
}

@media (max-width: 992px) {

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

  .logo-image2 {
    width: 180px;
    height: 29px;
  }
}

@media (max-width: 767px) {

  .main-text {
    font-size: 1.55rem !important;
  }

  #videoCarousel,
  .carousel-inner,
  .carousel-item {
    height: 315px;
  }

  .bg-video {
    height: 315px;
    min-height: 315px;
  }

  .logo-image2 {
    margin-top: -0.15rem;
    width: 136px;
    height: 22px;
  }
}

/**************** カルーセル2 ****************/

.slider-wrapper {
  width: 100%;
  height: 420px;
  position: relative;
}

.slider {
  animation: scrollSlider 20s linear infinite;
  display: flex;
  width: 200%;
  height: 100%;
  flex-shrink: 0;
}

.slide {
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
}

/* 背景画像を指定 */
/*.bg1 {
  background-image: url('../image/top-slide01.jpg');
}

.bg2 {
  background-image: url('../image/top-slide02.jpg');
}

.bg3 {
  background-image: url('../image/top-slide03.jpg');
}

.bg4 {
  background-image: url('../image/top-slide04.jpg');
}

.bg5 {
  background-image: url('../image/top-slide05.jpg');
}

.bg6 {
  background-image: url('../image/top-slide06.jpg');
}
*/
@keyframes scrollSlider {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

@media (max-width: 768px) {

  .slider-wrapper {
    width: 100%;
    height: 200px;
    position: relative;
  }
}

/**************** トップページ帯 ****************/
.hero-section {
  position: relative;
  height: 200px;
  width: 100%;
}

.hero-text {
  position: absolute;
  z-index: 2;
  color: white;
  text-align: center;
  font-size: 1.75rem;
  line-height: 1.75;
  padding: 0 1rem;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  width: 100%;
}

.hero-section-image {
  position: absolute;
  height: 100%;
  width: 100%;
  /*background-image: url('../image/top-bg01.jpg');*/
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0.4;
  z-index: -2;
}

.hero-section-color {
  content: "";
  position: relative;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: #218e78;
  mix-blend-mode: multiply !important;
  z-index: -1;
}

@media (max-width: 768px) {
  .hero-text {
    font-size: 1.125rem;
    line-height: 1.75;
  }

  .hero-section {
    height: 150px;
  }
/*
  .hero-section-image {
    background-image: url('../image/top-bg01-sf.jpg');
  }*/
}

/**************** トップページリンク一覧 ****************/
.card-title {
  font-size: 1.25rem;
  line-height: 1.5;
  font-weight: 700;
  min-height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-top: 1px solid rgb(0, 0, 0);
  border-bottom: 1px solid rgb(0, 0, 0);
}

.card {
  background-color: rgba(255, 255, 255, 0);
}

.card-text {
  text-align: left;
  line-height: 1.75;
  font-weight: 700;
  min-height: 70px;
  margin-bottom: 0.5rem;
}

.card-bg {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  height: 280px;
}


@media (max-width: 768px) {
  .card-bg {
    height: 220px;
  }

  .card-text {
    min-height: 85px;
  }

}

@media (max-width: 576px) {
  .card-bg {
    height: 200px;
  }

  .card-title {
    font-size: 1.0625rem;
    line-height: 1.5;
    min-height: 60px;
  }

  .card-text {
    min-height: auto;
    margin-bottom: 1.5rem;
  }
}

/* 背景画像を指定 */
/*.bg-c1 {
  background-image: url('../image/link-about.jpg');
}

.bg-c2 {
  background-image: url('../image/link-welcome.jpg');
}

.bg-c3 {
  background-image: url('../image/link-class.jpg');
}

.bg-c4 {
  background-image: url('../image/link-teacher.jpg');
}

.bg-c5 {
  background-image: url('../image/link-contact.jpg');
}

.bg-c6 {
  background-image: url('../image/link-voice.jpg');
}
*/
/**************** トップページ紹介ブロック ****************/
.tt1 {
  font-size: 1.0625rem;
  line-height: 1.55;
}

.tp1 {
  display: flex;
  align-items: center;
  justify-content: center;
}

.bg-tp1 {
  background-size: contain;
  background-repeat: no-repeat;
  width: 430px;
  height: 330px;
  /*background-image: url('../image/top-photo01.png');*/
}

@media (max-width: 768px) {
  .bg-tp1 {
    width: 300px;
    height: 225px;
    margin-bottom: 1rem;
  }
}

.bg-top {
  top: 0;
  position: absolute;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  height: 100%;
  /*background-image: url('../image/top-bg02.jpg');*/
  opacity: 0.1;
}

@media (max-width: 576px) {

  .bg-top {
    height: 650px;
    /*background-image: url('../image/top-bg02-sf.jpg');*/
  }

  .top-introduction {
    background-color: #eff7f5;
  }
}

/**************** フッター ****************/

.footer-container {
  max-width: 992px;
  margin: 0 auto;
  padding: 2rem;
}

.footer-link li {
  font-size: 0.875rem;
  line-height: 2;
}

.footer-copy {
  font-size: 0.8125rem;
  background-color: #1c7a6b;
  color: #ffffff;
  text-align: center;
  padding: 0.5rem 0;
}

.copy-mark {
  display: inline-block;
  vertical-align: 0.05rem;
  font-size: 0.8725rem;
}

@media (max-width: 576px) {

  .footer-copy {
    font-size: 0.6875rem;
  }

  .copy-mark {
    display: inline-block;
    vertical-align: 0rem;
  }

  .footer-container {
    padding: 0rem 1rem;
  }
}

/**************** 下層ページ共通メインビジュアル ****************/

.underlayer-introduction {
  background-color: #eff7f5;
}

.main-visual {
  position: relative;
  height: 400px;
}
/*
.main-visual.about {
  background: url('../image/about-main-visual.jpg') center center / cover no-repeat;
}

.main-visual.welcome {
  background: url('../image/welcome-main-visual.jpg') center 25% / cover no-repeat;
}

.main-visual.class {
  background: url('../image/class-main-visual.jpg') center top / cover no-repeat;
}

.main-visual.teacher {
  background: url('../image/teacher-main-visual.jpg') 75% 25% / cover no-repeat;
}

.main-visual.voice {
  background: url('../image/voice-main-visual.jpg') 75% center / cover no-repeat;
}

.main-visual.contact {
  background: url('../image/contact-main-visual.jpg') center bottom / cover no-repeat;
}

.main-visual.news {
  background: url('../image/news-main-visual.jpg') center 50% / cover no-repeat;
}*/

.main-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.25);
  /* 黒25%透過 */
  z-index: 1;
}

.main-title {
  color: #fff;
  font-size: 2.5rem;
  font-weight: 700;
  z-index: 2;
  line-height: 1.75;
}

/* スマホ対応 */
@media (max-width: 576px) {
  .main-visual {
    height: 260px;
  }

  .main-title {
    font-size: 1.5rem;
  }
/*
  .main-visual.about {
    background: url('../image/about-main-visual-sf.jpg') center center / cover no-repeat;
  }

  .main-visual.welcome {
    background: url('../image/welcome-main-visual-sf.jpg') 100% center / cover no-repeat;
  }

  .main-visual.class {
    background: url('../image/class-main-visual-sf.jpg') center center / cover no-repeat;
  }

  .main-visual.teacher {
    background: url('../image/teacher-main-visual-sf.jpg') center top / cover no-repeat;
  }

  .main-visual.voice {
    background: url('../image/voice-main-visual-sf.jpg') 75% center / cover no-repeat;
  }

  .main-visual.contact {
    background: url('../image/contact-main-visual-sf.jpg') center top / cover no-repeat;
  }

  .main-visual.news {
    background: url('../image/news-main-visual-sf.jpg') center top / cover no-repeat;
  }*/
}

/**************** 下層ページ共通帯 ****************/
.hero-section.underlayer {
  position: relative;
  height: 110px;
  width: 100%;
}

/**************** 下層ページ共通紹介文 ****************/
.container.underlayer {
  max-width: 992px;
  padding-inline: 2rem;
}

.ut1 {
  line-height: 2;
}

.bg-underlayer {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  height: 230px;
  margin-left: 1rem;
}
/*
.bg-underlayer.about {
  background-position: right center;
  background-image: url('../image/about-photo01.jpg');
}

.bg-underlayer.welcome {
  background-position: center center;
  background-image: url('../image/welcome-photo01.jpg');
}

.bg-underlayer.class01 {
  background-position: center center;
  background-image: url('../image/class-photo01.jpg');
}

.bg-underlayer.class02 {
  background-position: center center;
  background-image: url('../image/class-photo02.jpg');
}

.bg-underlayer.class03 {
  background-position: center center;
  background-image: url('../image/class-photo03.jpg');
}*/

@media (max-width: 768px) {
  .container.underlayer {
    max-width: 576px;
    padding-inline: 1rem;
  }

  .bg-underlayer {
    height: 225px;
    margin-left: 0rem;
  }
}

@media (max-width: 576px) {
  .container.underlayer {
    max-width: 405px;
  }

  .bg-underlayer {
    height: 205px;
    margin-left: 0rem;
  }

}

/**************** クラス紹介ページ ****************/
.class-tl {
  color: #1c7a6b;
  font-weight: 900;
  font-size: 1.125rem;
  line-height: 1.5;
  margin-bottom: 1rem;
}

.class-box {
  border-top: 1px solid #000000;
  padding-block: 2rem;
}

.class-box.last {
  border-bottom: 1px solid #000000;
}

@media (max-width: 576px) {

  .class-tl {
    font-size: 1.0625rem;
    margin-bottom: 0.75rem;
  }
}

.text-indent1 {
  padding-left: 1.07em;
  text-indent: -1.07em;
}

/**************** 会員の声ページ ****************/

.voice-box {
  padding-block: 1rem;
}

.voice-tl {
  border-bottom: 1px solid #1c7a6b;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.5;
  margin-bottom: 0.5rem;
  padding-bottom: 0.5rem;
}

/**************** 指導員ページ ****************/
.carousel-container {
  max-width: 950px;
  margin: auto;
  position: relative;
  overflow: hidden;
  padding-inline: 1rem;
}

.carousel-inner-custom {
  display: flex;
  transition: transform 0.5s ease;
}

.carousel-card {
  flex: 0 0 33.3333%;
  padding: 0 1.5rem;
  box-sizing: border-box;
}


.arrow-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  background: none;
  border-color: transparent;
  cursor: pointer;
  z-index: 10;
  opacity: 1;
  transition: opacity 0.3s;
}

.arrow-left {
  left: -20px;
  border-width: 20px 20px 20px 10px;
  border-right-color: #1c7a6b;
}

.arrow-right {
  right: -20px;
  border-width: 20px 10px 20px 20px;
  border-left-color: #1c7a6b;
}

.arrow-btn.disabled {
  pointer-events: none;
  opacity: 0.4;
}

@media (max-width: 768px) {
  .carousel-card {
    flex: 0 0 100%;
  }
}

.bg-teacher {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  height: 230px;
  margin-bottom: 2rem;
}

@media (max-width: 768px) {

  .bg-teacher {
    height: 330px;
  }
}

@media (max-width: 576px) {

  .bg-teacher {
    height: 250px;
  }

  .carousel-container {
    padding-inline: 1.5rem;
  }
}

.carousel-card p {
  margin-top: 1rem;
}
/*
.bg-teacher.teacher01 {
  background-position: center center;
  background-image: url('../image/teacher-photo01.jpg');
}

.bg-teacher.teacher02 {
  background-position: center center;
  background-image: url('../image/teacher-photo02.jpg');
}

.bg-teacher.teacher03 {
  background-position: center center;
  background-image: url('../image/teacher-photo03.jpg');
}

.bg-teacher.teacher04 {
  background-position: center center;
  background-image: url('../image/teacher-photo01.jpg');
}*/

/**************** アクセスページ ****************/
table.contact-table {
  width: 100%;
  max-width: 992px;
  margin: auto;
  border-collapse: collapse;
}

.table {
  border-top: 1px solid #000 !important;
}

.contact-table tr {
  border-bottom: 1px solid #000 !important;
}

table.contact-table td {
  padding: 1rem;
  vertical-align: top;
}

table.contact-table td.label {
  white-space: nowrap;
  font-weight: bold;
  width: 6em;
}

/* スマホ表示：縦並び、項目ごとにボーダー分離 */
@media (max-width: 768px) {

  table.contact-table,
  table.contact-table tbody,
  table.contact-table tr,
  table.contact-table td {
    display: block;
    width: 100%;
  }


  table.contact-table td.label {
    margin-bottom: -1.3rem;
  }

  .contact-table tr {
    border-bottom: 0px solid #000 !important;
  }

  .label {
    border-bottom: 0px solid #000 !important;
    padding-block: 0;
    margin-block: 0;
  }

}

.table {
  background-color: #eff7f5 !important;
}

.table td {
  background-color: #eff7f5 !important;
}

.contact-tl {
  color: #1c7a6b;
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1.5;
  margin-block: 3rem 1.5rem;
  text-align: center;
}


.h2title-bottom {
  margin-right: auto;
  margin-left: auto;
  width: 45px;
  margin-top: 1.5rem;
  margin-bottom: 2rem;
  border: none;
  height: 2px;
  background-color: rgb(0, 0, 0) !important;
}

.breadcrumb-item {
  font-size: 0.75rem;
  line-height: 1;
}

.breadcrumb-item.active {
  color: #3a3a3a;
}

.page-numbers {
  padding-right:0.75em;
}
.nav-links{
  display: flex;
	justify-content:space-between;
}
.underlayer-introduction h5{
    font-size: 1.0625rem;
  }
/**************** お問い合わせフォーム ****************/
.form-label-group {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.form-label-required {
  color: red;
  font-size: 0.875rem;
  white-space: nowrap;
  margin-left: 0.5rem;
}
