@charset "utf-8";

/* ======================================================
 * dc.css
 * ------------------------------------------------------
 * @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
====================================================== */

/* ======================================================
 * PC
====================================================== */
@media print, screen and (min-width: 768px) {
  /* ------------------------------------------------------
   * Page Component
  ------------------------------------------------------ */
  /* ----- data-col-pc ----- */
  [data-col-pc]:not([data-col-pc="1"]) {
    display: flex;
    flex-flow: row wrap;
  }
  [data-col-pc] > * {
    margin: 4rem 0 0 36px;
  }
  [data-col-pc="1"] > * {width: 100%;}
  [data-col-pc="2"] > * {width: calc((100% - (36px * 1)) / 2);}
  [data-col-pc="3"] > * {width: calc((100% - (36px * 2)) / 3);}
  [data-col-pc="4"] > * {width: calc((100% - (36px * 3)) / 4);}
  [data-browser="ie11"] [data-col-pc="2"] > * {width: calc(((100% - (36px * 1)) / 2) - 0.1px);}
  [data-browser="ie11"] [data-col-pc="3"] > * {width: calc(((100% - (36px * 2)) / 3) - 0.1px);}
  [data-browser="ie11"] [data-col-pc="4"] > * {width: calc(((100% - (36px * 3)) / 4) - 0.1px);}
  [data-col-pc="1"] > *,
  [data-col-pc="2"] > *:nth-child(2n+1),
  [data-col-pc="3"] > *:nth-child(3n+1),
  [data-col-pc="4"] > *:nth-child(4n+1) {
    margin-left: 0;
  }
  [data-col-pc="1"] > *:first-child,
  [data-col-pc="2"] > *:nth-child(-n+2),
  [data-col-pc="3"] > *:nth-child(-n+3),
  [data-col-pc="4"] > *:nth-child(-n+4) {
    margin-top: 0;
  }
  /* ----- hero_contents ---- */
  .hero_contents {
    position: relative;
  }
  .hero_visual {
    width: 100%;
  }
  .hero_contents > .hero_visual_data {
    position: absolute;
    display: inline-block;
    bottom: 0;
    right: 0;
    padding: 8px 9px 5px;
    background: #fff;
    color: #ee8800;
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 1.25;
  }
  .image-set-v2 {
    display: flex;
    justify-content: center;
  }

  /* ----- heading-wrap----- */
  .heading-wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 0 1.75em;
  }
  .heading-wrap > .heading-lv1 {
    margin-bottom: 0 !important;
  }
  .heading-wrap > .heading-ec-button-wrap {
    margin-top: 0 !important;
  }
  .heading-wrap + * {
    margin-top: 1.75em;
  }
  /* ----- heading-ec-button----- */
  .heading-ec-button {
    display: inline-block;
    margin-left: 25px;
    width: 88px;
    vertical-align: top;
  }
  .heading-ec-button_link {
    display: block;
    padding: 6px 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;
  }
  .heading-ec-button_link:hover {
    color: #418fde !important;
    background-color: #daebfc;
  }

  /* ----- pp-text-right ----- */
  .pp-text-right {
    margin-top: 20px;
    text-align: right;
    color: #333;
    font-size: 16px;
  }

  /* ----- dc-heading2 ----- */
  .dc-heading2 {
    margin: 2.8em 0 1.75em;
  }
  .dc-heading2_title {
    font-size: 3.8rem;
    text-align: center;
    font-weight: 700;
    font-family: Lato, Verdana, Arial, Helvetica, sans-serif;
  }

  /* ----- dc-heading-lv2 ----- */
  .dc-heading-lv2 {
    margin-top: 36px;
    text-align: center;
  }
  /* ----- dc-heading-lv2_title ----- */
  .dc-heading-lv2_title {
    font-family: "Noto Sans JP";
    color: #333;
    font-weight: 700;
    font-size: 2.6rem;
  }

  /* ----- dc-box-layout ----- */
  .dc-box-layout {
    width: 67%;
    margin: 0 auto;
    margin-top: 36px;
    padding: 30px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    border-radius: 20px;
    background: #F4F1E8;
  }
  /* ----- dc-box_title ----- */
  .dc-box_title {
    color: #333;
    text-align: center;
    font-family: "Noto Sans JP";
    font-size: 2.6rem;
    font-style: normal;
    font-weight: 700;
    line-height: 150%;
  }

  /* ----- media__column__detail ----- */
  .dc-media__column__detail {
    width: 40%;
    min-width:360px
  }
  /* ----- dc-column-layout ----- */
  .dc-column-layout {
    display: flex;
    flex-flow: row wrap;
    align-items: flex-start;
    align-self: stretch;
    gap: 36px;
  }
  /* ----- dc-column_item ----- */
  .dc-column_item {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1 0 0;
    margin-top: 30px !important;
    width: calc((100% - 40px) / 2);
  }
  .dc-column_item > ul {
    align-self: flex-start;
    text-align: left;
  }
  .link-text > li > a.a-down::before {
    left: 4px;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
  }
  .link-text > li > a::before {
    position: absolute;
    top: 0.4em;
    width: 10px;
    height: 10px;
    border-top: 1px solid #333;
    border-right: 1px solid #333;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    content: "";
  }

  /* ----- dc-image_inner ----- */
  .dc-image_inner {
    display: flex;
    justify-content: center;
    margin-top: 1.5rem;
    margin-bottom: 2.0rem;
  }

  /* ----- table-layout ----- */
  .dc-table-layout {
    margin-top: 2.1rem;
  }
  /* ----- table_inner ----- */
  .dc-table_inner {
    width: 100%;
    border-top: 1px solid #ddd;
    border-right: 1px solid #ddd;
  }
  /* ----- .cell-style2 ----- */
  .cell-style2 {
    background-color: #f1f1f1;
  }
  /* ----- th,td ----- */
  .dc-table-layout th {
    padding: 10px 20px;
    border-bottom: 1px solid #ddd;
    border-left: 1px solid #ddd;
    font-weight: normal;
    text-align: left;
    vertical-align: top;
  }
  .dc-table-layout td {
    padding: 10px 15px;
    border-bottom: 1px solid #ddd;
    border-left: 1px solid #ddd;
    background-color: #fff;
    font-weight: normal;
    text-align: left;
    vertical-align: top;
  }

  /* ----- dc-media ----- */
  .dc-media {
    gap: 36px;
    display: flex;
    flex-direction: row-reverse;
  }
  /* ----- dc-media__column-image ----- */
  .dc-media__column-image {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  /* ----- dc-media__column-image__inner ----- */
  .dc-media__column-image__inner {
    margin-top: 22px;
  }

  /* ----- dc-ec-button ----- */
  .dc-ec-button {
    margin-left: 7px;
    max-width: 250px;
    min-width: 88px;
    vertical-align: top;
  }
  /* ----- dc-ec-button-wrap ----- */
  .dc-ec-button-wrap {
    display: flex;
    align-items: center;
    margin-bottom: 8px;
  }
  /* ----- dc-ec-button__link ----- */
  .dc-ec-button__link {
    display: inline-block;
    padding: 6px 25px 6px;
    background-color: #fff;
    border: 2px solid #418fde;
    border-radius: 6px;
    color: #418fde;
    font-weight: bold;
    font-size: 1.6rem;
    line-height: 1;
    transition: .2s ease-out 0s;
  }
  .dc-ec-button__link:hover {
    opacity: 1;
    background-color: #daebfc;
  }

  /* ----- dc-gallery ----- */
  .dc-gallery {
    margin: 30px 0 0;
  }
  .dc-gallery .gallery_list {
    display: flex;
    flex-flow: row wrap;
  }
  .dc-gallery .gallery_link {
    display: block;
    border-radius: 15px;
    overflow: hidden;
  }
  .dc-gallery .gallery_link:hover {
    opacity: 0.8;
  }
  .dc-gallery .gallery_image {
    width: 100%;
  }

  /* ----- モーダル ----- */
  /* ----- dc-modal-container ----- */
  .dc-modal-container {
    display: none;
  }
  /* ----- dc-modal-content ----- */
  .dc-modal-content {
    position: relative;
    margin: 0;
    padding: 50px 50px 35px;
    background: #ffffff;
  }
  .dc-modal-image {
    display: flex;
    justify-content: center;
  }
  /* ----- dc-gallery-modal ----- */
  #cboxOverlay.dc-gallery-modal {
    background: #000000;
  }
  #colorbox.dc-gallery-modal #cboxContent {
    background: #fff
  }
  #colorbox.dc-gallery-modal #cboxLoadedContent {
    border: none;
    overflow: auto;
  }
  #colorbox.dc-gallery-modal #cboxClose {
    position: absolute;
    top: 12px;
    right: 10px;
    display: block;
    background: url(/sp/dc/img/btn-close.png) no-repeat;
    width: 30px;
    height: 30px;
    text-indent: -9999px;
    background-size: contain;
  }
  #colorbox.dc-gallery-modal #cboxNext,
  #colorbox.dc-gallery-modal #cboxPrevious {
    display: block!important;
    position: absolute;
    top: 51%;
    margin-top: -30px;
    background: url(/sp/dc/img/btn-pager.png) no-repeat;
    width: 20px;
    height: 38px;
    text-indent: -9999px;
    background-size: contain;
  }
  #colorbox.dc-gallery-modal #cboxPrevious {
    left: 10px;
  }
  #colorbox.dc-gallery-modal #cboxNext {
    transform: rotate(180deg);
    right: 10px;
  }

  /* ----- dc-notes ----- */
  .dc-notes {
    margin: 36px 0 0;
  }
  .dc-notes + .dc-notes {
    margin-top: 20px;
  }
  .dc-notes .notes_title {
    color: #555555;
    font-weight: bold;
  }
  .dc-notes .notes_title + .notes_detail {
    margin-top: .5em;
  }
  .dc-notes .notes_detail > :first-child {
    margin-top: 0!important;
  }

  .dc-image-set {
    display: flex;
    justify-content: center;
    margin-top: 2em;
  }
}
/* ======================================================
 * SP Media Queries
====================================================== */

@media only screen and (max-width: 767px) {
  .hero_visual > img {
    width: 100%;
  }
  .pp-text-right {
    margin-top: 10px;
    text-align: right;
    color: #333;
    font-size: 14px;
  }
  .heading-wrap {
    position: relative;
    padding-right: 80px;
  }
  .heading-ec-button {
    position: absolute;
    display: inline-block;
    width: 70px;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  .heading-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 JP", "Noto Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
  .dc-heading-lv2 {
    margin-top: 2rem;
  }
  .dc-heading-lv2_title {
    color: #333;
    text-align: center;
    font-family: var(--font-font-family-2, "Noto Sans JP");
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 150%;
  }
  .hero_contents {
    position: relative;
    width: calc(100% + 30px);
    margin: 0 -15px;
  }
  .dc-box-layout {
    width: 100%;
    margin: 0 auto;
    margin-top: 15px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    border-radius: 20px;
    background: #F4F1E8;
  }
  .dc-box_title {
    color: var(--color-font-TX1, #333);
    text-align: center;
    font-family: var(--font-font-family-2, "Noto Sans JP");
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 150%;
  }
  .dc-column_item {
    align-items: flex-start;
    gap: var(--gap-col-gap, 15px);
    align-self: stretch;
    margin-top: 20px;
  }
  .dc-column_item .image_inner img {
    width: 80px;
    height: 80px;
    aspect-ratio: 1/1;
  }
  .dc-image-set-v2 {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    flex: 1 0 0;
  }
  .dc-image-set-v2 img {
    width: 103px;
    height: 25px;
    aspect-ratio: 103/25;
  }
  .dc-column_item {
    display: flex;
    flex-wrap: wrap;
  }
  .dc-image-set-v2 > p {
    margin-top: 5px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    align-self: stretch;
    font-weight: 300;
    line-height: 150%;
  }
  .dc-image-set-v2 > .link-text {
    margin-top: 10px;
  }
  .dc-media__column__detail {
    margin-top: 20px;
  }
  /* ----- table-layout ----- */
  .dc-table-layout {
    margin-top: 2.6rem;
  }
  /* ----- table_inner ----- */
  .dc-table_inner {
    width: 100%;
    border-top: 1px solid #ddd;
    border-right: 1px solid #ddd;
  }
  /* ----- .cell-style2 ----- */
  .cell-style2 {
    background-color: #f1f1f1;
  }
  /* ----- th,td ----- */
  .dc-table-layout th {
    padding: 10px 20px;
    border-bottom: 1px solid #ddd;
    border-left: 1px solid #ddd;
    font-weight: normal;
    text-align: left;
    vertical-align: top;
  }
  .dc-table-layout td {
    padding: 10px 10px;
    border-bottom: 1px solid #ddd;
    border-left: 1px solid #ddd;
    background-color: #fff;
    font-weight: normal;
    text-align: left;
    vertical-align: top;
  }
  .gp-w-041per {
    width: 31% !important;
  }
  .dc-heading2 {
    margin-top: 2.9em;
  }
  .dc-heading2_title {
    font-size: 1.9rem;
    text-align: center;
    font-weight: 700;
    font-family: Lato, Verdana, Arial, Helvetica, sans-serif;
  }
  .dc-gallery {
    margin: 30px 0 0;
  }
  [data-col-sp]:not([data-col-sp="1"]) {
    display: flex;
    flex-flow: row wrap;
  }
  [data-col-sp="2"] > * {
    width: calc((100% - (15px * 1)) / 2);
  }
  [data-col-sp] > * {
    margin: 0;
  }
  .gallery_list li {
    margin-bottom: 18px;
  }
  .gallery_list li:nth-of-type(even) {
    margin-left: 15px;
  }
  .dc-gallery .gallery_link {
    display: block;
    border-radius: 8px;
    overflow: hidden;
  }
  .dc-gallery .gallery_link:hover {
    opacity: 0.8;
  }
  a:link {
    color: #3381d0;
    text-decoration: none;
  }
  a {
    transition: all .2s ease-out 0s;
  }
  .dc-gallery .gallery_image {
    width: 100%;
  }
  .dc-modal-container {
    display: none;
  }
  .dc-modal-content {
    position: relative;
    margin: 0;
    padding: 30px 30px 20px;
    background-color: #ffffff;
  }
  .dc-ec-button {
    max-width: 250px;
    min-width: 88px;
    vertical-align: top;
    margin-top: 3px;
  }
  .dc-ec-button__link {
    display: inline-block;
    padding: 6px 19px 6px;
    background-color: #fff;
    border: 2px solid #418fde;
    border-radius: 6px;
    color: #418fde;
    font-weight: bold;
    font-size: 1.6rem;
    line-height: 1;
    transition: .2s ease-out 0s;
  }
  .dc-ec-button__link:hover {
    opacity: 1;
    background-color: #daebfc;
  }
  .heading-lv3-v3 {
    margin: 2.8em 0 1em;
  }
  .dc-media__column-image {
    margin-top: 15px;
  }
  /* ----- dc-gallery-modal-container ----- */
  .dc-gallery-modal-container {
    display: none;
  }
  /* ----- dc-gallery-modal ----- */
  #cboxOverlay.dc-gallery-modal {
    background: #000000;
  }
  #colorbox.dc-gallery-modal #cboxContent {
    background: #fff;
    border-radius: 8px;
    overflow: hidden;
  }
  #colorbox.dc-gallery-modal #cboxLoadedContent {
    border: none;
    overflow: auto;
  }
  #colorbox.dc-gallery-modal #cboxClose {
    position: absolute;
    top: 10px;
    right: 10px;
    display: block;
    background: url(/sp/dc/img/btn-close-2.svg) no-repeat;
    width: 15px;
    height: 15px;
    text-indent: -9999px;
    background-size: contain;
    transition: all .2s ease-out 0s;
  }
  #colorbox.dc-gallery-modal #cboxClose:hover {
    opacity: .8;
  }
  /* ----- dc-gallery-modal-box ----- */
  .dc-gallery-modal-box {
    position: relative;
    margin: 0;
    padding: 60px 45px;
  }
  .dc-gallery-modal-image {
    display: flex;
    justify-content: center;
  }
  .dc-gallery-modal-image > img {
    width: 147px;
  }
  .dc-gallery-modal-box_body {
    margin-top: 1.7em;
  }
  .dc-gallery-modal-text {
    margin-top: 1em;
    line-height: 1.5;
  }

  /* ----- dc-gallery ----- */
  .dc-gallery {
    margin: 30px 0 0;
  }
  .dc-gallery .gallery_link {
    display: block;
    border-radius: 8px;
    overflow: hidden;
  }
  .dc-gallery .gallery_image {
    width: 100%;
  }
  /* ----- モーダル ----- */
  /* ----- dc-modal-container ----- */
  .dc-modal-container {
    display: none;
  }
  /* ----- dc-modal-content ----- */
  .dc-modal-content {
    position: relative;
    margin: 0;
    padding: 30px 30px 20px;
    background-color: #ffffff;
  }

  /* ----- dc-gallery-modal ----- */
  #colorbox.dc-gallery-modal #cboxContent {
    background: #fff;
    margin-top: 0;
  }
  #colorbox.dc-gallery-modal #cboxLoadedContent {
    border: none;
    overflow: auto;
  }
  #colorbox.dc-gallery-modal #cboxClose {
    position: absolute;
    top: 3px;
    right: 4px;
    display: block;
    background: url(/sp/dc/img/btn-close.png) no-repeat;
    width: 20px;
    height: 20px;
    text-indent: -9999px;
    background-size: contain;
  }
  #colorbox.dc-gallery-modal #cboxNext,
  #colorbox.dc-gallery-modal #cboxPrevious {
    display: block!important;
    position: absolute;
    top: 51%;
    margin-top: -16px;
    background: url(/sp/dc/img/btn-pager.png) no-repeat;
    width: 14px;
    height: 25px;
    text-indent: -9999px;
    background-size: contain;
  }
  #colorbox.dc-gallery-modal #cboxPrevious {
    left: 6px;
  }
  #colorbox.dc-gallery-modal #cboxNext {
    transform: rotate(180deg);
    right: 6px;
  }
  #cboxOverlay.dc-gallery-modal {
    background: #000000;
  }
}
@media only screen and (min-width: 569px) and (max-width: 767px) {
  .dc-discription-text {
    position: absolute;
    font-size: 2.8rem;
    font-weight: bold;
    text-align: center;
    top: calc(50% - 52px);
    left: calc(50% - 237px);
    line-height: 1.6;
  }
}
@media only screen and (min-width: 487px) and (max-width: 568px) {
  .dc-discription-text {
    position: absolute;
    font-size: 2.4rem;
    font-weight: bold;
    text-align: center;
    top: calc(50% - 43px);
    left: calc(50% - 205px);
    line-height: 1.6;
  }
}



/* ======================================================
 * Print
====================================================== */
@media print {
}