@charset "UTF-8";
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp, picture,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}


body {
  background: #fff;
  box-sizing: border-box;
  overflow-x: hidden;
}

article, aside, dialog, figure, footer, header,
hgroup, nav, section {
  display: block;
}

a {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

ul, ol {
  list-style: none;
}

picture {
  display: block;
}

.wrapper {
  width: 100%;
  margin: 0;
  font-family: '游ゴシック', 'Yu Gothic', '游ゴシック体', YuGothic, sans-serif;
  font-weight: 500;
  overflow-x: hidden;
}

.wrapper .inner {
  width: 100%;
  margin: 0 auto;
  max-width: 960px;
  position: relative;
  box-sizing: border-box;
}
.wrapper #header .inner {
  max-width: 1300px;
}
.pcView {
  display: block;
}
.spView {
  display: none;
}

@media screen and (max-width: 767px) {
  .wrapper .inner {
    padding: 0;
  }
  .pcView {
    display: none;
  }
  .spView {
    display: block;
  }
}

.wrapper img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
}

.ac_img {
  text-align: center;
}

.z-index_03 {
  z-index: 3;
}
.z-index_02 {
  z-index: 2;
  margin-top: -120px;
}
.z-index_01 {
  z-index: 1;
  margin-top: -130px;
}

@media screen and (max-width: 767px) {
  .z-index_01 {
    margin-top: -80px;
  }
  .z-index_02 {
    margin-top: -75px;
  }
}
@media screen and (max-width: 400px) {
  .z-index_02 {
    margin-top: -55px;
  }
}

.max-01 {
  max-width: 845px;
  margin: 0 auto;
  padding: 0 15px;
}
.max-02 {
  max-width: 500px;
  margin: 40px auto 0;
}

@media screen and (max-width: 767px) {
  .max-02 {
    max-width: 300px;
    margin-top: 20px;
  }
}

.cv-btn-member {
  width: 28.53%;
}

/************************************************
deco
************************************************/
.wrapper .relative {
  position: relative;
}
.wrapper .absolute {
  position: absolute;
}
.wrapper .notes {
  font-size: min(max(8px, calc(0.5rem + ((1vw - 3.75px) * 0.5333))), 10px);
  min-height: 0vw;
  line-height: 1.5;
  color: #313131;
}
.wrapper .white {
  color: #fff;
}
.wrapper .red{
  color: #bc3656;
}
/************************************************
header
************************************************/
#header .notes{
  bottom: 3%;
  right: 5%;
  text-align: right;
  font-weight: normal;
}
@media screen and (min-width: 768px) {
  #header {
    background: #000;
    overflow: hidden;
  }
  #header .notes{
    bottom: 2.5%;
    right: 2%;
    font-size: 8px;
  }
}
@media screen and (min-width: 960px) {
  #header .notes{
    bottom: 2.5%;
    right: -2%;
    font-size: min(max(8px, calc(0.5rem + ((1vw - 3.75px) * 0.5333))), 10px);
    min-height: 0vw;
  }
}

/************************************************
CV
************************************************/
.cv {
  padding-bottom: 10%;
}
.cv h2 {
  margin: 0 auto;
  top: 0;
  left: 0;
  right: 0;
}
.cv ul.notes {
  max-width: 320px;
  /* font-size: min(max(10px, calc(0.625rem + ((1vw - 3.75px) * 0.5333))), 12px); */
  font-size: min((18 / 768 * 100vw), 10px);
  min-height: 0vw;
  margin: 5% 3% 0 auto;
}
@media screen and (min-width: 768px) {
  .cv {
    padding-bottom: 5em;
  }
  .cv a picture {
    transition: all .3s;
  }
  .cv a picture:hover {
    opacity: .7;
  }
  
  .cv .authority picture {
    margin: 0 -480px;
  }  
  .cv .saeko picture {
    margin: 0 -480px;
  } 
  .cv .head .item picture {
    margin: 0 -480px;
  }
  .cv-tel a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
  .cv-tel {
    width: calc(847/960 *100%);
    margin: 0 auto;
  }
  .cv ul.notes {
    max-width: 400px;
    font-size: min(max(10px, calc(0.625rem + ((1vw - 3.75px) * 0.5333))), 11px);
    min-height: 0vw;
    margin: 3% 0 0 auto;
  }
}

.cv .head .item {
    position: relative;
  }
.cv .head .item .position_text {
  position: absolute;
  bottom: 30%;
  left: 50%;
  content: '';
  width: 100%;
  transform: translateX(-50%) translateY(-10%);
}
.cv .head .item .notes.position_text {
  max-width: 680px;
}
.cv .head .item .notes.position_text li {
  position: relative;
  padding-left: 20px;
}
.cv .head .item .notes.position_text li span {
  position: absolute;
  top: 0;
  left: 0;
}

@media screen and (max-width: 768px) {
  .cv .head .item .position_text {
    top: 50%;
    bottom: auto;
    transform: translateX(-50%) translateY(-12%);
  }
  .cv .head .item .notes.position_text {
    max-width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
  .cv .head .item .notes.position_text li {
    padding-left: 10px;
  }
}

/************************************************
contents_01_area
************************************************/
.contents_01_area {
  position: relative;
}
.contents_01_area:before {
  position: absolute;
  bottom: 0;
  left: 0;
  content: '';
  width: 100%;
  height: 1300px;
  background-image: url(../../../../shopping/images/pub/skicle/d_net04/bg01.png);
  background-repeat: no-repeat;
  background-size: cover;
}

@media screen and (max-width: 767px) {
  .contents_01_area:before {
    height: 800px;
  }
}



/************************************************
nayami
************************************************/
.nayami .head .notes {
  bottom: 6%;
  right: 5%;
  text-align: right;
}
.nayami .bottom .notes {
  bottom: 9.5%;
  right: 5%;
  text-align: right;
}
.btn_01 {
  max-width: 730px;
  margin: 0 auto;
}
.btn_01.mt {
  margin-top: 40px;
}
.btn_01.pb {
  padding-bottom: 40px;
}

@media screen and (min-width: 768px) {
  .nayami picture {
    margin: 0 -480px;
  }
  .nayami .head .notes {
    bottom: 7%;
    right: 15%;
  }
  .nayami .bottom .notes {
    bottom: 13%;
    right: 15%;
  }
  .nayami .max-01 picture {
    margin: 0;
  }
  .btn_01.mt {
    margin-top: 80px;
  }
  .btn_01.pb {
    padding-bottom: 80px;
  }
}

/************************************************
CV_short
************************************************/
.cv_short_ttl .notes {
  bottom: 28%;
  right: 6%;
}
.cv-btn-new.mt {
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .cv-btn-new.mt {
    margin-top: 30px;
  }
}

@media screen and (min-width: 768px) {
  .cv_short_ttl .notes {
    bottom: 30%;
    right: 16%;
  }
}
.cv-btn-new {
  max-width: 780px;
  margin: 0 auto;
}
#cv_short h2 {
  margin: 0 auto;
  top: 0;
  left: 0;
  right: 0;
  max-width: 750px;
}
#cv_short .cv-btn-new {
  background: none;
  position: absolute;
  width: 44%;
  margin: 34.5% 0 0;
  padding: 0;
  top: 0;
  left: 54.5%;
  right: 0;
}
@media screen and (min-width: 768px) {
  #cv_short .cv-btn-new {
    width: 33.126%;
    margin: 22.083% 0 0;
    left: 50.6%;
  }
  #cv_short a picture {
    transition: all .3s;
  }
  #cv_short a picture:hover {
    opacity: .7;
  }
  #cv_short h2 {
    width: calc(750/960*100%);
  }
}

/************************************************
brand
************************************************/
.brand {
  margin-bottom: 13%;
}
@media screen and (min-width: 768px) {
  .brand {
    margin-bottom: 6em;
  }
}
.brand .notes {
  text-align: right;
  padding-right: 5%;
}

/************************************************
contents
************************************************/
.contents .notes {
  text-align: right;
}
.contents_01 .notes {
  bottom: 2.5%;
  right: 8%;
}
.contents_02 .notes {
  bottom: 21%;
  right: 8%;
}
.contents_03 .notes {
  bottom: 18%;
  right: 10%;
}
.contents_04 .fuki {
  margin: 0 auto;
  top: -2.3%;
  left: 0;
  right: 0;
  width: calc(192/750*100%);
}
.contents_04 .notes {
  bottom: 16%;
  right: 5%;
}
.contents_05 .notes {
  bottom: 7%;
  right: 5%;
}
@media screen and (min-width: 768px) {
  .contents {
    max-width: 1920px;
    margin: 0 auto;
    overflow: hidden; 
  }
  .contents_01 {
    background-image: url(../../../../shopping/images/pub/ds_hf/d_net03/pc_contents_01_bg.jpg);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: 100% 100%;
  }
  .contents_01 .notes {
    bottom: 16.5%;
    right: 3%;
  }
  .contents_02,
  .contents_04 {
    background-image: url(../../../../shopping/images/pub/ds_hf/d_net03/pc_contents_02_bg.jpg);
    background-position: center top;
    background-repeat: repeat-y;
    background-size: 100% auto;
  }
  .contents_02 .notes {
    bottom: 19%;
    right: 20%;
  }
  .contents_03 picture {
    margin: 0 -480px;
  }
  .contents_03 .notes {
    bottom: 16%;
    right: 16%;
  }
  .contents_04 .notes {
    bottom: 24%;
    right: 20%;
  }
  .contents_04 .fuki {
    width: 156px;
  }
  .contents_05 picture {
    margin: 0 -330px;
  }
  .contents_05 .notes {
    bottom: 8%;
    right: 22%;
  }
}
@media screen and (min-width: 960px) {
  .contents_05 picture {
    margin: 0 -480px;
  }
}

/************************************************
imagevisual01
************************************************/
.imagevisual01 p.notes{
  bottom: 3%;
  right: 5%;
  text-align: right;
}
@media screen and (min-width: 768px) {
  .imagevisual01 {
    max-width: 1920px;
    margin: 0 auto;
    overflow: hidden; 
    background: #dad9ed;
  }
  .imagevisual01 .inner {
    overflow: visible;
    max-width: 1320px;
  }
  .imagevisual01 p.notes{
    bottom: 2.5%;
    right: 13.5%;
  }
}
@media screen and (min-width: 768px) {
  .imagevisual01 .notes {
    font-size: 8px;
  }
}
@media screen and (min-width: 1200px) {
  .imagevisual01 .notes {
    font-size: min(max(8px, calc(0.5rem + ((1vw - 3.75px) * 0.5333))), 10px);
    min-height: 0vw;
  }
}

/************************************************
feature
************************************************/
.feature_02 .notes {
  margin: 0 auto;
  bottom: 13%;
  right: 5%;
  text-align: right;
}
@media screen and (min-width: 768px) {
    .feature {
      max-width: 1920px;
      margin: 0 auto;
      overflow: hidden; 
    }
  .feature_01 {
    background-image: url(../../../../shopping/images/pub/ds_hf/d_net03/pc_feature_bg.png);
    background-position: top;
    background-repeat: repeat-x;
    background-size: auto 100%;
  }
  .feature_02 .notes {
    margin: 0 auto;
    bottom: 14%;
    right: 17%;
  }
}

/************************************************
step
************************************************/
.step {
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .step {
    overflow: hidden;
  }
  .step .inner {
    overflow: visible;
  }
  .step .inner picture {
    margin: 0 -480px;
  }
}

/************************************************
aloma
************************************************/
.aloma {
  position: relative;
}
.aloma .arrow {
  width: 30.2666666667%;
  margin: -2.6666666667% auto 0;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  z-index: 4;
}
.aloma .main .notes {
  bottom: 15%;
  right: 5%;
}
@media screen and (min-width: 768px) {
  .aloma {
  }
  .aloma .arrow {
    width: 23.6458333333%;
    margin: -20px auto 0;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
  }
  .aloma .main picture {
    margin: 0 -480px;
  }
  .aloma .main .notes {
    bottom: 15%;
    right: 17%;
  }
}

/************************************************
imagevisual02
************************************************/
@media screen and (min-width: 768px) {
  .imagevisual02 .inner picture {
    margin: 0 -300px;
  }
}
@media screen and (min-width: 960px) {
  .imagevisual02 .inner picture {
    margin: 0 -480px;
  }
}

/************************************************
imagevisual03
************************************************/
.imagevisual03 .notes {
  bottom: 4%;
  right: 5%;
  text-align: right;
}
@media screen and (min-width: 768px) {
  .imagevisual03 .inner picture {
    margin: 0 -480px;
  }
  .imagevisual03 .notes {
    bottom: 8%;
    right: 2%;
    font-size: 8px;
  }
}
@media screen and (min-width: 960px) {
  .imagevisual03 .notes {
    right: 0%;
    font-size: min(max(8px, calc(0.5rem + ((1vw - 3.75px) * 0.5333))), 10px);
    min-height: 0vw;
  }
}


/************************************************
guide
************************************************/
.guide {
    padding-bottom: 10%;
}
.guide .notes {
  padding: 2% 4% 0;
}
@media screen and (min-width: 768px) {
  .guide {
      padding-bottom: 7em;
  }
  .guide .sp {
    display: none;
  }
}

/************************************************
footer
************************************************/
#footer {
  background-color: #091749;
  padding: 5% 0;
}
#footer ul {
  list-style: none;
  text-align: center;
}
#footer ul li {
  display: inline-block;
  padding: 0 10px;
  position: relative;
  border-right: 1px solid #fff;
  line-height: 1.1;
}
#footer ul li:nth-child(2n) {
  border: 0;
}
#footer ul li a {
  font-size: 13px;
  line-height: 1.1;
  text-decoration: none;
  color: #fff;
}
#footer p {
  color: #fff;
  text-align: center;
  font-size: 10px;
  line-height: 1.1;
  margin-top: 10px;
}
@media screen and (max-width: 360px) {
  #footer ul li {
    display: block;
    border: 0;
  }
}
@media screen and (min-width: 460px) {
  #footer ul li:nth-child(2n) {
    border-right: 1px solid #fff;
  }
  #footer ul li:last-child {
    border: 0;
  }
}
@media screen and (min-width: 768px) {
  #footer {
    padding: 6em 0;
  }
  #footer ul li a,
  #footer p {
    font-size: 15px;
  }
}

/************************************************
yda用
************************************************/
.notes.yda {
  max-width: 750px;
  margin: 0 auto;
  text-align: right;
  padding: 1.5em 1em 5em;
}
@media screen and (min-width: 768px) {
  .notes.yda {
    padding: 1.5em 0 9em;
  }
}

/************************************************
IE対応
************************************************/
_:-ms-lang(x)::-ms-backdrop, .wrapper .inner {
  min-width: 768px;
  padding: 0;
}

/************************************************
contents03_03
************************************************/
.contents03_03_img {
  max-width: 730px;
  margin: 130px auto 0;
}

@media screen and (max-width: 767px) {
  .contents03_03_img {
    margin-top: 40px;
  }
}

/************************************************
cap_right
************************************************/
.cap_right {
  margin-bottom: 130px;
  padding-top: 40px;
  padding-right: 15px;
  text-align: right;
  font-size: min(max(10px, calc(0.625rem + ((1vw - 3.75px) * 0.5333))), 12px);
}
.cap_left {
  padding-top: 20px;
  font-size: min(max(10px, calc(0.625rem + ((1vw - 3.75px) * 0.5333))), 12px);
}

@media screen and (max-width: 767px) {
  .cap_right {
    padding-top: 20px;
    margin-bottom: 40px;
  }
}

/************************************************
list_img
************************************************/
.contents07_04 {
  position: relative;
}
.contents07_04 .gif {
  position: absolute;
  top: 458px;
  left: 0%;
  border: solid 1px #d9c6c6;
  width: 427px;
}
@media screen and (max-width: 978px) {
  .contents07_04 .gif {
    top: 41.5%;
    left: auto;
    right: 55.3%;
    width: 50%;
  }
}
@media screen and (max-width: 767px) {
  .contents07_04 .gif {
    margin: 0 auto;
    top: 27.4%;
    left: 0;
    right: 0;
    width: calc(438/767*100%);
  }
}



/*************************************************
アナ雪コンテンツ
*************************************************/
/*追従バナー*/
.fix_banner {
  position: fixed;
  margin: 15px 10px;
  z-index: 99998;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  width: min(calc(259/1420*100%),259px);
  visibility: hidden;
  opacity: 0;
}
.fix_banner.is-active {
    visibility: visible;
    opacity: 1;
  
}
@media screen and (max-width: 750px) {
  .fix_banner {
    position: fixed;
    margin: 15px 10px;
    z-index: 99998;
    top: 25%;
    transform: none;
    right: 0;
    width: min(calc(259/768*100%),259px);

  }
}
.fix_banner img {
  width: 100%;
}
.fix_banner .banner_inner {
  position: relative;
}
.banner-close {
  position: absolute;
  right: -9px;
  top: -15px
}
@media screen and (max-width: 750px){
 .banner-close {
    position: absolute;
    right: -5px;
    top: -10px
  } 
}
button{
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}
.round_btn {
  display: block;
  position: relative;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.29);
}
@media screen and (max-width: 750px){
  .round_btn {
    width: 20px;
    height: 20px;
  }
}
.round_btn::before, .round_btn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 3px; /* 棒の幅（太さ） */
  height: 22px; /* 棒の高さ */
  background: #333; /* バツ印の色 */
}
@media screen and (max-width: 750px){
  .round_btn::before, .round_btn::after {
    width: 2px; /* 棒の幅（太さ） */
    height: 16px; /* 棒の高さ */
  }
}
.round_btn::before {
  transform: translate(-50%,-50%) rotate(45deg);
}
 
.round_btn::after {
  transform: translate(-50%,-50%) rotate(-45deg);
}

/*FV下のCV*/
.cv_ana {
  margin: 30px auto;
  position: relative;
  width: 786px;
}
.cv_ana .btn_s {
  position: absolute;
  width: 545px;
  left: 50%;
  transform: translateX(-50%);
  bottom: 42px;
}
@media screen and (max-width: 768px){
  .cv_ana {
    margin: 0;
    width: 100%;
  }
  .cv_ana .btn_s {
    position: absolute;
    width: 100%;
    height: 100%;
    right: 0;
    bottom: auto;
    top: 0;
  }
  .cv_ana .btn_s a {
    display: block;
    width: 100%;
    height: 100%;
  }
}
/*最後のCV*/

#cv_ana.contents_01_area {
  position: relative;
  overflow: hidden;
}
#cv_ana.contents_01_area:before {
  position: absolute;
  bottom: 0;
  left: 0;
  content: '';
  width: 100%;
  height: 1266px;
  background-image: url("../../../../shopping/images/pub/skicle/d_net04/cv_ana_bg_pc.png");
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 768px){
    #cv_ana.contents_01_area:before {
    position: absolute;
    top: 0;
    left: 0;
    content: '';
    width: 100%;
    height: 800px;
    background-image: url("../../../../shopping/images/pub/skicle/d_net04/cv_ana_bg_sp.png");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center top;
  }
}
#cv_ana .cv_obi {
  position: relative;
  padding: 0;
  margin: 0 -480px 20px;
}
@media screen and (max-width: 768px){
  #cv_ana .cv_obi {
    position: relative;
    padding: 0;
    margin: 20px auto ;
  }
}



.wrapper #cv_ana .inner {
  width: 100%;
  margin: 0 auto;
  max-width: 900px;
  position: relative;
  box-sizing: border-box;
}
@media screen and (max-width: 768px){
 .wrapper #cv_ana .inner {
    width: 100%;
    padding: 0 2.665%;
  } 
}
.wrapper #cv_ana .inner .cv-btn-new {
  position: absolute;
  bottom: 18%;
  left: 50%;
  transform: translateX(-50%);
  width: 86.67%;
}
/*
@media screen and (max-width: 767px) {
  #cv_ana.contents_01_area:before {
    height: 800px;
  }
}
*/
