@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;
}

.wrapper .inner {
  width: 100%;
  margin: 0 auto;
  max-width: 960px;
  position: relative;
  box-sizing: border-box;
}
@media screen and (max-width: 767px) {
  .wrapper .inner {
    padding: 0;
  }
}

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

/************************************************
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: 20%;
  right: 5%;
  text-align: right;
  font-weight: normal;
  line-height: 1.3;
}
#header .voce_winter {
  position: absolute;
  bottom: -8px;
  left: 0;
}
@media screen and (min-width: 768px) {
  #header {
/*    background: #dad9ed;*/
    overflow: hidden;
  }
  #header picture {
    margin: 0 -380px;
  }
  #header .notes{
    bottom: 38.5%;
    right: 5%;
    text-align: right;
    font-size: 8px;
  }
  #header .voce_winter {
    position: absolute;
    bottom: 0;
    left: 0;
  }
}
@media screen and (min-width: 960px) {
  #header picture {
    margin: 0 -480px;
  }
  #header .notes{
    bottom: 38.5%;
    right: 5%;
    text-align: right;
    font-size: min(max(8px, calc(0.5rem + ((1vw - 3.75px) * 0.5333))), 10px);
    min-height: 0vw;
  }
}

/************************************************
CV
************************************************/
.cv {
  margin-bottom: 10%;
}
.cv h2 {
  margin: 0 auto;
  top: 0;
  left: 0;
  right: 0;
}
.cv ul.notes {
  font-size: min(max(10px, calc(0.625rem + ((1vw - 3.75px) * 0.5333))), 12px);
  min-height: 0vw;
  margin: 5% 6% 0;
}
@media screen and (min-width: 768px) {
  .cv {
    margin-bottom: 5em;
  }
  .cv a picture {
    transition: all .3s;
  }
  .cv a picture:hover {
    opacity: .7;
  }
  .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;
  }
}

/************************************************
benefit
************************************************/
@media screen and (min-width: 768px) {
    .benefit picture {
        margin: 0 -480px;
    }
}
/************************************************
nayami
************************************************/
.nayami .head .notes {
  bottom: 6%;
  right: 5%;
  text-align: right;
}
.nayami .bottom .notes {
  bottom: 9.5%;
  right: 5%;
  text-align: right;
}
@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%;
  }
}

/************************************************
CV_short
************************************************/
.cv_short {
  margin-bottom: 40px;
}
.cv_short_ttl .notes {
  bottom: 28%;
  right: 6%;
}
@media screen and (min-width: 768px) {
  .cv_short_ttl .notes {
    bottom: 30%;
    right: 16%;
  }
}
#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;
}
#cv_short .notes {
  display: flex;
  justify-content: flex-end;
  margin: 1em;
}
@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: 6%;
}
.contents_02 .notes {
  bottom: 1%;
  right: 6%;
}
@media screen and (min-width: 768px) {
  .contents {
    max-width: 1920px;
    margin: 0 auto;
    overflow: hidden; 
  }
    
  .contents_01 picture,
  .contents_02 picture{
    margin: 0 -480px;
  }
  .contents_01 .notes {
    bottom: 7.5%;
    right: 15.5%;
  }

  .contents_02 .notes {
    bottom: 4%;
    right: 15.5%;
  }
}
@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: 5%;
  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_net04/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
************************************************/
.imagevisual02 .notes {
  bottom: 1.5%;
  right: 6.5%;
  text-align: right;
}
@media screen and (min-width: 768px) {
  .imagevisual02 .inner picture {
    margin: 0 -300px;
  }
}
@media screen and (min-width: 960px) {
  .imagevisual02 .inner picture {
    margin: 0 -480px;
  }
  .imagevisual02 .notes {
    bottom: 4%;
    right: 3%;
    text-align: right;
  }
}

/************************************************
imagevisual03
************************************************/
.imagevisual03 .notes {
  bottom: 1%;
  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;
}
