@charset "utf-8";

/* ======================================================
 * flatote.css
 * ------------------------------------------------------
 * Common
 * @media print, screen and (min-width: 768px)
 * - Page Component
 * - Clearfix
 * PC Media Queries
 * @media only screen and (max-width: 767px)
 * - Page Component
 * - Clearfix
 * SP Media Queries
 * Print
====================================================== */
  /* ------------------------------------------------------
   * Common
  ------------------------------------------------------ */
/* ----- font ----- */
/* Noto Sans */
.flatote-hero_read,
.flatote-hero_release,
.flatote-layout {
  font-family: "Noto Sans", "Noto Sans CJK JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
/* ======================================================
 * PC
====================================================== */
@media print, screen and (min-width: 768px) {
  /* ------------------------------------------------------
   * Override
  ------------------------------------------------------ */
  .heading-lv3,
  .column-layout {
    margin-top: 40px;
  }
  
  /* ------------------------------------------------------
   * Page Component
  ------------------------------------------------------ */
  /* ----- 購入ボタン ----- */
  /* ----- ec-button ----- */
  .ec-heading {
    position: relative;
    padding-right: 100px;
  }
  .heading-ec-button {
    position: absolute;
    display: inline-block;
    width: 88px;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  .ec-button {
    display: inline-block;
    max-width: 300px;
    min-width: 88px;
    margin-top: 10px;
  }
  .ec-button_link {
    display: inline-block;
    padding: 5px 25px 7px;
    background-color: #fff;
    border: 2px solid #418fde;
    border-radius: 6px;
    color: #418fde!important;
    font-weight: bold;
    font-size: 1.6rem;
    line-height: 1;
    font-family: "Noto Sans CJK JP", "Noto Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
  .ec-button_link:hover {
    background-color: #daebfc;
  }
  .table-ec {
    display: flex;
    align-items: center;
  }
  .table-ec-button {
    margin-left: 10px;
    max-width: 250px;
    min-width: 88px;
    vertical-align: top;
  }
  .table-ec-button_link {
    display: inline-block;
    padding: 5px 25px 7px;
    background-color: #fff;
    border: 2px solid #418fde;
    border-radius: 6px;
    color: #418fde;
    font-weight: bold;
    font-size: 1.6rem;
    line-height: 1;
    font-family: "Noto Sans CJK JP", "Noto Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
  .table-ec-button_link:hover {
    opacity: 1;
    background-color: #daebfc;
  }
  
  /* ----- flatote-hero-layout ----- */
  .flatote-hero-layout {
    position: relative;
  }
  .flatote-hero_visual {
    position: relative;
  }
  .flatote-hero_visual .slick-dots {
    position: absolute;
    right: 0;
    bottom: 17px;
    width: 706px;
    text-align: center;
  }
  .flatote-hero_visual .slick-dots > li {
    width: 10px;
    height: 10px;
    display: inline-block;
  }
  .flatote-hero_visual .slick-dots > li + li {
    margin-left: 10px;
  }
  .flatote-hero_visual .slick-dots > li > button {
    width: 100%;
    height: 100%;
    display: block;
    padding: 0;
    background-color: #898785;
    border: none;
    border-radius: 50%;
    text-indent: -9999em;
    font-size: 0;
    -webkit-transition: opacity .2s ease-out 0s;
    transition: opacity .2s ease-out 0s;
    outline: none;
  }
  .flatote-hero_visual .slick-dots > li.slick-active > button {
    background-color: #fff;
  }
  .flatote-hero_read {
    position: absolute;
    top: 21px;
    left: -3px;
    font-size: 2.6rem;
    line-height: 1.6;
  }
  .flatote-hero_release {
    position: absolute;
    bottom: 30px;
    left: 0;
    max-width: 420px;
  }
  .flatote-hero_price,
  .flatote-hero_date {
    display: -webkit-flex;
    display: flex;
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.0;
  }
  .flatote-hero_price dt,
  .flatote-hero_date dt {
    width: 90px;
  }
  .flatote-hero_date {
    margin-top: 15px;
  }
  /* ----- flatote-detail ----- */
  .flatote-detail {
    margin-top: 41px;
  }
  .flatote-detail_read {
    text-align: center;
    font-size: 2.4rem;
    line-height: 1.75;
    position: relative;
    font-weight: bold;
  }
  .flatote-detail_read_text-color {
    position: relative;
  }
  .flatote-detail_read_text-color::before {
    display: block;
    content: "";
    position: absolute;
    bottom: 0px;
    left: 0;
    width: 95%;
    height: 12px;
    background-color: #a2cbe5;
    z-index: -1;
  }
  .flatote-detail-wrap {
    margin-top: 40px;
  }
  .flatote-detail-colmn {
    display: -webkit-flex;
    display: flex;
    flex-flow: row wrap;
  }
  .flatote-detail_item {
    text-align: center;
    width: calc((100% - 73px) / 3);
  }
  .flatote-detail_item:nth-child(n+2) {
    margin-left: 36px;
  }
  .flatote-detail_text {
    font-size: 2rem;
    font-weight: bold;
    color: #333;
    margin-top: 17px;
    line-height: 1.3;
  }
  /* ----- lots-layout ----- */
  .flatote-layout {
    margin-top: 67px;
  }
  .flatote-layout_head {
    padding: 13px;
    background: #a2cbe5;
    border-radius: 40px;
    text-align: center;
  }
  .flatote-layout_title {
    font-size: 3.0rem;
    font-weight: bold;
    line-height: 1.4;
  }
    /* ----- flatote-use ----- */
  .flatote-use {
    margin-top: 41px;
  }
  .flatote-use-colmn {
    display: -webkit-flex;
    display: flex;
    flex-flow: row wrap;
  }
  .flatote-use_item {
    text-align: center;
    width: calc((100% - 109px) / 4);
  }
  .flatote-use_item:nth-child(n+2) {
    margin-left: 36px;
  }
  .flatote-use_text {
    font-size: 1.6rem;
    color: #333;
    margin-top: 17px;
    line-height: 1.6;
  }
  .flatote-use_detail {
    border: 2px solid #6795b2;
    border-radius: 15px;
    padding: 17px 0 31px 4px;
  }
  .flatote-use_detail-text {
    font-size: 2.6rem;
    font-weight: bold;
    color: #6795b2;
    line-height: 1.55;
  }
  .flatote-use_detail-text-under {
    font-size: 2.2rem;
    border-bottom: 2px solid #6795b2;
  }
  .flatote-use_detail-head {
    margin-bottom: 20px;
  }
  /* ------------------------------------------------------
   * youtube
  ------------------------------------------------------ */
   /* -----youtube----- */
  .youtubeWrap {
    width: 60%;
    max-width: 720px;
    margin: 44px auto 0;
  }
  .youtube-title {
    font-size: 2.4rem;
  }
  .youtube {
    position: relative;
    width: 100%;
    margin-top: 15px;
    padding-top: 56.25%;
  }
  .youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
  }
  /* ----- モーダル ----- */
  /* ----- flatote-modal-container ----- */
  .flatote-modal-container {
    display: none;
  }
  /* ----- flatote-modal-content ----- */
  .flatote-modal-content {
    position: relative;
    margin: 0;
    padding: 50px 50px 35px;
    background: #ffffff;
  }
  
  /* ----- flatote-gallery (modal) ----- */
  #cboxOverlay.flatote-gallery {
    background: #000000;
  }
  #colorbox.flatote-gallery #cboxContent {
    background: #fff
  }
  #colorbox.flatote-gallery #cboxLoadedContent {
    border: none;
    overflow: auto;
  }
  #colorbox.flatote-gallery #cboxClose {
    position: absolute;
    top: 12px;
    right: 10px;
    display: block;
    background: url(/sp/flatote/img/btn-close.png) no-repeat;
    width: 30px;
    height: 30px;
    text-indent: -9999px;
    background-size: contain;
  }
  #colorbox.flatote-gallery #cboxNext,
  #colorbox.flatote-gallery #cboxPrevious {
    display: block!important;
    position: absolute;
    top: 51%;
    margin-top: -30px;
    background: url("/sp/flatote/img/btn-pager.png") no-repeat;
    width: 20px;
    height: 38px;
    text-indent: -9999px;
    background-size: contain;
  }
  #colorbox.flatote-gallery #cboxPrevious {
    left: 10px;
  }
  #colorbox.flatote-gallery #cboxNext {
    transform: rotate(180deg);
    right: 10px;
  }
  /* ----- type-flatote-gallery ----- */
  .type-flatote-gallery .column_item:hover {
    opacity: 0.8;
  }
  .type-flatote-gallery[data-row-pc]:not([data-row-pc="1"]) > .column_item {
    margin-left: 40px;
  }
  .type-flatote-gallery[data-row-pc="2"] > .column_item {width: calc((100% - (40px * 1)) / 2);}
  .type-flatote-gallery[data-row-pc="3"] > .column_item {width: calc((100% - (40px * 2)) / 3);}
  .type-flatote-gallery[data-row-pc="4"] > .column_item {width: calc((100% - (40px * 3)) / 4);}
  .type-flatote-gallery[data-row-pc="5"] > .column_item {width: calc((100% - (40px * 4)) / 5);}
  [data-browser="ie11"] .type-flatote-gallery[data-row-pc="2"] > .column_item {width: calc(((100% - (40px * 1)) / 2) - 0.1px);}
  [data-browser="ie11"] .type-flatote-gallery[data-row-pc="3"] > .column_item {width: calc(((100% - (40px * 2)) / 3) - 0.1px);}
  [data-browser="ie11"] .type-flatote-gallery[data-row-pc="4"] > .column_item {width: calc(((100% - (40px * 3)) / 4) - 0.1px);}
  [data-browser="ie11"] .type-flatote-gallery[data-row-pc="5"] > .column_item {width: calc(((100% - (40px * 4)) / 5) - 0.1px);}
  [data-browser="edge"] .type-flatote-gallery[data-row-pc="2"] > .column_item {width: calc(((100% - (40px * 1)) / 2) - 0.1px);}
  [data-browser="edge"] .type-flatote-gallery[data-row-pc="3"] > .column_item {width: calc(((100% - (40px * 2)) / 3) - 0.1px);}
  [data-browser="edge"] .type-flatote-gallery[data-row-pc="4"] > .column_item {width: calc(((100% - (40px * 3)) / 4) - 0.1px);}
  [data-browser="edge"] .type-flatote-gallery[data-row-pc="5"] > .column_item {width: calc(((100% - (40px * 4)) / 5) - 0.1px);}
  .type-flatote-gallery[data-row-pc="2"] > .column_item:nth-child(2n+1),
  .type-flatote-gallery[data-row-pc="3"] > .column_item:nth-child(3n+1),
  .type-flatote-gallery[data-row-pc="4"] > .column_item:nth-child(4n+1),
  .type-flatote-gallery[data-row-pc="5"] > .column_item:nth-child(5n+1) {
    margin-left: 0;
  }
  .type-flatote-gallery[data-row-pc="1"] > .column_item + .column_item,
  .type-flatote-gallery[data-row-pc="2"] > .column_item:nth-child(n+3),
  .type-flatote-gallery[data-row-pc="3"] > .column_item:nth-child(n+4),
  .type-flatote-gallery[data-row-pc="4"] > .column_item:nth-child(n+5),
  .type-flatote-gallery[data-row-pc="5"] > .column_item:nth-child(n+6) {
    margin-top: 40px;
  }
  /* ------------------------------------------------------
   * Clearfix
  ------------------------------------------------------ */
  .clearfix::after{
    display: block;
    clear: both;
    content: "";
  }
}

/* ======================================================
 * PC Media Queries
====================================================== */
@media screen and (min-width: 768px) and (max-width: 1280px) {
  .flatote-hero_visual .slick-dots {
    width: calc((706/1280)*100vw);
  }
  .flatote-hero_read {
    font-size: 2vw;
  }
  .flatote-hero_release {
    bottom: 1vw;
  }
  .flatote-use_detail-text {
    font-size: 2vw;
  }
  .flatote-use_detail-text-under {
   font-size: 1.7vw;
  }
  .youtubeWrap .youtube-title {
    font-size: calc( 24 * 100vw / 1280);
  }
}
/***
@media screen and (min-width: 768px) and (max-width: 1080px) {
}
@media screen and (min-width: 768px) and (max-width: 960px) {
}
@media screen and (min-width: 1921px) {
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
}
***/


/* ======================================================
 * SP
====================================================== */
@media only screen and (max-width: 767px) {
  /* ----- ec-button ----- */
  .ec-heading {
    position: relative;
    padding-right: 80px;
  }
  .heading-ec-button {
    position: absolute;
    display: inline-block;
    width: 70px;
    right: 0;
    top: 0;
  }
  .ec-button {
    margin-top: 17px;
    text-align: center;
  }
  .ec-button_link {
    display: inline-block;
    padding: 2px 19px;
    background-color: #fff;
    border: 2px solid #418fde;
    border-radius: 5px;
    color: #418fde!important;
    font-weight: bold;
    font-size: 1.4rem;
    font-family: "Noto Sans CJK JP", "Noto Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
  .table-ec {
    display: flex;
    align-items: center;
    flex-flow: row wrap;
  }
  .table-ec-button {
    display: inline-block;
    max-width: 120px;
    min-width: 65px;
    margin-top: 5px;
    margin-left: 10px;
    padding: 0;
    vertical-align: middle;
  }
  .table-ec-button_link {
    display: inline-block;
    border: 2px solid #418fde;
    border-radius: 5px;
    padding: 3px 15px;
    color: #418fde;
    font-weight: bold;
    font-size: 1.4rem;
    font-family: "Noto Sans CJK JP", "Noto Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
  
  /* ----- flatote-hero-layout ----- */
  .flatote-hero-layout {
    position: relative;
  }
  .flatote-hero_visual {
    position: relative;
    margin: 0 -15px;
  }
  .flatote-hero_visual .flatote-hero_visual_item > img {
    width: 100%;
  }
  .flatote-hero_visual .slick-dots {
    position: absolute;
    left: 0;
    top: calc((236/376)*100vw);
    width: 100%;
    text-align: center;
  }
  .flatote-hero_visual .slick-dots > li {
    width: 10px;
    height: 10px;
    display: inline-block;
  }
  .flatote-hero_visual .slick-dots > li + li {
    margin-left: 10px;
  }
  .flatote-hero_visual .slick-dots > li > button {
    width: 100%;
    height: 100%;
    display: block;
    padding: 0;
    background-color: #898785;
    border: none;
    border-radius: 50%;
    text-indent: -9999em;
    font-size: 0;
    -webkit-transition: opacity .2s ease-out 0s;
    transition: opacity .2s ease-out 0s;
    outline: none;
  }
  .flatote-hero_visual .slick-dots > li.slick-active > button {
    background-color: #fff;
  }
  .flatote-hero_read {
    position: absolute;
    left: -0.8%;
    bottom: 27.9%;
    font-size: 1.6rem;
    line-height: 1.6;
  }
  .flatote-hero_release {
    position: absolute;
    bottom: 25px;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    text-align: center;
  }
  .flatote-hero_price,
  .flatote-hero_date {
    display: -webkit-flex;
    display: flex;
    justify-content: center;
    font-size: 1.4rem;
    line-height: 1.0;
  }
  .flatote-hero_date {
    margin-top: 10px;
  }
  /* ----- flatote-detail ----- */
  .flatote-detail {
    margin-top: 13px;
  }
  .flatote-detail_read {
    text-align: center;
    font-size: 1.8rem;
    line-height: 1.75;
    position: relative;
    font-weight: bold;
  }
  .flatote-detail_read_text-color {
    position: relative;
  }
  .flatote-detail_read_text-color::before {
    display: block;
    content: "";
    position: absolute;
    bottom: 0px;
    left: 0;
    width: 95%;
    height: 12px;
    background-color: #a2cbe5;
    z-index: -1;
  }
  .flatote-detail-wrap {
    margin-top: 20px;
  }
  .flatote-detail_item {
    text-align: center;
  }
  .flatote-detail_item:nth-child(n+2) {
    margin-top: 22px;
  }
  .flatote-detail_text {
    font-size: 1.6rem;
    font-weight: bold;
    color: #333;
    margin-top: 10px;
    line-height: 1.3;
  }
  /* ----- lots-layout ----- */
  .flatote-layout {
    margin-top: 45px;
  }
  .flatote-layout_head {
    padding: 5px;
    border-radius: 20px;
    background: #a2cbe5;
    text-align: center;
  }
  .flatote-layout_title {
    font-size: 2rem;
    font-weight: bold;
    line-height: 1.4;
  }
    /* ----- flatote-use ----- */
  .flatote-use {
    margin-top: 20px;
  }
  .flatote-use_item-col {
    display: -webkit-flex;
    display: flex;
    justify-content: center;
    flex-flow: row nowrap;
    align-items: center;
  }
  .flatote-use-head {
    width: calc((100% - 32px) / 2);
    flex-shrink: 0;
    margin-right: 15px;
  }
  .flatote-use-body {
    width: 100%
  }
  .flatote-use_item:nth-child(n+2) {
    margin-top: 22px;
  }
  .flatote-use_text {
    font-size: 1.4rem;
    color: #333;
    margin-top: 17px;
    line-height: 1.6;
  }
  .flatote-use_detail {
    display: -webkit-flex;
    display: flex;
    justify-content: center;
    border: 2px solid #6795b2;
    border-radius: 15px;
    padding: 20px 0 16px 9px;
    max-width: 470px;
    margin: 0 auto;
  }
  .flatote-use_detail-head {
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .flatote-use_detail-text {
    text-align: center;
    font-size: 2rem;
    font-weight: bold;
    color: #6795b2;
    line-height: 1.55;
  }
  .flatote-use_detail-text-under {
    font-size: 1.5rem;
    border-bottom: 1px solid #6795b2;
  }
  .flatote-use_detail-body {
    width: calc((100% - 20px) / 2);
    flex-shrink: 0;
    margin: 7px 0 0 17px;
}
  /* ------------------------------------------------------
   * youtube
  ------------------------------------------------------ */
   /* -----youtube----- */
  .youtubeWrap {
    margin: 18px auto 0;
  }
  .youtube-title {
    font-size: 1.7rem;
  }
  .youtube {
    position: relative;
    width: 100%;
    margin-top: 10px;
    padding-top: 56.25%;
  }
  .youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
  }

  /* ----- モーダル ----- */
  /* ----- flatote-modal-container ----- */
  .flatote-modal-container {
    display: none;
  }

  /* ----- flatote-modal-content ----- */
  .flatote-modal-content {
    position: relative;
    margin: 0;
    padding: 30px 30px 20px;
    background-color: #ffffff;
  }
  /* ----- flatote-gallery (modal) ----- */
  #colorbox.flatote-gallery #cboxContent {
    background: #fff;
    margin-top: 0;
  }
  #colorbox.flatote-gallery #cboxLoadedContent {
    border: none;
    overflow: auto;
  }
  #colorbox.flatote-gallery #cboxClose {
    position: absolute;
    top: 3px;
    right: 4px;
    display: block;
    background: url(/sp/flatote/img/btn-close.png) no-repeat;
    width: 20px;
    height: 20px;
    text-indent: -9999px;
    background-size: contain;
  }
  #colorbox.flatote-gallery #cboxNext,
  #colorbox.flatote-gallery #cboxPrevious {
    display: block!important;
    position: absolute;
    top: 51%;
    margin-top: -16px;
    background: url("/sp/flatote/img/btn-pager.png") no-repeat;
    width: 14px;
    height: 25px;
    text-indent: -9999px;
    background-size: contain;
  }
  #colorbox.flatote-gallery #cboxPrevious {
    left: 6px;
  }
  #colorbox.flatote-gallery #cboxNext {
    transform: rotate(180deg);
    right: 6px;
  }
  #cboxOverlay.flatote-gallery {
    background: #000000;
  }
  /* ------------------------------------------------------
   * Clearfix
  ------------------------------------------------------ */
  .clearfix::after {
    display: block;
    clear: both;
    content: "";
  }
}


/* ======================================================
 * SP Media Queries
====================================================== */
/***
@media only screen and (min-width: 320px) and (max-width: 767px) {
}
@media only screen and (max-width: 736px) {
}
@media only screen and (max-width: 667px) {
}
@media only screen and (max-width: 640px) {
}
@media only screen and (max-width: 568px) {
}

@media only screen and (max-width: 375px) {
}
***/
@media only screen and (min-width: 480px) and (max-width: 767px) {
  .flatote-hero_price,
  .flatote-hero_date {
    font-size: 1.6rem;
  }
}
@media only screen and (max-width: 374px) {
}
@media only screen and (max-width: 370px) {
  .table-ec {
    flex-flow: column;
    align-items: baseline;
  }
  .table-ec-button {
    margin-left: 0;
    margin-top: 5px;
  }
}
/***
@media only screen and (max-width: 320px) {
}



/* ======================================================
 * Print
====================================================== */
@media print {
}