@charset "UTF-8"; /* Table Of Contents
----------------------------------------------------------------------------
General Elements
header
gNav
visual
topicPath
footer
---------------------------------------------------------------------------- */
/*General Elements
---------------------------------------------------------------------------- */
html {
    font-size: 62.5%;
}

body {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-weight: 400;
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.7;
	-webkit-text-size-adjust: 100%;
	color: #2E2E2E;
}

a {
    text-decoration: none;
    color: #505050;
    outline: none;
}

a:hover {
    text-decoration: none;
}

* {
    box-sizing: border-box;
}

input[type="text"], button, textarea, select {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

i {
  font-style: italic;
}

.clearfix:after {
  content: "";
  clear: both;
  display: block;
}


#wrpper {
    position: relative;
}


/*l-header
---------------------------------------------------------------------------- */
.l-header {
  position: absolute;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 10;
}

.l-header-content {
  position: relative;
    width: 100%;
    margin: 0 auto;
    padding: 0 30px;
}

.l-header-block {
    float: right;
}

.l-header-en {
    display: inline-block;
    font-size: 20px;
    font-size: 2rem;
    font-family: myriad-pro, sans-serif;
    font-weight: 400;
    font-style: normal;
    vertical-align: middle;
    position: relative;
    z-index: 10;
}

.l-header-en a {
    color: #fff;
}

.l-header-tw {
    position: relative;
    display: inline-block;
    width: 60px;
    vertical-align: middle;
    margin: 0 20px;
    z-index: 10;
}

.l-header-tw a {
    display: block;
    transition: .3s;
}

.l-header-menu {
    display: inline-block;
    vertical-align: middle;
    /* font-family: ten-mincho, serif;
    font-weight: 400;
    font-style: normal; */
}

.l-header-menu a {
    display: block;
}

.l-header.open .l-header-en a {
  color: #000;
}

.l-header-nav {
  display: none;
    position: absolute;
    right: 0;
    top: 0;
    background: #FFDED9;
    width: 287px;
    padding: 0 0 30px 33px;
}

.l-header-nav .l-header-menu {
    text-align: right;
    display: block;
    margin: 15px 28px 25px auto;
    width: 53px;
}


.l-header-nav ul li {
  position: relative;
    padding-bottom: 24px;
    font-size: 20px;
    font-size: 2rem;
    letter-spacing: 0.03em;
    line-height: 1;
}

.l-header-nav ul li::before {
  position: absolute;
  content: "";
  background: url(../img/menu/ico_menu_logo.svg)no-repeat;
  width: 17px;
  height: 28px;
  left: 0;
  top: -2px;
  background-size: cover;
}

.l-header-nav ul li:last-child {
  font-size: 13px;
  font-size: 1.3rem;
  letter-spacing: 0;
}

.l-header-nav ul li span {
  display: inline-block;
  border-top: solid 1px #fff;
  border-bottom: solid 1px #fff;
  padding-bottom: 5px;
  padding-top: 5px;
}

.l-header-nav ul li:last-child a {
  color: #71161E;
}

.l-header-nav ul li a {
    display: block;
    padding-left: 30px;
    color: #2E2E2E;
}

.l-header-navLogo a {
  display: block;
  transition: .3s;
}

@media screen and (max-width: 960px){

  p {
    font-size: 1.4rem;
  }

}

@media screen and (min-width: 768px){
  .l-header-en a:hover {
    text-decoration: underline;
  }

  .l-header-tw a:hover {
    opacity: .7;
    transition: .3s;
  }

  .l-header-navLogo a:hover {
    opacity: .7;
    transition: .3s;
  }
}

@media screen and (max-width: 767px){

  .l-header-en {
    font-size: 1.6rem;
  }

  .l-header-tw {
      width: 40px;
      margin: 0 10px;
  }

  .l-header-content {
      padding: 0 5%;
  }

  .l-header-menu {
      width: 40px;
      height: 23px;
  }

  .l-header-menu a {
      height: 23px;
  }

  .l-header-menu a img {
      vertical-align: top;
  }

  .l-header-nav .l-header-menu {
    margin-right: 5%;
    margin-top: 10px;
    width: 40px;
    height: 23px;
  }

}

/* l-gNav
---------------------------------------------------------------------------- */
.l-gNav {

}


@media screen and (max-width: 767px){
}

/* l-topicPath
---------------------------------------------------------------------------- */
.l-topicPath {
}

/* l-content
---------------------------------------------------------------------------- */

.l-container {
  overflow: hidden;
}

.l-content {
}

/* l-sidebar
---------------------------------------------------------------------------- */
.l-sidebar {
}

/* l-footer
---------------------------------------------------------------------------- */
.l-footer {

}

.l-footer-logo {
  text-align: center;
  max-width: 514px;
  margin: 0 auto;
}

.l-footer-logo a {
    display: block;
    transition: .3s;
}

.l-footer-sns {
    width: 37px;
    margin: 10px auto 20px;
    transition: .3s;
}

.l-footer-sns a {
    display: block;
}

.l-footer-list {
    text-align: center;
    font-size: 13px;
    font-size: 1.3rem;
}

.l-footer-list li {
    display: inline-block;
    vertical-align: middle;
    margin: 0 10px 20px;
}

.l-footer small {
    display: block;
    text-align: center;
    font-size: 13px;
    font-size: 1.3rem;
    padding: 20px 0 50px;
    border-top: solid 1px #B86158;
}

@media screen and (min-width: 768px){
  .l-footer-sns:hover {
    opacity: .7;
    transition: .3s;
  }

  .l-footer-list li:hover {
    text-decoration: underline;
  }

  .l-footer-logo a:hover {
    opacity: .7;
    transition: .3s;
  }
}


@media screen and (max-width: 960px){

  .l-footer-logo {
    max-width: 300px;
    margin: 0 auto;
  }

}

@media screen and (max-width: 767px){

  .l-footer small {
    font-size: 1rem;
    padding: 10px 10px 30px;
  }

}
