@charset "utf-8";


html,body{
   font-family: 'Zen Kaku Gothic New', sans-serif;

  font-weight: lighter ;
  
  font-style: normal;

  color: #333333 !important;
  overflow: hidden;

}
body{
  min-width: 1200px;
  /*background-color: rgb(250, 247, 254);*/
  letter-spacing: 3px;
  background-color: #F2F2F2;

}
.pc{
  display: block;
}
.sp{
  display: none;
}
li{
  list-style: none;
}
a{
  text-decoration: none;
  color: #000;

}
.fade-in {
  opacity: 0;
  transition-duration: 500ms;
  transition-property: opacity, transform;
}

.fade-in-up {
  transform: translate(0, 50px);
}
.scroll-in {
  opacity: 1;
  transform: translate(0, 0);
}
.fade-in-left {
  transform: translate(-50px, 0);
}

.fade-in-right {
  transform: translate(50px, 0);
}
/* =========================
   基本レイアウト
========================= */
.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #fff;
  border-bottom: 1px solid #ddd;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
  z-index: 1000;
}

.header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
}

/* ロゴ */
.logo img {
  height: 100px;
  width: auto;
  display: block;
  padding: 10px 20px;
}

/* 右側（メニュー＋赤ブロック） */
.header-right {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* メニューアイコン（二本線） */
.menu-toggle {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 5px;
}
.menu-toggle span {
  display: block;
  width: 26px;
  height: 2px;
  background: #333;
  transition: 0.3s;
}

/* 赤ブロック */
.reserve-area {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 240px;
  background-color: #c23a2c;
}

/* PC画像ボタン */
.header-btn-pc {
  flex: 1;
}
.header-btn-pc img {
  display: block;
  width: 100%;
  height: auto;
}

/* SP用テキストボタン */
.header-btn-sp {
  display: none;
  flex: 1;
  justify-content: center;
  align-items: center;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
  padding: 14px 0;
  text-align: center;
}
.header-btn-sp.reserve {
  background-color: #c23a2c;
}
.header-btn-sp.coupon {
  background-color: #d74b38;
}
.sp-fixed-buttons{
  display: none;
}
/* =========================
   レスポンシブ
========================= */
@media (max-width: 900px) {
  .header-inner {
    flex-direction: row; /* 横並びに戻す */
    justify-content: space-between; /* 左右に配置 */
    align-items: center; /* 垂直中央揃え */
  }

  .logo img {
    height: 58px;
    padding: 10px 16px;
  }

  .header-right {
    width: auto; /* 横幅固定を解除 */
    justify-content: flex-end; /* 右端に寄せる */
    gap: 10px; /* ボタン間の間隔 */
    padding: 0 10px;
  }

  .reserve-area {
    width: auto; /* 元々の100%から解除 */
    background: none;
    display: flex; 
    gap: 5px; 
  }

  .header-btn-pc {
    display: none;
  }

  .header-btn-sp {
    display: flex;
  }
  .sp-fixed-buttons {
    display: flex;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 9999;
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 -2px 6px rgba(0,0,0,0.2);
  }

  .sp-fixed-buttons a {
    flex: 1;
    text-align: center;
    padding: 14px 0;
    font-weight: 600;
    color: #fff;
    text-decoration: none;
    font-size: 14px;
  }

  .sp-fixed-buttons a.reserve {
    background-color: #c23a2c;
  }

  .sp-fixed-buttons a.coupon {
    background-color: #d74b38;
  }

  /* 元のヘッダー内SPボタンは非表示に */
  .header-btn-sp {
    display: none !important;
  }
}

/* =========================
   ナビメニュー
========================= */
.global-nav {
  display: none;
  background: #fff;
  border-top: 1px solid #ddd;
}
.global-nav.open {
  display: block;
}
.global-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.global-nav li a {
  display: block;
  padding: 14px 20px;
  color: #333;
  text-decoration: none;
  border-bottom: 1px solid #eee;
}
.global-nav li a:hover {
  background: #f5f5f5;
  color: #c23a2c;
}

/* 固定ヘッダーの余白対策 */
body {
  padding-top: 80px;
}
.kv{
  width: 100%;
  
}
.heading{
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 60px;
  text-align: center;
}
.slick-img1 img{
  width: 100%;
  
}
.top-blog-wrapper{
  padding: 100px 0;
  background-color: #FAF6F0;
}
.news-btn {
  display: flex;
  width: 250px;
  margin: 0 auto;
  align-items: center;
  justify-content: center;
  padding: 14px 28px;
  border: 2px solid #c23a2c;
  border-radius: 8px;
  background-color: #fff;
  color: #c23a2c;
  font-size: 16px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.3s ease;
}

.news-btn .arrow {
  font-size: 14px;
  transition: transform 0.3s ease;
}

/* hover時の動き */
.news-btn:hover {
  background-color: #c23a2c;
  color: #fff;
}

.news-btn:hover .arrow {
  transform: translateX(4px);
}
.top-blog-box{
  width: 1100px;
  margin: 0 auto;
  margin-bottom: 70px;
}
.blog-slick-item{
  width: 300px;
  margin: 0 20px;
}
.blog-slick-img{
  width: 100%;
  height: 200px;
  border-radius: 10px;
  content: "";
  background-image: url("../img/thumb.jpg");
  background-size: cover;
  margin-bottom: 20px;
}
.blog-slick-img a{
  display: block;
  content: "";
}
.slick-prev:before, .slick-next:before{
  color: #DD0000 !important;
}
.blog-slick-title{
  font-size: 16px;
  margin-bottom: 8px;
  font-weight: 500;
}
.blog-slick-content{
  font-size: 13px;
  text-align: justify;
}
.top-about-wrapper{
  padding: 100px 0;
}
.top-about-box{
  width: 1100px;
  margin: 0 auto;
}
.top-about-flex{
  display: flex;
  margin-bottom: 100px;
}
.top-about-img{
  width: 55%;
  margin-right: 5%;
}
.top-about-img img{
  width: 100%;
}
.top-about-right{
  width: 40%;
}
.about-heading{
  width: 400px;
  padding: 20px 0;
  background-color: #DD0000;
  margin-bottom: 50px;
  display: flex;
  justify-content: center;
}
.about-heading2{
  margin: 0 auto;
  margin-bottom: 50px;
}
.about-heading h3{
  color: #fff;
}
.logo25{
  width: 300px;
  margin: 0 auto;
  margin-bottom: 60px;
}
.logo25 img{
  width: 100%;
}
.top-about-right p{
  font-size: 15px;
  font-weight: 500;
}
.top-about-img2 img{
  width: 100%;
}
.top-access-wrapper{
  background-color: #FAF6F0;
  margin-bottom: 80px;
  padding: 100px 0;
}
.top-access-box{
  width: 1100px;
  margin: 0 auto;
  display: flex;
}
.top-access-box table{
  width: 55%;
  margin-right: 3%;
}

.top-access-box table th{
  width: 30%;
  border-top: 1px solid #707070;
  padding: 20px 0;
  font-size: 13px;
}
.top-access-box table td{
  width: 70%;
    border-top: 1px solid #707070 !important;
    padding: 20px 0;
    font-size: 13px;
}
.top-access-box table tr img{
  width: 100%;
}
.map{
  width: 42%;
}
.map iframe{
  height: 100%;
}
.top-price-wrapper{
  padding: 100px 0;
}
.top-price-box{
  width: 1100px;
  margin: 0 auto;
  margin-bottom: 50px;
  padding: 50px 0;
  background-color: #FAF6F0;
  border-radius: 25px;
}
.top-price-img{
  width: 70%;
  margin: 0 auto;
  margin-bottom: 50px;
}
.top-price-img img{
  width: 100%;
}
.shop-wrapper{
    padding: 50px 0;
}
.shop-box{
  width: 900px;
  margin: 0 auto;
  display: flex;
}
.shop-list{
  width: 45%;
  margin :0 2.5%;
}
.shop-img{
  width: 100%;
  margin-bottom: 10px;
}
.shop-img img{
  width: 100%;

}
.shop-list p{
  text-align: center;
}
.top-coupon-wrapper{
  padding: 50px 0;
}
.coupon-img{
  width: 1100px;
  margin: 0 auto;
  margin-bottom: 50px;
}
.coupon-img img{
  width: 100%;
}
footer{
  background-color: #E3E3E3;
  padding: 80px 0;
}
footer ul{
  width: 500px;
  margin: 0 auto;
  margin-bottom: 60px;
  display: flex;
  justify-content: space-between;
}
footer ul li{
  font-size: 13px;
  border-right: solid 1px #333333;
  padding-right: 11px;
}
footer ul li:nth-last-child(1){
 border-right: initial;
}
.footer-img-list{
  width: 210px;
  margin: 0 auto;
  display: flex;
  
}
.footer-img-item{
  width: 60px;
  margin: 0 5px;
}
.footer-img-item img{
  width: 100%;
}
.footer-logo{
  width: 180px;
  margin: 0 auto;
}
.footer-logo img{
  width: 100%;
}
.copy{
  padding: 40px 0;
  background-color: #DD0000;
}
.copy p{
  text-align: center;
  color: #fff;
  font-size: 13px;
  letter-spacing: 1px;
}
/*page-service*/
.page-kv{
  width: 100%;
  margin-bottom: 100px;
}
.page-kv img{
  width: 100%;
}
.service-box{
  padding: 100px 0;
}
.service-inner{
  width: 1100px;
  margin: 0 auto;
}
.service-flex{
  display: flex;
}
.service-img{
  width: 40%;
  margin-right: 5%;
}
.service-img img{
  width: 100%;
}
.service-contents{
  width: 55%;
}
.service-contents h3{
  font-size: 16px;
  letter-spacing: 1px;
  margin-bottom: 20px;
  text-align: justify;
}
.service-contents-inner{
  padding: 30px;
  background-color: #FAF6F0;
  border-radius: 25px;
  box-shadow: 0px 0px 10px #5c5c5c2d;
}
.service-point{
  width: 50%;
  margin: 0 auto;
  margin-bottom: 20px;
  background-color: #E32C13;
  border-radius: 10px;
  padding: 10px 0;
  text-align: center;
  color: #fff;
}
.service-point-inner{
  margin-bottom: 20px;
}
.service-point-inner:nth-last-child(1){
  margin-bottom: 0;
}
.service-point-inner h4{
  margin-bottom: 10px;
  
}
.service-point-inner p{
  font-size: 14px;
  letter-spacing: 1px;
  font-weight: 500;
}
.service-box2{
  background-color: #FAF6F0;
}
.service-box2 .service-img{
  order: 1;
  margin-right: 0;
}
.service-box2 .service-contents{
  margin-right: 5%;
}
/*page-menu*/
.menu-nav{
  width: 700px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 100px;
}
.menu-nav a{
  width: 200px;
  padding: 10px 0;
  border-radius: 10px;
  color: #fff;
  background-color: #E32C13;
  margin: 0 15px;
  margin-bottom: 10px;
  text-align: center;
}
.menu-wrapper{
  margin-bottom: 100px;
}
.menu-box{
  width: 1000px;
  margin: 0 auto;
  padding: 70px 0;
  border-radius: 25px;
  background-color: #FAF6F0;
}
.menu-box-inner{
  width: 80%;
  margin: 0 auto;
}
.menu-flex{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.menu-flex-item{
  width: 45%;
  margin: 0 2.5%;
  margin-bottom: 50px;
}
.menu-img{
  width: 100%;
}
.menu-img img{
  width: 100%;
}
.menu-flex-item p{
  text-align: center;
  font-size: 13px;
  font-weight: 500;
}
.menu-flex2{
  display: flex;
  width: 50%;
  margin: 0 auto;
  margin-bottom: 70px;
}
.menu-flex-inner{
  width: 50%;
}
.menu-flex-inner p{
  font-size: 13px;
  line-height: 30px;
  font-weight: 500;
}
.read-more{
  display: block;
  width: 200px;
  padding: 10px 0;
  text-align: center;
  color: #fff;
  background-color: #E32C13;
  border-radius: 10px;
  margin: 0 auto;
  margin-bottom: 100px;
}
.more-box{
  display: none;
}
.more-contents{
  display: flex;
  flex-wrap: wrap;  
  justify-content: space-between;
  margin-bottom: 50px;
}

.more-flex{
  display: flex;
  width: 45%;
  margin: 0 2.5%;
  justify-content: space-between;
  margin-bottom: 20px;
}
.more-flex p{
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 1px;
}
.course-img{
  width: 50%;
  margin: 0 auto;
  margin-bottom: 30px;
}
.course-img img{
  width: 100%;
}
.course-heading{
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 20px;
  letter-spacing: 1px;
}
.course-caption{
  font-size: 14px;
  margin-bottom: 30px;
  letter-spacing: 1px;
}
.plan-wrapper{
  padding: 100px 0;
}
.plan-box{
  width: 1100px;
  margin: 0 auto;
}
.plan-flex{
  display: flex;
  align-items: center;
  margin-bottom: 70px;
}
.plan-left{
  width: 45%;
  margin-right: 5%;
}
.plan-left img{
  width: 100%;
}
.plan-right{
  width: 50%;
}
.plan-right p{
  font-size: 14px;
  letter-spacing: 1px;
}
.news-wrapper{
  width: 1100px;
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  margin-bottom: 70px;
}
.blog-item{
  width: 300px;
  margin: 0 20px;
  margin-bottom: 50px;
}
.blog-img{
  width: 100%;
  height: 200px;
  border-radius: 10px;
  content: "";
  background-image: url("../img/news/thumb.jpg");
  background-size: cover;
  margin-bottom: 20px;
}
.blog-img a{
  display: block;
  content: "";
}
.blog-day{
  font-size: 13px;
  margin-bottom: 8px;
  font-weight: 500;
}
.blog-title{
  font-size: 16px;
  margin-bottom: 8px;
  font-weight: 500;
}
.blog-content{
  font-size: 13px;
  text-align: justify;
}
.single-wrapper{
  padding: 100px 0;
}
.single-box{
  width: 900px;
  margin: 0 auto;
}
.single-title{
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 30px;
}
.single-thumb{
  width: 100%;
  margin-bottom: 40px;
}
.single-thumb img{
  width: 100%;
}
.single-inner{
  padding: 30px 0;
}
.news-list-btn{
  display: block;
  width: 300px;
  background-color: #c23a2c;
  text-align: center;
  margin: 0 auto;
  padding: 10px 0;
  border-radius: 15px;
  color: #fff;
}
@media(max-width: 900px){
 body{
  min-width: initial;
  padding-top: 50px;
  padding-bottom: 40px;
 } 
 .heading{
  font-size: 18px;
 }
 .top-blog-box{
  width: 90%;
}
 .blog-slick-item{
  width: 100%;
  margin: 0 20px;
}
.news-btn{
  font-size: 14px;
}
.slick-next{
  right: -11px!important;
}
.slick-prev{
 left: -11px!important; 
}
.top-about-box{
  width: 90%;
}
.top-about-flex{
  flex-direction: column;
  margin-bottom: 50px;
}
.top-about-img{
  width: 100%;
  margin-right: 0;
  margin-bottom: 30px;
}
.top-about-right{
  width: 100%;
}
.about-heading{
  width: 100%;
}
.about-heading{
  font-size: 14px;
}
.top-access-box{
  width: 90%;
  flex-direction: column;
}
.top-access-box table{
  width: 100%;
  margin-right: 0;
  margin-bottom: 30px;
}
.map{
  width: 100%;
  height: 300px;
}
.top-price-wrapper{
  padding: 50px 0;
}
.top-price-box{
  width: 90%;
}
.top-price-img{
  width: 100%;
  margin-bottom: 10px;
}
.shop-box{
  width: 90%;
  flex-direction: column;
}
.shop-list{
  width: 100%;
  margin: 0;
  margin-bottom: 50px;
}
.top-coupon-wrapper{
  overflow-x: scroll;
}
footer ul{
  width: 100%;
  margin: 0 auto;
  margin-bottom: 60px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
footer ul li{
  margin-bottom: 20px;
  border-right: initial;
}
.copy p{
  font-size: 2.5vw;
}
.page-kv{
  margin-bottom: 30px;
}
.service-box{
  padding: 20px 0;
}
.service-inner{
  width: 90%;
}
.service-flex{
  flex-direction: column;
}
.service-img{
  width: 100%;
  margin-right: 0;
  margin-bottom: 30px;
}
.service-contents{
  width: 100%;
}
.service-contents h3{
  font-size: 15px;
}
.service-contents-inner{
  padding: 20px 15px;
}
.service-point{
  width: 90%;
}
.service-point-inner h4{
  font-size: 15px;
}
.service-box2 .service-img{
  order: 1;
}
.service-box2 .service-contents{
  order: 2;
}
.service-point-inner p{
  font-size: 13px;
  line-height: 27px;
}
.menu-nav{
  width: 95%;
}
.menu-nav a{
  width: 45%;
  margin: 10px 2.5% 0;
}
.menu-wrapper{
  margin-bottom: 50px;
}
.menu-box{
  width: 100%;
}
.menu-box-inner{
  width: 90%;
}
.menu-flex2{
  width: 100%;
}
.more-contents{
  flex-direction: column;
}
.more-flex{
  width: 100%;
  margin: 0;
  margin-bottom: 10px;
}
.more-contents p{
  font-size: 14px;
}
.course-img{
  width: 80%;
}
.course-heading{
  font-size: 16px;
}
.plan-box{
  width: 90%;
}
.plan-flex{
  flex-direction: column;
  margin-bottom: 30px;
}
.plan-left{
  width: 100%;
  margin-right: 0;
  margin-bottom: 10px;
}
.plan-right{
  width: 100%;
}
.plan-right p{
  font-size: 13px;
}
.news-wrapper{
  width: 90%;
}
.blog-item{
  width: 100%;
  margin: 0 auto;
  margin-bottom: 30px;
}
.single-wrapper{
  padding: 50px 0;
}
.single-box{
  width: 90%;
}
.news-list-btn{
  width: 100%;
  border-radius: 10px;
}
.sp{
  display: block;
}
.pc{
  display: none;
}
}