/* ===================================================================

scss core settings

=================================================================== */
@font-face {
  font-family: "Reminisce";
  src: url("../font/Reminisce-Light.woff2") format("woff2"), url("../font/Reminisce-Light.woff") format("woff");
}
@font-face {
  font-family: "handsome";
  src: url("../font/HANDSOME_GOTHIC-Medium.otf") format("opentype"),url("../font/HANDSOME_GOTHIC-Bold.otf") format("opentype");
}
@font-face {
  font-family: "handsome-light";
  src: url("../font/HANDSOME_GOTHIC-Light.otf") format("opentype");
}

.reminisce {
  font-family: "Reminisce", Reminisce, sans-serif;
}
.handsome-font {
  font-family: "handsome", sans-serif;
  font-weight: normal;
}
.handsome-boldfont {
  font-family: "handsome", sans-serif;
  font-weight: bold;
}
.handsome-lightfont {
  font-family: "handsome-light", sans-serif;
  font-weight: lighter;
}

/* ===================================================================

reset style

=================================================================== */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  letter-spacing: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* ===================================================================

util style

=================================================================== */
/* text */
.tl {
  text-align: left;
}

.tc {
  text-align: center;
}

.tr {
  text-align: right;
}

.bold {
  font-weight: bold;
}

.underline {
  text-decoration: underline;
}

/* float */
.fl {
  float: left;
}

.fr {
  float: right;
}

/* clear */
.clear {
  clear: both;
}

.clear_l {
  clear: left;
}

.clear_r {
  clear: right;
}

/* clearfix */
.clearfix {
  zoom: 1;
}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

/* box center */
.center {
  margin-left: auto;
  margin-right: auto;
}

/* Font-Size */
.f10 {
  font-size: 10px;
}

.f11 {
  font-size: 11px;
}

.f12 {
  font-size: 12px;
}

.f13 {
  font-size: 13px;
}

.f14 {
  font-size: 14px;
}

.f15 {
  font-size: 15px;
}

.f16 {
  font-size: 16px;
}

.f17 {
  font-size: 17px;
}

.f18 {
  font-size: 18px;
}

.f19 {
  font-size: 19px;
}

.f20 {
  font-size: 20px;
}

.f21 {
  font-size: 21px;
}

.f22 {
  font-size: 22px;
}

.f23 {
  font-size: 23px;
}

.f24 {
  font-size: 24px;
}

.f25 {
  font-size: 25px;
}

.f26 {
  font-size: 26px;
}

.f27 {
  font-size: 27px;
}

.f28 {
  font-size: 28px;
}

.f29 {
  font-size: 29px;
}

.f30 {
  font-size: 30px;
}

.f31 {
  font-size: 31px;
}

.f32 {
  font-size: 32px;
}

.f33 {
  font-size: 33px;
}

.f34 {
  font-size: 34px;
}

.f35 {
  font-size: 35px;
}

.f36 {
  font-size: 36px;
}

.f37 {
  font-size: 37px;
}

.f38 {
  font-size: 38px;
}

.f39 {
  font-size: 39px;
}

.f40 {
  font-size: 40px;
}

/* line-height */
.lh10 {
  line-height: 10px;
}

.lh11 {
  line-height: 11px;
}

.lh12 {
  line-height: 12px;
}

.lh13 {
  line-height: 13px;
}

.lh14 {
  line-height: 14px;
}

.lh15 {
  line-height: 15px;
}

.lh16 {
  line-height: 16px;
}

.lh17 {
  line-height: 17px;
}

.lh18 {
  line-height: 18px;
}

.lh19 {
  line-height: 19px;
}

.lh20 {
  line-height: 20px;
}

.lh21 {
  line-height: 21px;
}

.lh22 {
  line-height: 22px;
}

.lh23 {
  line-height: 23px;
}

.lh24 {
  line-height: 24px;
}

.lh25 {
  line-height: 25px;
}

.lh26 {
  line-height: 26px;
}

.lh27 {
  line-height: 27px;
}

.lh28 {
  line-height: 28px;
}

.lh29 {
  line-height: 29px;
}

.lh30 {
  line-height: 30px;
}

.lh31 {
  line-height: 31px;
}

.lh32 {
  line-height: 32px;
}

.lh33 {
  line-height: 33px;
}

.lh34 {
  line-height: 34px;
}

.lh35 {
  line-height: 35px;
}

.lh36 {
  line-height: 36px;
}

.lh37 {
  line-height: 37px;
}

.lh38 {
  line-height: 38px;
}

.lh39 {
  line-height: 39px;
}

.lh40 {
  line-height: 40px;
}

/* Margin-Top & Padding-Top */
.mt00 {
  margin-top: 0px;
}

.pt00 {
  padding-top: 0px;
}

.mt05 {
  margin-top: 5px;
}

.pt05 {
  padding-top: 5px;
}

.mt10 {
  margin-top: 10px;
}

.pt10 {
  padding-top: 10px;
}

.mt15 {
  margin-top: 15px;
}

.pt15 {
  padding-top: 15px;
}

.mt20 {
  margin-top: 20px;
}

.pt20 {
  padding-top: 20px;
}

.mt25 {
  margin-top: 25px;
}

.pt25 {
  padding-top: 25px;
}

.mt30 {
  margin-top: 30px;
}

.pt30 {
  padding-top: 30px;
}

.mt35 {
  margin-top: 35px;
}

.pt35 {
  padding-top: 35px;
}

.mt40 {
  margin-top: 40px;
}

.pt40 {
  padding-top: 40px;
}

.mt45 {
  margin-top: 45px;
}

.pt45 {
  padding-top: 45px;
}

.mt50 {
  margin-top: 50px;
}

.pt50 {
  padding-top: 50px;
}

.mt55 {
  margin-top: 55px;
}

.pt55 {
  padding-top: 55px;
}

.mt60 {
  margin-top: 60px;
}

.pt60 {
  padding-top: 60px;
}

.mt65 {
  margin-top: 65px;
}

.pt65 {
  padding-top: 65px;
}

.mt70 {
  margin-top: 70px;
}

.pt70 {
  padding-top: 70px;
}

.mt75 {
  margin-top: 75px;
}

.pt75 {
  padding-top: 75px;
}

.mt80 {
  margin-top: 80px;
}

.pt80 {
  padding-top: 80px;
}

.mt85 {
  margin-top: 85px;
}

.pt85 {
  padding-top: 85px;
}

.mt90 {
  margin-top: 90px;
}

.pt90 {
  padding-top: 90px;
}

.mt95 {
  margin-top: 95px;
}

.pt95 {
  padding-top: 95px;
}

.mt100 {
  margin-top: 100px;
}

.pt100 {
  padding-top: 100px;
}

/* Margin-Right & Padding-Right */
.mr00 {
  margin-right: 0px;
}

.pr00 {
  padding-right: 0px;
}

.mr05 {
  margin-right: 5px;
}

.pr05 {
  padding-right: 5px;
}

.mr10 {
  margin-right: 10px;
}

.pr10 {
  padding-right: 10px;
}

.mr15 {
  margin-right: 15px;
}

.pr15 {
  padding-right: 15px;
}

.mr20 {
  margin-right: 20px;
}

.pr20 {
  padding-right: 20px;
}

.mr25 {
  margin-right: 25px;
}

.pr25 {
  padding-right: 25px;
}

.mr30 {
  margin-right: 30px;
}

.pr30 {
  padding-right: 30px;
}

.mr35 {
  margin-right: 35px;
}

.pr35 {
  padding-right: 35px;
}

.mr40 {
  margin-right: 40px;
}

.pr40 {
  padding-right: 40px;
}

.mr45 {
  margin-right: 45px;
}

.pr45 {
  padding-right: 45px;
}

.mr50 {
  margin-right: 50px;
}

.pr50 {
  padding-right: 50px;
}

.mr55 {
  margin-right: 55px;
}

.pr55 {
  padding-right: 55px;
}

.mr60 {
  margin-right: 60px;
}

.pr60 {
  padding-right: 60px;
}

.mr65 {
  margin-right: 65px;
}

.pr65 {
  padding-right: 65px;
}

.mr70 {
  margin-right: 70px;
}

.pr70 {
  padding-right: 70px;
}

.mr75 {
  margin-right: 75px;
}

.pr75 {
  padding-right: 75px;
}

.mr80 {
  margin-right: 80px;
}

.pr80 {
  padding-right: 80px;
}

.mr85 {
  margin-right: 85px;
}

.pr85 {
  padding-right: 85px;
}

.mr90 {
  margin-right: 90px;
}

.pr90 {
  padding-right: 90px;
}

.mr95 {
  margin-right: 95px;
}

.pt95 {
  padding-right: 95px;
}

.mr100 {
  margin-right: 100px;
}

.pr100 {
  padding-right: 100px;
}

/* Margin-Bottom & Padding-Bottom */
.mb00 {
  margin-bottom: 0px;
}

.pb00 {
  padding-bottom: 0px;
}

.mb05 {
  margin-bottom: 5px;
}

.pb05 {
  padding-bottom: 5px;
}

.mb10 {
  margin-bottom: 10px;
}

.pb10 {
  padding-bottom: 10px;
}

.mb15 {
  margin-bottom: 15px;
}

.pb15 {
  padding-bottom: 15px;
}

.mb20 {
  margin-bottom: 20px;
}

.pb20 {
  padding-bottom: 20px;
}

.mb25 {
  margin-bottom: 25px;
}

.pb25 {
  padding-bottom: 25px;
}

.mb30 {
  margin-bottom: 30px;
}

.pb30 {
  padding-bottom: 30px;
}

.mb35 {
  margin-bottom: 35px;
}

.pb35 {
  padding-bottom: 35px;
}

.mb40 {
  margin-bottom: 40px;
}

.pb40 {
  padding-bottom: 40px;
}

.mb45 {
  margin-bottom: 45px;
}

.pb45 {
  padding-bottom: 45px;
}

.mb50 {
  margin-bottom: 50px;
}

.pb50 {
  padding-bottom: 50px;
}

.mb55 {
  margin-bottom: 55px;
}

.pb55 {
  padding-bottom: 55px;
}

.mb60 {
  margin-bottom: 60px;
}

.pb60 {
  padding-bottom: 60px;
}

.mb65 {
  margin-bottom: 65px;
}

.pb65 {
  padding-bottom: 65px;
}

.mb70 {
  margin-bottom: 70px;
}

.pb70 {
  padding-bottom: 70px;
}

.mb75 {
  margin-bottom: 75px;
}

.pb75 {
  padding-bottom: 75px;
}

.mb80 {
  margin-bottom: 80px;
}

.pb80 {
  padding-bottom: 80px;
}

.mb85 {
  margin-bottom: 85px;
}

.pb85 {
  padding-bottom: 85px;
}

.mb90 {
  margin-bottom: 90px;
}

.pb90 {
  padding-bottom: 90px;
}

.mb95 {
  margin-bottom: 95px;
}

.pt95 {
  padding-bottom: 95px;
}

.mb100 {
  margin-bottom: 100px;
}

.pb100 {
  padding-bottom: 100px;
}

/* Margin-Left & Padding-Left */
.ml00 {
  margin-left: 0px;
}

.pl00 {
  padding-left: 0px;
}

.ml05 {
  margin-left: 5px;
}

.pl05 {
  padding-left: 5px;
}

.ml10 {
  margin-left: 10px;
}

.pl10 {
  padding-left: 10px;
}

.ml15 {
  margin-left: 15px;
}

.pl15 {
  padding-left: 15px;
}

.ml20 {
  margin-left: 20px;
}

.pl20 {
  padding-left: 20px;
}

.ml25 {
  margin-left: 25px;
}

.pl25 {
  padding-left: 25px;
}

.ml30 {
  margin-left: 30px;
}

.pl30 {
  padding-left: 30px;
}

.ml35 {
  margin-left: 35px;
}

.pl35 {
  padding-left: 35px;
}

.ml40 {
  margin-left: 40px;
}

.pl40 {
  padding-left: 40px;
}

.ml45 {
  margin-left: 45px;
}

.pl45 {
  padding-left: 45px;
}

.ml50 {
  margin-left: 50px;
}

.pl50 {
  padding-left: 50px;
}

.ml55 {
  margin-left: 55px;
}

.pl55 {
  padding-left: 55px;
}

.ml60 {
  margin-left: 60px;
}

.pl60 {
  padding-left: 60px;
}

.ml65 {
  margin-left: 65px;
}

.pl65 {
  padding-left: 65px;
}

.ml70 {
  margin-left: 70px;
}

.pl70 {
  padding-left: 70px;
}

.ml75 {
  margin-left: 75px;
}

.pl75 {
  padding-left: 75px;
}

.ml80 {
  margin-left: 80px;
}

.pl80 {
  padding-left: 80px;
}

.ml85 {
  margin-left: 85px;
}

.pb85 {
  padding-left: 85px;
}

.ml90 {
  margin-left: 90px;
}

.pl90 {
  padding-left: 90px;
}

.ml95 {
  margin-left: 95px;
}

.pt95 {
  padding-left: 95px;
}

.ml100 {
  margin-left: 100px;
}

.pl100 {
  padding-left: 100px;
}

.tj {
  text-align: justify;
}

.lh1 {
  line-height: 1;
}

.lh1-1 {
  line-height: 1.1;
}

.lh1-2 {
  line-height: 1.2;
}

.lh1-3 {
  line-height: 1.3;
}

.lh1-4 {
  line-height: 1.4;
}

.lh1-5 {
  line-height: 1.5;
}

.lh1-6 {
  line-height: 1.6;
}

.lh1-7 {
  line-height: 1.7;
}

.lh1-8 {
  line-height: 1.8;
}

.lh1-9 {
  line-height: 1.9;
}

.lh2 {
  line-height: 2;
}

.lh2-1 {
  line-height: 2.1;
}

.lh2-2 {
  line-height: 2.2;
}

.lh2-3 {
  line-height: 2.3;
}

.lh2-4 {
  line-height: 2.4;
}

.lh2-5 {
  line-height: 2.5;
}

.lh2-6 {
  line-height: 2.6;
}

.lh2-7 {
  line-height: 2.7;
}

.lh2-8 {
  line-height: 2.8;
}

.lh2-9 {
  line-height: 2.9;
}

.lh3 {
  line-height: 3;
}

.ls1 {
  letter-spacing: 0.1em;
}

.ls2 {
  letter-spacing: 0.2em;
}

.ls3 {
  letter-spacing: 0.3em;
}

.ls4 {
  letter-spacing: 0.4em;
}

.ls5 {
  letter-spacing: 0.5em;
}

.w1 {
  width: 1%;
}

.w2 {
  width: 2%;
}

.w3 {
  width: 3%;
}

.w4 {
  width: 4%;
}

.w5 {
  width: 5%;
}

.w6 {
  width: 6%;
}

.w7 {
  width: 7%;
}

.w8 {
  width: 8%;
}

.w9 {
  width: 9%;
}

.w10 {
  width: 10%;
}

.w11 {
  width: 11%;
}

.w12 {
  width: 12%;
}

.w13 {
  width: 13%;
}

.w14 {
  width: 14%;
}

.w15 {
  width: 15%;
}

.w16 {
  width: 16%;
}

.w17 {
  width: 17%;
}

.w18 {
  width: 18%;
}

.w19 {
  width: 19%;
}

.w20 {
  width: 20%;
}

.w21 {
  width: 21%;
}

.w22 {
  width: 22%;
}

.w23 {
  width: 23%;
}

.w24 {
  width: 24%;
}

.w25 {
  width: 25%;
}

.w26 {
  width: 26%;
}

.w27 {
  width: 27%;
}

.w28 {
  width: 28%;
}

.w29 {
  width: 29%;
}

.w30 {
  width: 30%;
}

.w31 {
  width: 31%;
}

.w32 {
  width: 32%;
}

.w33 {
  width: 33%;
}

.w34 {
  width: 34%;
}

.w35 {
  width: 35%;
}

.w36 {
  width: 36%;
}

.w37 {
  width: 37%;
}

.w38 {
  width: 38%;
}

.w39 {
  width: 39%;
}

.w40 {
  width: 40%;
}

.w41 {
  width: 41%;
}

.w42 {
  width: 42%;
}

.w43 {
  width: 43%;
}

.w44 {
  width: 44%;
}

.w45 {
  width: 45%;
}

.w46 {
  width: 46%;
}

.w47 {
  width: 47%;
}

.w48 {
  width: 48%;
}

.w49 {
  width: 49%;
}

.w50 {
  width: 50%;
}

.w51 {
  width: 51%;
}

.w52 {
  width: 52%;
}

.w53 {
  width: 53%;
}

.w54 {
  width: 54%;
}

.w55 {
  width: 55%;
}

.w56 {
  width: 56%;
}

.w57 {
  width: 57%;
}

.w58 {
  width: 58%;
}

.w59 {
  width: 59%;
}

.w60 {
  width: 60%;
}

.w61 {
  width: 61%;
}

.w62 {
  width: 62%;
}

.w63 {
  width: 63%;
}

.w64 {
  width: 64%;
}

.w65 {
  width: 65%;
}

.w66 {
  width: 66%;
}

.w67 {
  width: 67%;
}

.w68 {
  width: 68%;
}

.w69 {
  width: 69%;
}

.w70 {
  width: 70%;
}

.w71 {
  width: 71%;
}

.w72 {
  width: 72%;
}

.w73 {
  width: 73%;
}

.w74 {
  width: 74%;
}

.w75 {
  width: 75%;
}

.w76 {
  width: 76%;
}

.w77 {
  width: 77%;
}

.w78 {
  width: 78%;
}

.w79 {
  width: 79%;
}

.w80 {
  width: 80%;
}

.w81 {
  width: 81%;
}

.w82 {
  width: 82%;
}

.w83 {
  width: 83%;
}

.w84 {
  width: 84%;
}

.w85 {
  width: 85%;
}

.w86 {
  width: 86%;
}

.w87 {
  width: 87%;
}

.w88 {
  width: 88%;
}

.w89 {
  width: 89%;
}

.w90 {
  width: 90%;
}

.w91 {
  width: 91%;
}

.w92 {
  width: 92%;
}

.w93 {
  width: 93%;
}

.w94 {
  width: 94%;
}

.w95 {
  width: 95%;
}

.w96 {
  width: 96%;
}

.w97 {
  width: 97%;
}

.w98 {
  width: 98%;
}

.w99 {
  width: 99%;
}

.w100 {
  width: 100%;
}

sup {
  font-size: smaller;
  vertical-align: super;
}

/* ===================================================================

utility

=================================================================== */
.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -moz-flex;
  display: flex;
}

.fw-w {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.fd-r {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}

.fd-rr {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}

.fd-cr {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
}

.fd-c {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.jc-c {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.jc-sb {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.jc-sa {
  -ms-flex-pack: distribute;
      justify-content: space-around;
}

.jc-fe {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

.jc-fs {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.ai-c {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.ai-fe {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

.ai-fs {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.half-width {
  width: 50%;
}

.quarter-width {
  width: 25%;
}

.col2-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -moz-flex;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.col2-list li {
  width: 50%;
}

.col3-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -moz-flex;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.col3-list li {
  width: 33.33%;
}

.col4-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -moz-flex;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.col4-list li {
  width: 25%;
}

.col5-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -moz-flex;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.col5-list li {
  width: 20%;
}

.list-space1 li {
  padding-right: 1%;
  padding-left: 1%;
}

.anm {
  -webkit-transition: 1s;
  transition: 1s;
}

.anm.fading {
  opacity: 0;
}

.anm.to-up {
  -webkit-transform: translateY(20px);
          transform: translateY(20px);
}

.anm.to-down {
  -webkit-transform: translateY(-20px);
          transform: translateY(-20px);
}

.anm.to-right {
  -webkit-transform: translateX(-10px);
          transform: translateX(-10px);
}

.anm.to-left {
  -webkit-transform: translateX(10px);
          transform: translateX(10px);
}

.anm.to-left-zoomin {
  -webkit-transform: translateX(10px) scale(0.9);
          transform: translateX(10px) scale(0.9);
  -webkit-transform-origin: right bottom;
          transform-origin: right bottom;
}

.anm.blur {
  filter: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg"><filter id="filter"><feGaussianBlur stdDeviation="10" /></filter></svg>#filter');
  -webkit-filter: blur(10px);
          filter: blur(10px);
}

.anm.ease-back {
  -webkit-transition-duration: 2s;
          transition-duration: 2s;
  -webkit-transition-timing-function: cubic-bezier(0.18, 0.89, 0.32, 1.28);
          transition-timing-function: cubic-bezier(0.18, 0.89, 0.32, 1.28);
}

.anm.ease-back.to-up {
  -webkit-transform: translateY(40px);
          transform: translateY(40px);
}

.anm.is-show.fading {
  opacity: 1;
}

.anm.is-show.to-up {
  -webkit-transform: translateY(0px);
          transform: translateY(0px);
}

.anm.is-show.to-down {
  -webkit-transform: translateY(0px);
          transform: translateY(0px);
}

.anm.is-show.to-right {
  -webkit-transform: translateX(0px);
          transform: translateX(0px);
}

.anm.is-show.to-left {
  -webkit-transform: translateX(0px);
          transform: translateX(0px);
}

.anm.is-show.to-left-zoomin {
  -webkit-transition: 2s 0.4s;
  transition: 2s 0.4s;
  -webkit-transform: translateX(0px) scale(1);
          transform: translateX(0px) scale(1);
}

.anm.is-show.blur {
  filter: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg"><filter id="filter"><feGaussianBlur stdDeviation="0" /></filter></svg>#filter');
  -webkit-filter: blur(0px);
          filter: blur(0px);
}

.anm.is-show.delay1 {
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
}

.anm.is-show.delay2 {
  -webkit-transition-delay: 0.4s;
          transition-delay: 0.4s;
}

.anm.is-show.ease-back {
  -webkit-transition-duration: 2s;
          transition-duration: 2s;
  -webkit-transition-timing-function: cubic-bezier(0.18, 0.89, 0.32, 1.28);
          transition-timing-function: cubic-bezier(0.18, 0.89, 0.32, 1.28);
}

.anm.is-show.ease-back.to-up {
  -webkit-transform: translateY(0px);
          transform: translateY(0px);
}

.ofi {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  font-family: "object-fit: cover;";
  width: 100%;
  height: 100%;
}

.pc {
  display: block !important;
}

.sp {
  display: none !important;
}

/* Loading */
.spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transform-origin: center;
          transform-origin: center;
  width: 40px;
  height: 40px;
  z-index: 99999;
}

.spinner.type1 {
  border-radius: 50%;
  border-width: 3px;
  border-style: solid;
  border-color: #333 rgba(30, 30, 30, .12) rgba(30, 30, 30, .12);
  -webkit-animation: spinner1_1 1.5s infinite linear forwards;
          animation: spinner1_1 1.5s infinite linear forwards;
}

.spinner.type1 span {
  animation: spinner_loading_text 1.5s infinite linear forwards reverse;
}

.spinner span {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  font-size: 10px;
}

.slider-full-height {
  height: 100%;
}

.slider-full-height .slick-list {
  height: 100%;
}

.slider-full-height .slick-list .slick-track {
  height: 100%;
}

.slider-full-height .slick-list .slick-track .slick-slide {
  height: 100%;
}

.slider-full-height .slick-list .slick-track .slick-slide > div {
  height: 100%;
}

.slider-full-height .slick-list .slick-track .slick-slide .slide-each {
  height: 100%;
}

.tj {
  text-align: justify;
}

.w100 {
  width: 100% !important;
  max-width: 100% !important;
}

.fz-xs {
  font-size: 10px;
  font-size: 1rem;
}

.fz-s {
  font-size: 12px;
  font-size: 1.2rem;
}

.fz-sm {
  font-size: 14px;
  font-size: 1.4rem;
}

.fz-m {
  font-size: 16px;
  font-size: 1.6rem;
}

.fz-ml {
  font-size: 18px;
  font-size: 1.8rem;
}

.fz-l {
  font-size: 20px;
  font-size: 2rem;
}

.fz-xl {
  font-size: 22px;
  font-size: 2.2rem;
}

.fz-2l {
  font-size: 26px;
  font-size: 2.6rem;
}

.fz-3l {
  font-size: 32px;
  font-size: 3.2rem;
}

.fz-4l {
  font-size: 40px;
  font-size: 4rem;
}

.fz-5l {
  font-size: 50px;
  font-size: 5rem;
}

.fz-6l {
  font-size: 60px;
  font-size: 6rem;
}

.fz-7l {
  font-size: 70px;
  font-size: 7rem;
}

.fz-10l {
  font-size: 100px;
  font-size: 10rem;
}

.color-white {
  color: #fff;
}

.color-black {
  color: #030000;
}

.color-base {
  color: #231916;
}

.color-primary {
  color: #ea511f;
}

.color-secondary {
  color: #1b3053;
}

.color-attention {
  color: #e6e5e2;
}

.color-caution {
  color: #9e9e9e;
}

.bg-white {
  background: #fff;
}

.bg-black {
  background: #030000;
}

.bg-base {
  background: #231916;
}

.bg-primary {
  background: #ea511f;
}

.bg-secondary {
  background: #1b3053;
}

.bg-attention {
  background: #e6e5e2;
}

.bg-caution {
  background: #9e9e9e;
}

.mb-xs {
  margin-bottom: 10px;
}

.mb-s {
  margin-bottom: 20px;
}

.mb-m {
  margin-bottom: 40px;
}

.mb-l {
  margin-bottom: 80px;
}

.pb-xs {
  padding-bottom: 10px;
}

.pb-s {
  padding-bottom: 20px;
}

.pb-m {
  padding-bottom: 40px;
}

.pb-l {
  padding-bottom: 80px;
}

.mt-xs {
  margin-top: 10px;
}

.mt-s {
  margin-top: 20px;
}

.mt-m {
  margin-top: 40px;
}

.mt-l {
  margin-top: 80px;
}

.pt-xs {
  padding-top: 10px;
}

.pt-s {
  padding-top: 20px;
}

.pt-m {
  padding-top: 40px;
}

.pt-l {
  padding-top: 80px;
}

.posr {
  position: relative;
}

/* ===================================================================

init style

=================================================================== */
html {
  font-size: 62.5%;
  width: 100%;
  height: 100%;
  overscroll-behavior: none;
}

html.is-open {
  overflow: hidden;
  height: 100%;
}

body {
  font-family: "Reminisce", Reminisce, "Helvetica Neue", HelveticaNeue, Helvetica, Arial, sans-serif;
  font-weight: 400;
  font-size: 10px;
  font-size: 10px;
  font-size: 1rem;
  line-height: 1.7;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.8px;
  color: #231916;
  background: #2c2c2d;
  width: 100%;
  height: 100%;
  overscroll-behavior: none;
}

::-moz-selection {
  background: rgba(20, 0, 0, .6);
  color: #fff;
}

::selection {
  background: rgba(20, 0, 0, .6);
  color: #fff;
}

_:lang(x)::-ms-backdrop,
.selector {
  font-family: "Segoe UI", Meiryo, sans-serif;
}

a {
  text-decoration: none;
  color: #231916;
}

a:hover {
  text-decoration: none;
  color: #231916;
}

img {
  vertical-align: bottom;
  max-width: 100%;
}

select,
input,
textarea,
button {
  vertical-align: middle;
}

#wrap {
  font-size: 14px;
  font-size: 1.4rem;
  width: 100%;
  height: 100%;
}

main {
  display: block;
  width: 100%;
  height: 100%;
}

/* ===================================================================

header style

=================================================================== */
.header {
  position: fixed;
  z-index: 9999;
  top: 10px;
  left: 25%;
  width: 50%;
  text-align: center;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}

.header svg {
  /* width: 108px; */
  width: 54px;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}

.gnav-btn {
  width: 25px;
  height: 18px;
  position: absolute;
  cursor: pointer;
  z-index: 10001;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  right: 0;
  top: calc(50% - 9px);
}

.gnav-btn:before, .gnav-btn:after {
  content: "";
  width: 100%;
  height: 2px;
  background: #231916;
  position: absolute;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  right: 0;
}

.gnav-btn:before {
  top: 0;
}

.gnav-btn:after {
  bottom: 0;
}

.gnav-btn span {
  display: block;
  width: 100%;
  height: 2px;
  background: #231916;
  position: absolute;
  top: calc(50% - 1px);
  right: 0;
  -webkit-transition: 0.2s 0.2s;
  transition: 0.2s 0.2s;
}

.gnav-btn.is-active:before, .gnav-btn.is-active:after {
  background: #fff;
  -webkit-transition: 0.4s 0.2s;
  transition: 0.4s 0.2s;
}

.gnav-btn.is-active:before {
  -webkit-transform: rotate(405deg);
          transform: rotate(405deg);
  top: calc(50% + 1px);
}

.gnav-btn.is-active:after {
  bottom: calc(50% - 3px);
  -webkit-transform: rotate(-405deg);
          transform: rotate(-405deg);
}

.gnav-btn.is-active span {
  -webkit-transform: scaleX(0);
          transform: scaleX(0);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

.gnav {
  background: #595757;
  width: 100%;
  overflow-x: hidden;
  -webkit-transition: right 0.4s, opacity 0.2s 0.2s;
  transition: right 0.4s, opacity 0.2s 0.2s;
}

.gnav.is-active {
  right: 0;
  opacity: 1;
  -webkit-transition: right 0.4s, opacity 0.2s;
  transition: right 0.4s, opacity 0.2s;
}

.gnav.on .gnav-inner {
  opacity: 1;
  -webkit-transform: translateX(0%);
          transform: translateX(0%);
  -webkit-transition: 1s 0.4s cubic-bezier(0.18, 0.89, 0.32, 1.28);
  transition: 1s 0.4s cubic-bezier(0.18, 0.89, 0.32, 1.28);
}

.gnav .gnav-inner {
  height: 100%;
  width: 100%;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

.gnav .gnav-inner ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.gnav .gnav-inner ul li {
  color: #fff;
}

.gnav .gnav-inner ul li.icons img {
  height: 20px;
}

.gnav .gnav-inner ul li a {
  letter-spacing: 0.15vw;
  display: block;
  color: #fff;
}

.gnav-bg {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
}

/* ===================================================================

footer style

=================================================================== */
.footer {
  position: relative;
}

/* ===================================================================

box style

=================================================================== */
.box-common {
  max-width: 1210px;
  margin-right: auto;
  margin-left: auto;
  padding-right: 20px;
  padding-left: 20px;
}

.box-medium {
  width: 1080px;
  margin-right: auto;
  margin-left: auto;
}

.box-narrow {
  max-width: 850px;
  margin-right: auto;
  margin-left: auto;
}

.box-x-narrow {
  max-width: 710px;
  margin-right: auto;
  margin-left: auto;
}

.box-wide {
  max-width: 1200px;
  margin-right: auto;
  margin-left: auto;
  padding: 0 2%;
}

.block-common {
  padding-top: 80px;
  padding-bottom: 80px;
}

.border-top {
  border-top: 1px solid #ddd;
}

.block-common-s {
  padding-top: 40px;
  padding-bottom: 40px;
}

/* ===================================================================

common parts

=================================================================== */

.toggle-nav dt {
  border-bottom: 1px solid #333;
  padding: 10px 20px;
  font-size: 16px;
  font-size: 1.6rem;
  position: relative;
  cursor: pointer;
}

.toggle-nav dt:before {
  content: "";
  width: 18px;
  height: 1px;
  background: #333;
  position: absolute;
  right: 10px;
  top: calc(50% - 0.5px);
}

.toggle-nav dt:after {
  content: "";
  width: 1px;
  height: 18px;
  background: #333;
  position: absolute;
  right: 18.5px;
  top: calc(50% - 9px);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

.toggle-nav dt.is-active:after {
  -webkit-transform: scaleY(0);
          transform: scaleY(0);
}

.toggle-nav dd {
  display: none;
}

.title-common01 {
  text-align: center;
  font-size: 36px;
  font-size: 3.6rem;
  margin-bottom: 40px;
  letter-spacing: 0.1em;
  line-height: 1;
  font-family: adobe-garamond-pro, serif;
  font-weight: 400;
  font-style: italic;
}

.title-common01 span {
  display: block;
  padding-top: 10px;
  letter-spacing: 0.2em;
}

.btn-more {
  display: inline-block;
  line-height: 1;
  padding: 20px 60px;
  max-width: 100%;
  position: relative;
  border: 1px solid #ccc;
  border-radius: 100px;
  font-size: 14px;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  overflow: hidden;
  z-index: 1;
  text-align: center;
}

.btn-more:before {
  content: "";
  width: 100%;
  height: 100%;
  background: #ea511f;
  position: absolute;
  top: 100%;
  left: 0;
  z-index: -1;
}

.btn-more.arw-r:after {
  content: "";
  position: absolute;
  right: 20px;
  top: calc(50% - 5px);
  width: 17px;
  height: 8px;
  border-bottom: 1px solid #333;
  border-right: 1px solid #333;
  -webkit-transform: skew(45deg);
          transform: skew(45deg);
}

.btn-more.invert {
  background: #333;
  color: #fff;
}

.btn-size-s {
  font-size: 16px;
  font-size: 1.6rem;
  padding: 8px 20px;
  line-height: 1.3;
  font-weight: 600;
  display: inline-block;
}

.btn-size-sm {
  font-size: 22px;
  font-size: 2.2rem;
  padding: 20px 60px;
  line-height: 1.3;
  letter-spacing: 0.1em;
  display: inline-block;
}

.btn-size-m {
  font-size: 22px;
  font-size: 2.2rem;
  padding: 20px 100px;
  line-height: 1.3;
  letter-spacing: 0.1em;
  display: inline-block;
}

.btn-size-l {
  font-size: 22px;
  font-size: 2.2rem;
  padding: 20px 100px;
  line-height: 1.3;
  letter-spacing: 0.1em;
  display: inline-block;
}

.full-width {
  width: 100%;
}

/* ===================================================================

index style

=================================================================== */
.fp-viewing-kv .header {
  top: calc(50% - 55px);
}

.fp-viewing-kv .header svg {
  /* width: 193px; */
  /* width: 250px; */
  width: 97px;
}

.is-play .hlogo svg .svg-fill-w:nth-child(1) {
  -webkit-animation: logoUpper 0.8s ease 0.05s 1 forwards;
          animation: logoUpper 0.8s ease 0.05s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(2) {
  -webkit-animation: logoUpper 0.8s ease 0.1s 1 forwards;
          animation: logoUpper 0.8s ease 0.1s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(3) {
  -webkit-animation: logoUpper 0.8s ease 0.15s 1 forwards;
          animation: logoUpper 0.8s ease 0.15s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(4) {
  -webkit-animation: logoUpper 0.8s ease 0.2s 1 forwards;
          animation: logoUpper 0.8s ease 0.2s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(5) {
  -webkit-animation: logoUpper 0.8s ease 0.25s 1 forwards;
          animation: logoUpper 0.8s ease 0.25s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(6) {
  -webkit-animation: logoUpper 0.8s ease 0.3s 1 forwards;
          animation: logoUpper 0.8s ease 0.3s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(7) {
  -webkit-animation: logoUnder 0.8s ease 0.65s 1 forwards;
          animation: logoUnder 0.8s ease 0.65s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(8) {
  -webkit-animation: logoUnder 0.8s ease 0.7s 1 forwards;
          animation: logoUnder 0.8s ease 0.7s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(9) {
  -webkit-animation: logoUnder 0.8s ease 0.75s 1 forwards;
          animation: logoUnder 0.8s ease 0.75s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(10) {
  -webkit-animation: logoUnder 0.8s ease 0.8s 1 forwards;
          animation: logoUnder 0.8s ease 0.8s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(11) {
  -webkit-animation: logoUnder 0.8s ease 0.85s 1 forwards;
          animation: logoUnder 0.8s ease 0.85s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(12) {
  -webkit-animation: logoUnder 0.8s ease 0.9s 1 forwards;
          animation: logoUnder 0.8s ease 0.9s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(13) {
  -webkit-animation: logoUnder 0.8s ease 0.95s 1 forwards;
          animation: logoUnder 0.8s ease 0.95s 1 forwards;
}

.is-play .hlogo svg .svg-fill-w:nth-child(14) {
  -webkit-animation: logoUnder 0.8s ease 1s 1 forwards;
          animation: logoUnder 0.8s ease 1s 1 forwards;
}

.is-play .kv-load video {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.is-play .kv-load .kv-scroll {
  opacity: 1;
}

.hlogo svg .svg-fill-w {
  fill: #fff;
  opacity: 0;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}

.wheel {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 999999;
  background: #aaa;
  padding: 10px 30px;
}

.kv-section {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overscroll-behavior: none;
}

.nav-section {
  position: fixed;
  top: 100%;
  left: 0;
  width: 100%;
  z-index: 1;
  background: #000;
  overscroll-behavior: none;
  -webkit-transition: top 1s cubic-bezier(0.68, 0.01, 0.08, 0.99);
  transition: top 1s cubic-bezier(0.68, 0.01, 0.08, 0.99);
}

.nav-section.is-show {
  top: 0%;
}

.kv-load {
  background: #2c2c2d;
  height: 100%;
  position: relative;
  overflow: hidden;
}

.kv-load video {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  -webkit-transform: translateY(100%);
          transform: translateY(100%);
  -webkit-transition: -webkit-transform 1s cubic-bezier(0.68, 0.01, 0.08, 0.99) 3s;
  transition: -webkit-transform 1s cubic-bezier(0.68, 0.01, 0.08, 0.99) 3s;
  transition: transform 1s cubic-bezier(0.68, 0.01, 0.08, 0.99) 3s;
  transition: transform 1s cubic-bezier(0.68, 0.01, 0.08, 0.99) 3s, -webkit-transform 1s cubic-bezier(0.68, 0.01, 0.08, 0.99) 3s;
}

.kv-load .kv-scroll {
  opacity: 0;
  -webkit-transition: opacity 0.4s 4s;
  transition: opacity 0.4s 4s;
  position: absolute;
  bottom: 0;
  left: 0;
  text-align: center;
  color: #fff;
  width: 100%;
}

.kv-load .kv-scroll span {
  display: inline-block;
  line-height: 1;
  letter-spacing: 0.1em;
}

.kv-load .kv-scroll span em {
  position: relative;
  display: block;
  overflow: hidden;
  padding-bottom: 70px;
}

.kv-load .kv-scroll span em:after {
  content: "";
  position: absolute;
  left: 50%;
  top: 10px;
  width: 1px;
  height: 60px;
  background: #fff;
  -webkit-animation: scrollLine 1.4s ease infinite forwards;
          animation: scrollLine 1.4s ease infinite forwards;
}

.top-wrap {
  height: 100%;
  overscroll-behavior: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}

.section {
  height: 100%;
}

.iScrollVerticalScrollbar {
  right: -10px !important;
}

.projectSlide {
  height: 100%;
}

.projectSlide .slick-slide > div {
  height: 100%;
}

.projectSlide .section-each {
  height: 100%;
}

.projectSlide .fixImg {
  position: absolute;
  left: 100%;
  width: 100%;
  height: 100%;
  -webkit-transition: 0.5s 0.5s cubic-bezier(0.79, 0.13, 0.45, 0.9);
  transition: 0.5s 0.5s cubic-bezier(0.79, 0.13, 0.45, 0.9);
}

.projectSlide .fixImg.resetTst {
  -webkit-transition: 0s;
  transition: 0s;
}

.projectSlide .pcImg {
  display: block;
}

.projectSlide .spImg {
  display: none;
}

.projectSlide .bg {
  content: "";
  position: absolute;
  top: 0;
  left: 100%;
  width: 100%;
  height: 100%;
  background: #fff;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  display: block;
}

.projectSlide .bg.resetTst {
  -webkit-transition: 0s;
  transition: 0s;
}

.projectSlide .slick-slide {
  opacity: 1 !important;
}

.projectSlide .slick-current .bg {
  left: 0 !important;
}

.projectSlide .slick-current .fixImg {
  left: 0 !important;
}

.projectSlide .slick-current .spImg {
  left: 0 !important;
}

.projectSlide .slick-current .info {
  opacity: 1;
}

.projectSlide .info {
  position: absolute;
  top: 90px;
  left: 25px;
  color: #fff;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.5;
  letter-spacing: 0.2px;
  letter-spacing: 0.02rem;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
  opacity: 0;
}

.projectSlide .info.bottom {
  top: auto;
  bottom: 25px;
}

.slick-list {
  height: 100%;
}

.slick-track {
  height: 100%;
}

.slick-dots {
  bottom: 10px;
}

.prevArea,
.nextArea {
  width: 50%;
  height: 100%;
  position: absolute;
  top: 0;
}

.prevArea:before,
.nextArea:before {
  content: "";
}

.flickArea {
  display: none;
}

.prevArea {
  left: 0;
  z-index: 2;
  cursor: none !important;
}

.nextArea {
  right: 0;
  z-index: 2;
  cursor: none !important;
}

img.pointerL,
img.pointerR {
  visibility: hidden;
  opacity: 0;
  cursor: none !important;
  display: none;
}

img.pointerL.onMouse,
img.pointerR.onMouse {
  display: inline-block;
  position: fixed;
  visibility: visible;
  opacity: 1;
}

.fp-scroller {
  height: 100%;
}

.main-nav {
  width: 100%;
  height: 100%;
}

.main-nav nav .nav-each a {
  position: relative;
  z-index: 2;
  opacity: 0.3;
  color: #fff;
  /* font-size: 85px; */
  font-size: 56px;
  /* letter-spacing: 1.5rem; */
  letter-spacing: 0.4rem;
}

.main-nav nav .nav-each .bg-img {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}

.main-nav nav .nav-each.is-active .bg-img {
  opacity: 1;
}

.main-nav nav .nav-each.is-active a {
  opacity: 1;
}

.main-nav .nav-list {
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
}

.main-nav .nav-list .nav-list-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.main-nav .nav-list .nav-list-inner .nav-each:not(:last-of-type) {
  margin-bottom: 10px;
}

.main-nav .nav-list .nav-list-inner .nav-each.nav-introduction {
  width: auto;
}

.main-nav .nav-list .nav-list-inner .nav-each.nav-service {
  width: auto;
}

.main-nav .nav-list .nav-list-inner .nav-each.nav-works {
  width: auto;
}

.main-nav .nav-list .nav-list-inner .nav-each.nav-contact {
  width: auto;
}

.main-nav .nav-list .nav-list-inner .nav-each .nav-text {
  display: inline;
}

.main-nav .sp-nav-list {
  height: 100%;
}

.main-nav .sp-nav-list .nav-each {
  height: 100%;
  position: relative;
}

.main-nav .sp-nav-list .nav-each .bg-img {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  opacity: 1;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}

.main-nav .sp-nav-list .nav-each a {
  position: relative;
  z-index: 1;
  opacity: 1;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.main-nav .sp-nav-list .nav-each a img {
  max-height: 100%;
  height: 8vw;
}

.main-nav .sp-nav-list .nav-each .nav-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
}

.slick-dots li {
  width: 30px;
}

.slick-dots li button {
  width: 100%;
  height: 100%;
}

.slick-dots li button:before {
  font-family: "";
  width: 100%;
  height: 4px;
  background: #565656;
  opacity: 1;
  content: "";
}

.slick-dots li.slick-active button:before {
  opacity: 1;
  background: #cacaca;
}

.slick-next,
.slick-prev {
  z-index: 2;
}

.slick-next:before,
.slick-prev:before {
  font-size: 50px;
  font-size: 5rem;
  font-family: "Reminisce", sans-serif;
  content: "";
  opacity: 1;
  width: 100%;
  height: 100%;
  display: block;
}

.slick-next {
  right: 2%;
}

.slick-next:before {
  content: ">";
}

.slick-prev {
  left: 2%;
}

.slick-prev:before {
  content: "<";
}

.under-wrap {
  position: fixed;
  top: 100%;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  color: #fff;
  z-index: 999;
  -webkit-transition: 1s cubic-bezier(0.68, 0.01, 0.08, 0.99);
  transition: 1s cubic-bezier(0.68, 0.01, 0.08, 0.99);
  overscroll-behavior: none;
}

.under-wrap.is-show {
  top: 0%;
}

.under-wrap .under-wrap-inner {
  height: 100%;
}

.under-wrap .under-wrap-inner .under-contents {
  height: 100%;
  position: relative;
}

.under-wrap .under-wrap-inner .under-contents .under-slide .slick-prev,
.under-wrap .under-wrap-inner .under-contents .under-slide .slick-next {
  width: 50px;
  height: 50px;
}

.section-each {
  background: #2c2c2d;
  width: 100%;
  height: 100%;
}

.under-box {
  width: 100%;
  height: 100%;
}

.h100 {
  height: 100%;
}

.text-box p {
  /* font-size: 1.4rem; */
  font-size: 0.98rem;
  letter-spacing: 0.02em;
}

.text-box p:not(:last-of-type) {
  margin-bottom: 25px;
  margin-bottom: 2.5rem;
}

.text-box a {
  color: #fff;
  letter-spacing: 0.02em;
}

.modal-close-btn {
  position: absolute;
  right: 2%;
  top: 10px;
  z-index: 99999;
}

.modal-close-btn span {
  position: relative;
  display: block;
  width: 40px;
  height: 40px;
  cursor: pointer;
}

.modal-close-btn span:before {
  content: "";
  width: 100%;
  height: 1px;
  background: #fff;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 0;
}

.modal-close-btn span:after {
  content: "";
  width: 100%;
  height: 1px;
  background: #fff;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  position: absolute;
  top: 50%;
  left: 0;
}

.video-loader {
  display: none;
  position: fixed;
  bottom: -200%;
}

.works-list-wrap {
  height: 100vh;
  overflow: scroll;
  -webkit-overflow-scrolling: touch;
}

.works-list-wrap .works-list {
  -webkit-transition: 0.1s;
  transition: 0.1s;
}

.works-list-wrap .works-list li {
  position: relative;
  height: 100vh;
}

.works-list-wrap .works-list li a {
  display: block;
  width: 100%;
  height: 100%;
  outline: none;
}

.works-list-wrap .works-list li a:focus {
  outline: none;
}

.works-list-wrap .works-list li div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  /* letter-spacing: 0.8rem; */
  letter-spacing: 0.4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 85px;
  font-size: 5.6rem;
  line-height: 1;
  text-align: center;
  padding: 0 10%;
  mix-blend-mode: difference;
  color: #ccc;
}
.works-list-wrap .works-list li span {
  /* font-size: 5.6rem; */
  font-size: 2.8rem;
  display: block;
}

/* .works-list-wrap .works-list li h3 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  letter-spacing: 0.4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 85px;
  font-size: 5.6rem;
  line-height: 1;
  text-align: center;
  padding: 0 10%;
  mix-blend-mode: difference;
  color: #ccc;
}
.works-list-wrap .works-list li span {
  font-size: 2.8rem;
  display: block;
} */

.video-modal-wrap {
  display: none;
}

.video-modal-inner {
  background: rgba(0, 0, 0, .92);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.video-modal-inner video {
  width: 100%;
}

.modaal-noscroll {
  overflow: visible;
}

.modaal-container {
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.modaal-content-container {
  padding: 0;
}

.modaal-fullscreen .modaal-close {
  background: transparent;
  right: 2%;
  top: 10px;
}

.modaal-close {
  width: 40px;
  height: 40px;
}

.modaal-close:before, .modaal-close:after {
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
}

.modaal-close:focus, .modaal-close:hover {
  background: transparent;
}

.modaal-close:focus:before, .modaal-close:focus:after, .modaal-close:hover:before, .modaal-close:hover:after {
  background: #aaa;
}

.modaal-content,
.modaal-content-container,
.video-modal-inner {
  height: 100%;
}

.text-link {
  -webkit-transition: 0.4s;
  transition: 0.4s;
  position: relative;
}

.text-link:before {
  content: "";
  width: 0;
  height: 1px;
  background: #fff;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  position: absolute;
  bottom: 0;
  left: 0;
}

.sec-contact {
  position: relative;
}

.sec-contact .sec-contact-footer {
  position: absolute;
  bottom: 10px;
  left: 0;
  width: 100%;
  padding: 0 2%;
  font-size: 10px;
  font-size: 1rem;
  line-height: 1.1;
}

/* ===================================================================

keyframes

=================================================================== */
@-webkit-keyframes logoUpper {
  0% {
    -webkit-transform: translateY(5px) translateX(5px) rotate(20deg);
            transform: translateY(5px) translateX(5px) rotate(20deg);
    -webkit-transform-origin: 33.874% 50.205%;
            transform-origin: 33.874% 50.205%;
    opacity: 0;
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px) translateX(0px) rotate(0deg);
            transform: translateY(0px) translateX(0px) rotate(0deg);
    -webkit-transform-origin: 33.874% 50.205%;
            transform-origin: 33.874% 50.205%;
  }
}
@keyframes logoUpper {
  0% {
    -webkit-transform: translateY(5px) translateX(5px) rotate(20deg);
            transform: translateY(5px) translateX(5px) rotate(20deg);
    -webkit-transform-origin: 33.874% 50.205%;
            transform-origin: 33.874% 50.205%;
    opacity: 0;
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px) translateX(0px) rotate(0deg);
            transform: translateY(0px) translateX(0px) rotate(0deg);
    -webkit-transform-origin: 33.874% 50.205%;
            transform-origin: 33.874% 50.205%;
  }
}

@-webkit-keyframes logoUnder {
  0% {
    -webkit-transform: translateY(-5px) translateX(-5px) rotate(-20deg);
            transform: translateY(-5px) translateX(-5px) rotate(-20deg);
    -webkit-transform-origin: 33.874% 50.205%;
            transform-origin: 33.874% 50.205%;
    opacity: 0;
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px) translateX(0px) rotate(0deg);
            transform: translateY(0px) translateX(0px) rotate(0deg);
    -webkit-transform-origin: 33.874% 50.205%;
            transform-origin: 33.874% 50.205%;
  }
}

@keyframes logoUnder {
  0% {
    -webkit-transform: translateY(-5px) translateX(-5px) rotate(-20deg);
            transform: translateY(-5px) translateX(-5px) rotate(-20deg);
    -webkit-transform-origin: 33.874% 50.205%;
            transform-origin: 33.874% 50.205%;
    opacity: 0;
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px) translateX(0px) rotate(0deg);
            transform: translateY(0px) translateX(0px) rotate(0deg);
    -webkit-transform-origin: 33.874% 50.205%;
            transform-origin: 33.874% 50.205%;
  }
}

@-webkit-keyframes scrollLine {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(120%);
            transform: translateY(120%);
  }
  51% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes scrollLine {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(120%);
            transform: translateY(120%);
  }
  51% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@-webkit-keyframes flash {
  0% {
    opacity: 0.3;
  }
  100% {
    opacity: 0;
  }
}

@keyframes flash {
  0% {
    opacity: 0.3;
  }
  100% {
    opacity: 0;
  }
}

@-webkit-keyframes bnav {
  0% {
    display: none;
    opacity: 0;
    -webkit-transform: translateY(-10px);
            transform: translateY(-10px);
  }
  1% {
    display: block;
    opacity: 0;
    -webkit-transform: translateY(-10px);
            transform: translateY(-10px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}

@keyframes bnav {
  0% {
    display: none;
    opacity: 0;
    -webkit-transform: translateY(-10px);
            transform: translateY(-10px);
  }
  1% {
    display: block;
    opacity: 0;
    -webkit-transform: translateY(-10px);
            transform: translateY(-10px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}

@-webkit-keyframes spinner1_1 {
  0% {
    -webkit-transform: translate(-50%, -50%) rotate(0);
            transform: translate(-50%, -50%) rotate(0);
  }
  100% {
    -webkit-transform: translate(-50%, -50%) rotate(360deg);
            transform: translate(-50%, -50%) rotate(360deg);
  }
}

@keyframes spinner1_1 {
  0% {
    -webkit-transform: translate(-50%, -50%) rotate(0);
            transform: translate(-50%, -50%) rotate(0);
  }
  100% {
    -webkit-transform: translate(-50%, -50%) rotate(360deg);
            transform: translate(-50%, -50%) rotate(360deg);
  }
}

@-webkit-keyframes spinner_loading_text {
  0% {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%) rotate(0deg);
            transform: translate(-50%, -50%) rotate(0deg);
  }
  50% {
    opacity: 0;
    -webkit-transform: translate(-50%, -50%) rotate(180deg);
            transform: translate(-50%, -50%) rotate(180deg);
  }
  100% {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%) rotate(360deg);
            transform: translate(-50%, -50%) rotate(360deg);
  }
}

@keyframes spinner_loading_text {
  0% {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%) rotate(0deg);
            transform: translate(-50%, -50%) rotate(0deg);
  }
  50% {
    opacity: 0;
    -webkit-transform: translate(-50%, -50%) rotate(180deg);
            transform: translate(-50%, -50%) rotate(180deg);
  }
  100% {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%) rotate(360deg);
            transform: translate(-50%, -50%) rotate(360deg);
  }
}

@-webkit-keyframes showUp {
  0% {
    display: none;
    opacity: 0;
  }
  1% {
    display: block;
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes showUp {
  0% {
    display: none;
    opacity: 0;
  }
  1% {
    display: block;
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@-webkit-keyframes hideDown {
  0% {
    display: block;
    opacity: 1;
  }
  99% {
    display: block;
    opacity: 0;
  }
  100% {
    visibility: hidden;
    display: none;
    opacity: 0;
  }
}

@keyframes hideDown {
  0% {
    display: block;
    opacity: 1;
  }
  99% {
    display: block;
    opacity: 0;
  }
  100% {
    visibility: hidden;
    display: none;
    opacity: 0;
  }
}

@-webkit-keyframes shakeIco {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  10% {
    -webkit-transform: rotate(20deg);
            transform: rotate(20deg);
  }
  20% {
    -webkit-transform: rotate(-20deg);
            transform: rotate(-20deg);
  }
  30% {
    -webkit-transform: rotate(10deg);
            transform: rotate(10deg);
  }
  40% {
    -webkit-transform: rotate(-10deg);
            transform: rotate(-10deg);
  }
  50% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg);
  }
  60% {
    -webkit-transform: rotate(-5deg);
            transform: rotate(-5deg);
  }
  70% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}

@keyframes shakeIco {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  10% {
    -webkit-transform: rotate(20deg);
            transform: rotate(20deg);
  }
  20% {
    -webkit-transform: rotate(-20deg);
            transform: rotate(-20deg);
  }
  30% {
    -webkit-transform: rotate(10deg);
            transform: rotate(10deg);
  }
  40% {
    -webkit-transform: rotate(-10deg);
            transform: rotate(-10deg);
  }
  50% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg);
  }
  60% {
    -webkit-transform: rotate(-5deg);
            transform: rotate(-5deg);
  }
  70% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}

@-webkit-keyframes moreIco {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
    opacity: 1;
  }
  50% {
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
    opacity: 0.6;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
    opacity: 1;
  }
}

@keyframes moreIco {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
    opacity: 1;
  }
  50% {
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
    opacity: 0.6;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
    opacity: 1;
  }
}

@-webkit-keyframes bounceIco2 {
  0% {
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
  20% {
    -webkit-transform: translateX(3px);
            transform: translateX(3px);
  }
  40% {
    -webkit-transform: translateX(-3px);
            transform: translateX(-3px);
  }
  60% {
    -webkit-transform: translateX(1px);
            transform: translateX(1px);
  }
  80% {
    -webkit-transform: translateX(-1px);
            transform: translateX(-1px);
  }
  100% {
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
}

@keyframes bounceIco2 {
  0% {
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
  20% {
    -webkit-transform: translateX(3px);
            transform: translateX(3px);
  }
  40% {
    -webkit-transform: translateX(-3px);
            transform: translateX(-3px);
  }
  60% {
    -webkit-transform: translateX(1px);
            transform: translateX(1px);
  }
  80% {
    -webkit-transform: translateX(-1px);
            transform: translateX(-1px);
  }
  100% {
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
}

@-webkit-keyframes bounceIco {
  0% {
    -webkit-transform: scaleY(1) translateY(0px);
            transform: scaleY(1) translateY(0px);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  15% {
    -webkit-transform: scaleY(0.8) translateY(0px);
            transform: scaleY(0.8) translateY(0px);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  30% {
    -webkit-transform: scaleY(1) translateY(0px);
            transform: scaleY(1) translateY(0px);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  37.5% {
    -webkit-transform: scaleY(1.1) translateY(-10px);
            transform: scaleY(1.1) translateY(-10px);
    -webkit-transform-origin: center center;
            transform-origin: center center;
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  45% {
    -webkit-transform: scaleY(1) translateY(-10px);
            transform: scaleY(1) translateY(-10px);
    -webkit-transform-origin: center top;
            transform-origin: center top;
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  60% {
    -webkit-transform: scaleY(1) translateY(0px);
            transform: scaleY(1) translateY(0px);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  70% {
    -webkit-transform: scaleY(0.95) translateY(0px);
            transform: scaleY(0.95) translateY(0px);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  80% {
    -webkit-transform: scaleY(1) translateY(0px);
            transform: scaleY(1) translateY(0px);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
}

@keyframes bounceIco {
  0% {
    -webkit-transform: scaleY(1) translateY(0px);
            transform: scaleY(1) translateY(0px);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  15% {
    -webkit-transform: scaleY(0.8) translateY(0px);
            transform: scaleY(0.8) translateY(0px);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  30% {
    -webkit-transform: scaleY(1) translateY(0px);
            transform: scaleY(1) translateY(0px);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  37.5% {
    -webkit-transform: scaleY(1.1) translateY(-10px);
            transform: scaleY(1.1) translateY(-10px);
    -webkit-transform-origin: center center;
            transform-origin: center center;
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  45% {
    -webkit-transform: scaleY(1) translateY(-10px);
            transform: scaleY(1) translateY(-10px);
    -webkit-transform-origin: center top;
            transform-origin: center top;
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  60% {
    -webkit-transform: scaleY(1) translateY(0px);
            transform: scaleY(1) translateY(0px);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  70% {
    -webkit-transform: scaleY(0.95) translateY(0px);
            transform: scaleY(0.95) translateY(0px);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  80% {
    -webkit-transform: scaleY(1) translateY(0px);
            transform: scaleY(1) translateY(0px);
    -webkit-transform-origin: center bottom;
            transform-origin: center bottom;
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
}

@-webkit-keyframes liFadeIn {
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}

@keyframes liFadeIn {
  100% {
    opacity: 1;
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
  }
}

@-webkit-keyframes scrlArw {
  0% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  50% {
    -webkit-transform: scaleX(0.5);
            transform: scaleX(0.5);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  100% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
}

@keyframes scrlArw {
  0% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  50% {
    -webkit-transform: scaleX(0.5);
            transform: scaleX(0.5);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  100% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
}

@media (min-width: 768px) and (max-width: 1024px) {
  .mb70 {
    margin-bottom: 45px;
  }
  .tb-w1 {
    width: 1%;
  }
  .tb-w2 {
    width: 2%;
  }
  .tb-w3 {
    width: 3%;
  }
  .tb-w4 {
    width: 4%;
  }
  .tb-w5 {
    width: 5%;
  }
  .tb-w6 {
    width: 6%;
  }
  .tb-w7 {
    width: 7%;
  }
  .tb-w8 {
    width: 8%;
  }
  .tb-w9 {
    width: 9%;
  }
  .tb-w10 {
    width: 10%;
  }
  .tb-w11 {
    width: 11%;
  }
  .tb-w12 {
    width: 12%;
  }
  .tb-w13 {
    width: 13%;
  }
  .tb-w14 {
    width: 14%;
  }
  .tb-w15 {
    width: 15%;
  }
  .tb-w16 {
    width: 16%;
  }
  .tb-w17 {
    width: 17%;
  }
  .tb-w18 {
    width: 18%;
  }
  .tb-w19 {
    width: 19%;
  }
  .tb-w20 {
    width: 20%;
  }
  .tb-w21 {
    width: 21%;
  }
  .tb-w22 {
    width: 22%;
  }
  .tb-w23 {
    width: 23%;
  }
  .tb-w24 {
    width: 24%;
  }
  .tb-w25 {
    width: 25%;
  }
  .tb-w26 {
    width: 26%;
  }
  .tb-w27 {
    width: 27%;
  }
  .tb-w28 {
    width: 28%;
  }
  .tb-w29 {
    width: 29%;
  }
  .tb-w30 {
    width: 30%;
  }
  .tb-w31 {
    width: 31%;
  }
  .tb-w32 {
    width: 32%;
  }
  .tb-w33 {
    width: 33%;
  }
  .tb-w34 {
    width: 34%;
  }
  .tb-w35 {
    width: 35%;
  }
  .tb-w36 {
    width: 36%;
  }
  .tb-w37 {
    width: 37%;
  }
  .tb-w38 {
    width: 38%;
  }
  .tb-w39 {
    width: 39%;
  }
  .tb-w40 {
    width: 40%;
  }
  .tb-w41 {
    width: 41%;
  }
  .tb-w42 {
    width: 42%;
  }
  .tb-w43 {
    width: 43%;
  }
  .tb-w44 {
    width: 44%;
  }
  .tb-w45 {
    width: 45%;
  }
  .tb-w46 {
    width: 46%;
  }
  .tb-w47 {
    width: 47%;
  }
  .tb-w48 {
    width: 48%;
  }
  .tb-w49 {
    width: 49%;
  }
  .tb-w50 {
    width: 50%;
  }
  .tb-w51 {
    width: 51%;
  }
  .tb-w52 {
    width: 52%;
  }
  .tb-w53 {
    width: 53%;
  }
  .tb-w54 {
    width: 54%;
  }
  .tb-w55 {
    width: 55%;
  }
  .tb-w56 {
    width: 56%;
  }
  .tb-w57 {
    width: 57%;
  }
  .tb-w58 {
    width: 58%;
  }
  .tb-w59 {
    width: 59%;
  }
  .tb-w60 {
    width: 60%;
  }
  .tb-w61 {
    width: 61%;
  }
  .tb-w62 {
    width: 62%;
  }
  .tb-w63 {
    width: 63%;
  }
  .tb-w64 {
    width: 64%;
  }
  .tb-w65 {
    width: 65%;
  }
  .tb-w66 {
    width: 66%;
  }
  .tb-w67 {
    width: 67%;
  }
  .tb-w68 {
    width: 68%;
  }
  .tb-w69 {
    width: 69%;
  }
  .tb-w70 {
    width: 70%;
  }
  .tb-w71 {
    width: 71%;
  }
  .tb-w72 {
    width: 72%;
  }
  .tb-w73 {
    width: 73%;
  }
  .tb-w74 {
    width: 74%;
  }
  .tb-w75 {
    width: 75%;
  }
  .tb-w76 {
    width: 76%;
  }
  .tb-w77 {
    width: 77%;
  }
  .tb-w78 {
    width: 78%;
  }
  .tb-w79 {
    width: 79%;
  }
  .tb-w80 {
    width: 80%;
  }
  .tb-w81 {
    width: 81%;
  }
  .tb-w82 {
    width: 82%;
  }
  .tb-w83 {
    width: 83%;
  }
  .tb-w84 {
    width: 84%;
  }
  .tb-w85 {
    width: 85%;
  }
  .tb-w86 {
    width: 86%;
  }
  .tb-w87 {
    width: 87%;
  }
  .tb-w88 {
    width: 88%;
  }
  .tb-w89 {
    width: 89%;
  }
  .tb-w90 {
    width: 90%;
  }
  .tb-w91 {
    width: 91%;
  }
  .tb-w92 {
    width: 92%;
  }
  .tb-w93 {
    width: 93%;
  }
  .tb-w94 {
    width: 94%;
  }
  .tb-w95 {
    width: 95%;
  }
  .tb-w96 {
    width: 96%;
  }
  .tb-w97 {
    width: 97%;
  }
  .tb-w98 {
    width: 98%;
  }
  .tb-w99 {
    width: 99%;
  }
  .tb-w100 {
    width: 100%;
  }
  .tb-mb10 {
    margin-bottom: 10px;
  }
  .tb-mb20 {
    margin-bottom: 20px;
  }
  .tb-mb30 {
    margin-bottom: 30px;
  }
  .tb-mb40 {
    margin-bottom: 40px;
  }
  .tb-mb50 {
    margin-bottom: 50px;
  }
  .tb-mb60 {
    margin-bottom: 60px;
  }
  .tb-mb70 {
    margin-bottom: 70px;
  }
  .tb-mb80 {
    margin-bottom: 80px;
  }
  .tb-mb90 {
    margin-bottom: 90px;
  }
  .tb-mb100 {
    margin-bottom: 100px;
  }
  .tb-pb10 {
    padding-bottom: 10px;
  }
  .tb-pb20 {
    padding-bottom: 20px;
  }
  .tb-pb30 {
    padding-bottom: 30px;
  }
  .tb-pb40 {
    padding-bottom: 40px;
  }
  .tb-pb50 {
    padding-bottom: 50px;
  }
  .tb-pb60 {
    padding-bottom: 60px;
  }
  .tb-pb70 {
    padding-bottom: 70px;
  }
  .tb-pb80 {
    padding-bottom: 80px;
  }
  .tb-pb90 {
    padding-bottom: 90px;
  }
  .tb-pb100 {
    padding-bottom: 100px;
  }
  .tb-flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -moz-flex;
    display: flex;
  }
  .tb-fw-w {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .tb-fd-r {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
  .tb-fd-rr {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  .tb-fd-cr {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  .tb-fd-c {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .tb-jc-c {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .tb-jc-sb {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .tb-jc-sa {
    -ms-flex-pack: distribute;
        justify-content: space-around;
  }
  .tb-jc-fe {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  .tb-jc-fs {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .tb-ai-c {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .tb-ai-fe {
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
  .tb-ai-fs {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .fz-10l {
    font-size: 8vw;
  }
  .gnav .gnav-inner ul li.icons img {
    height: 15px;
  }
  .gnav .gnav-inner ul li {
    padding: 0 1.5vw;
    font-size: 1.5vw;
  }
  .box-common {
    width: 100%;
    padding-right: 4%;
    padding-left: 4%;
  }
  .box-medium {
    width: 100%;
    padding-right: 4%;
    padding-left: 4%;
  }
  .box-narrow {
    padding-right: 4%;
    padding-left: 4%;
  }
  .box-x-narrow {
    padding: 0 4%;
  }
  .btn-more {
    font-size: 1.3rem;
  }
  .btn-more.arw-r:after {
    right: 14px;
    width: 9px;
    height: 4px;
    top: calc(50% - 2px);
  }
  .works-list-wrap .works-list li {
    height: 33.333vh;
  }
  .works-list-wrap .works-list li div {
    font-size: 6vw;
  }
  .works-list-wrap .works-list li span {
    font-size: 3vw;
  }
  .main-nav nav .nav-each a {
    /* font-size: 6vw; */
    font-size: 4vw;
  }
  .video-modal-inner video {
    height: auto !important;
    -o-object-fit: contain;
       object-fit: contain;
  }
}

@media (max-width: 767px) {
  .sp-w1 {
    width: 1%;
  }
  .sp-w2 {
    width: 2%;
  }
  .sp-w3 {
    width: 3%;
  }
  .sp-w4 {
    width: 4%;
  }
  .sp-w5 {
    width: 5%;
  }
  .sp-w6 {
    width: 6%;
  }
  .sp-w7 {
    width: 7%;
  }
  .sp-w8 {
    width: 8%;
  }
  .sp-w9 {
    width: 9%;
  }
  .sp-w10 {
    width: 10%;
  }
  .sp-w11 {
    width: 11%;
  }
  .sp-w12 {
    width: 12%;
  }
  .sp-w13 {
    width: 13%;
  }
  .sp-w14 {
    width: 14%;
  }
  .sp-w15 {
    width: 15%;
  }
  .sp-w16 {
    width: 16%;
  }
  .sp-w17 {
    width: 17%;
  }
  .sp-w18 {
    width: 18%;
  }
  .sp-w19 {
    width: 19%;
  }
  .sp-w20 {
    width: 20%;
  }
  .sp-w21 {
    width: 21%;
  }
  .sp-w22 {
    width: 22%;
  }
  .sp-w23 {
    width: 23%;
  }
  .sp-w24 {
    width: 24%;
  }
  .sp-w25 {
    width: 25%;
  }
  .sp-w26 {
    width: 26%;
  }
  .sp-w27 {
    width: 27%;
  }
  .sp-w28 {
    width: 28%;
  }
  .sp-w29 {
    width: 29%;
  }
  .sp-w30 {
    width: 30%;
  }
  .sp-w31 {
    width: 31%;
  }
  .sp-w32 {
    width: 32%;
  }
  .sp-w33 {
    width: 33%;
  }
  .sp-w34 {
    width: 34%;
  }
  .sp-w35 {
    width: 35%;
  }
  .sp-w36 {
    width: 36%;
  }
  .sp-w37 {
    width: 37%;
  }
  .sp-w38 {
    width: 38%;
  }
  .sp-w39 {
    width: 39%;
  }
  .sp-w40 {
    width: 40%;
  }
  .sp-w41 {
    width: 41%;
  }
  .sp-w42 {
    width: 42%;
  }
  .sp-w43 {
    width: 43%;
  }
  .sp-w44 {
    width: 44%;
  }
  .sp-w45 {
    width: 45%;
  }
  .sp-w46 {
    width: 46%;
  }
  .sp-w47 {
    width: 47%;
  }
  .sp-w48 {
    width: 48%;
  }
  .sp-w49 {
    width: 49%;
  }
  .sp-w50 {
    width: 50%;
  }
  .sp-w51 {
    width: 51%;
  }
  .sp-w52 {
    width: 52%;
  }
  .sp-w53 {
    width: 53%;
  }
  .sp-w54 {
    width: 54%;
  }
  .sp-w55 {
    width: 55%;
  }
  .sp-w56 {
    width: 56%;
  }
  .sp-w57 {
    width: 57%;
  }
  .sp-w58 {
    width: 58%;
  }
  .sp-w59 {
    width: 59%;
  }
  .sp-w60 {
    width: 60%;
  }
  .sp-w61 {
    width: 61%;
  }
  .sp-w62 {
    width: 62%;
  }
  .sp-w63 {
    width: 63%;
  }
  .sp-w64 {
    width: 64%;
  }
  .sp-w65 {
    width: 65%;
  }
  .sp-w66 {
    width: 66%;
  }
  .sp-w67 {
    width: 67%;
  }
  .sp-w68 {
    width: 68%;
  }
  .sp-w69 {
    width: 69%;
  }
  .sp-w70 {
    width: 70%;
  }
  .sp-w71 {
    width: 71%;
  }
  .sp-w72 {
    width: 72%;
  }
  .sp-w73 {
    width: 73%;
  }
  .sp-w74 {
    width: 74%;
  }
  .sp-w75 {
    width: 75%;
  }
  .sp-w76 {
    width: 76%;
  }
  .sp-w77 {
    width: 77%;
  }
  .sp-w78 {
    width: 78%;
  }
  .sp-w79 {
    width: 79%;
  }
  .sp-w80 {
    width: 80%;
  }
  .sp-w81 {
    width: 81%;
  }
  .sp-w82 {
    width: 82%;
  }
  .sp-w83 {
    width: 83%;
  }
  .sp-w84 {
    width: 84%;
  }
  .sp-w85 {
    width: 85%;
  }
  .sp-w86 {
    width: 86%;
  }
  .sp-w87 {
    width: 87%;
  }
  .sp-w88 {
    width: 88%;
  }
  .sp-w89 {
    width: 89%;
  }
  .sp-w90 {
    width: 90%;
  }
  .sp-w91 {
    width: 91%;
  }
  .sp-w92 {
    width: 92%;
  }
  .sp-w93 {
    width: 93%;
  }
  .sp-w94 {
    width: 94%;
  }
  .sp-w95 {
    width: 95%;
  }
  .sp-w96 {
    width: 96%;
  }
  .sp-w97 {
    width: 97%;
  }
  .sp-w98 {
    width: 98%;
  }
  .sp-w99 {
    width: 99%;
  }
  .sp-w100 {
    width: 100%;
  }
  .sp-mb10 {
    margin-bottom: 10px;
  }
  .sp-mb20 {
    margin-bottom: 20px;
  }
  .sp-mb30 {
    margin-bottom: 30px;
  }
  .sp-mb40 {
    margin-bottom: 40px;
  }
  .sp-mb50 {
    margin-bottom: 50px;
  }
  .sp-mb60 {
    margin-bottom: 60px;
  }
  .sp-mb70 {
    margin-bottom: 70px;
  }
  .sp-mb80 {
    margin-bottom: 80px;
  }
  .sp-mb90 {
    margin-bottom: 90px;
  }
  .sp-mb100 {
    margin-bottom: 100px;
  }
  .sp-pb10 {
    padding-bottom: 10px;
  }
  .sp-pb20 {
    padding-bottom: 20px;
  }
  .sp-pb30 {
    padding-bottom: 30px;
  }
  .sp-pb40 {
    padding-bottom: 40px;
  }
  .sp-pb50 {
    padding-bottom: 50px;
  }
  .sp-pb60 {
    padding-bottom: 60px;
  }
  .sp-pb70 {
    padding-bottom: 70px;
  }
  .sp-pb80 {
    padding-bottom: 80px;
  }
  .sp-pb90 {
    padding-bottom: 90px;
  }
  .sp-pb100 {
    padding-bottom: 100px;
  }
  .sp-pl0 {
    padding-left: 0;
  }
  .sp-flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -moz-flex;
    display: flex;
  }
  .sp-fw-w {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .sp-fd-r {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
  .sp-fd-rr {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  .sp-fd-cr {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  .sp-fd-c {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .sp-jc-c {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .sp-jc-sb {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .sp-jc-sa {
    -ms-flex-pack: distribute;
        justify-content: space-around;
  }
  .sp-jc-fe {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  .sp-jc-fs {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .sp-ai-c {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .sp-ai-fe {
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
  .sp-ai-fs {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .half-width {
    width: 100%;
  }
  .quarter-width {
    width: 50%;
  }
  .sp-col2-list li {
    width: 50%;
  }
  .sp-col1-list li {
    width: 100%;
  }
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
  .tc.sp-tl {
    text-align: left;
  }
  .sp-tc {
    text-align: center;
  }
  .sp-tr {
    text-align: right;
  }
  .sp-tj {
    text-align: justify;
  }
  .sp-w100 {
    width: 100%;
    max-width: 100%;
  }
  .fz-sm {
    font-size: 1.3rem;
  }
  .fz-m {
    font-size: 1.3rem;
  }
  .fz-ml {
    font-size: 1.4rem;
  }
  .fz-l {
    font-size: 1.5rem;
  }
  .fz-xl {
    font-size: 1.6rem;
  }
  .fz-2l {
    font-size: 1.8rem;
  }
  .fz-3l {
    font-size: 2rem;
  }
  .fz-4l {
    font-size: 2rem;
  }
  .fz-5l {
    font-size: 2rem;
  }
  .fz-6l {
    font-size: 2rem;
  }
  .fz-7l {
    font-size: 3.5rem;
  }
  .fz-10l {
    font-size: 3.5rem;
  }
  .sp-fz-xs {
    font-size: 1rem;
  }
  .sp-fz-s {
    font-size: 1.2rem;
  }
  .sp-fz-sm {
    font-size: 1.4rem;
  }
  .sp-fz-m {
    font-size: 1.6rem;
  }
  .sp-fz-ml {
    font-size: 1.8rem;
  }
  .sp-fz-l {
    font-size: 2rem;
  }
  .sp-fz-xl {
    font-size: 2.2rem;
  }
  .sp-fz-2l {
    font-size: 2.6rem;
  }
  .sp-fz-3l {
    font-size: 3.2rem;
  }
  .sp-fz-4l {
    font-size: 4rem;
  }
  .sp-tl {
    text-align: left;
  }
  .mb-xs {
    margin-bottom: 5px;
  }
  .mb-s {
    margin-bottom: 10px;
  }
  .mb-m {
    margin-bottom: 20px;
  }
  .mb-l {
    margin-bottom: 40px;
  }
  .pb-xs {
    padding-bottom: 5px;
  }
  .pb-s {
    padding-bottom: 10px;
  }
  .pb-m {
    padding-bottom: 20px;
  }
  .pb-l {
    padding-bottom: 40px;
  }
  .mt-xs {
    margin-top: 5px;
  }
  .mt-s {
    margin-top: 10px;
  }
  .mt-m {
    margin-top: 20px;
  }
  .mt-l {
    margin-top: 40px;
  }
  .pt-xs {
    padding-top: 5px;
  }
  .pt-s {
    padding-top: 10px;
  }
  .pt-m {
    padding-top: 20px;
  }
  .pt-l {
    padding-top: 40px;
  }
  .header svg {
    /* width: 101px; */
    width: 50px;
  }
  .gnav {
    position: fixed;
    opacity: 0;
    top: 0;
    right: -100%;
    height: 100%;
    z-index: 10000;
    padding: 100px 15px 15px 15px;
    overflow-y: auto;
    padding: 15px;
    height: 100%;
  }
  .gnav .gnav-inner {
    opacity: 0;
    -webkit-transform: translateX(20px);
            transform: translateX(20px);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .gnav .gnav-inner ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-bottom: 20%;
    position: relative;
  }
  .gnav .gnav-inner ul li.icons {
    position: absolute;
    bottom: 0;
  }
  .gnav .gnav-inner ul li.icons.icon-search {
    left: 0%;
  }
  .gnav .gnav-inner ul li.icons.icon-cart {
    left: 45%;
  }
  .gnav .gnav-inner ul li.icons.icon-mypage {
    right: 0%;
  }
  .gnav .gnav-inner ul li {
    font-size: 1.8rem;
    margin-bottom: 20px;
  }
  .gnav .gnav-inner ul li a {
    letter-spacing: 0.3em;
  }
  .box-common {
    max-width: 100%;
    padding-right: 4%;
    padding-left: 4%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .box-medium {
    width: 100%;
    padding-right: 4%;
    padding-left: 4%;
  }
  .box-narrow {
    max-width: 100%;
    padding-right: 8%;
    padding-left: 8%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .box-x-narrow {
    max-width: 100%;
    padding: 0 4%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .box-wide {
    max-width: 100%;
    padding: 0 2%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .block-common {
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .block-common-s {
    padding-top: 20px;
    padding-bottom: 20px;
  }
  .toggle-nav dt {
    font-size: 1.3rem;
  }
  .title-common01 {
    font-size: 2rem;
    margin-bottom: 30px;
  }
  .btn-more {
    font-size: 1.2rem;
    padding: 15px 30px;
  }
  .btn-more.arw-r:after {
    height: 5px;
    width: 14px;
  }
  .btn-size-s {
    font-size: 1.4rem;
  }
  .btn-size-sm {
    font-size: 1.5rem;
    padding: 15px 30px;
  }
  .btn-size-m {
    font-size: 1.5rem;
    padding: 15px 50px;
  }
  .btn-size-l {
    font-size: 1.5rem;
    padding: 15px 50px;
  }
  .fp-viewing-kv .header svg {
    /* width: 156px; */
    width: 78px;
  }
  .projectSlide .pcImg {
    display: none;
  }
  .projectSlide .spImg {
    display: block;
    position: relative;
    left: 100%;
    -webkit-transition: 0.5s 0.5s cubic-bezier(0.79, 0.13, 0.45, 0.9);
    transition: 0.5s 0.5s cubic-bezier(0.79, 0.13, 0.45, 0.9);
  }
  .projectSlide .spImg.resetTst {
    -webkit-transition: 0s;
    transition: 0s;
  }
  .projectSlide .info {
    top: auto;
    bottom: 30px;
    left: 5.335%;
  }
  .projectSlide .info.bottom {
    left: 0;
    right: 0;
    bottom: 0;
    padding-bottom: 5.335%;
    text-align: center;
    margin: auto;
  }
  .prevArea,
  .nextArea {
    display: none;
  }
  .flickArea {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  img.pointerL.onMouse,
  img.pointerR.onMouse {
    opacity: 0;
  }
  .main-nav .nav-list .nav-list-inner .nav-each {
    margin-right: auto;
    margin-left: auto;
  }
  .text-box {
    padding: 0 4%;
  }
  .text-box p {
    /* font-size: 1.3rem; */
    font-size: 0.9rem;
    line-height: 1.45rem;
  }
  .text-box p:not(:last-of-type) {
    margin-bottom: 1.5rem;
  }
  .modal-close-btn {
    top: 10px;
    right: 2%;
  }
  .modal-close-btn span {
    width: 30px;
    height: 30px;
  }
  .works-list-wrap .works-list {
    padding: 80px 0;
  }
  .works-list-wrap .works-list li {
    height: 33.333vh;
  }
  .works-list-wrap .works-list li a {
    height: 100%;
  }
  .works-list-wrap .works-list li div {
    /* font-size: 3.2rem; */
    /* font-size: 1.6rem; */
    font-size: 2.5rem;
  }
  .works-list-wrap .works-list li span {
    /* font-size: 0.8rem; */
    font-size: 1.2rem;
  }
  .main-nav nav .nav-each a {
    font-size: 3.2rem;
    /* font-size: 2rem; */
  }
  .video-modal-inner video {
    height: auto !important;
    -o-object-fit: contain;
       object-fit: contain;
  }
  .modaal-close {
    width: 30px;
    height: 30px;
  }
  .sec-contact .sec-contact-footer {
    bottom: 50px;
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
}

@media (min-width: 768px) {
  .pc-tr {
    text-align: right;
  }
  .pc-w100 {
    width: 100% !important;
    max-width: 100% !important;
  }
  .pc-pt0 {
    padding-top: 0 !important;
  }
  .pc-mt0 {
    margin-top: 0 !important;
  }
  .pc-pb0 {
    padding-bottom: 0 !important;
  }
  .pc-mb0 {
    margin-bottom: 0 !important;
  }
  .pc-mb20 {
    margin-bottom: 20px !important;
  }
  .gnav {
    padding: 10px 2%;
    overflow-y: hidden;
  }
  .gnav .gnav-inner ul li {
    line-height: 1;
  }
  .gnav .gnav-inner ul li a {
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .gnav .gnav-inner ul li a:hover {
    color: #ea511f;
  }
  .tel-link {
    pointer-events: none;
  }
  .btn-more {
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .btn-more:before, .btn-more:after {
    -webkit-transition: 0.2s;
    transition: 0.2s;
  }
  .btn-more:hover {
    color: #fff;
  }
  .btn-more:hover:before {
    top: 0;
  }
  .btn-more:hover:after {
    right: 14px;
    border-color: #fff;
    -webkit-transition-delay: 0.2s;
            transition-delay: 0.2s;
  }
  .btn-more.invert:hover {
    color: #555;
  }
  .btn-more.invert:hover:before {
    background: #fff;
  }
  .text-link:hover:before {
    width: 100%;
  }
  .ig-link {
    -webkit-transition: 0.4s;
    transition: 0.4s;
    display: inline-block;
  }
  .ig-link:hover {
    opacity: 0.7;
  }
  .ig-link:hover img {
    -webkit-animation: shakeIco 0.8s 1 forwards;
            animation: shakeIco 0.8s 1 forwards;
  }
}

@media all and (-ms-high-contrast: none) {
  body {
    width: 100%;
    overflow-x: hidden;
  }
}

@media (min-width: 1025px) {
  .gnav .gnav-inner ul li {
    padding: 0 2vw;
    font-size: 1.3vw;
  }
}

/*# sourceMappingURL=maps/style.css.map */
