@charset "UTF-8";
/*--------------------------------------------------------*/
/*　フレーム　*/
/*--------------------------------------------------------*/
.side-access li:before, .side-new h2:before,
.side-vote h2:before,
.side-reco h2:before, .side-access h2:before {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 400;
  font-style: italic;
}

.foot-cate h2,
.foot-info h2, .foot-about h2 {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 600;
  font-style: italic;
}

body {
  color: #333;
}

a:link,
a:visited {
  color: #0047BA;
}

a:hover,
a:active {
  color: #932A40;
}

body * {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.clr:before, .clr:after {
  content: "";
  display: table;
  clear: both;
  overflow: hidden;
}

img {
  max-width: 100%;
  height: auto;
}

.content-wrap {
  max-width: 114.5em;
  margin: 0 auto;
}

.breadcrumb {
  padding: 1em;
}

.side-wrap {
  margin-top: 3em;
}

.side-box {
  margin: 1.5em 1em;
}
.side-box:first-child {
  margin-top: 0;
}

.footer {
  margin-top: 6em;
  padding: 6em 1em 0 1em;
  background: #F2F2F2;
}

.side-access li:before, .side-new h2:before,
.side-vote h2:before,
.side-reco h2:before, .side-access h2:before {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 400;
  font-style: italic;
}

.foot-cate h2,
.foot-info h2, .foot-about h2 {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 600;
  font-style: italic;
}

@media only screen and (min-width: 1024px) {
  .content-wrap {
    padding: 0 1em;
  }
  .content-wrap:before, .content-wrap:after {
    content: "";
    display: table;
    clear: both;
    overflow: hidden;
  }
  .entry-wrap {
    width: 66.6666%;
    float: left;
  }
  .entry-head figure {
    margin: 0;
  }
  .side-wrap {
    width: 26.6666%;
    float: right;
    margin: 0;
  }
  .side-box {
    margin: 4em 0 0 0;
  }
}
/*--------------------------------------------------------*/
/*　ヘッダー（グローバルメニュー含む） */
/*--------------------------------------------------------*/
.side-access li:before, .side-new h2:before,
.side-vote h2:before,
.side-reco h2:before, .side-access h2:before {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 400;
  font-style: italic;
}

.foot-cate h2,
.foot-info h2, .foot-about h2 {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 600;
  font-style: italic;
}

.head {
  position: relative;
  background: #FFF;
}
.head h1 {
  padding: 0.58333em 0.83333em;
  background: #932A40;
  color: #FFF;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.2;
}
.head h1 span {
  display: block;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.head-logo {
  width: 10em;
  margin: 1.5em auto;
  font-size: 10px;
  font-size: 1rem;
}
.head-logo a {
  height: 0;
  display: block;
  padding-top: 4.5em;
  background-size: cover;
  background-image: url("../images/share/head_logo_sp.svg");
  overflow: hidden;
}

.side-access li:before, .side-new h2:before,
.side-vote h2:before,
.side-reco h2:before, .side-access h2:before {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 400;
  font-style: italic;
}

.foot-cate h2,
.foot-info h2, .foot-about h2 {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 600;
  font-style: italic;
}

.head-logo-txt {
  display: none;
}

body {
  overflow-x: hidden;
}

.body-wrap {
  position: relative;
  top: 0;
  right: 0;
  width: 100%;
  overflow: hidden;
  margin-right: -100%;
  -webkit-transition: right 0.5s;
  transition: right 0.5s;
}

.body-wrap.is-open {
  right: 100vw;
  -webkit-transition: right 0.5s;
  transition: right 0.5s;
}

.body-wrap.is-visible {
  overflow: visible;
}

.hmenu {
  position: absolute;
  top: 0;
  left: 30em;
  left: 100vw;
  width: 30em;
  width: 100vw;
  min-height: 100vh;
  padding: 0 1.5em;
  z-index: 9000;
  border-top: solid 28px #932A40;
}

.hmenu-logo {
  width: 10em;
  margin: 1.5em 0;
  font-size: 10px;
  font-size: 1rem;
}
.hmenu-logo a {
  height: 0;
  display: block;
  padding-top: 4.5em;
  background-size: cover;
  background-image: url("../images/share/head_logo_sp.svg");
  overflow: hidden;
}

.hmenu-btn,
.hmenu-close {
  position: absolute;
  width: 5em;
  height: 5em;
  height: 0;
  padding-top: 4em;
  font-size: 10px;
  font-size: 1rem;
  border: solid 5px #FFF;
  border-radius: 50%;
  background: #CCC;
  overflow: hidden;
}
.hmenu-btn:before, .hmenu-btn:after,
.hmenu-btn span,
.hmenu-close:before,
.hmenu-close:after,
.hmenu-close span {
  content: "";
  position: absolute;
  left: 1.1em;
  display: block;
  width: 1.8em;
  height: 0;
  border-top: solid 2px #FFF;
  overflow: hidden;
}
.hmenu-btn:hover,
.hmenu-close:hover {
  cursor: pointer;
}

.hmenu-btn {
  right: 1.5em;
  top: 4.2em;
}
.hmenu-btn:before {
  top: 1.4em;
}
.hmenu-btn:after {
  top: 2.6em;
}
.hmenu-btn span {
  top: 50%;
}

.hmenu-close {
  right: 1.5em;
  top: 1.2em;
}
.hmenu-close:before {
  top: 2em;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.hmenu-close:after {
  top: 2em;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.menu-search {
  margin-bottom: 0.5em;
  overflow: hidden;
}
.menu-search form {
  position: relative;
  display: block;
}
.menu-search input[type=text],
.menu-search input[type=submit] {
  padding: 0.8125em 0.9375em;
  border: none;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1;
}
.menu-search input[type=text] {
  display: block;
  width: 100%;
  padding-right: 2.9375em;
  background: #F2F2F2;
  border-radius: 0.3125em;
}
.menu-search input[type=submit] {
  position: absolute;
  top: 0;
  right: 0;
  width: 2.625em;
  height: 0;
  padding: 3.125em 0 0 0;
  background-color: #F2F2F2;
  background-image: url("../images/share/hmenu_sp_search.svg");
  background-size: cover;
  overflow: hidden;
}

.menu-main > li {
  padding: 0.625em 0;
  font-size: 16px;
  font-size: 1.6rem;
  border-top: solid 1px #CCC;
}
.menu-main > li:first-child {
  border: 0;
}
.menu-main > li > a {
  position: relative;
  display: block;
  min-height: 3.4375em;
  padding: 0.75em 1.25em 0.5em 4.6875em;
  font-weight: bold;
  text-decoration: none;
  line-height: 1;
  color: #333;
  background-size: 3.4375em 3.4375em;
  background-repeat: no-repeat;
  background-position: left top;
}
.menu-main > li > a:before {
  content: "";
  display: block;
  position: absolute;
  right: 0;
  top: 0.875em;
  width: 0.625em;
  height: 1.5625em;
  background-image: url("../images/share/hmenu_sp_arr.svg");
  background-size: cover;
}
.menu-main > li > a:after {
  display: block;
  font-size: 12px;
  font-size: 1.2rem;
  margin-top: 0.41667em;
  font-weight: normal;
  color: #999;
}

.menu-howto a {
  background-image: url("../images/share/hmenu_sp01.png");
}
.menu-howto a:after {
  content: "English conversation";
}

.menu-school a {
  background-image: url("../images/share/hmenu_sp02.png");
}
.menu-school a:after {
  content: "School";
}

.menu-online a {
  background-image: url("../images/share/hmenu_sp03.png");
}
.menu-online a:after {
  content: "Online school";
}

.menu-material a {
  background-image: url("../images/share/hmenu_sp04.png");
}
.menu-material a:after {
  content: "Learning material";
}

.menu-business a {
  background-image: url("../images/share/hmenu_sp05.png");
}
.menu-business a:after {
  content: "Business";
}

.menu-personal a {
  background-image: url("../images/share/hmenu_sp06.png");
}
.menu-personal a:after {
  content: "Coaching";
}

.menu-senior a {
  background-image: url("../images/share/hmenu_sp07.png");
}
.menu-senior a:after {
  content: "Senior";
}

.menu-test a {
  background-image: url("../images/share/hmenu_sp08.png");
}
.menu-test a:after {
  content: "Qualification";
}

.menu-drama a {
  background-image: url("../images/share/hmenu_sp09.png");
}
.menu-drama a:after {
  content: "TV drama";
}

.menu-kids a {
  background-image: url("../images/share/hmenu_sp10.png");
}
.menu-kids a:after {
  content: "for Kids";
}

.menu-abroad a {
  background-image: url("../images/share/hmenu_sp11.png");
}
.menu-abroad a:after {
  content: "Study Abroad";
}

.menu-other {
  padding: 0.5em 0;
}
.menu-other li {
  padding: 0.71429em 0;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1;
}
.menu-other li a {
  color: #333;
  text-decoration: none;
}

.hmenu-close_btm {
  padding: 1.07143em 0.71429em;
  font-size: 14px;
  font-size: 1.4rem;
  text-align: center;
  color: #1B2F66;
  line-height: 1;
  border: solid 1px #1B2F66;
  border-radius: 0.35714em;
  cursor: pointer;
}
.hmenu-close_btm:before {
  content: "\e64b";
  display: inline-block;
  width: 1.6em;
  height: 1.6em;
  margin-right: 0.5em;
  font-size: 10px;
  font-size: 1rem;
  font-family: "icomoon";
  font-weight: normal;
  line-height: 1.6;
  text-align: center;
  color: #FFF;
  background: #1B2F66;
  border-radius: 50%;
}

.side-access li:before, .side-new h2:before,
.side-vote h2:before,
.side-reco h2:before, .side-access h2:before {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 400;
  font-style: italic;
}

.foot-cate h2,
.foot-info h2, .foot-about h2 {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 600;
  font-style: italic;
}

@media only screen and (min-width: 1024px) {
  .body-wrap {
    overflow: hidden;
  }
  .body-wrap.open {
    right: 0;
  }
  .head {
    border-bottom: solid 1px #CCC;
  }
  .head h1 {
    padding: 0.91667em 0.83333em 0.83333em 0.83333em;
  }
  .head h1 span {
    max-width: 93.75em;
    margin: 0 auto;
  }
  .head:after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 0;
    margin-bottom: -10000em;
    background: #FFF;
    opacity: 0;
    -webkit-transition-property: opacity;
    transition-property: opacity;
    -webkit-transition-duration: 0.5s;
            transition-duration: 0.5s;
    z-index: 100;
  }
  .is-open-pc .head:after {
    height: 10000em;
    opacity: 0.75;
    -webkit-transition-property: opacity;
    transition-property: opacity;
    -webkit-transition-duration: 0.5s;
            transition-duration: 0.5s;
  }
  .head-wrap {
    position: relative;
    max-width: 114.5em;
    margin: 0 auto;
    padding: 0 1em;
    overflow: hidden;
  }
  .head-logo {
    width: 45em;
    margin: 2.8em auto 2.5em 0;
    font-size: 10px;
    font-size: 1rem;
  }
  .head-logo a {
    padding-top: 7.2em;
    background-image: url("../images/share/head_logo_pc.svg");
  }
  .head-logo-txt {
    display: block;
    padding: 0 0 0 11.78571em;
    margin-top: -1em;
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.14;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
  }
  .head-logo-txt:before {
    content: "｜";
  }
  .hmenu {
    position: absolute;
    display: none;
    top: auto;
    left: 0;
    width: 100%;
    min-height: 0;
    padding: 0 1.5em;
    background: #FFF;
    border-top: solid 1px #CCC;
  }
  .hmenu:after {
    content: "";
    position: absolute;
    left: 0;
    display: block;
    width: 100%;
  }
  .hmenu:after {
    height: 2em;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.05)), color-stop(2%, rgba(0, 0, 0, 0.05)), to(rgba(0, 0, 0, 0)));
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.05) 0%, rgba(0, 0, 0, 0.05) 2%, rgba(0, 0, 0, 0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#26000000", endColorstr="#00000000",GradientType=0 );
  }
  .is-open-pc .hmenu:before {
    opacity: 0.75;
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .hmenu-logo {
    display: none;
  }
  .hmenu-btn {
    right: 1em;
    top: auto;
    bottom: 5em;
    width: 4.2em;
    padding-top: 2.4em;
    border: 0;
    border-radius: 0;
    background: none;
  }
  .hmenu-btn:before, .hmenu-btn:after,
  .hmenu-btn span {
    left: 0;
    width: 4.2em;
    -webkit-transition: 0.5s;
    transition: 0.5s;
    border-top: solid 2px #CCC;
  }
  .hmenu-btn:before {
    top: 0;
  }
  .hmenu-btn:after {
    top: auto;
    bottom: 0;
  }
  .hmenu-btn span {
    top: 50%;
    opacity: 1;
  }
  .is-open-pc .hmenu-btn:before {
    top: 50%;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  .is-open-pc .hmenu-btn:after {
    bottom: 50%;
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  .is-open-pc .hmenu-btn span {
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  .hmenu-close {
    display: none;
  }
  .menu-search {
    max-width: 112.5em;
    margin: 6em auto 0 auto;
  }
  .menu-search input[type=text] {
    text-align: center;
  }
  .menu-main {
    max-width: 112.5em;
    margin: 1em auto 6em auto;
  }
  .menu-main:before, .menu-main:after {
    content: "";
    display: table;
    clear: both;
    overflow: hidden;
  }
  .menu-main > li {
    float: left;
    padding: 0;
    width: 18.5777%;
    margin: 1.66667em 0 0 1.777%;
    font-size: 18px;
    font-size: 1.8rem;
    border: 0;
  }
  .menu-main > li:nth-child(5n+1) {
    margin: 1.66667em 0 0 0;
  }
  .menu-main > li > a {
    position: relative;
    display: block;
    padding: 0;
    font-weight: normal;
    color: #1B2F66;
    background: none;
    -webkit-transition: color 0.25s;
    transition: color 0.25s;
  }
  .menu-main > li > a:before {
    content: "";
    display: block;
    position: relative;
    right: auto;
    top: auto;
    width: 100%;
    height: 0;
    padding-top: 58.3732%;
    margin-bottom: 0.72222em;
    background-size: cover;
    -webkit-box-shadow: 0 0 0 #932A40 inset, 0 0 0 #932A40 inset;
            box-shadow: 0 0 0 #932A40 inset, 0 0 0 #932A40 inset;
    -webkit-transition: -webkit-box-shadow 0.25s;
    transition: -webkit-box-shadow 0.25s;
    transition: box-shadow 0.25s;
    transition: box-shadow 0.25s, -webkit-box-shadow 0.25s;
  }
  .menu-main > li > a:hover, .menu-main > li > a:active {
    color: #932A40;
    -webkit-transition: color 0.25s;
    transition: color 0.25s;
  }
  .menu-main > li > a:hover:before, .menu-main > li > a:active:before {
    -webkit-box-shadow: 9px 9px 0 #932A40 inset, -9px -9px 0 #932A40 inset;
            box-shadow: 9px 9px 0 #932A40 inset, -9px -9px 0 #932A40 inset;
    -webkit-transition: -webkit-box-shadow 0.25s;
    transition: -webkit-box-shadow 0.25s;
    transition: box-shadow 0.25s;
    transition: box-shadow 0.25s, -webkit-box-shadow 0.25s;
  }
  .menu-main .menu-howto a:before {
    background-image: url("../images/share/hmenu_pc01.png");
  }
  .menu-main .menu-school a:before {
    background-image: url("../images/share/hmenu_pc02.png");
  }
  .menu-main .menu-online a:before {
    background-image: url("../images/share/hmenu_pc03.png");
  }
  .menu-main .menu-material a:before {
    background-image: url("../images/share/hmenu_pc04.png");
  }
  .menu-main .menu-business a:before {
    background-image: url("../images/share/hmenu_pc05.png");
  }
  .menu-main .menu-personal a:before {
    background-image: url("../images/share/hmenu_pc06.png");
  }
  .menu-main .menu-senior a:before {
    background-image: url("../images/share/hmenu_pc07.png");
  }
  .menu-main .menu-test a:before {
    background-image: url("../images/share/hmenu_pc08.png");
  }
  .menu-main .menu-drama a:before {
    background-image: url("../images/share/hmenu_pc09.png");
  }
  .menu-main .menu-kids a:before {
    background-image: url("../images/share/hmenu_pc10.png");
  }
  .menu-main .menu-abroad a:before {
    background-image: url("../images/share/hmenu_pc11.png");
  }
  .menu-other {
    padding: 0;
  }
  .menu-other li {
    position: relative;
    padding: 0 0 1.07143em 1.42857em;
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1;
  }
  .menu-other li:before {
    content: "";
    position: absolute;
    top: 0.07143em;
    left: 0;
    border-style: solid;
    border-width: 5px;
    border-color: #1B2F66 #DDD #DDD #1B2F66;
  }
  .menu-other li a {
    text-decoration: none;
  }
  .menu-other li a:link, .menu-other li a:visited {
    color: #1B2F66;
  }
  .menu-other li a:hover, .menu-other li a:active {
    color: #932A40;
  }
  .hmenu-close_btm {
    max-width: 80.35714em;
    margin: 0 auto 5.71429em auto;
  }
}
/*--------------------------------------------------------*/
/*　サイドメニュー　*/
/*--------------------------------------------------------*/
.side-access h2:before, .side-access li:before, .side-new h2:before,
.side-vote h2:before,
.side-reco h2:before {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 400;
  font-style: italic;
}

.foot-cate h2,
.foot-info h2, .foot-about h2 {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 600;
  font-style: italic;
}

.side-pr h2 {
  display: none;
}
.side-pr p {
  text-align: center;
}
.side-pr img {
  vertical-align: bottom;
}
.side-pr img:hover {
  -webkit-box-shadow: 0 0 0.5em rgba(0, 0, 0, 0.3);
          box-shadow: 0 0 0.5em rgba(0, 0, 0, 0.3);
}

.side-new h2,
.side-vote h2,
.side-reco h2, .side-access h2 {
  padding: 1.07143em;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: normal;
  color: #FFF;
  line-height: 1;
  background: #932A40;
  border-radius: 0.35714em 0.35714em 0 0;
}
.side-new h2:before,
.side-vote h2:before,
.side-reco h2:before, .side-access h2:before {
  margin-right: 0.5em;
  font-size: 21px;
  font-size: 2.1rem;
}

.side-access {
  padding-bottom: 2em;
  background: #F2F2F2;
  border-radius: 0.5em;
}
.side-access h2:before {
  content: "Accsess Ranking";
}
.side-access li {
  position: relative;
  margin-top: 1.25em;
  padding: 0 0.9375em 0 3.4375em;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.2;
}
.side-access li span {
  display: block;
  margin-top: 0.41667em;
  font-size: 12px;
  font-size: 1.2rem;
  font-weight: normal;
  color: #666;
}
.side-access li:before {
  position: absolute;
  width: 1em;
  left: 0.30769em;
  top: -0.23077em;
  font-size: 52px;
  font-size: 5.2rem;
  color: #999;
}
.side-access li:nth-child(1):before {
  content: "1";
}
.side-access li:nth-child(2):before {
  content: "2";
}
.side-access li:nth-child(3):before {
  content: "3";
}
.side-access li:nth-child(4):before {
  content: "4";
}
.side-access li:nth-child(5):before {
  content: "5";
}
.side-access a {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.side-access a:link, .side-access a:visited {
  color: #1B2F66;
}
.side-access a:hover, .side-access a:active {
  color: #932A40;
}

.side-new,
.side-vote,
.side-reco {
  padding-bottom: 0.5em;
  background: #F2F2F2;
  border-radius: 0.5em;
}
.side-new ul,
.side-vote ul,
.side-reco ul {
  margin-top: 0.5em;
}
.side-new li,
.side-vote li,
.side-reco li {
  padding: 1em;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.6;
  border-top: solid 1px #CCC;
}
.side-new li a,
.side-vote li a,
.side-reco li a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-left: 6em;
  height: 5em;
}
.side-new li a:link, .side-new li a:visited,
.side-vote li a:link,
.side-vote li a:visited,
.side-reco li a:link,
.side-reco li a:visited {
  color: #1B2F66;
}
.side-new li a:hover, .side-new li a:active,
.side-vote li a:hover,
.side-vote li a:active,
.side-reco li a:hover,
.side-reco li a:active {
  color: #932A40;
}
.side-new li .ttl,
.side-vote li .ttl,
.side-reco li .ttl {
  display: block;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
.side-new li img,
.side-vote li img,
.side-reco li img {
  position: absolute;
  left: 0;
  top: 0;
  width: 5em;
}
.side-new li:first-child,
.side-vote li:first-child,
.side-reco li:first-child {
  border: 0;
}

.side-new h2:before {
  content: "New Contents";
}

.side-vote h2:before {
  content: "Call for Reviews";
}

.side-reco h2:before {
  content: "Recommended";
}

.side-fb {
  position: relative;
  margin-bottom: 5em;
  padding: 0 1.5em 8em 1.5em;
  background: #F2F2F2;
  border-radius: 0.5em;
}
.side-fb h2 {
  padding: 1em 0.9375em 0.625em 0.9375em;
  margin: 0 -0.9375em 0.9375em -0.9375em;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
  color: #FFF;
  line-height: 1.4;
  background: #1B2F66;
  border-radius: 0.3125em 0.3125em 0 0;
}
.side-fb span {
  display: inline-block;
  position: relative;
}
.side-fb span:before, .side-fb span:after {
  content: "";
  display: block;
  width: 2.5em;
  height: 2.8125em;
  position: absolute;
  top: -0.3125em;
  background-size: cover;
}
.side-fb span:before {
  left: -2.1875em;
  background-image: url("../images/share/side_fb_ttl01.gif");
}
.side-fb span:after {
  background-image: url("../images/share/side_fb_ttl02.gif");
  right: -2.1875em;
}
.side-fb .btn a {
  display: block;
  margin: 0.625em 0;
  padding: 0.75em 1.5625em;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: normal;
  color: #FFF;
  text-align: center;
  text-decoration: none;
  text-shadow: 1px 1px 0 rgba(0, 0, 0, 0.2);
  line-height: 1.4;
  background: rgb(96.1, 193.4, 146.5);
  background: -webkit-gradient(linear, left top, left bottom, from(rgb(96.1, 193.4, 146.5)), to(#1CA764));
  background: linear-gradient(to bottom, rgb(96.1, 193.4, 146.5) 0%, #1CA764 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="$clr02", endColorstr="$clr01",GradientType=0 );
  -webkit-box-shadow: 0 0 0.3125em rgba(0, 0, 0, 0.2);
          box-shadow: 0 0 0.3125em rgba(0, 0, 0, 0.2);
  border-radius: 0.3125em;
}
.side-fb .btn a:after {
  content: "\e62b";
  margin: 0 0 0 0.3em;
  font-family: "icomoon";
  font-weight: normal;
  line-height: 1;
  -webkit-transform: translateY(-0.6em);
  transform: translateY(-0.6em);
}
.side-fb .txt {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 2;
}
.side-fb figure {
  position: absolute;
  bottom: -5em;
  right: 3em;
  width: 30em;
}

.side-access h2:before, .side-access li:before, .side-new h2:before,
.side-vote h2:before,
.side-reco h2:before {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 400;
  font-style: italic;
}

.foot-cate h2,
.foot-info h2, .foot-about h2 {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 600;
  font-style: italic;
}

@media only screen and (min-width: 1024px) {
  .side-pr img {
    -webkit-box-shadow: 0 0 0 rgba(0, 0, 0, 0.3);
            box-shadow: 0 0 0 rgba(0, 0, 0, 0.3);
    -webkit-transition: -webkit-box-shadow 0.5s;
    transition: -webkit-box-shadow 0.5s;
    transition: box-shadow 0.5s;
    transition: box-shadow 0.5s, -webkit-box-shadow 0.5s;
  }
  .side-pr img:hover {
    -webkit-box-shadow: 0 0 0.5em rgba(0, 0, 0, 0.3);
            box-shadow: 0 0 0.5em rgba(0, 0, 0, 0.3);
    -webkit-transition: -webkit-box-shadow 0.5s;
    transition: -webkit-box-shadow 0.5s;
    transition: box-shadow 0.5s;
    transition: box-shadow 0.5s, -webkit-box-shadow 0.5s;
  }
  .engco-fixed {
    position: fixed;
    top: 0;
    z-index: 10000;
    max-width: 300px;
  }
  .side-fb figure {
    right: -1em;
  }
  .side-fb .btn a:hover {
    background: #1CA764;
  }
}
/*--------------------------------------------------------*/
/*　フッター　*/
/*--------------------------------------------------------*/
.side-access h2:before, .side-access li:before, .side-new h2:before,
.side-vote h2:before,
.side-reco h2:before {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 400;
  font-style: italic;
}

.foot-about h2, .foot-cate h2,
.foot-info h2 {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 600;
  font-style: italic;
}

.foot-gotop {
  position: relative;
}
.foot-gotop a {
  position: absolute;
  top: -9em;
  left: 50%;
  display: block;
  width: 6em;
  height: 0;
  padding-top: 6em;
  font-size: 10px;
  font-size: 1rem;
  background-color: #1B2F66;
  background-image: url("../images/share/foot_gotop.svg");
  background-size: cover;
  border-radius: 50%;
  -webkit-box-shadow: 0.1em 0.1em 1.5em rgba(0, 0, 0, 0.5);
          box-shadow: 0.1em 0.1em 1.5em rgba(0, 0, 0, 0.5);
  overflow: hidden;
  -webkit-transform: translateX(-3em);
  transform: translateX(-3em);
}

.foot-cate h2,
.foot-info h2, .foot-about h2 {
  margin-bottom: 0.47619em;
  font-size: 21px;
  font-size: 2.1rem;
  line-height: 1;
}

.foot-cate a:link,
.foot-info a:link,
.foot-cate a:visited,
.foot-info a:visited {
  color: #333;
  text-decoration: none;
}
.foot-cate a:hover,
.foot-info a:hover,
.foot-cate a:active,
.foot-info a:active {
  color: #932A40;
}

.foot-about {
  padding: 2em 1.5em;
  background: #E6E6E6;
  border-radius: 0.5em;
}
.foot-about p {
  line-height: 2;
}

.foot-cate,
.foot-info {
  margin-top: 2em;
  padding: 0 1.5em;
}
.foot-cate ul,
.foot-info ul {
  float: left;
  width: 49%;
  margin-left: 2%;
}
.foot-cate ul:first-child,
.foot-info ul:first-child {
  margin: 0;
}
.foot-cate li,
.foot-info li {
  padding: 0.5em 0;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1;
}
.foot-cate li:nth-child(2n+1),
.foot-info li:nth-child(2n+1) {
  margin-left: 0;
}

.foot-copy {
  margin: 3em -1em 0 -1em;
  padding: 3em 1em;
  font-size: 10px;
  font-size: 1rem;
  background: #1B2F66;
  color: #FFF;
  text-align: center;
  line-height: 1;
}
.foot-copy small {
  font-size: 14px;
  font-size: 1.4rem;
}
.foot-copy a:link,
.foot-copy a:visited {
  color: #FFF;
  text-decoration: none;
}
.foot-copy a:hover,
.foot-copy a:active {
  color: #FFF;
  text-decoration: underline;
}

.side-access h2:before, .side-access li:before, .side-new h2:before,
.side-vote h2:before,
.side-reco h2:before {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 400;
  font-style: italic;
}

.foot-about h2, .foot-cate h2,
.foot-info h2 {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 600;
  font-style: italic;
}

@media only screen and (min-width: 1024px) {
  .foot-gotop a {
    position: fixed;
    top: auto;
    left: auto;
    bottom: 6em;
    right: 4em;
    width: 8em;
    padding-top: 8em;
  }
  .foot-wrap {
    max-width: 112.5em;
    margin: 0 auto;
    padding-bottom: 2em;
    overflow: hidden;
  }
  .foot-about {
    float: left;
    position: relative;
    width: 43.3333%;
    margin-right: 6.666%;
    padding: 3em 12em 3em 3em;
  }
  .foot-about p {
    line-height: 2;
    font-size: 15px;
    font-size: 1.5rem;
  }
  .foot-about:after {
    content: "";
    position: absolute;
    display: block;
    right: -2em;
    bottom: -1em;
    width: 12.5em;
    height: 15.5em;
    background-image: url("../images/share/foot_about_img.png");
    background-size: cover;
  }
  .foot-cate {
    float: left;
    width: 21.666%;
    margin: 0 6.666% 0 0;
  }
  .foot-cate ul {
    float: none;
    width: 100%;
    margin: 0;
  }
  .foot-info {
    float: left;
    width: 21.666%;
    margin: 0;
  }
  .foot-info ul {
    float: none;
    width: 100%;
    margin: 0;
  }
}
.promotion-note {
  position: fixed;
  padding: 1.5em 1.5em;
  font-size: 10px;
  font-size: 1rem;
  border-radius: 0.3em;
  opacity: 0.95;
  width: 4.1em;
  overflow: hidden;
  -webkit-transition: width 1s;
  transition: width 1s;
  /*---customize---*/
  bottom: 1em;
  left: 1em;
  background: #1B2F66;
  color: #FFF;
  /*---customize---*/
}
.promotion-note.is-open {
  width: 26.5em;
  -webkit-transition: width 1s;
  transition: width 1s;
}
.promotion-note.is-open p span {
  opacity: 1;
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
}
.promotion-note.is-close {
  width: 4.1em;
  -webkit-transition: width 1s;
  transition: width 1s;
}
.promotion-note.is-close p span {
  opacity: 0;
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
}
.promotion-note p {
  font-size: 11px;
  font-size: 1.1rem;
  line-height: 1;
  position: relative;
}
.promotion-note p span {
  display: block;
  position: absolute;
  top: 0;
  left: 1.54545em;
  width: 21em;
  opacity: 0;
}
.promotion-note p::before {
  content: "";
  display: inline-block;
  vertical-align: -0.2em;
  margin-right: 0.5em;
  height: 1em;
  width: 1em;
  background: url("data:image/svg+xml;utf8,<svg id='a' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 50 50'><path d='M17.003,13.636c-.351-.232-.775-.348-1.271-.348h-2.997v9.925h2.997c.48,0,.895-.112,1.247-.335,.351-.224,.623-.552,.816-.983,.192-.432,.287-.943,.287-1.534v-4.1c0-.623-.092-1.159-.276-1.606-.184-.447-.452-.787-.803-1.019Z' style='fill:%23fff;'/><path d='M37.555,13.564c-.375-.2-.819-.3-1.331-.3h-3.116v8.727h3.116c.512,0,.956-.092,1.331-.276,.376-.184,.66-.448,.851-.792,.192-.344,.288-.755,.288-1.234v-3.884c0-.528-.096-.983-.288-1.367-.191-.384-.475-.675-.851-.875Z' style='fill:%23fff;'/><path d='M45,0H5C2.25,0,0,2.25,0,5V45c0,2.75,2.25,5,5,5H45c2.75,0,5-2.25,5-5V5c0-2.75-2.25-5-5-5ZM24.1,21.272c0,1.615-.324,2.993-.971,4.135-.647,1.143-1.586,2.015-2.817,2.614-1.231,.599-2.701,.899-4.411,.899h-3.165v13.521H6.791V7.583H15.901c1.726,0,3.204,.304,4.435,.911,1.231,.608,2.166,1.498,2.805,2.673,.639,1.175,.959,2.585,.959,4.231v5.873Zm15.313,21.169l-4.311-14.744h-1.994v14.744h-5.826V7.559h8.583c1.886,0,3.496,.308,4.83,.923,1.334,.615,2.353,1.518,3.057,2.709,.703,1.191,1.055,2.618,1.055,4.279v4.076c0,1.71-.352,3.176-1.055,4.4-.704,1.222-1.726,2.153-3.069,2.792-.015,.007-.032,.012-.047,.019l5.155,15.685h-6.377Z' style='fill:%23fff;'/></svg>") center/cover no-repeat;
}
@media only screen and (min-width: 1024px) {
  .promotion-note {
    bottom: auto;
    top: 1em;
  }
}

/*--------------------------------------------------------*/
/*　パンくずリスト　*/
/*--------------------------------------------------------*/
.side-access h2:before, .side-access li:before, .side-new h2:before,
.side-vote h2:before,
.side-reco h2:before {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 400;
  font-style: italic;
}

.foot-about h2, .foot-cate h2,
.foot-info h2 {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 600;
  font-style: italic;
}

.breadcrumb {
  padding: 1em;
  background: #F2F2F2;
  overflow-y: auto;
}
.breadcrumb ul {
  width: 1000vw;
  margin-right: -900vw;
  width: -moz-fit-content; /* Firefox */
  width: -webkit-fit-content;
  width: fit-content; /* other browsers */
}
.breadcrumb li {
  position: relative;
  padding-right: 2em;
  display: inline;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1;
}
.breadcrumb li:before {
  content: "";
  position: absolute;
  right: 1em;
  top: 0.4em;
  display: block;
  width: 0.5em;
  height: 0.5em;
  border-top: solid 1px #666;
  border-right: solid 1px #666;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.breadcrumb li:last-child {
  display: none;
}
.breadcrumb li:last-child:before {
  content: normal;
}
.breadcrumb a:link,
.breadcrumb a:visited {
  color: #666;
  text-decoration: none;
}
.breadcrumb a:hover,
.breadcrumb a:active {
  color: #932A40;
}

.side-access h2:before, .side-access li:before, .side-new h2:before,
.side-vote h2:before,
.side-reco h2:before {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 400;
  font-style: italic;
}

.foot-about h2, .foot-cate h2,
.foot-info h2 {
  font-family: "Crimson Text", "Georgia", serif;
  font-weight: 600;
  font-style: italic;
}

@media only screen and (min-width: 1024px) {
  .breadcrumb {
    padding: 4em 0;
    background: none;
  }
  .breadcrumb ul {
    margin-right: 0;
    width: auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .breadcrumb li:before {
    top: 0.4em;
  }
  .breadcrumb li:last-child {
    display: inline;
  }
  .sp-wrap .breadcrumb {
    max-width: 114.5em;
    margin: 0 auto;
    padding: 4em 1em 4em 1em;
  }
}