html {
  scroll-behavior: smooth;
}
body {
  font-family: "方正蘭亭黑-繁","Noto Sans TC", "Microsoft JhengHei UI", "Microsoft JhengHei", sans-serif;
  font-size: 16px;
  line-height: 1.7;
  color: #333;
  padding: 0;
  margin: 0;
  background-color: #74837e;
  min-height: 100vh;
  opacity:0;
  transition: 0.3s;
}
img{
  display: block;
  max-width: 100%;
}
.inner {
   width: 1445px;
  margin-inline: auto;
  min-height: calc(100vh - 250px);
  background: url(../imgs/bg_sidebelt.jpg) repeat-y left top,
              url(../imgs/bg_sidebelt.jpg) repeat-y right top,
              #fff;
  background-size: 239px auto, 239px auto, auto;
  overflow: hidden;
  box-sizing: content-box;
  padding-left: 239px;
  padding-right: 239px;
  padding-bottom:250px;
  position: relative;
}

/* Header */
.site-header {
  background-color: #fff;

}

.header-top {
  height:208px;
  background-color: #f5f0e8;
  background: url(../imgs/bg_header_top.png) repeat-x;
  position: relative;
}

.logo-area {
  display: flex;
  align-items: center;
  gap: 15px;
}

.logo-taiyaki {
  position: absolute;
  top:14px;
  left:154px;
}

.logo-main {
  position: absolute;
  top:62px;
  left:414px;
}

.site-link{
  display: flex;
  flex-flow: column;
  gap:8px;
  align-items: center;
  position: absolute;
  text-decoration: none;
  font-size:25px;
}


.site-link.english ,.site-link.english:visited {
  right:176px;
  top:14px;
  color:#052e4f;
}

.site-link.japanese ,.site-link.japanese:visited {
  right:31px;
  top:14px;
  color: #008950;
}

/* Main Navigation */
.main-nav{
  box-sizing: content-box;
  display: flex;
  background-position: bottom;
  justify-content: left;
  align-items: center;
  height:112px;
  background: url(../imgs/bg_menu_ref.jpg);
}



.nav-item {
  display: flex;
  justify-content: left;
  align-items: center;
  height:112px;
  color: #fff;
  text-decoration: none;
  background: transparent;
  flex-shrink: 0;
  text-indent:-99999px;
}

.nav-item.plan{
  width: 328px;
  background: url(../imgs/navi_plan.png) no-repeat;
}
.nav-item.see_do{
  width: 329px;
  background: url(../imgs/navi_see_do.png) no-repeat;
}
.nav-item.eat_drink{
  width: 329px;
  background: url(../imgs/navi_eat_drink.png) no-repeat;
}
.nav-item.shop{
  width: 329px;
  background: url(../imgs/navi_shop.png) no-repeat;
}
.nav-item.search{
  width: 130px;
  background: url(../imgs/navi_search.png) no-repeat;
}

/* Breadcrumb */
.breadcrumb {
  background-color: #95d0a5;
  color: #731b4b;
  font-size: 24px;
  font-weight:bold;
  padding:10px 0;
  font-family: 'Noto Sans TC', sans-serif;
  font-weight: 600; /* ExtraLightに近い細さ */
}

.breadcrumb{
  background: #95d0a5 ;
}


.breadcrumb_inner{
  margin-inline:auto;
  max-width: 1000px;
}

.gsc-control-cse{
  background: transparent!important;
  border:none!important;
}
.gsc-input{  font-size: 30px!important;}
.gsc-search-button-v2 svg{
  width:36px;
  height:40px;
}
#g_search_wrapper{
  transition: 0.3s;
  margin-inline:auto;
}

.color_border + #g_search_wrapper{
  background: #008345;
  padding-inline: min(30vw , 300px);
}
.hidden{
  opacity: 0;
  height:0;
  transition: 0.3s;
}
/* Main Content */
main {
  padding:20px;
}

.page-title {
  text-align: center;
  color: #2d8b6b;
  margin-bottom: 40px;
  font-weight: bold;
}
.page-title img{
  margin-inline: auto;
}

/* Course Grid */
.course-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 50px;
  max-width: 1160px;
  margin: 0 auto;
}
.see_do_top .course-grid ,
.eat_drink_top .course-grid,
.shop_top .course-grid  {
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}

.course-card {
  display: block;
  border: 10px solid #2d8b6b;
  background-color: #fff;
  text-decoration: none;
  color:#000;
}

.see_do_top .course-card {
  border-color:#009090;
}
.eat_drink_top .course-card {
  border-color:#e8124d;
}
.shop_top .course-card {
  border-color:#b459a4;
}

.course-image {
  /* aspect-ratio: 540 / 405; */
  /* aspect-ratio: 1; */
  /* height:auto;  */
  background-color: #ccc;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #666;
  font-size: 24px;
}
.course-image img{
  aspect-ratio: 1.333;
  object-fit: cover;
}

.course-info {
  padding: 15px;
  font-size: 30px;
  background-color: #fff;
  border-top: 3px solid #2d8b6b;
  height: 160px;
  font-family: 'Noto Sans TC', sans-serif;
  font-weight: 600; 
  display: flex;
  align-items: center;
}



/* Footer */
.site-footer {
  background-color: #2d6b4f;
  color: #fff;
  margin-top: 60px;
  position: absolute;
  width:1445px;
  bottom:0;
}

.footer-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height:142px;
  background-color: #5fb89a;
}



.footer-bottom {
  background-color: #2d6b4f;
  text-align: center;
  height:50px;
}

.footer-logo {
  height: 40px;
  margin-bottom: 10px;
}

.footer-logo-title {
  height: 20px;
  margin-bottom: 15px;
}

.copyright {
  margin:0;
  padding:10px;
}
.footer-link-top{
  margin-left: 78px;
}
.footer_fb{
  display: flex;
  gap:8px;
  align-items:center;
  margin-right: 70px;;
}
.footer-facebook .icon{
  margin-right: 20px;;
}
.fb_icon{
  margin-right: 10px;
}
.fb_text_sp{display: none;}
main.article{
  width: 960px;
  margin-inline: auto ;
}

.l2Title_wrapper{
  margin-top: 74px;
  margin-inline :auto ;
  width: 960px;
  display: flex;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  gap: 40px;
  border-bottom: solid 10px #000;
  padding-bottom: 50px;
}

.plan .l2Title_wrapper{
  border-color:#2d6b4f;
}
.see_do .l2Title_wrapper{
  border-color:#009090;
}
.eat_drink .l2Title_wrapper{
  border-color:#e8124d;
}

.l2Title{
  font-size: 45px;
  display: flex;
  align-items: center;
  width: 900px;
  margin: 0;
  font-weight: 900;
} 

.color_border{
  margin-top: 20px;
  width:100%;
  height:17px;}

.color_border{
  background: #008345;
}

.anchor_nav{
  margin-top: 45px;
  margin-bottom: 70px;
  font-size: 27px;
  font-weight: 600
}
article + article{
  margin-top: 60px;
}
.article_title{
  font-size: 28px;
  border-bottom: solid 6px #000;
  padding-bottom: 6px;
  margin-bottom: 20px;
  padding-left:6px;

  color:#721b4b;
}

.paln .article_title{
  border-color:#008345;
  color: #2d6b4f;
}
.see_do .article_title{
  border-color:#10b8b8;
  color: #06487e;
}
.eat_drink .article_title{
    border-color:#e484b8;
      color:#721b4b;
}
.shop .article_title{
    border-color:#e484b8;
      color:#731b4b;
}
article p,
.article_text{
  font-size: 24px;
}
.article_image{margin-inline:auto;}
.article p + .article_image{
  margin-top: 70px;
}

.article_image {
  margin-top: 1rem;
}
.jp{
  margin-bottom: 3rem;
}

span.wb{
  white-space: nowrap;
}

section > h2:first-child{
  margin-bottom: 0;
  font-size:26px;
}

section h2 + p{
  margin-top: 0;
}

section + section {
  margin-top: 4rem;
}

th{
  vertical-align: top;
}