@charset "utf-8";

/* ======================================================
 * horupo.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 */
.horupo-hero_release,
.horupo-hero_point,
.horupo-layout_title,
.horupo-layout-v2_title,
.horupo-layout_lead,
.horupo-layout_lead-v2,
.horupo-layout_lead-v3,
.horupo-layout_flow_num,
.horupo-list-note > li,
.horupo-layout-v2_media_image > figcaption {
  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
  ------------------------------------------------------ */
  .column-layout {
    margin-top: 20px;
  }
  
  /* ------------------------------------------------------
   * 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 26px 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;
  }
  
  /* ----- horupo-hero-layout ----- */
  .horupo-hero-layout {
    position: relative;
  }
  .horupo-hero_visual {
    position: relative;
  }
  .horupo-hero_visual .slick-dots {
    position: absolute;
    left: 0;
    bottom: 17px;
    width: 100%;
    text-align: center;
  }
  .horupo-hero_visual .slick-dots > li {
    width: 10px;
    height: 10px;
    display: inline-block;
  }
  .horupo-hero_visual .slick-dots > li + li {
    margin-left: 10px;
  }
  .horupo-hero_visual .slick-dots > li > button {
    width: 100%;
    height: 100%;
    display: block;
    padding: 0;
    background-color: #fff;
    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;
    opacity: .5;
  }
  .horupo-hero_visual .slick-dots > li.slick-active > button {
    opacity: 1.0;
  }
  .horupo-hero_release {
    position: absolute;
    top: 269px;
    left: 40px;
    max-width: 420px;
  }
  .horupo-hero_price,
  .horupo-hero_date {
    font-size: 1.8rem;
    line-height: 1.0;
  }
  .horupo-hero_date {
    margin-top: 12px;
  }
  .horupo-hero_point {
    display: -webkit-flex;
    display: flex;
    justify-content: center;
    padding: 26px 20px;
    background-color: #66bdba;
  }
  .horupo-hero_point_item {
    display: -webkit-flex;
    display: flex;
    align-items: center;
  }
  .horupo-hero_point_item + .horupo-hero_point_item {
    margin-left: 58px;
  }
  .horupo-hero_point_body {
    margin-left: 18px;
  }
  .horupo-hero_point_badge {
    padding: 3px 19px;
    border-radius: 16px 0 16px 0;
    background-color: #fff;
    color: #1d2088;
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1;
  }
  .horupo-hero_point_badge > span {
    font-size: 2.8rem;
  }
  .horupo-hero_point_text {
    color: #fff;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.6;
  }
  
  /* ----- horupo-layout ----- */
  .horupo-layout {
    margin-top: 70px;
  }
  .horupo-layout_head {
    text-align: center;
  }
  .horupo-layout_title {
    display: inline-block;
    position: relative;
    padding: 0 120px;
    font-size: 4.0rem;
    font-weight: bold;
    line-height: 1.4;
    color: #1e2186;
  }
  .horupo-layout_title:before {
    position: absolute;
    content: "";
    left: 0;
    top: 54%;
    height: 2px;
    width: 90px;
    background-color: #1e2186;
  }
  .horupo-layout_title:after {
    position: absolute;
    content: "";
    right: 0;
    top: 54%;
    height: 2px;
    width: 90px;
    background-color: #1e2186;
  }
  .horupo-layout_body {
    margin-top: 42px;
  }
  .horupo-layout_body > *:first-child,
  .horupo-layout_body > section:first-child > *:first-child {
    margin-top: 0!important;
  }
  .horupo-layout_lead {
    margin-bottom: 24px;
    padding-bottom: 20px;
    border-bottom: 1px solid #9b9b9b;
    color: #1e2186;
    font-size: 3.0rem;
    font-weight: bold;
    line-height: 1.4;
  }
  .horupo-layout_text,
  .horupo-layout_text-v2 {
    font-size: 1.8rem;
    line-height: 1.8;
  }
  .horupo-layout_lead-v2 {
    margin-top: 51px;
    text-align: center;
  }
  .horupo-layout_lead-v2_inner {
    display: inline-block;
    margin-bottom: 25px;
    padding-bottom: 20px;
    border-bottom: 1px solid #9b9b9b;
    color: #1e2186;
    font-size: 3.0rem;
    font-weight: bold;
    line-height: 1.4;
  }
  .horupo-layout_lead-v3 {
    text-align: center;
    font-size: 2.6rem;
    font-weight: bold;
    line-height: 1.4;
  }
  .horupo-layout_text-v2 {
    text-align: center;
  }
  
  /* ----- horupo-layout_media ----- */
  .horupo-layout_media {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    margin-top: 31px;
  }
  .horupo-layout_media > * {
    width: calc((100% - 36px) / 2);
  }
  .horupo-layout_media[data-image-pc="left"] {
    flex-direction: row-reverse;
  }
  .horupo-layout_media[data-image-pc="left"] > .horupo-layout_media_head {
    margin-left: 36px;
  }
  .horupo-layout_media[data-image-pc="right"] > .horupo-layout_media_body {
    margin-left: 36px;
  }
  .horupo-layout_media_image {
    text-align: center;
  }
  .horupo-layout_media_image > img {
    max-width: 100%;
  }
  
  /* ----- horupo-layout_colmn ----- */
  .horupo-layout_colmn {
    display: -webkit-flex;
    display: flex;
    flex-flow: row wrap;
    margin-top: 20px;
  }
  .horupo-layout_colmn > * {
    width: calc((100% - 36px) / 2);
  }
  .horupo-layout_colmn_item {
    margin-left: 36px;
  }
  .horupo-layout_colmn_item:nth-of-type(odd) {
    margin-left: 0!important;
  }
  .horupo-layout_colmn_item:nth-of-type(n+3) {
    margin-top: 30px;
  }
  
  /* ----- horupo-layout_image ----- */
  .horupo-layout_image {
    text-align: center;
  }
  .horupo-layout_image > img {
    max-width: 100%;
  }
  
  /* ----- horupo-layout_flow ----- */
  .horupo-layout_flow {
    display: -webkit-flex;
    display: flex;
    flex-flow: row wrap;
    margin-top: 50px;
  }
  .horupo-layout_flow > * {
    width: calc((100% - 36px) / 2);
  }
  .horupo-layout_flow_item {
    margin-left: 36px;
  }
  .horupo-layout_flow_item:nth-of-type(odd) {
    margin-left: 0!important;
  }
  .horupo-layout_flow_item:nth-of-type(n+3) {
    margin-top: 35px;
  }
  .horupo-layout_flow_content {
    position: relative;
    margin-top: 28px;
  }
  .horupo-layout_flow_num {
    position: absolute;
    display: inline-block;
    left: 0;
    top: -10px;
    color: #1e2186;
    font-size: 4.0rem;
    font-weight: bold;
    line-height: 1.0;
  }
  .horupo-layout_flow_inner {
    padding-left: 50px;
  }
  .horupo-layout_flow_text {
    color: #1e2186;
    font-size: 1.8rem;
    line-height: 1.6;
  }
  .horupo-layout_flow_notes {
    position: relative;
    margin-top: 6px;
    padding-left: 1.3em;
    font-size: 1.4rem;
    line-height: 1.6;
  }
  .horupo-layout_flow_notes_mark {
    position: absolute;
    top: 0;
    left: 0;
  }
  
  
  /* ----- horupo-modal-container ----- */
  .horupo-modal-container {
    display: none;
  }
  /* ----- horupo-modal-content ----- */
  .horupo-modal-content {
    position: relative;
    margin: 0;
    padding: 50px 50px 35px;
    background: #ffffff;
  }
  /* ----- horupo-gallery (modal) ----- */
  #cboxOverlay.horupo-gallery {
    background: #000000;
  }
  #colorbox.horupo-gallery #cboxContent {
    background: #fff
  }
  #colorbox.horupo-gallery #cboxLoadedContent {
    border: none;
    overflow: auto;
  }
  #colorbox.horupo-gallery #cboxClose {
    position: absolute;
    top: 12px;
    right: 10px;
    display: block;
    background: url(/sp/horupo/img/btn-close.png) no-repeat;
    width: 30px;
    height: 30px;
    text-indent: -9999px;
    background-size: contain;
  }
  #colorbox.horupo-gallery #cboxNext,
  #colorbox.horupo-gallery #cboxPrevious {
    display: block!important;
    position: absolute;
    top: 51%;
    margin-top: -30px;
    background: url("/sp/horupo/img/btn-pager.png") no-repeat;
    width: 20px;
    height: 38px;
    text-indent: -9999px;
    background-size: contain;
  }
  #colorbox.horupo-gallery #cboxPrevious {
    left: 10px;
  }
  #colorbox.horupo-gallery #cboxNext {
    transform: rotate(180deg);
    right: 10px;
  }
  /* ----- type-horupo-gallery ----- */
  .type-horupo-gallery .column_item:hover {
    opacity: 0.8;
  }
  .type-horupo-gallery[data-row-pc]:not([data-row-pc="1"]) > .column_item {
    margin-left: 40px;
  }
  .type-horupo-gallery[data-row-pc="2"] > .column_item {width: calc((100% - (40px * 1)) / 2);}
  .type-horupo-gallery[data-row-pc="3"] > .column_item {width: calc((100% - (40px * 2)) / 3);}
  .type-horupo-gallery[data-row-pc="4"] > .column_item {width: calc((100% - (40px * 3)) / 4);}
  .type-horupo-gallery[data-row-pc="5"] > .column_item {width: calc((100% - (40px * 4)) / 5);}
  [data-browser="ie11"] .type-horupo-gallery[data-row-pc="2"] > .column_item {width: calc(((100% - (40px * 1)) / 2) - 0.1px);}
  [data-browser="ie11"] .type-horupo-gallery[data-row-pc="3"] > .column_item {width: calc(((100% - (40px * 2)) / 3) - 0.1px);}
  [data-browser="ie11"] .type-horupo-gallery[data-row-pc="4"] > .column_item {width: calc(((100% - (40px * 3)) / 4) - 0.1px);}
  [data-browser="ie11"] .type-horupo-gallery[data-row-pc="5"] > .column_item {width: calc(((100% - (40px * 4)) / 5) - 0.1px);}
  [data-browser="edge"] .type-horupo-gallery[data-row-pc="2"] > .column_item {width: calc(((100% - (40px * 1)) / 2) - 0.1px);}
  [data-browser="edge"] .type-horupo-gallery[data-row-pc="3"] > .column_item {width: calc(((100% - (40px * 2)) / 3) - 0.1px);}
  [data-browser="edge"] .type-horupo-gallery[data-row-pc="4"] > .column_item {width: calc(((100% - (40px * 3)) / 4) - 0.1px);}
  [data-browser="edge"] .type-horupo-gallery[data-row-pc="5"] > .column_item {width: calc(((100% - (40px * 4)) / 5) - 0.1px);}
  .type-horupo-gallery[data-row-pc="2"] > .column_item:nth-child(2n+1),
  .type-horupo-gallery[data-row-pc="3"] > .column_item:nth-child(3n+1),
  .type-horupo-gallery[data-row-pc="4"] > .column_item:nth-child(4n+1),
  .type-horupo-gallery[data-row-pc="5"] > .column_item:nth-child(5n+1) {
    margin-left: 0;
  }
  .type-horupo-gallery[data-row-pc="1"] > .column_item + .column_item,
  .type-horupo-gallery[data-row-pc="2"] > .column_item:nth-child(n+3),
  .type-horupo-gallery[data-row-pc="3"] > .column_item:nth-child(n+4),
  .type-horupo-gallery[data-row-pc="4"] > .column_item:nth-child(n+5),
  .type-horupo-gallery[data-row-pc="5"] > .column_item:nth-child(n+6) {
    margin-top: 40px;
  }
  
  /* ----- horupo-layout-v2 ----- */
  .horupo-layout-v2 {
    margin-top: 35px;
  }
  .horupo-layout-v2 + .horupo-layout-v2 {
    margin-top: 38px;
  }
  .horupo-layout-v2_title {
    display: inline-block;
    margin-bottom: 21px;
    position: relative;
    padding: 5px 68px 8px 70px;
    font-size: 2.5rem;
    font-weight: bold;
    line-height: 1.4;
    color: #fff;
    background-color: #1d2088;
  }
  .horupo-layout-v2_title:after {
    position: absolute;
    content: '';
    width: 0px;
    height: 0px;
    top: 0;
    right: 0;
    border-width: 25px 25px 25px 0px;
    border-color: transparent #fff transparent transparent;
    border-style: solid;
    z-index: 1;
  }
  .horupo-layout-v2_title.type-new:before {
    position: absolute;
    content: '';
    width: 64px;
    height: 64px;
    top: -8px;
    left: -1px;
    background: url("/sp/horupo/img/horupo_ic01.png") no-repeat left top/100%;
  }
  .horupo-layout-v2_text {
    font-size: 1.8rem;
  }
  .horupo-layout-v2_image {
    margin-top: 12px;
  }
  .horupo-layout-v2_image + .horupo-layout-v2_image {
    margin-top: 28px;
  }
  .horupo-layout-v2_media {
    display: flex;
    margin-bottom: 14px;
  }
  .horupo-layout-v2_media_head {
    flex: 1 1;
  }
  .horupo-layout-v2_media_body {
    display: flex;
    margin-left: 15px;
    padding: 0 40px;
  }
  .horupo-layout-v2_media_image {
    width: 130px;
    margin-left: 20px;
  }
  .horupo-layout-v2_media_image:first-child {
    margin-left: 0;
  }
  .horupo-layout-v2_media_image > figcaption {
    text-align: center;
    margin-top: .25em;
    font-weight: 500;
  }
  
  /* ----- horupo-list-note ----- */
  .horupo-list-note {
    text-align: right;
    margin-top: .2em;
  }
  .horupo-list-note > li {
    display: inline;
    font-size: 1.8rem;
    font-weight: bold;
    color: #333;
  }
  .horupo-list-note > li > .list_mark {
    top: -1px;
  }
  /* ------------------------------------------------------
   * Clearfix
  ------------------------------------------------------ */
  .clearfix::after{
    display: block;
    clear: both;
    content: "";
  }
}

/* ======================================================
 * PC Media Queries
====================================================== */
@media screen and (min-width: 768px) and (max-width: 1280px) {
  
  .horupo-hero_point_item + .horupo-hero_point_item {
    margin-left: 5%;
  }
  
  .horupo-hero_release {
    top: 21vw;
  }
  
  .horupo-layout_flow_inner {
    padding-left: 8%;
  }
}
@media screen and (min-width: 768px) and (max-width: 1023px) {
  .horupo-hero_release {
    top: 22vw;
  }
}
/***
@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: 50%;
    transform: translateY(-50%);
  }
  .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;
  }
  
  /* ----- horupo-hero-layout ----- */
  .horupo-hero-layout {
    position: relative;
  }
  .horupo-hero_visual {
    position: relative;
    margin: 0 -15px;
  }
  .horupo-hero_visual .horupo-hero_visual_item > img {
    width: 100%;
  }
  .horupo-hero_visual .slick-dots {
    position: absolute;
    left: 0;
    bottom: 15px;
    width: 100%;
    text-align: center;
  }
  .horupo-hero_visual .slick-dots > li {
    width: 10px;
    height: 10px;
    display: inline-block;
  }
  .horupo-hero_visual .slick-dots > li + li {
    margin-left: 10px;
  }
  .horupo-hero_visual .slick-dots > li > button {
    width: 100%;
    height: 100%;
    display: block;
    padding: 0;
    background-color: #fff;
    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;
    opacity: .5;
  }
  .horupo-hero_visual .slick-dots > li.slick-active > button {
    opacity: 1.0;
  }
  .horupo-hero_release {
    position: absolute;
    top: 103vw;
    left: 0;
    right: 0;
    text-align: center;
  }
  .horupo-hero_price,
  .horupo-hero_date {
    font-size: 1.4rem;
    line-height: 1.6;
  }
  .horupo-hero_point {
    margin: 0 -15px;
    padding: 20px 15px;
    background-color: #66bdba;
  }
  .horupo-hero_point_item {
    display: -webkit-flex;
    display: flex;
    max-width: 550px;
    margin: 0 auto;
  }
  .horupo-hero_point_item + .horupo-hero_point_item {
    margin-top: 15px;
  }
  .horupo-hero_point_body {
    margin-left: 8px;
  }
  .horupo-hero_point_badge {
    padding: 1px 9px;
    border-radius: 13px 0 13px 0;
    background-color: #fff;
    color: #1d2088;
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1;
  }
  .horupo-hero_point_badge > span {
    font-size: 2.2rem;
  }
  .horupo-hero_point_text {
    color: #fff;
    font-size: 1.5rem;
    font-weight: bold;
    line-height: 1.4;
  }
  
  /* ----- horupo-layout ----- */
  .horupo-layout {
    margin-top: 45px;
  }
  .horupo-layout_head {
    text-align: center;
  }
  .horupo-layout_title {
    display: inline-block;
    position: relative;
    padding: 0 75px;
    font-size: 2.9rem;
    font-weight: bold;
    line-height: 1.4;
    color: #1e2186;
  }
  .horupo-layout_title:before {
    position: absolute;
    content: "";
    left: 0;
    top: 50%;
    height: 2px;
    width: 60px;
    transform: translateY(-50%);
    background-color: #1e2186;
  }
  .horupo-layout_title:after {
    position: absolute;
    content: "";
    right: 0;
    top: 50%;
    height: 2px;
    width: 60px;
    transform: translateY(-50%);
    background-color: #1e2186;
  }
  .horupo-layout_body {
    margin-top: 32px;
  }
  .horupo-layout_body > *:first-child,
  .horupo-layout_body > section:first-child > *:first-child {
    margin-top: 0!important;
  }
  .horupo-layout_lead {
    margin-bottom: 17px;
    padding-bottom: 10px;
    border-bottom: 1px solid #9b9b9b;
    color: #1e2186;
    font-size: 2.1rem;
    font-weight: bold;
    line-height: 1.4;
    text-align: center;
  }
  .horupo-layout_text,
  .horupo-layout_text-v2 {
    font-size: 1.4rem;
    line-height: 1.6;
    text-align: center;
  }
  .horupo-layout_lead-v2 {
    margin-top: 40px;
  }
  .horupo-layout_lead-v2_inner {
    margin-bottom: 17px;
    padding-bottom: 10px;
    border-bottom: 1px solid #9b9b9b;
    color: #1e2186;
    font-size: 2.1rem;
    font-weight: bold;
    line-height: 1.4;
    text-align: center;
  }
  .horupo-layout_lead-v3 {
    text-align: center;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.4;
  }
  .horupo-layout-v2_text {
    font-size: 1.4rem;
    line-height: 1.6;
  }
  
  /* ----- horupo-layout_media ----- */
  .horupo-layout_media {
    margin-top: 40px;
  }
  .horupo-layout_media > * {
    width: 100%;
  }
  .horupo-layout_media_body {
    margin-top: 14px;
  }
  .horupo-layout_media_image {
    text-align: center;
  }
  .horupo-layout_media_image > img {
    max-width: 100%;
  }
  
  /* ----- horupo-layout_colmn ----- */
  .horupo-layout_colmn {
    margin-top: 14px;
  }
  .horupo-layout_colmn > * {
    width: 100%;
  }
  .horupo-layout_colmn_item {
    margin-top: 20px;
  }
  .horupo-layout_colmn_item:first-child {
    margin-top: 0!important;
  }
  
  /* ----- horupo-layout_image ----- */
  .horupo-layout_image {
    text-align: center;
  }
  .horupo-layout_image > img {
    max-width: 100%;
  }
  
  /* ----- horupo-layout_flow ----- */
  .horupo-layout_flow {
    margin-top: 35px;
  }
  .horupo-layout_flow > * {
    width: 100%;
  }
  .horupo-layout_flow_item {
    margin-top: 18px;
  }
  .horupo-layout_flow_item:first-child {
    margin-top: 0!important;
  }
  .horupo-layout_flow_content {
    position: relative;
    margin-top: 16px;
  }
  .horupo-layout_flow_num {
    position: absolute;
    display: inline-block;
    left: 0;
    top: -5px;
    color: #1e2186;
    font-size: 3.0rem;
    font-weight: bold;
    line-height: 1.0;
  }
  .horupo-layout_flow_inner {
    padding-left: 28px;
  }
  .horupo-layout_flow_text {
    color: #1e2186;
    font-size: 1.5rem;
    line-height: 1.6;
  }
  .horupo-layout_flow_notes {
    position: relative;
    margin-top: 4px;
    padding-left: 1.4em;
    font-size: 1.2rem;
    line-height: 1.6;
  }
  .horupo-layout_flow_notes_mark {
    position: absolute;
    top: 0;
    left: 0;
  }
  
  /* ----- horupo-modal-container ----- */
  .horupo-modal-container {
    display: none;
  }

  /* ----- horupo-modal-content ----- */
  .horupo-modal-content {
    position: relative;
    margin: 0;
    padding: 30px 30px 20px;
    background-color: #ffffff;
  }
  /* ----- horupo-gallery (modal) ----- */
  #colorbox.horupo-gallery #cboxContent {
    background: #fff;
    margin-top: 0;
  }
  #colorbox.horupo-gallery #cboxLoadedContent {
    border: none;
    overflow: auto;
  }
  #colorbox.horupo-gallery #cboxClose {
    position: absolute;
    top: 3px;
    right: 4px;
    display: block;
    background: url(/sp/horupo/img/btn-close.png) no-repeat;
    width: 20px;
    height: 20px;
    text-indent: -9999px;
    background-size: contain;
  }
  #colorbox.horupo-gallery #cboxNext,
  #colorbox.horupo-gallery #cboxPrevious {
    display: block!important;
    position: absolute;
    top: 51%;
    margin-top: -16px;
    background: url("/sp/horupo/img/btn-pager.png") no-repeat;
    width: 14px;
    height: 25px;
    text-indent: -9999px;
    background-size: contain;
  }
  #colorbox.horupo-gallery #cboxPrevious {
    left: 6px;
  }
  #colorbox.horupo-gallery #cboxNext {
    transform: rotate(180deg);
    right: 6px;
  }
  #cboxOverlay.horupo-gallery {
    background: #000000;
  }
  /* ----- horupo-layout-v2 ----- */
  .horupo-layout-v2 {
    margin-top: 14px;
  }
  .horupo-layout-v2 + .horupo-layout-v2 {
    margin-top: 23px;
  }
  .horupo-layout-v2_title {
    display: inline-block;
    margin-bottom: 15px;
    position: relative;
    padding: 3px 49px 6px 47px;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.4;
    color: #fff;
    background-color: #1d2088;
  }
  .horupo-layout-v2_title:after {
    position: absolute;
    content: '';
    width: 0px;
    height: 0px;
    top: 0;
    right: 0;
    border-width: 16px 16px 16px 0px;
    border-color: transparent #fff transparent transparent;
    border-style: solid;
    z-index: 1;
  }
  .horupo-layout-v2_title.type-new:before {
    position: absolute;
    content: '';
    width: 43px;
    height: 43px;
    top: -5px;
    left: 0;
    background: url("/sp/horupo/img/horupo_ic01.png") no-repeat left top/100%;
  }
  .horupo-layout-v2_text {
    font-size: 1.4rem;
  }
  .horupo-layout-v2_image {
    margin-top: 9px;
  }
  .horupo-layout-v2_image + .horupo-layout-v2_image {
    margin-top: 26px;
  }
  .horupo-layout-v2_media{
    margin-bottom: 18px;
  }
  .horupo-layout-v2_media_body {
    display: flex;
    justify-content: center;
    margin-top: 11px;
  }
  .horupo-layout-v2_media_image {
    width: 130px;
    margin-left: 15px;
  }
  .horupo-layout-v2_media_image:first-child {
    margin-left: 0;
  }
  .horupo-layout-v2_media_image > figcaption {
    text-align: center;
    margin-top: .6em;
    font-weight: 500;
  }
  
  /* ----- horupo-list-note ----- */
  .horupo-list-note {
    text-align: right;
    margin-top: .7em;
  }
  .horupo-list-note > li {
    display: inline;
    font-size: 1.4rem;
    font-weight: bold;
    color: #333;
  }
  .horupo-list-note > li > .list_mark {
    top: -1px;
  }
  /* ------------------------------------------------------
   * 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) {
  .horupo-hero_price,
  .horupo-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;
  }
  .horupo-hero_point {
    padding: 20px 8px;
  }
}
/***
@media only screen and (max-width: 320px) {
}



/* ======================================================
 * Print
====================================================== */
@media print {
}