@charset "UTF-8";
.siteWrapper {
  --font-century-gothic: "Century Gothic", "CenturyGothic", "Helvetica",
    "Futura", Arial, "AppleGothic", sans-serif;
  --color-text: #111;
  --color-text-hover: var(--color-font-light);
  --color-btn-blue: #003e92;
  --color-btn-blue-hover: #0451b9;
  --color-bg: #fcc800;
  --color-bg-light: #fff4d3;
  --color-bg-glay: #f8f8f8;
  --color-bg-glay-dark: #efefef;
  --color-method-elementary: #ffa700;
  --color-method-intermediate: #2445ed;
  --color-method-toeic: #883de2;
  --color-method-drama: #e84040;
  --color-methodTitle-business: rgba(18, 43, 173, 0.7);
  --color-methodTitle-private: rgba(7, 136, 33, 0.7);
  --color-methodTitle-toeic: rgba(101, 49, 163, 0.7);
  --color-methodTitle-drama: rgba(214, 1, 1, 0.7);
  --grad-method-yellow: linear-gradient(
    90deg,
    #ffd310,
    var(--color-method-elementary)
  );
  --grad-method-blue: linear-gradient(
    90deg,
    var(--color-method-intermediate),
    #42c75d
  );
  --grad-method-purple: linear-gradient(
    90deg,
    var(--color-method-toeic),
    #d16b56
  );
  --grad-method-red: linear-gradient(90deg, var(--color-method-drama), #f88d40);
  --grad-method-yellow-anime: linear-gradient(
    90deg,
    #ffd310,
    var(--color-method-elementary),
    #ffd310
  );
  --grad-method-blue-anime: linear-gradient(
    90deg,
    var(--color-method-intermediate),
    #42c75d,
    var(--color-method-intermediate)
  );
  --grad-method-purple-anime: linear-gradient(
    90deg,
    var(--color-method-toeic),
    #d16b56,
    var(--color-method-toeic)
  );
  --grad-method-red-anime: linear-gradient(
    90deg,
    var(--color-method-drama),
    #f88d40,
    var(--color-method-drama)
  );
}

.siteWrapper {
  --height-menu: 50px;
}

.l-menu {
  /*background-color: var(--color-bg);
  width: 100%;*/
  height: var(--height-menu);
  /*position: sticky;
  top: 0;
  left: 0;
  z-index: 10*/
}

@media print, screen and (min-width: 768px) {
  .l-menu {
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  }
}
.l-menu__inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
}

@media print, screen and (min-width: 768px) {
  .l-menu__inner {
    max-width: var(--width-pc-max);
    margin-right: auto;
    margin-left: auto;
  }
}
@media screen and (max-width: 767px) {
  .l-menu__inner {
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  }
}
.l-menu__siteid {
  line-height: 0;
}

@media screen and (max-width: 767px) {
  .l-menu__siteid {
    width: 25.3333333333vw;
    max-width: 95px;
    padding-left: 5.3333333333vw;
  }
}
@media screen and (max-width: 767px) {
  .l-menu__toggle {
    width: var(--height-menu);
    height: var(--height-menu);
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
  }
}
.l-menu__toggle__inner {
  width: 28px;
  height: 28px;
  background-repeat: no-repeat;
  background-position: center;
}

@media screen and (max-width: 767px) {
  .siteWrapper:not(.is-menuOpen) .l-menu__toggle__inner {
    background-image: url("/~/media//Images/rosettastone/common/icon-open.svg");
    background-size: 28px 23px;
  }
}
@media screen and (max-width: 767px) {
  .siteWrapper.is-menuOpen .l-menu__toggle__inner {
    background-image: url("/~/media//Images/rosettastone/common/icon-close.svg");
    background-size: 22px 22px;
  }
}
.l-menu__navigation {
  background-color: var(--color-bg);
}

@media print, screen and (min-width: 768px) {
  .l-menu__navigation {
    display: flex;
    align-items: center;
    height: 100%;
    width: 80%;
    max-width: 740px;
  }
}
@media screen and (max-width: 767px) {
  .l-menu__navigation {
    position: absolute;
    top: var(--height-menu);
    left: 0;
    z-index: -1;
    width: 100%;
    height: calc(100vh - 50px);
    height: calc(100dvh - 50px);
    padding-right: 12.6%;
    padding-left: 12.6%;
    opacity: 0;
    transition: opacity 0.2s, visibility 0s ease 0.2s;
    opacity: 0;
    visibility: hidden;
  }
  .siteWrapper.is-menuOpen .l-menu__navigation {
    transition-delay: 0s;
    opacity: 1;
    visibility: visible;
  }
}
@media print, screen and (min-width: 768px) {
  .l-menu__item {
    position: relative;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1;
    max-width: 146px;
    width: 20%;
    height: 100%;
    padding-right: 16px;
    padding-left: 16px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .l-menu__item:hover .l-menu__item__label:after {
    transform: translateY(100%) scaleX(1);
  }
}
@media screen and (max-width: 767px) {
  .l-menu__item {
    display: block;
    padding-top: 8vw;
    padding-bottom: 8vw;
    text-align: center;
    border-bottom: 1px solid #707070;
  }
}
@media print, screen and (min-width: 768px) {
  .l-menu__item:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    display: block;
    width: 1px;
    height: 25px;
    background-color: #707070;
  }
}
@media print, screen and (min-width: 768px) {
  .l-menu__item:last-of-type:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    display: block;
    width: 1px;
    height: 25px;
    background-color: #707070;
  }
}
@media print, screen and (min-width: 768px) {
  .l-menu__item__label {
    position: relative;
    display: inline-flex;
    align-items: center;
    height: 25px;
    font-size: var(--size-txt-s);
    white-space: nowrap;
  }
}
@media screen and (max-width: 767px) {
  .l-menu__item__label {
    font-size: 3.7333333333vw;
  }
}
@media print, screen and (min-width: 768px) {
  .l-menu__item__label:after {
    content: "";
    display: block;
    width: calc(100% + 20px);
    height: 3px;
    background-color: #fff;
    position: absolute;
    left: -10px;
    bottom: 0;
    transform: translateY(100%) scaleX(0);
    transition: transform 0.2s;
  }
}
@media print, screen and (min-width: 768px) {
  .l-menu__item.-current .l-menu__item__label:after {
    transform: translateY(100%) scaleX(1);
  }
}
.c-button {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-max);
  box-shadow: var(--shadow-dark);
}

@media print, screen and (min-width: 768px) {
  .c-button {
    height: 53px;
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media screen and (max-width: 767px) {
  .c-button {
    height: 14.1333333333vw;
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}
.c-button__label {
  text-align: center;
  width: 100%;
  font-weight: bold;
}

.c-button:after {
  content: "";
  flex-shrink: 0;
  background-repeat: no-repeat;
  background-size: contain;
}

@media print, screen and (min-width: 768px) {
  .c-button:after {
    width: 7px;
    height: 12px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .c-button:after {
    transition: all 0.3s;
  }
}
@media screen and (max-width: 767px) {
  .c-button:after {
    width: 1.9733333333vw;
    height: 3.2vw;
  }
}
.c-button.-blue {
  background-color: var(--color-btn-blue);
  color: #fff;
}

@media (hover: hover) and (pointer: fine) {
  .c-button.-blue:hover {
    background-color: var(--color-btn-blue-hover);
  }
}
.c-button.-blue:after {
  background-image: url("/~/media//Images/rosettastone/common/icon-arrow-white.svg");
}

.c-button.-white {
  background-color: var(--color-ui-light);
  color: var(--color-btn-blue);
}

@media (hover: hover) and (pointer: fine) {
  .c-button.-white:hover {
    background-color: var(--color-ui-light-action);
    color: var(--color-btn-blue-hover);
  }
}
.c-button.-white:after {
  background-image: url("/~/media//Images/rosettastone/common/icon-arrow-blue.svg");
}

.c-methodButton {
  display: block;
  border-radius: 5px;
  overflow: hidden;
  box-shadow: var(--shadow-mid);
  background-color: #fff;
}

@media (hover: hover) and (pointer: fine) {
  .c-methodButton {
    transition: box-shadow 0.3s;
  }
  .c-methodButton .c-methodButton__head {
    transition: background-position 0.3s;
  }
  .c-methodButton .c-methodButton__body {
    transition: opacity 0.3s;
  }
  .c-methodButton:hover {
    box-shadow: var(--shadow-dark);
  }
  .c-methodButton:hover .c-methodButton__head {
    background-position: 100% 0;
  }
  .c-methodButton:hover .c-methodButton__body {
    opacity: 0.7;
  }
}
.c-methodButton__head {
  background-color: var(--color-bg);
  background-size: 200% auto;
  color: #fff;
  font-weight: bold;
  line-height: 1;
}

@media print, screen and (min-width: 768px) {
  .c-methodButton__head {
    padding-top: 14px;
    padding-bottom: 14px;
  }
}
@media screen and (max-width: 767px) {
  .c-methodButton__head {
    padding-top: 3.7333333333vw;
    padding-bottom: 3.7333333333vw;
  }
}
.c-methodButton__head__label {
  display: block;
  text-align: center;
}

.c-methodButton__body {
  position: relative;
}

@media print, screen and (min-width: 768px) {
  .c-methodButton__body {
    padding: 18px 3px 28px;
  }
}
@media screen and (max-width: 767px) {
  .c-methodButton__body {
    padding: 4.8vw 3px 7.4666666667vw;
  }
}
.c-methodButton__body__text {
  display: block;
  text-align: center;
  line-height: 1.4;
}

@media screen and (max-width: 767px) {
  .c-methodButton__body__text {
    font-size: 3.7333333333vw;
  }
}
.c-methodButton__body__icon {
  line-height: 0;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  display: block;
}

@media print, screen and (min-width: 768px) {
  .c-methodButton__body__icon {
    bottom: 10px;
  }
}
@media screen and (max-width: 767px) {
  .c-methodButton__body__icon {
    bottom: 2.6666666667vw;
  }
}
.c-methodButton__body__icon svg path {
  fill: var(--color-bg);
}

.c-methodButton.-elementary .c-methodButton__head {
  background-image: var(--grad-method-yellow-anime);
}

.c-methodButton.-elementary .c-methodButton__body__icon svg path {
  fill: var(--color-method-elementary);
}

.c-methodButton.-intermediate .c-methodButton__head {
  background-image: var(--grad-method-blue-anime);
}

.c-methodButton.-intermediate .c-methodButton__body__icon svg path {
  fill: var(--color-method-intermediate);
}

.c-methodButton.-toeic .c-methodButton__head {
  background-image: var(--grad-method-purple-anime);
}

.c-methodButton.-toeic .c-methodButton__body__icon svg path {
  fill: var(--color-method-toeic);
}

.c-methodButton.-drama .c-methodButton__head {
  background-image: var(--grad-method-red-anime);
}

.c-methodButton.-drama .c-methodButton__body__icon svg path {
  fill: var(--color-method-drama);
}

.c-categoryTitle {
  text-align: center;
}

.c-categoryTitle__label {
  font-weight: bold;
  text-align: center;
}

@media print, screen and (min-width: 768px) {
  .c-categoryTitle__label {
    font-size: 32px;
  }
}
@media screen and (max-width: 767px) {
  .c-categoryTitle__label {
    font-size: 8.5333333333vw;
  }
}
.c-categoryTitle:after {
  content: "";
  display: block;
  height: 5px;
  background-color: var(--color-bg);
  margin-right: auto;
  margin-left: auto;
}

@media print, screen and (min-width: 768px) {
  .c-categoryTitle:after {
    margin-top: 16px;
    width: 182px;
  }
}
@media screen and (max-width: 767px) {
  .c-categoryTitle:after {
    margin-top: 4.2666666667vw;
    width: 48.5333333333vw;
  }
}
.c-categoryTitle.-elementary:after {
  background-image: var(--grad-method-yellow);
}

.c-categoryTitle.-intermediate:after {
  background-image: var(--grad-method-blue);
}

.c-categoryTitle.-toeic:after {
  background-image: var(--grad-method-purple);
}

.c-categoryTitle.-drama:after {
  background-image: var(--grad-method-red);
}

.c-textLink {
  display: inline-flex;
  align-items: center;
  color: var(--color-link);
}

.c-textLink:hover {
  text-decoration: underline;
}

.c-textLink:after {
  content: "";
  background-image: url("/~/media//Images/rosettastone/common/icon-linkArrow.svg");
  background-size: contain;
  line-height: 0;
  margin-left: 10px;
}

@media print, screen and (min-width: 768px) {
  .c-textLink:after {
    width: 7px;
    height: 12.4px;
  }
}
@media screen and (max-width: 767px) {
  .c-textLink:after {
    width: 1.8666666667vw;
    height: 3.3066666667vw;
  }
}
main {
  display: block;
}

.product__profile-box:first-of-type {
  display: none;
}

/*.product__system {
  display: none
}*/
@layer base {
  @media screen and (max-width: 767px) {
    .siteWrapper img {
      width: 100%;
      height: auto;
    }
  }
  .siteWrapper svg {
    overflow: visible;
  }
  .siteWrapper small {
    font-size: 1em;
  }
  .siteWrapper em,
.siteWrapper i {
    font-style: normal;
  }
  .siteWrapper button {
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
  }
  .siteWrapper a {
    color: var(--color-text);
  }
  @media (hover: hover) and (pointer: fine) {
    .siteWrapper a img {
      transition: filter 0.3s;
    }
    .siteWrapper a:hover img {
      filter: brightness(1.1);
    }
  }
}
.siteWrapper {
  background-color: var(--color-bg);
  color: var(--color-text);
}

@media print, screen and (min-width: 768px) {
  .siteWrapper {
    font-size: var(--size-txt-m);
    line-height: 1.7;
  }
}
@media screen and (max-width: 767px) {
  .siteWrapper {
    font-size: 4.2666666667vw;
    line-height: 1.8;
  }
}
@media screen and (max-width: 767px) {
  .siteWrapper .for-PC {
    display: none;
    display: contents;
  }
}
@media print, screen and (min-width: 768px) {
  .siteWrapper .for-SP {
    display: none;
    display: contents;
  }
}
.siteWrapper .anchorTarget {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  padding-top: var(--height-menu);
  margin-top: calc(var(--height-menu) * -1);
}

.Design-Type-A.cart__area:not(:first-of-type) {
  border-left: none;
  margin-top: 0;
}

/*.Design-Type-A .cart__item {
  display: flex
}*/
@media (max-width: 768px) {
  .Design-Type-A .IsSpecial .cart__price-default {
    display: block;
  }
}
@media (max-width: 768px) {
  .IsSpecial .cart__price-area:after {
    content: "↓";
    position: absolute;
    top: 50%;
    right: -20px;
    transform: translateY(-60%);
    display: block;
  }
}
/*KV追加デザイン調整*/
div#i-rosettaMenu {
  position: -webkit-sticky;
  position: sticky;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 10;
}

/*rosettastone.jp style.cssから移植*/
footer {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
  background: transparent;
  list-style-type: none;
  font-size: medium;
  color: #000;
  font-family: arial, "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "Meiryo UI", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1.6em;
  font-weight: 500;
}

footer img {
  vertical-align: bottom;
  width: 100%;
}

@media only screen and (max-width: 767px) {
  #foot {
    background: #fcc800;
    padding: 20px 0;
    margin-top: 10px;
  }
  .footer-logo {
    width: 140px;
    margin: 0 auto 50px;
  }
  .foot-nav-wrap {
    width: 90%;
    border-top: 1px dotted #666;
    margin: 0 auto 25px;
  }
  .foot-nav {
    font-size: 14px;
    line-height: 2.8;
    text-align: center;
    border-bottom: 1px dotted #666;
  }
  .copyright-text {
    font-size: 13px;
    text-align: center;
    padding: 0 10px;
  }
}
@media print, screen and (min-width: 768px) {
  #foot {
    background: #fcc800;
    padding: 30px 0;
    margin-top: 10px;
  }
  .footer-logo {
    width: 140px;
    margin: 0 auto 50px;
  }
  .foot-nav {
    font-size: 14px;
    text-align: center;
    margin-bottom: 15px;
  }
  .copyright-text {
    font-size: 13px;
    text-align: center;
  }
}
@media print, screen and (min-width: 768px) {
  .display-sp {
    display: none !important;
  }
}
@media only screen and (max-width: 767px) {
  .display-pc {
    display: none !important;
  }
}