html {
  scroll-behavior: smooth;
}
body {
  font-family: "方正蘭亭黑-繁","Noto Sans TC", "Microsoft JhengHei UI", "Microsoft JhengHei", sans-serif;
  font-size: 13px;
  line-height: 1.7;
  color: #333;
  padding: 0;
  margin: 0;
  width:100vw;
  opacity:0;
  transition: 0.3s;
}
img{
  max-width:100%;
  height: auto;
  display: block;}


/* Header */
.site-header {
  background-color: #fff;

}

.header-top {
  height:17.5vw;
  width:100vw;
  background-color: #f5f0e8;
  background: url(../imgs/bg_header_top.png) ;
  background-size: 100% 100%;
  position: relative;
}

.logo-area {
  display: flex;
  align-items: center;
  gap: 15px;
}

.logo-taiyaki {
  position: absolute;
  top:1.2vw;
  left:1.8vw;
  width:16vw;
}

.logo-main {
  width: 53vw;
  position: absolute;
  top:5.2vw;
  left:19.5vw;
}

.site-link{
  display: flex;
  flex-flow: column;
  align-items: center;
  position: absolute;
  text-decoration: none;
  font-size:2.5vw;
  width: 11vw;
}


.site-link.english ,.site-link.english:visited {
  right:14vw;
  top:1.2vw;
  color:#052e4f;
}

.site-link.japanese ,.site-link.japanese:visited {
  right:1vw;
  top:1.2vw;
  color: #008950;
}

/* Main Navigation */
.main-nav{
  box-sizing: content-box;
  display: flex;
  background-position: bottom;
  justify-content: left;
  align-items: center;
  height:calc(100vw / 1000 *95);
  background: url(../imgs/nav_sp.png);
  background-size: cover;
}


.nav-item {
  display: flex;
  justify-content: left;
  align-items: center;
  height:calc(100vw / 1000 *95);
  color: #fff;
  text-decoration: none;
  background: transparent;
  flex-shrink: 0;
  text-indent:-99999px;
}

.nav-item.plan{
  width: 23.8vw;
}
.nav-item.see_do{
  width: 22.7vw;
}
.nav-item.eat_drink{
  width: 23.1vw;
}
.nav-item.shop{
  width: 22.1vw;
}
.nav-item.search{
  width: 8.4vw;
}

/* Breadcrumb */
.breadcrumb {
  background-color: #95d0a5;
  color: #731b4b;
  font-size: 16px;
  font-weight:bold;
  padding:0;
  font-family: 'Noto Sans TC', sans-serif;
  font-weight: 600; 
}



.breadcrumb p{
  margin: 0;padding: 0;
}

.bar{
  width: 100%;
  height:auto;
  display: block;
}
.breadcrumb_inner{
  margin-inline:auto;
  max-width: 90vw;
  padding:10px 0;

}

.hidden{
  opacity: 0;
  height:0;
  transition: 0.3s;
}
.gsc-search-button-v2 svg{
  width:50px;
  height:50px;
}
.gsc-search-button-v2{
  height:50px;;
}
.gsc-input{
  font-size: 22px;
}

.color_border{
  margin-top: 10px;
  width:100%;
  height:8px;}
.see_do .color_border{
  background: #008345;
}

.color_border + #g_search_wrapper{
  background: #008345;
  padding-inline: min(30vw , 100px);
}

.gsc-control-cse{
  background: transparent!important;
  border:none!important;
}
/* Main Content */
main {
  padding:8px;
}

.page-title {
  text-align: center;
  color: #2d8b6b; 
  margin-bottom: 40px;
}
.page-title img{
  max-width:50vw;
  height:auto;
  margin-inline: auto;
}

/* Course Grid */
.course-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;

  margin: 0 auto;
}

.course-card {
  display: block;
  border: 3px 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;
    display: flex;
  align-items: center;
  justify-content: center;
  color: #666;
  background-color: #ccc;
}
.course-image img{
  aspect-ratio: 540 / 405;
  object-fit: cover;
}

.course-info {
  padding: 4px;
  background-color: #fff;
  border-top: 2px solid #2d8b6b;
  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;

}

.footer-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height:17vw;
  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: 0;
}
.footer_fb{
  display: flex;
  max-width:60vw;
  gap:4px;
 
  margin-right: 10px;
}
.fb_icon{
  margin-right: 2vw;;
  width: 8vw;
}
.footer_top_image{
  width: 28.5vw; 
  margin-left: 3vw;;
}

.footer_top_image_tokyo , .footer_top_image_fb{
display: none;}
.fb_text_sp{
  max-width: 26vw;;
}
.anchor_nav{
  margin-top: 35px;
  margin-bottom: 35px;
  font-size: 20px;
  font-weight: 600
}

.article_title{
  font-size: 20px;
  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:#009090;
  color: #06487e;
}
.eat_drink .article_title{
    border-color:#e484b8;
      color:#721b4b;
}
.shop .article_title{
    border-color:#e484b8;
      color:#721b4b;
}

article p,
.article_text{
  font-size: 14px;
}

.article_text+.article_image{
  margin-top: 50px;
}
.article_image{margin-inline:auto;}

.article_text+.article_image{
  margin-top: 50px;
}
.article_image + .article_image{
  margin-top: 1rem;
}
.l2Title_wrapper{
  margin-top: 44px;
  margin-inline :auto ;

  display: flex;
  flex-shrink: 0;
  justify-content: left;
  align-items: center;
  gap: 16px;
  border-bottom: solid 10px #000;
  padding-bottom: 10px;
}

.plan .l2Title_wrapper{
  border-color:#2d6b4f;
}
.see_do .l2Title_wrapper{
  border-color:#009090;
}
.eat_drink .l2Title_wrapper{
  border-color:#e8124d;
}

.l2Title{
  font-size: 25px;
  display: flex;
  align-items: center;

  margin: 0;
  font-weight: 900;
} 

.l2Title_icon{
  height:70px;
  width:auto ;
  margin-left:10px;
}

section > h2:first-child{
  margin-bottom: 0;
}

section h2 + p{
  margin-top: 0;
}

section + section {
  margin-top: 4rem;
}