@charset "UTF-8";
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section,
summary {
  display: block;
}

audio,
canvas,
video {
  display: inline-block;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

[hidden], template {
  display: none;
}

html {
  background: #fff;
  color: #000;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

html,
button,
input,
select,
textarea {
  font-family: "Hiragino Kaku Gothic Pro","Yu Gothic","Meiryo",sans-serif;
}

body {
  margin: 0;
}

a {
  background: transparent;
}

a:focus {
  /*outline: thin dotted;*/
}

a:hover, a:active {
  outline: 0;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

h2 {
  font-size: 1.5em;
  margin: 0.83em 0;
}

h3 {
  font-size: 1.17em;
  margin: 1em 0;
}

h4 {
  font-size: 1em;
  margin: 1.33em 0;
}

h5 {
  font-size: 0.83em;
  margin: 1.67em 0;
}

h6 {
  font-size: 0.75em;
  margin: 2.33em 0;
}

abbr[title] {
  border-bottom: 1px dotted;
}

b,
strong {
  font-weight: bold;
}

dfn {
  font-style: italic;
}

mark {
  background: #ff0;
  color: #000;
}

code,
kbd,
pre,
samp {
  font-family: monospace, serif;
  font-size: 1em;
}

pre {
  white-space: pre;
  white-space: pre-wrap;
  word-wrap: break-word;
}

q {
  quotes: "\201C" "\201D" "\2018" "\2019";
}

q:before,
q:after {
  content: '';
  content: none;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

img {
  vertical-align: middle;
  border: 0;
}

svg:not(:root) {
  overflow: hidden;
}

figure {
  margin: 0;
}

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

legend {
  border: 0;
  padding: 0;
  white-space: normal;
}

button,
input,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  margin: 0;
  vertical-align: baseline;
}

button,
input {
  line-height: normal;
}

button,
select {
  text-transform: none;
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  cursor: pointer;
}

button[disabled],
input[disabled] {
  cursor: default;
}

input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

input[type="search"] {
  -webkit-appearance: textfield;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
}

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
  vertical-align: top;
}

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

body {
  /* font-family: "A1ゴシック R", sans-serif; */
  font-family: "Noto Sans Jp", sans-serif;
}

.font-DIN-C {
  /* font-family: "DINNextLTPro-Condensed", sans-serif; */
  font-family: "din-condensed", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.font-DIN-C-light {
  /* font-family: "DINNextLTPro-LightCondensed", sans-serif; */
  font-family: "din-condensed", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.font-DIN-C-bold {
  /* font-family: "DINNextLTPro-MediumCond", sans-serif; */
  font-family: "din-condensed", sans-serif;
  font-weight: 300;
  font-style: normal;
}
.got2b-products-title-txt.font-DIN-C-bold {
  /* font-family: "DINNextLTPro-MediumCond", sans-serif; */
  font-family: "din-condensed", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.font-a1-M {
  /* font-family: "A1ゴシック M", sans-serif; */
  font-family: "Noto Sans Jp", sans-serif;
}

.font-a1-R {
  /* font-family: "A1ゴシック R", sans-serif; */
  font-family: "Noto Sans Jp", sans-serif;
}

/*
font icon
*/
@font-face {
  font-family: 'icon';
  src: url("../../../fonts/icon.eot?gwslk4");
  src: url("../../../fonts/icon.eot?gwslk4#iefix") format("embedded-opentype"), url("../../../fonts/icon.ttf?gwslk4") format("truetype"), url("../../../fonts/icon.woff?gwslk4") format("woff"), url("../../../fonts/icon.svg?gwslk4#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
}

[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-arrow-right-01:before {
  content: "\e900";
}

.icon-facebook:before {
  content: "\ea90";
}

.icon-instagram:before {
  content: "\ea92";
}

.icon-twitter:before {
  content: "\ea96";
}

html {
  height: 100%;
  overflow: auto;
}

html, body {
  width: 100%;
}

body {
  -webkit-text-size-adjust: 100%;
}

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

*, *:before, *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  padding: 0;
}

a {
  color: inherit;
  text-decoration: none;
}

a img {
  border-style: none;
}

img {
  vertical-align: top;
  width: 100%;
}

p {
  margin: 0;
  padding: 0;
}

ul, li, figure, dl, dt, dd {
  margin: 0;
  padding: 0;
}

/*
clear fix
*/
/* For modern browsers */
.cf:before,
.cf:after {
  content: "";
  display: table;
}

.cf:after {
  clear: both;
}

/*
ofi　
*/
.ofi {
  object-fit: cover;
  object-position: center;
  font-family: 'object-fit: cover; object-position: center';
}

/*
pre-wrap
*/
.pre-wrap {
  white-space: pre-wrap;
  word-wrap: break-word;
}

/* .font-DIN-Cの文字縦位置ずれ調整 */
.font-DIN-C {
  padding-top: 0.2em;
  /*transform:translateY(-0.2em);*/
}

em.em-pink {
  color: #e74291;
  font-style: normal;
}

/************************************************************
small
*************************************************************/
@media screen and (max-width: 768px) {
  br.pc {
    display: none;
  }
}

/************************************************************
large
*************************************************************/
@media screen and (min-width: 769px) {
  br.sp {
    display: none;
  }
}

/************************************************************
COMMON
*************************************************************/
header .font-DIN-C {
  padding-top: 0.2em !important;
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  header .cp-header-logo {
    width: 60px;
    height: 60px;
    background-color: black;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 110;
  }
  header .cp-header-logo .cp-header-logo-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }
  header .cp-header-logo .cp-logo {
    width: 40px;
  }
  header .sns {
    position: fixed;
    top: 15px;
    right: 65px;
    z-index: 105;
    color: white;
    font-size: 0;
    display: flex;
  }
  header .sns .btn.buy-btn {
    width: 120px;
    height: 30px;
    border-radius: 21px;
    background-color: #e74291;
    display: inline-block;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
  }
  header .sns .btn.buy-btn img {
    width: 16px;
    margin-right: 9px;
  }
  header .sns .btn.buy-btn .buy-btn-texts {
    line-height: 1em;
    white-space: nowrap;
  }
  header .sns .btn.buy-btn .buy-btn-texts .buy-btn-text {
    font-size: 18px;
    color: white;
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    display: inline-block;
    padding-top: 0.4em !important;
  }
  header .sns .btn {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: black;
    display: inline-block;
    position: relative;
  }
  header .sns .btn span {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  header .sns .tw {
    font-size: 14px;
    margin-left: 10px;
  }
  header .sns .insta {
    font-size: 14px;
    margin-left: 10px;
  }
  header .menu-btn {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 100;
    width: 42px;
    height: 42px;
    background-color: white;
    cursor: pointer;
  }
  header .menu-btn .checkbox-toggle {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 105;
    cursor: pointer;
    width: 42px;
    height: 42px;
    opacity: 0;
  }
  header .menu-btn .checkbox-toggle:checked + .hamburger > div {
    height: 0;
    border: none;
  }
  header .menu-btn .checkbox-toggle:checked + .hamburger > div:before {
    top: 0;
  }
  header .menu-btn .checkbox-toggle:checked + .hamburger > div:after {
    top: 0;
  }
  header .menu-btn .hamburger {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 101;
    width: 42px;
    height: 42px;
    padding: 0 13px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  header .menu-btn .hamburger:before {
    content: "";
    width: 100%;
    height: 100%;
    background-color: black;
    position: absolute;
    top: 4px;
    right: 4px;
    z-index: 102;
  }
  header .menu-btn .hamburger:after {
    content: "";
    width: 100%;
    height: 100%;
    background-color: white;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 103;
  }
  header .menu-btn .hamburger > div {
    position: relative;
    z-index: 104;
    width: 100%;
    height: 2px;
    background-color: black;
    transition: all 0.4s ease;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  header .menu-btn .hamburger > div:before, header .menu-btn .hamburger > div:after {
    content: '';
    position: absolute;
    z-index: 104;
    top: -6px;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: black;
    transition: all 0.4s ease;
  }
  header .menu-btn .hamburger > div:after {
    top: 6px;
  }
  header .menu {
    visibility: hidden;
    opacity: 0;
    transition: .3s;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    overflow-y: scroll;
    width: 100%;
    height: 100%;
    z-index: 95;
    background-color: rgba(242, 242, 242, 0.95);
  }
  header .menu.show {
    visibility: visible;
    opacity: 1;
  }
  header .menu.show ul {
    transform: translateY(0);
  }
  header .menu ul {
    width: 95vw;
    margin: 0 auto;
    transform: translateY(-25px);
    transition: .3s ease;
  }
  header .menu ul.nav-01 {
    margin-top: 100px;
  }
  header .menu ul.nav-02 {
    margin-top: 40px;
    padding-bottom: 80px;
  }
  header .menu ul li {
    list-style: none;
    margin-top: 10px;
    background-color: white;
  }
  header .menu ul li.ar-simulator {
    background-color: black;
    color: white;
  }
  header .menu ul li.buy-now {
    background-color: #e74291;
    color: white;
  }
  header .menu ul li a {
    font-size: 30px;
    display: block;
    width: 100%;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 15px;
    white-space: nowrap;
  }
  header .menu ul li a::after {
    content: "\e900";
    font-size: 10px;
    font-family: 'icon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  header {
    width: 100%;
    min-width: 1200px;
  }
  header .cp-header-logo {
    width: 168px;
    height: 168px;
    background-color: black;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
  }
  header .cp-header-logo .cp-header-logo-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }
  header .cp-header-logo .cp-logo {
    width: 100px;
  }
  header .sns {
    position: fixed;
    top: 0;
    right: 8%;
    z-index: 100;
    color: white;
    font-size: 0;
    display: flex;
    flex-direction: row-reverse;
  }
  header .sns .btn.buy-btn {
    width: 200px;
    height: 120px;
    border-radius: 0;
    background-color: #e74291;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 0;
    margin-right: 0;
    cursor: pointer;
  }
  header .sns .btn.buy-btn img {
    width: 30px;
    margin-right: 23px;
  }
  header .sns .btn.buy-btn .buy-btn-texts .buy-btn-text {
    color: white;
    line-height: 1em;
    position: relative;
    top: auto;
    left: auto;
    transform: none;
  }
  header .sns .btn.buy-btn .buy-btn-texts .buy-btn-text.buy-btn-text-1 {
    font-size: 50px;
  }
  header .sns .btn.buy-btn .buy-btn-texts .buy-btn-text.buy-btn-text-2 {
    font-size: 38px;
  }
  header .sns .btn {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background-color: black;
    display: inline-block;
    position: relative;
    margin-top: 20px;
    margin-right: 10px;
  }
  header .sns .btn span {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  header .sns .tw {
    font-size: 20px;
  }
  header .sns .insta {
    font-size: 20px;
    margin-left: 10px;
  }
  header .menu-btn {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 100;
    width: 84px;
    height: 84px;
    background-color: white;
  }
  header .menu-btn .checkbox-toggle {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 105;
    cursor: pointer;
    width: 84px;
    height: 84px;
    opacity: 0;
  }
  header .menu-btn .checkbox-toggle:checked + .hamburger > div:before, header .menu-btn .checkbox-toggle:checked + .hamburger > div:after {
    top: 0;
  }
  header .menu-btn .hamburger {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 101;
    width: 84px;
    height: 84px;
    padding: 0 25px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  header .menu-btn .hamburger:before {
    content: "";
    width: 100%;
    height: 100%;
    background-color: black;
    position: absolute;
    top: 7px;
    right: 7px;
    z-index: 102;
  }
  header .menu-btn .hamburger:after {
    content: "";
    width: 100%;
    height: 100%;
    background-color: white;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 103;
  }
  header .menu-btn .hamburger > div {
    position: relative;
    z-index: 104;
    width: 100%;
    height: 4px;
    background-color: black;
    transition: all 0.4s ease;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  header .menu-btn .hamburger > div:before, header .menu-btn .hamburger > div:after {
    content: '';
    position: absolute;
    z-index: 104;
    top: -12px;
    left: 0;
    width: 100%;
    height: 4px;
    background-color: black;
    transition: all 0.4s ease;
  }
  header .menu-btn .hamburger > div:after {
    top: 12px;
  }
  header .menu {
    visibility: hidden;
    opacity: 0;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 90;
    transition: .5s;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  header .menu.show {
    visibility: visible;
    opacity: 1;
  }
  header .menu .bg {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 90;
    width: 100%;
    height: 100%;
    background-color: white;
    background-image: url("../../../images/campaign/bonding-metallics/header/menu-bg.jpg");
    background-size: cover;
  }
  header .menu nav {
    position: relative;
    z-index: 91;
  }
  header .menu nav ul {
    width: 1000px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  header .menu nav ul.nav-02 {
    margin-top: 40px;
  }
  header .menu nav ul li {
    width: 490px;
    height: 70px;
    list-style: none;
    margin-top: 20px;
    background-color: white;
  }
  header .menu nav ul li.ar-simulator {
    background-color: black;
    color: white;
  }
  header .menu nav ul li.buy-now {
    background-color: #e74291;
    color: white;
  }
  header .menu nav ul li a {
    font-size: 40px;
    display: block;
    width: 100%;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    white-space: nowrap;
  }
  header .menu nav ul li a::after {
    content: "\e900";
    font-size: 18px;
    font-family: 'icon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
}

/************************************************************
small online-shopping
*************************************************************/
@media screen and (max-width: 768px) {
  header .online-shopping {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 200;
    background-color: rgba(0, 0, 0, 0.8);
    width: 100%;
    height: 100%;
    visibility: hidden;
    opacity: 0;
    transition: .5s;
  }
  header .online-shopping.show {
    visibility: visible;
    opacity: 1;
  }
  header .online-shopping .store-container {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90vw;
    padding: 30px;
    background-color: white;
    text-align: center;
  }
  header .online-shopping .store-container p.p-01 {
    font-size: 15px;
    text-align: center;
  }
  header .online-shopping .store-container p.p-02 {
    margin-top: 20px;
    font-size: 12px;
    text-align: center;
  }
  header .online-shopping .store-container .close {
    width: 40px;
    height: 40px;
    background-color: black;
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: -40px;
    right: 0;
  }
  header .online-shopping .store-container .close img {
    width: 20px;
  }
  header .online-shopping .store-container .store-wrapper .store-btn {
    margin: 20px auto 0;
    width: 63vw;
    height: 84px;
    border: 1px solid black;
    background-color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
  }
  header .online-shopping .store-container .store-wrapper .store-btn:nth-child(n+2) {
    margin-top: 15px;
  }
  header .online-shopping .store-container .store-wrapper .store-btn .store-logo {
    width: 150px;
  }
  header .online-shopping .store-container .store-wrapper .store-btn .store-logo img {
    width: 100%;
  }
  header .online-shopping .store-container .store-wrapper .store-btn .icon {
    position: absolute;
    right: 5px;
    bottom: 5px;
    width: 16px;
    height: 16px;
  }
  header .online-shopping .store-container .store-wrapper .store-btn .icon img {
    width: 16px;
  }
}

/************************************************************
large online-shopping
*************************************************************/
@media screen and (min-width: 769px) {
  header .online-shopping {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
    background-color: rgba(0, 0, 0, 0.8);
    width: 100%;
    height: 100%;
    visibility: hidden;
    opacity: 0;
    transition: .5s;
  }
  header .online-shopping.show {
    visibility: visible;
    opacity: 1;
  }
  header .online-shopping .store-container {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 850px;
    background-color: white;
  }
  header .online-shopping .store-container-inner {
    width: 100%;
    height: 100%;
    padding: 40px;
  }
  header .online-shopping .store-container p.p-01 {
    font-size: 16px;
    text-align: center;
  }
  header .online-shopping .store-container p.p-02 {
    font-size: 14px;
    text-align: center;
  }
  header .online-shopping .store-container .close {
    cursor: pointer;
    width: 40px;
    height: 40px;
    background-color: black;
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: -40px;
    right: 0;
  }
  header .online-shopping .store-container .close img {
    width: 20px;
  }
  header .online-shopping .store-container .store-wrapper {
    display: flex;
    justify-content: space-between;
    margin: 20px auto;
    /*width: 516px;*/
  }
  header .online-shopping .store-container .store-wrapper .store-btn {
    width: 246px;
    height: 97px;
    border: 1px solid black;
    background-color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    transition: .2s;
  }
  header .online-shopping .store-container .store-wrapper .store-btn:hover .store-logo {
    transform: scale(1);
  }
  header .online-shopping .store-container .store-wrapper .store-btn:hover .icon {
    transform: scale(1);
  }
  header .online-shopping .store-container .store-wrapper .store-btn .store-logo {
    width: 158px;
    transition: .2s;
    transform: scale(0.95);
  }
  header .online-shopping .store-container .store-wrapper .store-btn .store-logo img {
    width: 100%;
  }
  header .online-shopping .store-container .store-wrapper .store-btn .icon {
    position: absolute;
    right: 5px;
    bottom: 5px;
    width: 21px;
    height: 21px;
    transform-origin: right bottom;
    transform: scale(0.8);
    transition: .2s;
  }
  header .online-shopping .store-container .store-wrapper .store-btn .icon img {
    width: 21px;
  }
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  footer {
    width: 100%;
    background-color: black;
    position: relative;
    padding: 30px 0;
    margin-top: auto;
    text-align: center;
    color: white;
  }
  footer .logo {
    width: 107px;
    height: 78px;
    margin: 0 auto;
  }
  footer p.copyright {
    margin-top: 20px;
  }
  footer p.copyright small {
    font-size: 10px;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  footer {
    width: 100%;
    background-color: black;
    position: relative;
    margin-top: auto;
    text-align: center;
    color: white;
    padding: 45px 0;
  }
  footer .logo {
    width: 154px;
    height: 113px;
    margin: 0 auto;
  }
  footer p.copyright {
    margin-top: 40px;
  }
  footer p.copyright small {
    font-size: 12px;
  }
}

/************************************************************
COMMON
*************************************************************/
section.kv .swiper-slide {
  transform: translate3d(0, 0, 0);
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  section.kv {
    position: relative;
    padding-top: 0;
  }
  section.kv .kv-img-container {
    position: relative;
    z-index: 15;
  }
  section.kv .kv-txts {
    background-image: url("../../../images/campaign/bonding-colormask/bg-01-sp.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    margin-top: -46vw;
    padding-bottom: 30vw;
  }
  section.kv .kv-txts::before {
    content: "";
    display: block;
    width: 100%;
    height: 18.6vw;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 9;
    background-image: url("../../../images/campaign/bonding-colormask/paint-mask-01-sp.png");
    background-size: cover;
  }
  section.kv .kv-txts::after {
    content: "";
    display: block;
    width: 100%;
    height: 25.3vw;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 10;
    background-image: url("../../../images/campaign/bonding-colormask/paint-mask-02-sp.png");
    background-size: cover;
  }
  section.kv .kv-txts .kv-txts-inner {
    width: 92vw;
    margin: 0 auto;
    position: relative;
    z-index: 11;
    padding-top: 50vw;
  }
  section.kv .kv-txts .kv-txts-inner .kv-txt-01 {
    font-size: 70px;
    line-height: 60px;
    white-space: nowrap;
  }
  section.kv .kv-txts .kv-txts-inner .kv-txt-02 {
    margin-top: 15px;
    font-size: 18px;
    line-height: 30px;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  section.kv {
    position: relative;
  }
  section.kv .kv-img-container {
    position: relative;
  }
}

/************************************************************
COMMON
*************************************************************/
/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  .kv-notes .kv-notes-txts {
    font-size: 11px;
    line-height: 1.7em;
    padding: 10px 3.8vw 0;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  .kv-notes {
    position: relative;
  }
  .kv-notes .kv-notes-txts {
    position: absolute;
    top: 10px;
    right: 30px;
    z-index: 10;
    font-size: 11px;
    line-height: 1.3em;
  }
}

/************************************************************
COMMON
*************************************************************/
/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  .technologies .technologies-flex {
    width: 90vw;
    margin: 0 auto;
  }
  .technologies .technologies-box {
    padding-top: 40px;
  }
  .technologies .technologies-box .box-ttl-01 {
    color: #9E9FA0;
    font-size: clamp(10px, 6vw, 24px);
    line-height: 1.7em;
  }
  .technologies .technologies-box .box-ttl-02 {
    background-color: black;
    font-size: clamp(10px, 4vw, 16px);
    line-height: 1.7em;
    color: white;
    padding: 6px 0;
    text-align: center;
  }
  .technologies .technologies-box .box-img {
    width: 71.4vw;
    margin: 40px auto 0;
    text-align: right;
  }
  .technologies .technologies-box .box-img .txt-image {
    font-size: 11px;
  }
  .technologies .technologies-box .box-txt-01 {
    margin-top: 30px;
    font-size: 16px;
    line-height: 1.7em;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  .technologies .technologies-flex {
    display: flex;
    width: 96%;
    max-width: 1200px;
    margin: 60px auto 0;
  }
  .technologies .technologies-box {
    width: 50%;
  }
  .technologies .technologies-box:nth-child(2) {
    margin-left: 40px;
  }
  .technologies .technologies-box .box-ttl-01 {
    color: #9E9FA0;
    font-size: 36px;
    line-height: 1.7em;
  }
  .technologies .technologies-box .box-ttl-02 {
    background-color: black;
    font-size: 22px;
    line-height: 1.7em;
    color: white;
    padding: 11px 0;
    text-align: center;
  }
  .technologies .technologies-box .box-img {
    width: 400px;
    margin: 45px auto 0;
    text-align: right;
  }
  .technologies .technologies-box .box-img .txt-image {
    font-size: 11px;
  }
  .technologies .technologies-box .box-txt-01 {
    margin-top: 30px;
    font-size: 16px;
    line-height: 1.7em;
    text-align: center;
  }
}

/************************************************************
COMMON
*************************************************************/
/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  .concept {
    background-image: url("../../../images/campaign/bonding-colormask/concept/concept-bg-sp.jpg");
    background-size: 100% auto;
    background-position: left top;
    padding: 40px 0 70px;
  }
  .concept .concept-img {
    width: 58vw;
    max-width: 450px;
    margin: 0 auto;
  }
  .concept .concept-ttl {
    width: 90vw;
    max-width: 350px;
    margin: 0 auto;
  }
  .concept .concept-txt-01 {
    padding: 0 5vw;
    margin-top: 30px;
    font-size: 15px;
    line-height: 1.7em;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  .concept {
    background-image: url("../../../images/campaign/bonding-colormask/concept/concept-bg.jpg");
    background-size: 100% auto;
    background-position: left top;
    padding: 68px 0;
  }
  .concept .concept-flex {
    display: flex;
    width: 1180px;
    margin: 0 auto;
  }
  .concept .concept-img {
    width: 472px;
  }
  .concept .concept-txts {
    margin-left: 42px;
    padding-top: 37px;
  }
  .concept .concept-ttl {
    width: 502px;
    transform: translateX(-50px);
  }
  .concept .concept-txt-01 {
    margin-top: 40px;
    font-size: 20px;
    line-height: 1.7em;
  }
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  section.ar-link {
    background-image: url("../../../images/campaign/bonding-colormask/concept/concept-bg-sp.jpg");
    background-size: 100% auto;
    background-position: left bottom;
    text-align: center;
    width: 100%;
    padding: 80px 0 80px;
  }
  section.ar-link .ar-link-copy {
    font-size: clamp(10px, 4vw, 15px);
    /* font-weight: normal; */
    line-height: 1em;
    display: inline-block;
    position: relative;
    letter-spacing: 0.05em;
  }
  section.ar-link .ar-link-copy::before {
    content: "";
    display: block;
    width: 2px;
    height: 25px;
    background-color: black;
    position: absolute;
    top: -4px;
    left: -15px;
    transform: rotate(-28deg);
    border-radius: 2px;
  }
  section.ar-link .ar-link-copy::after {
    content: "";
    display: block;
    width: 2px;
    height: 25px;
    background-color: black;
    position: absolute;
    top: -4px;
    right: -15px;
    transform: rotate(28deg);
    border-radius: 2px;
  }
  section.ar-link .ar-link-contents {
    margin-top: 10px;
    position: relative;
    display: block;
  }
  section.ar-link .ar-link-contents .device-01 {
    width: 84px;
    position: absolute;
    bottom: -20px;
    left: 50%;
    z-index: 10;
    margin-left: -180px;
  }
  section.ar-link .ar-link-contents .device-02 {
    width: 84px;
    position: absolute;
    bottom: -20px;
    left: 50%;
    z-index: 2;
    margin-left: 98px;
  }
  section.ar-link .ar-link-contents .logo-sp {
    width: 64px;
    margin: 0 auto;
  }
  section.ar-link .ar-link-contents .obi {
    margin-top: 10px;
    background-color: white;
    position: relative;
  }
  section.ar-link .ar-link-contents .obi .obi-inner {
    width: 100%;
    height: 100px;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  section.ar-link .ar-link-contents .obi .obi-inner::after {
    content: "\e900";
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    font-size: 10px;
    color: white;
    background-color: black;
    position: absolute;
    bottom: -15px;
    left: 50%;
    margin-left: -15px;
    font-family: 'icon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  section.ar-link .ar-link-contents .obi .obi-inner .logo-pc {
    display: none;
  }
  section.ar-link .ar-link-contents .obi .obi-inner .ar-txts {
    text-align: left;
  }
  section.ar-link .ar-link-contents .obi .obi-inner .ar-txts .ar-txt-en {
    font-size: 37px;
    font-weight: 400;
    line-height: 1em;
    white-space: nowrap;
  }
  section.ar-link .ar-link-contents .obi .obi-inner .ar-txts .ar-txt-ja {
    line-height: 1em;
    font-size: 10px;
    /* margin-top: -5px; */
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  section.ar-link {
    background-image: url("../../../images/campaign/bonding-colormask/concept/concept-bg.jpg");
    background-size: 100% auto;
    background-position: left bottom;
    text-align: center;
    padding: 90px 0 160px;
    width: 100%;
  }
  section.ar-link .ar-link-copy {
    font-size: 24px;
    /* font-weight: normal; */
    line-height: 1em;
    display: inline-block;
    position: relative;
    letter-spacing: 0.05em;
  }
  section.ar-link .ar-link-copy::before {
    content: "";
    display: block;
    width: 3px;
    height: 45px;
    background-color: black;
    position: absolute;
    top: -8px;
    left: -30px;
    transform: rotate(-28deg);
    border-radius: 3px;
  }
  section.ar-link .ar-link-copy::after {
    content: "";
    display: block;
    width: 3px;
    height: 45px;
    background-color: black;
    position: absolute;
    top: -8px;
    right: -20px;
    transform: rotate(28deg);
    border-radius: 3px;
  }
  section.ar-link .ar-link-contents {
    margin-top: 30px;
    position: relative;
    display: block;
  }
  section.ar-link .ar-link-contents .device-01 {
    width: 147px;
    position: absolute;
    top: -95px;
    left: 50%;
    margin-left: -500px;
  }
  section.ar-link .ar-link-contents .device-02 {
    width: 147px;
    position: absolute;
    top: -95px;
    left: 50%;
    margin-left: 355px;
  }
  section.ar-link .ar-link-contents .logo-sp {
    display: none;
  }
  section.ar-link .ar-link-contents .obi {
    background-color: white;
  }
  section.ar-link .ar-link-contents .obi .obi-inner {
    width: 624px;
    height: 140px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  section.ar-link .ar-link-contents .obi .obi-inner::after {
    content: "\e900";
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    font-size: 10px;
    color: white;
    background-color: black;
    font-family: 'icon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  section.ar-link .ar-link-contents .obi .obi-inner .logo-pc {
    width: 114px;
  }
  section.ar-link .ar-link-contents .obi .obi-inner .ar-txts {
    text-align: left;
  }
  section.ar-link .ar-link-contents .obi .obi-inner .ar-txts .ar-txt-en {
    font-size: 80px;
    line-height: 1em;
    white-space: nowrap;
  }
  section.ar-link .ar-link-contents .obi .obi-inner .ar-txts .ar-txt-ja {
    line-height: 1em;
    font-size: 20px;
    /* margin-top: -5px; */
  }
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  section.store {
    margin-top: 45px;
    position: relative;
    background-image: url("../../../images/campaign/bonding-metallics/store/store-bg-sp.png");
    background-size: 375px auto;
    background-position: center top;
    padding-top: 40px;
    z-index: 5;
  }
  section.store.store-a {
    margin-top: -40px;
  }
  section.store::after {
    content: "";
    display: block;
    width: 100%;
    height: 40px;
    background-image: url("../../../images/campaign/bonding-metallics/store/store-bg-sp.png");
    background-size: 375px auto;
    background-position: center bottom;
    position: absolute;
    bottom: -39px;
    left: 0;
  }
  section.store .store-inner .store-title {
    font-size: 18px;
    line-height: 1em;
    font-weight: normal;
    text-align: center;
    color: white;
  }
  section.store .store-inner .btns {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin: 20px auto 0;
  }
  section.store .store-inner .btns .btn {
    width: 160px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: white;
    position: relative;
    margin: 2vw;
  }
  section.store .store-inner .btns .btn.btn-amazon {
    padding-top: 5px;
  }
  section.store .store-inner .btns .btn::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: bottom 10px right 10px;
    background-image: url("../../../images/campaign/bonding-bleach/store/icon-blank.png");
    background-size: 10px 10px;
    position: absolute;
    top: 0;
    left: 0;
  }
  section.store .store-inner .btns .btn::after img {
    width: 100%;
  }
  section.store .store-inner .btns .btn img {
    width: 50%;
  }
  section.store .store-inner .store-txt-01 {
    margin-top: 10px;
    font-size: 15px;
    line-height: 1.5em;
    text-align: center;
    color: white;
  }
  section.store .store-inner .store-txt-kome {
    margin-top: 10px;
    font-size: 12px;
    text-align: center;
    color: white;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  section.store {
    position: relative;
    height: 360px;
    background-color: black;
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 10px;
    z-index: 5;
  }
  section.store.store-b {
    margin-top: 120px;
  }
  section.store::before {
    content: "";
    width: 1440px;
    height: 500px;
    display: block;
    background-image: url("../../../images/campaign/bonding-metallics/store/store-bg.png");
    background-size: cover;
    position: absolute;
    top: -70px;
    left: 50%;
    transform: translateX(-50%);
  }
  section.store .store-inner {
    /*background-color: black;
      padding:45px 0;*/
    position: relative;
  }
  section.store .store-inner .store-title {
    font-size: 24px;
    line-height: 1em;
    font-weight: normal;
    text-align: center;
    color: white;
  }
  section.store .store-inner .btns {
    display: flex;
    justify-content: center;
    width: 1000px;
    margin: 25px auto 0;
  }
  section.store .store-inner .btns .btn {
    width: 320px;
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: white;
    position: relative;
  }
  section.store .store-inner .btns .btn:hover img {
    transform: scale(1.05);
  }
  section.store .store-inner .btns .btn:nth-child(n+2) {
    margin-left: 20px;
  }
  section.store .store-inner .btns .btn.btn-amazon {
    padding-top: 12px;
  }
  section.store .store-inner .btns .btn::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: bottom 10px right 10px;
    background-image: url("../../../images/campaign/bonding-bleach/store/icon-blank.png");
    background-size: 16px 16px;
    position: absolute;
    top: 0;
    left: 0;
  }
  section.store .store-inner .btns .btn::after img {
    width: 100%;
  }
  section.store .store-inner .btns .btn img {
    width: 50%;
    transition: .2s;
  }
  section.store .store-inner .store-txt-01 {
    margin-top: 25px;
    font-size: 18px;
    line-height: 1.88em;
    text-align: center;
    color: white;
  }
  section.store .store-inner .store-txt-kome {
    margin-top: 20px;
    font-size: 14px;
    text-align: center;
    color: white;
  }
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  section.my-insta {
    margin-top: 100px;
  }
  section.my-insta .my-insta-title {
    position: relative;
    display: flex;
    justify-content: flex-end;
  }
  section.my-insta .my-insta-title .title-copy {
    width: 193px;
    position: absolute;
    top: -17px;
    right: 154px;
  }
  section.my-insta .my-insta-title .title-main {
    font-size: 60px;
    line-height: 0.91em;
    position: relative;
    display: inline-block;
    padding: 0 5vw 0px 0;
    white-space: nowrap;
    text-align: right;
    letter-spacing: -0.02em;
  }
  section.my-insta .my-insta-title .title-main::after {
    content: "";
    width: 100%;
    height: 5px;
    display: block;
    position: absolute;
    bottom: -6px;
    left: 0;
    z-index: 1;
    background-color: black;
  }
  section.my-insta .my-insta-title .insta-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 17px;
    color: white;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: black;
    position: absolute;
    bottom: -8px;
    right: 84vw;
  }
  section.my-insta .my-insta-contents .ig-wrapper {
    margin-top: 40px;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  section.my-insta {
    margin-top: 150px;
    position: relative;
    z-index: 2;
    background-color: white;
  }
  section.my-insta .my-insta-title {
    width: 1200px;
    margin: 0 auto;
    position: relative;
    display: flex;
    justify-content: flex-end;
  }
  section.my-insta .my-insta-title .title-copy {
    width: 386px;
    position: absolute;
    top: -33px;
    right: 376px;
  }
  section.my-insta .my-insta-title .title-main {
    font-size: 120px;
    line-height: 0.91em;
    position: relative;
    display: inline-block;
    padding: 0 100px 0 0;
    text-align: right;
    white-space: nowrap;
    letter-spacing: -0.02em;
  }
  section.my-insta .my-insta-title .title-main::after {
    content: "";
    width: 100%;
    height: 8px;
    display: block;
    position: absolute;
    bottom: -8px;
    left: 0;
    z-index: 1;
    background-color: black;
  }
  section.my-insta .my-insta-title .insta-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 27px;
    color: white;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: black;
    position: absolute;
    bottom: 50px;
    left: 100px;
  }
  section.my-insta .my-insta-contents .ig-wrapper {
    margin-top: 40px;
  }
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  .breadcrumbs {
    display: inline-block;
    height: 25px;
    position: relative;
    margin-top: 64px;
    transform-origin: 0 0;
    transform: scale(0.9);
  }
  .breadcrumbs ul {
    display: inline-block;
    white-space: nowrap;
    padding: 0 7px;
    min-width: 84px;
    height: 20px;
    max-width: calc(100vw - 10px);
    overflow-y: hidden;
    overflow-x: auto;
    position: relative;
  }
  .breadcrumbs ul li {
    display: inline-block;
    vertical-align: top;
    list-style: none;
    font-size: 10px;
    margin-right: 3px;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 20px;
  }
  .breadcrumbs ul li:nth-child(n+2):before {
    content: "\003e";
    margin-right: 3px;
  }
  .breadcrumbs ul li a:hover span {
    opacity: .5 !important;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  .breadcrumbs {
    display: inline-block;
    position: absolute;
    top: 40px;
    left: 180px;
  }
  .breadcrumbs ul {
    display: inline-block;
    white-space: nowrap;
    padding: 0 10px;
    min-width: 168px;
    height: 30px;
    position: relative;
  }
  .breadcrumbs ul li {
    display: inline-block;
    vertical-align: top;
    list-style: none;
    font-size: 11px;
    margin-right: 5px;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 30px;
  }
  .breadcrumbs ul li:nth-child(n+2):before {
    content: "\003e";
    margin-right: 5px;
  }
  .breadcrumbs ul li a:hover span {
    opacity: .5 !important;
  }
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  section.about-bt {
    margin-top: -70px;
    padding-top: 70px;
    padding-bottom: 50px;
  }
  section.about-bt .about-bb-title {
    position: relative;
    display: flex;
    justify-content: flex-end;
  }
  section.about-bt .about-bb-title .title-copy {
    width: 200px;
    position: absolute;
    top: 9px;
    right: 160px;
  }
  section.about-bt .about-bb-title .title-main {
    margin-top: 10px;
    font-size: 60px;
    line-height: 0.91em;
    position: relative;
    display: inline-block;
    padding: 0 8vw 0px 0;
    text-align: right;
    letter-spacing: -0.02em;
  }
}

@media screen and (max-width: 768px) and (max-width: 374px) {
  section.about-bt .about-bb-title .title-main {
    padding: 0 4vw 0px 0;
  }
}

@media screen and (max-width: 768px) and (min-width: 360px) {
  section.about-bt .about-bb-title .title-main {
    white-space: nowrap;
  }
}

@media screen and (max-width: 768px) {
  section.about-bt .about-bb-title .title-main .small {
    font-size: 50px;
  }
  section.about-bt .about-bb-title .title-main::after {
    content: "";
    width: 100%;
    height: 5px;
    display: block;
    position: absolute;
    bottom: -6px;
    left: 0;
    z-index: 1;
    background-color: black;
  }
  section.about-bt .content-box {
    position: relative;
    margin-top: 35px;
  }
  section.about-bt .content-box .content-box-txt-00 {
    font-size: 18px;
    line-height: 30px;
    letter-spacing: 1.8px;
    text-align: right;
  }
  section.about-bt .content-box .content-box-row {
    margin-top: 35px;
    position: relative;
    background-image: url("../../../images/campaign/bonding-metallics/about-bb/content-bg-paint-sp.jpg");
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: top 12px center;
  }
  section.about-bt .content-box .content-box-row .content-box-img {
    margin: 0 auto;
    width: 59.73vw;
    max-width: 300px;
  }
  section.about-bt .content-box .content-box-row .content-txts {
    padding-top: 20px;
  }
  section.about-bt .content-box .content-box-row .content-txts .content-box-txt-01 {
    margin: 20px auto 0;
    font-size: 18px;
    line-height: 30px;
  }
}

@media screen and (max-width: 768px) and (min-width: 360px) {
  section.about-bt .content-box .content-box-row .content-txts .content-box-txt-01 .nowrap {
    white-space: nowrap;
  }
}

@media screen and (max-width: 768px) {
  section.about-bt .content-box .content-box-row .content-txts .content-box-txt-02 {
    margin: 20px auto 0;
    font-size: 14px;
    letter-spacing: 1px;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  section.about-bt .about-bb-title {
    width: 1200px;
    margin: 0 auto;
    position: relative;
    display: flex;
    justify-content: flex-end;
  }
  section.about-bt .about-bb-title .title-copy {
    width: 400px;
    position: absolute;
    top: -12px;
    right: 576px;
  }
  section.about-bt .about-bb-title .title-main {
    font-size: 120px;
    line-height: 0.91em;
    position: relative;
    display: inline-block;
    padding: 0 100px 0 0;
    text-align: right;
    white-space: nowrap;
    letter-spacing: -0.02em;
  }
  section.about-bt .about-bb-title .title-main::after {
    content: "";
    width: 100%;
    height: 10px;
    display: block;
    position: absolute;
    bottom: -8px;
    left: 0;
    z-index: 1;
    background-color: black;
  }
  section.about-bt .content-box {
    width: 1200px;
    margin: 0 auto;
    position: relative;
    padding-top: 110px;
  }
  section.about-bt .content-box .content-box-txt-00 {
    position: absolute;
    top: 35px;
    right: 100px;
    text-align: right;
    font-size: 28px;
    line-height: 47.6px;
    letter-spacing: 1.2px;
  }
  section.about-bt .content-box .content-box-row {
    width: 1130px;
    min-height: 457px;
    margin: 0 auto;
    position: relative;
    background-image: url("../../../images/campaign/bonding-metallics/about-bb/content-bg-paint.png");
    background-size: 538px 457px;
    background-repeat: no-repeat;
    background-position: 0 0;
    display: flex;
    align-items: center;
    padding: 0 0 0 130px;
  }
  section.about-bt .content-box .content-box-row .content-box-img {
    padding: 127px 0 0 0;
    width: 300px;
    min-width: 300px;
  }
  section.about-bt .content-box .content-box-row .content-txts {
    margin-top: 127px;
    margin-left: 85px;
  }
  section.about-bt .content-box .content-box-row .content-txts .content-box-txt-01 {
    font-size: 24px;
    line-height: 40.8px;
    letter-spacing: 1.2px;
  }
  section.about-bt .content-box .content-box-row .content-txts .content-box-txt-02 {
    margin-top: 20px;
    font-size: 14px;
    line-height: 30px;
    letter-spacing: 0.7px;
  }
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  .whats {
    background-image: url("../../../images/campaign/bonding-colormask/whats/whats-bg-02-sp.jpg");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    padding-top: 60px;
    /*
    .salon-txt{
      width:95vw;
      max-width: 400px;
      margin:27px 0 0 2.5vw;
    }
    .prod-container{
      position: relative;
      .prod-bg{
        position: absolute;
        width: 100%;
        height: 100%;
        .prod-bg-inner{
          height: 101%;
          background-size: cover;
          position: absolute;
          top:-1px;
        }
        .prod-bg-green{
          left:0;
          width: calc(50% - 60px);
          background-image: url("../../../images/campaign/bonding-colormask/whats/prod-bg-green.png");
        }
        .prod-bg-pink{
          right:0;
          width: calc(50% - 60px);
          background-image: url("../../../images/campaign/bonding-colormask/whats/prod-bg-pink.png");
        }
        .prod-bg-blue{
          left:50%;
          margin-left:-63px;
          width: 126px;
          background-image: url("../../../images/campaign/bonding-colormask/whats/prod-bg-blue.png");
        }
      }
      .prod-contents{
        position: relative;
        z-index: 5;
        padding:15px 0 50px;
        .prod-logo{
          width: 46.8vw;
          max-width: 250px;
          margin:0 auto;
        }
        .prod-pics{
          position: relative;
          margin-top:3vw;
          .prod-img{
            width: 85.8vw;
            max-width: 450px;
            margin:0 auto;
            position: relative;
          }
          .prod-new{
            width: 84px;
            position: absolute;
            top:-37px;
            left:-15px;
          }
          .prod-mix{
            width: 28.8vw;
            max-width: 120px;
            position: absolute;
            top:-60px;
            right:-27px;
          }
          .prod-kesho{
            width: 60px;
            height: 20px;
            font-size: 10px;
            text-align: center;
            display: flex;
            justify-content: center;
            align-items: center;
            position: absolute;
            bottom:10px;
            right:-17px;
            border:0.5px solid black;
          }
        }
      }
    }
    */
  }
  .whats .whats-title {
    position: relative;
  }
  .whats .whats-title .title-copy {
    width: 209px;
    position: absolute;
    top: -4px;
    left: 128px;
  }
  .whats .whats-title .title-main {
    font-size: 60px;
    font-weight: 500;
    line-height: 0.97em;
    position: relative;
    display: inline-block;
    padding: 0 0 1vw 5vw;
    letter-spacing: -0.02em;
  }
  .whats .whats-title .title-main .small {
    font-size: 52px;
  }
  .whats .whats-title .title-main::after {
    content: "";
    width: 100%;
    height: 5px;
    display: block;
    position: absolute;
    bottom: -6px;
    left: 0;
    z-index: 1;
    background-color: black;
  }
  .whats .prod-img-wrapper {
    padding-top: 10vw;
    background-image: url("../../../images/campaign/bonding-colormask/whats/whats-bg-02-paint-sp.png");
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-position: left bottom;
  }
  .whats .prod-img-wrapper .prod-img {
    width: 71.4vw;
    max-width: 500px;
    margin: 0 auto;
  }
  .whats .prod-txt-wrapper {
    background-color: white;
  }
  .whats .prod-txt-wrapper .prod-txt {
    width: 90vw;
    margin: -2vw auto 0;
    font-size: 15px;
    line-height: 1.7em;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  .whats {
    padding-top: 110px;
    background-image: url("../../../images/campaign/bonding-colormask/whats/whats-bg-02.jpg");
    background-repeat: no-repeat;
    background-size: 100% auto;
    position: relative;
    /*
    .salon-txt{
      width: $pc_min_width;
      margin:40px auto 0;
      padding:0 0 0 100px;
      img{
        width:893px;
      }
    }
    .prod-container{
      position: relative;
      .prod-bg{
        position: absolute;
        width: 100%;
        height: 100%;
        .prod-bg-inner{
          height: 100%;
          background-size: cover;
          position: absolute;
          top:0;
        }
        .prod-bg-green{
          left:0;
          width: calc(50% - 236px);
          background-image: url("../../../images/campaign/bonding-colormask/whats/prod-bg-green.png");
        }
        .prod-bg-pink{
          right:0;
          width: calc(50% - 236px);
          background-image: url("../../../images/campaign/bonding-colormask/whats/prod-bg-pink.png");
        }
        .prod-bg-blue{
          left:50%;
          margin-left:-240px;
          width: 480px;
          background-image: url("../../../images/campaign/bonding-colormask/whats/prod-bg-blue.png");
        }
      }
      .prod-contents{
        position: relative;
        z-index: 5;
        padding:40px 0 20px;
        .prod-logo{
          width: 243px;
          margin:0 auto;
        }
        .prod-pics{
          position: relative;
          margin-top:34px;
          .prod-img{
            width: 590px;
            margin:0 auto;
          }
          .prod-new{
            width: 138px;
            position: absolute;
            top:-16px;
            left:50%;
            margin-left:-392px;
          }
          .prod-mix{
            width: 216px;
            position: absolute;
            top:-116px;
            left:50%;
            margin-left:198px;
          }
          .prod-kesho{
            width: 64px;
            height: 20px;
            font-size: 10px;
            text-align: center;
            display: flex;
            justify-content: center;
            align-items: center;
            position: absolute;
            bottom:20px;
            left:50%;
            margin-left:-32px;
            border:1px solid black;
          }
        }
      }
    }
    */
  }
  .whats .whats-inner {
    background-image: url("../../../images/campaign/bonding-colormask/whats/whats-bg-02-paint.png");
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-position: left bottom;
  }
  .whats .whats-title {
    width: 1200px;
    margin: 0 auto;
    position: relative;
  }
  .whats .whats-title .title-copy {
    width: 413px;
    position: absolute;
    top: -12px;
    left: 435px;
  }
  .whats .whats-title .title-main {
    font-size: 120px;
    font-weight: 400;
    line-height: 0.96em;
    position: relative;
    display: inline-block;
    padding: 0 0 10px 100px;
    letter-spacing: -0.02em;
    white-space: nowrap;
  }
  .whats .whats-title .title-main::after {
    content: "";
    width: 100%;
    height: 10px;
    display: block;
    position: absolute;
    bottom: -8px;
    left: 0;
    z-index: 1;
    background-color: black;
  }
  .whats .whats-flex {
    display: flex;
    width: 96%;
    max-width: 1200px;
    margin: 100px auto 0;
    justify-content: space-between;
  }
  .whats .prod-img-wrapper {
    padding-right: 85px;
    width: 20%;
    flex-grow: 1;
  }
  .whats .prod-txt {
    padding-top: 60px;
    font-size: 20px;
    line-height: 1.7em;
    white-space: nowrap;
    width: 535px;
  }
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  section.features {
    padding: 70px 0 0;
  }
  section.features .features-title {
    margin: 0 auto;
    width: 170px;
    height: 62px;
    background-image: url("../../../images/campaign/bonding-colormask/features/title-bg.png");
    background-size: cover;
    font-size: 40px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
  }
  section.features .boxes .box {
    width: 90vw;
    max-width: 450px;
    position: relative;
    margin: 30px auto 0;
  }
  section.features .boxes .box.box-point01 .box-frame .box-pic {
    width: 89%;
    margin-bottom: 27px;
  }
  section.features .boxes .box .box-point {
    width: 80px;
    position: absolute;
    top: -21px;
    left: 0;
  }
  section.features .boxes .box .box-frame {
    width: 100%;
    height: 100%;
    border: 3px solid #A9AAAB;
    padding-top: 38px;
  }
  section.features .boxes .box .box-frame .features-txt-wrapper {
    display: flex;
    justify-content: center;
  }
  section.features .boxes .box .box-frame .features-txt-01 {
    font-size: 18px;
    line-height: 1.7em;
  }
  section.features .boxes .box .box-frame .box-pic {
    margin: 20px auto 0;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  section.features {
    padding: 90px 0 0;
  }
  section.features .features-title {
    margin: 0 auto;
    width: 340px;
    height: 124px;
    background-image: url("../../../images/campaign/bonding-colormask/features/title-bg.png");
    background-size: cover;
    font-size: 80px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
  }
  section.features .boxes {
    margin-top: 60px;
    display: flex;
    justify-content: center;
  }
  section.features .boxes .box {
    width: 390px;
    height: 380px;
    position: relative;
  }
  section.features .boxes .box:nth-child(n+2) {
    margin-left: 15px;
  }
  section.features .boxes .box.box-point01 .box-frame .box-pic {
    margin-left: -168px;
    width: 336px;
    bottom: 38px;
    left: 50%;
  }
  section.features .boxes .box .box-point {
    width: 130px;
    position: absolute;
    bottom: 301px;
    left: 0;
  }
  section.features .boxes .box .box-frame {
    width: 100%;
    height: 100%;
    border: 3px solid #A9AAAB;
    padding-top: 55px;
  }
  section.features .boxes .box .box-frame .features-txt-wrapper {
    display: flex;
    justify-content: center;
  }
  section.features .boxes .box .box-frame .features-txt-01 {
    font-size: 20px;
    line-height: 1.7em;
  }
  section.features .boxes .box .box-frame .box-pic {
    position: absolute;
    bottom: 0;
    left: 0;
    padding: 3px;
  }
}

.color-juicy-orange {
  color: #D28549;
}

.color-deep-turquoise {
  color: #2F4145;
}

.color-cherry-red {
  color: #4C3221;
}

.color-tomato-red {
  color: #B44E3C;
}

.color-canary-yellow {
  color: #BCAE53;
}

.color-mustard-yellow {
  color: #A18A42;
}

.color-mocha-ash {
  color: #947966;
}

.color-ash-pink {
  color: #A37376;
}

.color-mauve-pink {
  color: #965A54;
}

.color-silver-pink {
  color: #AF7A65;
}

.color-light-blue {
  color: #6F848F;
}

.color-cobalt-blue {
  color: #698EA2;
}

.color-aqua-blue {
  color: #3D729F;
}

.color-indigo-blue {
  color: #3E4759;
}

.color-recipe-modal {
  transition: .3s;
  visibility: hidden;
  opacity: 0;
  /*.modal-paint{
    &.paint-gravityblue{
      background-image: url("../../../images/campaign/bonding-colormask/color-recipe/paint-gravityblue.png");
    }
    &.paint-unlimitedyellow{
      background-image: url("../../../images/campaign/bonding-colormask/color-recipe/paint-unlimitedyellow.png");
    }
    &.paint-exoticrouge{
      background-image: url("../../../images/campaign/bonding-colormask/color-recipe/paint-exoticrouge.png");
    }
    &.paint-platinumsilver{
      background-image: url("../../../images/campaign/bonding-colormask/color-recipe/paint-platinumsilver.png");
    }
    &.paint-ivorygreige{
      background-image: url("../../../images/campaign/bonding-colormask/color-recipe/paint-ivorygreige.png");
    }
    &.paint-sepiamauve{
      background-image: url("../../../images/campaign/bonding-colormask/color-recipe/paint-sepiamauve.png");
    }
    &.paint-topazmocha{
      background-image: url("../../../images/campaign/bonding-colormask/color-recipe/paint-topazmocha.png");
    }
  }*/
}

.color-recipe-modal.show {
  visibility: visible;
  opacity: 1;
}

.color-recipe-modal.show .color-recipe-modal-box {
  transform: scale(1);
}

.color-recipe-modal .color-recipe-modal-box {
  transition: .2s;
  transform: scale(0.8);
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  section.color-recipe {
    padding-top: 70px;
    margin-top: 25px;
  }
  section.color-recipe .color-recipe-title {
    position: relative;
    display: flex;
    justify-content: flex-end;
  }
  section.color-recipe .color-recipe-title .title-copy {
    width: 200px;
    position: absolute;
    top: -85px;
    right: 140px;
  }
  section.color-recipe .color-recipe-title .title-main {
    margin-top: 10px;
    font-size: 60px;
    font-weight: normal;
    line-height: 0.91em;
    position: relative;
    display: inline-block;
    padding: 0 8vw 1vw 0;
    text-align: right;
    letter-spacing: -0.02em;
  }
}

@media screen and (max-width: 768px) and (max-width: 374px) {
  section.color-recipe .color-recipe-title .title-main {
    padding: 0 4vw 0px 0;
  }
}

@media screen and (max-width: 768px) and (min-width: 360px) {
  section.color-recipe .color-recipe-title .title-main {
    white-space: nowrap;
  }
}

@media screen and (max-width: 768px) {
  section.color-recipe .color-recipe-title .title-main::after {
    content: "";
    width: 100%;
    height: 5px;
    display: block;
    position: absolute;
    bottom: -6px;
    left: 0;
    z-index: 1;
    background-color: black;
  }
  section.color-recipe .color-recipe-boxes {
    background-image: url("../../../images/campaign/bonding-colormask/color-recipe/bg-sp.jpg");
    background-size: cover;
    padding: 40px 0 100px;
  }
  section.color-recipe .color-recipe-boxes .color-recipe-txt-01 {
    text-align: right;
    font-size: clamp(10px, 3.7vw, 15px);
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.7em;
    padding: 0 5vw 0 0;
    margin: 0 auto;
    padding-bottom: 10px;
  }
  section.color-recipe .color-recipe-boxes .color-recipe-boxes-wrapper {
    display: flex;
    flex-wrap: wrap;
    width: 90vw;
    margin: 10px auto 0;
  }
  section.color-recipe .color-recipe-boxes .color-recipe-box {
    width: 50%;
    margin: 5vw 0 0;
    padding: 0 2.5vw;
    position: relative;
  }
}

@media screen and (max-width: 768px) and (min-width: 500px) {
  section.color-recipe .color-recipe-boxes .color-recipe-box {
    width: 33%;
  }
}

@media screen and (max-width: 768px) {
  section.color-recipe .color-recipe-boxes .color-recipe-box .color-recipe-box-btn {
    display: block;
    width: 100%;
    height: 100%;
  }
  section.color-recipe .color-recipe-boxes .color-recipe-box .color-image {
    position: relative;
  }
  section.color-recipe .color-recipe-boxes .color-recipe-box .color-image::after {
    content: "\e900";
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: white;
    color: black;
    font-size: 10px;
    position: absolute;
    bottom: 10px;
    right: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'icon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  section.color-recipe .color-recipe-boxes .color-recipe-box .color-name {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    text-align: center;
    white-space: nowrap;
    font-size: 28px;
    line-height: 1em;
  }
  section.color-recipe .color-recipe-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    z-index: 200;
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box {
    width: 320px;
    height: 365px;
    border: 3px solid black;
    background-color: white;
    position: relative;
    /*.modal-paint{
            position: absolute;
            top:0;
            left:0;
            width: 100%;
            height: 100%;
            background-repeat: no-repeat;
            background-size: 100% auto;
            background-position: 0 0;
          }*/
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box .color-recipe-modal-close {
    display: inline-block;
    text-align: right;
    padding: 10px 10px 0 0;
    position: absolute;
    top: 0;
    right: 0;
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box .color-recipe-modal-close::before {
    content: "CLOSE";
    font-size: 15px;
    /* font-family: "DINNextLTPro-Condensed", sans-serif; */
    font-family: "din-condensed", sans-serif;
    font-weight: 300;
    font-style: normal;
    line-height: 1em;
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box .modal-recipe-pic {
    width: 185px;
    margin: 20px auto 0;
    position: relative;
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box .modal-txts {
    margin-top: 15px;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box .modal-txts .modal-txt {
    font-size: 15px;
    line-height: 21px;
    text-align: center;
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box .modal-txts .batu {
    width: 24px;
    height: 24px;
    background-image: url("../../../images/campaign/bonding-colormask/color-recipe/batu.png");
    background-size: cover;
    margin: 0 27px;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  section.color-recipe {
    padding-top: 150px;
    margin-top: 100px;
  }
  section.color-recipe .color-recipe-title {
    width: 1200px;
    margin: 0 auto;
    position: relative;
    display: flex;
    justify-content: flex-end;
  }
  section.color-recipe .color-recipe-title .title-copy {
    width: 360px;
    position: absolute;
    top: -120px;
    right: 370px;
  }
  section.color-recipe .color-recipe-title .title-main {
    font-size: 120px;
    font-weight: normal;
    line-height: 0.91em;
    position: relative;
    display: inline-block;
    padding: 0 100px 10px 0;
    text-align: right;
    white-space: nowrap;
    letter-spacing: -0.02em;
    padding-left: 300px;
  }
  section.color-recipe .color-recipe-title .title-main::after {
    content: "";
    width: 100%;
    height: 10px;
    display: block;
    position: absolute;
    bottom: -8px;
    left: 0;
    z-index: 1;
    background-color: black;
  }
  section.color-recipe .color-recipe-boxes {
    background-image: url("../../../images/campaign/bonding-colormask/color-recipe/bg.jpg");
    background-size: cover;
    padding: 40px 0 150px;
    position: relative;
  }
  section.color-recipe .color-recipe-boxes .color-recipe-txt-01 {
    text-align: right;
    font-size: 20px;
    letter-spacing: 1px;
    line-height: 1.7em;
    width: 1200px;
    margin: 0 auto;
    padding-right: 100px;
    padding-bottom: 35px;
  }
  section.color-recipe .color-recipe-boxes .color-recipe-boxes-wrapper {
    display: flex;
    flex-wrap: wrap;
    width: 1216px;
    margin: 0 auto;
  }
}

@media screen and (min-width: 769px) and (max-width: 1260px) {
  section.color-recipe .color-recipe-boxes .color-recipe-boxes-wrapper {
    width: 1160px;
  }
}

@media screen and (min-width: 769px) {
  section.color-recipe .color-recipe-boxes .color-recipe-box {
    width: 130px;
    margin: 60px 11px 0;
    position: relative;
  }
}

@media screen and (min-width: 769px) and (max-width: 1260px) {
  section.color-recipe .color-recipe-boxes .color-recipe-box {
    width: 125px;
    margin: 60px 10px 0;
  }
}

@media screen and (min-width: 769px) {
  section.color-recipe .color-recipe-boxes .color-recipe-box .color-recipe-box-btn {
    display: block;
    width: 100%;
    height: 100%;
  }
  section.color-recipe .color-recipe-boxes .color-recipe-box .color-recipe-box-btn:hover .color-image::after {
    transform: scale(1.1);
  }
  section.color-recipe .color-recipe-boxes .color-recipe-box .color-image {
    position: relative;
  }
  section.color-recipe .color-recipe-boxes .color-recipe-box .color-image::after {
    content: "\e900";
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: white;
    color: black;
    font-size: 10px;
    position: absolute;
    bottom: 8px;
    right: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: .2s;
    font-family: 'icon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  section.color-recipe .color-recipe-boxes .color-recipe-box .color-name {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    white-space: nowrap;
    font-size: 28px;
    line-height: 1em;
    color: white;
  }
  section.color-recipe .color-recipe-box:nth-of-type(6) .color-recipe-modal, section.color-recipe .color-recipe-box:nth-of-type(7) .color-recipe-modal, section.color-recipe .color-recipe-box:nth-of-type(8) .color-recipe-modal, section.color-recipe .color-recipe-box:nth-of-type(14) .color-recipe-modal, section.color-recipe .color-recipe-box:nth-of-type(15) .color-recipe-modal, section.color-recipe .color-recipe-box:nth-of-type(16) .color-recipe-modal {
    left: -410px;
  }
  section.color-recipe .color-recipe-modal {
    position: absolute;
    top: -190px;
    left: 160px;
    z-index: 200;
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box {
    width: 400px;
    height: 460px;
    border: 3px solid black;
    background-color: white;
    position: relative;
    /*.modal-paint{
            position: absolute;
            top:0;
            left:0;
            width: 100%;
            height: 100%;
            background-repeat: no-repeat;
            background-size: 100% auto;
            background-position: 0 0;
          }*/
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box .color-recipe-modal-close {
    cursor: pointer;
    display: inline-block;
    text-align: right;
    padding: 20px 20px 0 0;
    position: absolute;
    top: 0;
    right: 0;
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box .color-recipe-modal-close::before {
    content: "CLOSE";
    font-size: 20px;
    /* font-family: "DINNextLTPro-Condensed", sans-serif; */
    font-family: "din-condensed", sans-serif;
    font-weight: 300;
    font-style: normal;
    line-height: 1em;
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box .modal-recipe-pic {
    width: 232px;
    margin: 25px auto 0;
    position: relative;
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box .modal-txts {
    margin-top: 15px;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box .modal-txts .modal-txt {
    font-size: 20px;
    line-height: 28px;
    text-align: center;
  }
  section.color-recipe .color-recipe-modal .color-recipe-modal-contents .color-recipe-modal-box .modal-txts .batu {
    width: 48px;
    height: 48px;
    background-image: url("../../../images/campaign/bonding-colormask/color-recipe/batu.png");
    background-size: cover;
    margin: 0 30px;
  }
}

.lineup-prods-box-btn.show + .lineup-prods-box-stores {
  visibility: visible;
  opacity: 1;
}

.lineup-prods-box-stores {
  visibility: hidden;
  opacity: 0;
  transition: .2s;
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  section.color-lineup {
    margin-top: -26vw;
  }
  section.color-lineup .color-lineup-title-wrapper {
    background-image: url("../../../images/campaign/bonding-colormask/color-lineup/title-bg-sp.jpg");
    background-repeat: no-repeat;
    background-position: left bottom -5vw;
    background-size: 100% auto;
    padding-top: 75vw;
  }
  section.color-lineup .color-lineup-title {
    position: relative;
  }
  section.color-lineup .color-lineup-title .title-copy {
    width: 209px;
    position: absolute;
    top: -56px;
    left: 126px;
  }
  section.color-lineup .color-lineup-title .title-main {
    font-size: 60px;
    font-weight: normal;
    line-height: 0.91em;
    position: relative;
    display: inline-block;
    padding: 0 0 1vw 5vw;
    letter-spacing: -0.02em;
  }
  section.color-lineup .color-lineup-title .title-main::after {
    content: "";
    width: 100%;
    height: 5px;
    display: block;
    position: absolute;
    bottom: -6px;
    left: 0;
    z-index: 1;
    background-color: black;
  }
  section.color-lineup .color-lineup-intro {
    font-size: 15px;
    line-height: 1.7em;
    padding: 30px 5vw 0;
  }
  section.color-lineup .lineup-prods {
    margin: 0 auto;
    position: relative;
  }
  section.color-lineup .lineup-prods.lineup-prods-bold {
    margin-top: 30px;
  }
  section.color-lineup .lineup-prods.lineup-prods-bold .lineup-prods-title {
    width: 100%;
    height: 236px;
    background-image: url("../../../images/campaign/bonding-colormask/color-lineup/title-bold-line-bg-sp.png?2");
    background-size: 429px 236px;
    background-repeat: no-repeat;
    background-position: calc(50%) top;
    position: relative;
  }
  section.color-lineup .lineup-prods.lineup-prods-bold .lineup-prods-title .lineup-prods-title-txt {
    width: 245px;
    position: absolute;
    top: 30px;
    left: 50%;
    margin-left: -123px;
  }
  section.color-lineup .lineup-prods.lineup-prods-bold .lineup-prods-boxes {
    margin-top: -83px;
  }
  section.color-lineup .lineup-prods.lineup-prods-nuance {
    margin-top: 50px;
  }
  section.color-lineup .lineup-prods.lineup-prods-nuance .lineup-prods-title {
    width: 100%;
    height: 355px;
    background-image: url("../../../images/campaign/bonding-colormask/color-lineup/title-nuance-line-bg-sp.png");
    background-size: 685px 355px;
    background-repeat: no-repeat;
    background-position: calc(50%) top;
    position: relative;
  }
  section.color-lineup .lineup-prods.lineup-prods-nuance .lineup-prods-title .lineup-prods-title-txt {
    width: 245px;
    position: absolute;
    top: 67px;
    left: 50%;
    margin-left: -123px;
  }
  section.color-lineup .lineup-prods.lineup-prods-nuance .lineup-prods-boxes {
    margin-top: -158px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes {
    margin: 0 auto;
    width: 90vw;
    max-width: 500px;
    border-top: 3px solid black;
    position: relative;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box {
    position: relative;
    min-height: 260px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .lineup-prods-box-btn {
    border-bottom: 3px solid black;
    display: flex;
    padding: 35px 0 23px 12px;
    position: relative;
    background-color: rgba(255, 255, 255, 0.9);
    min-height: 260px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-arrow {
    position: absolute;
    bottom: 20px;
    right: 20px;
    display: flex;
    align-items: center;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-arrow .box-arrow-txt {
    font-size: 20px;
    line-height: 1em;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-arrow::after {
    content: "\e900";
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: black;
    color: white;
    font-size: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: scale(0.66);
    transform-origin: right center;
    font-family: 'icon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-pic {
    display: flex;
    align-items: flex-end;
    transform: translateX(-10px);
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-pic .box-pic-prod {
    width: 77px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-pic .box-pic-paint {
    width: 71px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-txts {
    margin-left: 0;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-txts .box-name-en {
    font-size: 32px;
    white-space: nowrap;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-txts .box-name-en .font-DIN-C-bold{
    font-weight: 500;
    }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-txts .box-name-jp {
    font-size: 15px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-txts .box-txt-01 {
    font-size: 12px;
    margin-top: 15px;
    line-height: 20px;
  }
  section.color-lineup .lineup-prods-box-stores {
    background-color: rgba(0, 0, 0, 0.8);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  section.color-lineup .lineup-prods-box-stores .store-title {
    font-size: 18px;
    line-height: 1em;
    letter-spacing: 1px;
    font-weight: normal;
    text-align: center;
    color: white;
  }
  section.color-lineup .lineup-prods-box-stores .btns {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin: 10px auto 0;
  }
  section.color-lineup .lineup-prods-box-stores .btns .btn {
    width: 200px;
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: white;
    position: relative;
    margin: 1.3vw;
  }
  section.color-lineup .lineup-prods-box-stores .btns .btn.btn-amazon {
    padding-top: 2%;
  }
  section.color-lineup .lineup-prods-box-stores .btns .btn::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: bottom 10px right 10px;
    background-image: url("../../../images/campaign/bonding-bleach/store/icon-blank.png");
    background-size: 10px 10px;
    position: absolute;
    top: 0;
    left: 0;
  }
  section.color-lineup .lineup-prods-box-stores .btns .btn::after img {
    width: 100%;
  }
  section.color-lineup .lineup-prods-box-stores .btns .btn img {
    width: 50%;
  }
  section.color-lineup .lineup-prods-box-stores .close {
    cursor: pointer;
    display: inline-block;
    text-align: right;
    padding: 5px 10px 0 0;
    position: absolute;
    top: 0;
    right: 0;
    color: white;
  }
  section.color-lineup .lineup-prods-box-stores .close::before {
    content: "CLOSE";
    font-size: 15px;
    /* font-family: "DINNextLTPro-Condensed", sans-serif; */
    font-family: "din-condensed", sans-serif;
    font-weight: 300;
    font-style: normal;
    line-height: 1em;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  section.color-lineup .color-lineup-title-wrapper {
    background-image: url("../../../images/campaign/bonding-colormask/color-lineup/title-bg.jpg");
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 100% auto;
    padding-top: 26vw;
  }
  section.color-lineup .color-lineup-title {
    width: 1200px;
    margin: 0 auto;
    position: relative;
  }
  section.color-lineup .color-lineup-title .title-copy {
    width: 413px;
    position: absolute;
    top: -110px;
    left: 411px;
  }
  section.color-lineup .color-lineup-title .title-main {
    font-size: 120px;
    font-weight: normal;
    line-height: 0.91em;
    position: relative;
    display: inline-block;
    padding: 0 220px 10px 100px;
    letter-spacing: -0.02em;
    white-space: nowrap;
  }
  section.color-lineup .color-lineup-title .title-main::after {
    content: "";
    width: 100%;
    height: 10px;
    display: block;
    position: absolute;
    bottom: -8px;
    left: 0;
    z-index: 1;
    background-color: black;
  }
  section.color-lineup .color-lineup-intro {
    width: 1200px;
    margin: 0 auto;
    font-size: 20px;
    line-height: 1.7em;
    padding: 30px 0 0 100px;
  }
  section.color-lineup .lineup-prods {
    margin: 0 auto;
    width: 1200px;
    position: relative;
  }
  section.color-lineup .lineup-prods.lineup-prods-bold {
    margin-top: 90px;
  }
  section.color-lineup .lineup-prods.lineup-prods-bold .lineup-prods-title {
    width: 468px;
    height: 851px;
    background-image: url("../../../images/campaign/bonding-colormask/color-lineup/title-bold-line-bg.png?2");
    background-size: cover;
    position: absolute;
    top: -45px;
    left: -78px;
  }
  section.color-lineup .lineup-prods.lineup-prods-bold .lineup-prods-title .lineup-prods-title-txt {
    width: 113px;
    position: absolute;
    top: 243px;
    left: 236px;
  }
  section.color-lineup .lineup-prods.lineup-prods-nuance {
    margin-top: 100px;
  }
  section.color-lineup .lineup-prods.lineup-prods-nuance .lineup-prods-title {
    width: 571px;
    height: 1103px;
    background-image: url("../../../images/campaign/bonding-colormask/color-lineup/title-nuance-line-bg.png");
    background-size: cover;
    position: absolute;
    top: -48px;
    left: -127px;
  }
  section.color-lineup .lineup-prods.lineup-prods-nuance .lineup-prods-title .lineup-prods-title-txt {
    width: 113px;
    position: absolute;
    top: 317px;
    left: 307px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes {
    margin: 0 0 0 auto;
    width: 760px;
    border-top: 4px solid black;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box {
    position: relative;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .lineup-prods-box-btn {
    border-bottom: 4px solid black;
    display: flex;
    align-items: center;
    padding: 14px 0 14px 60px;
    position: relative;
    cursor: pointer;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .lineup-prods-box-btn:hover .box-arrow::after {
    transform: scale(1.1);
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-arrow {
    position: absolute;
    top: 50%;
    right: 40px;
    transform: translateY(-50%);
    display: flex;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-arrow .box-arrow-txt {
    font-size: 24px;
    line-height: 30px;
    margin-right: 13px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-arrow .box-arrow-txt .font-DIN-C{
    font-weight: 400;
    }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-arrow::after {
    content: "\e900";
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: black;
    color: white;
    font-size: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: .2s;
    font-family: 'icon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-pic {
    display: flex;
    align-items: flex-end;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-pic .box-pic-prod {
    width: 85px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-pic .box-pic-paint {
    width: 86px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-txts {
    margin-left: 40px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-txts .box-name-en {
    font-size: 40px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-txts .box-name-en .font-DIN-C-bold{
    font-weight: 400;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-txts .box-name-jp {
    font-size: 20px;
  }
  section.color-lineup .lineup-prods .lineup-prods-boxes .lineup-prods-box .box-txts .box-txt-01 {
    font-size: 16px;
    margin-top: 20px;
  }
  section.color-lineup .lineup-prods-box-stores {
    background-color: rgba(0, 0, 0, 0.7);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    padding-top: 40px;
  }
  section.color-lineup .lineup-prods-box-stores .store-title {
    font-size: 24px;
    line-height: 1em;
    letter-spacing: 1px;
    font-weight: normal;
    text-align: center;
    color: white;
  }
  section.color-lineup .lineup-prods-box-stores .btns {
    display: flex;
    justify-content: center;
    margin: 25px auto 0;
  }
  section.color-lineup .lineup-prods-box-stores .btns .btn {
    width: 230px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: white;
    position: relative;
  }
  section.color-lineup .lineup-prods-box-stores .btns .btn:hover img {
    transform: scale(1.05);
  }
  section.color-lineup .lineup-prods-box-stores .btns .btn:nth-child(n+2) {
    margin-left: 10px;
  }
  section.color-lineup .lineup-prods-box-stores .btns .btn.btn-amazon {
    padding-top: 8px;
  }
  section.color-lineup .lineup-prods-box-stores .btns .btn::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: bottom 10px right 10px;
    background-image: url("../../../images/campaign/bonding-bleach/store/icon-blank.png");
    background-size: 16px 16px;
    position: absolute;
    top: 0;
    left: 0;
  }
  section.color-lineup .lineup-prods-box-stores .btns .btn::after img {
    width: 100%;
  }
  section.color-lineup .lineup-prods-box-stores .btns .btn img {
    width: 50%;
    transition: .2s;
  }
  section.color-lineup .lineup-prods-box-stores .close {
    cursor: pointer;
    display: inline-block;
    text-align: right;
    padding: 20px 20px 0 0;
    position: absolute;
    top: 0;
    right: 0;
    color: white;
  }
  section.color-lineup .lineup-prods-box-stores .close::before {
    content: "CLOSE";
    font-size: 20px;
    /* font-family: "DINNextLTPro-Condensed", sans-serif; */
    font-family: "din-condensed", sans-serif;
    font-weight: 300;
    font-style: normal;
    line-height: 1em;
  }
}

/************************************************************
common
*************************************************************/
/************************************************************
small
*************************************************************/
@media screen and (max-width: 768px) {
  .base-make {
    margin-top: 20px;
    padding-top: 80px;
    position: relative;
  }
  .base-make::before {
    content: "";
    display: block;
    width: 76.26vw;
    height: 57.6vw;
    background-image: url("../../../images/campaign/bonding-colormask/base-make/photo-bg-sp.jpg");
    background-size: cover;
    position: absolute;
    top: 175px;
    left: 0;
  }
  .base-make .base-make-title {
    position: relative;
    display: flex;
    justify-content: flex-end;
  }
  .base-make .base-make-title .title-copy {
    width: 200px;
    position: absolute;
    top: -15px;
    right: 160px;
  }
  .base-make .base-make-title .title-main {
    margin-top: 33px;
    font-size: 60px;
    line-height: 0.91em;
    position: relative;
    display: inline-block;
    padding: 0 8vw 0 0;
    white-space: nowrap;
    text-align: right;
    letter-spacing: -0.02em;
  }
  .base-make .base-make-title .title-main::after {
    content: "";
    width: 100%;
    height: 5px;
    display: block;
    position: absolute;
    bottom: -6px;
    left: 0;
    z-index: 1;
    background-color: black;
  }
  .base-make .base-make-contents {
    position: relative;
  }
  .base-make .base-make-contents .bm-photo {
    width: 65vw;
    max-width: 380px;
    margin: 25px auto 0;
  }
}

@media screen and (max-width: 768px) and (min-width: 360px) {
  .base-make .base-make-contents .bm-txts .nowrap {
    white-space: nowrap;
  }
}

@media screen and (max-width: 768px) {
  .base-make .base-make-contents .bm-txts .bm-txt-01 {
    padding: 0 10px 15px 9vw;
    margin-top: 25px;
    font-size: 26px;
    line-height: 46.7px;
    letter-spacing: -0.1em;
  }
}

@media screen and (max-width: 768px) and (max-width: 374px) {
  .base-make .base-make-contents .bm-txts .bm-txt-01 {
    white-space: normal;
  }
  .base-make .base-make-contents .bm-txts .bm-txt-01 br {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  .base-make .base-make-contents .bm-txts .bm-txt-02 {
    margin-top: 20px;
    font-size: 18px;
    line-height: 30.6px;
  }
  .base-make .base-make-contents .bm-txts .bm-txt-03 {
    margin-top: 20px;
    font-size: 14px;
    letter-spacing: 1px;
  }
}

/************************************************************
large
*************************************************************/
@media screen and (min-width: 769px) {
  .base-make {
    margin-top: -90px;
    padding-top: 170px;
  }
  .base-make .base-make-title {
    width: 1200px;
    margin: 0 auto;
    position: relative;
    display: flex;
    justify-content: flex-end;
  }
  .base-make .base-make-title .title-copy {
    width: 410px;
    position: absolute;
    top: 0;
    right: 517px;
  }
  .base-make .base-make-title .title-main {
    font-size: 120px;
    line-height: 0.91em;
    position: relative;
    display: inline-block;
    padding: 0 100px 0 0;
    text-align: right;
    white-space: nowrap;
    letter-spacing: -0.02em;
  }
  .base-make .base-make-title .title-main::after {
    content: "";
    width: 100%;
    height: 8px;
    display: block;
    position: absolute;
    bottom: -8px;
    left: 0;
    z-index: 1;
    background-color: black;
  }
  .base-make .base-make-contents {
    width: 940px;
    margin: 46px auto 0;
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
  }
  .base-make .base-make-contents .bm-photo {
    margin-top: 40px;
    width: 383px;
    min-width: 383px;
  }
  .base-make .base-make-contents .bm-txts .bm-txt-01 {
    font-size: 36px;
    line-height: 61.2px;
    padding-bottom: 15px;
  }
  .base-make .base-make-contents .bm-txts .bm-txt-02 {
    margin-top: 20px;
    font-size: 24px;
    line-height: 40.8px;
    letter-spacing: 1.2px;
    white-space: nowrap;
  }
  .base-make .base-make-contents .bm-txts .bm-txt-03 {
    margin-top: 20px;
    font-size: 14px;
    letter-spacing: 0.7px;
  }
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  .bb {
    margin-top: 112px;
  }
  .bb .bb-contents {
    margin: 0 auto;
    background-image: url("../../../images/campaign/bonding-colormask/bb/bg-bright-sp.jpg");
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-position: center 45px;
  }
  .bb .bb-contents .content-product {
    width: 84vw;
    margin: 0 auto;
  }
  .bb .bb-contents .content-product .detail-title {
    margin-top: 20px;
    width: 312px;
  }
  .bb .bb-contents .content-product .detail-txt-01 {
    font-size: 13px;
    line-height: 1.5em;
    text-align: center;
    margin-top: 10px;
    white-space: nowrap;
  }
  .bb .bb-contents .content-product .product-name {
    position: relative;
  }
  .bb .bb-contents .content-product .product-name img {
    width: 213px;
  }
  .bb .bb-contents .content-product .product-name .product-name-txt {
    margin-top: 8px;
    font-size: 15px;
    line-height: 1em;
  }
  .bb .bb-contents .content-product .product-pic {
    margin: 19vw auto 0;
    position: relative;
  }
  .bb .bb-contents .content-product .product-pic img.tx {
    width: 83.3vw;
    max-width: 450px;
    display: block;
    margin: 0 auto;
    position: relative;
  }
  .bb .bb-contents .content-product .product-pic .product-pic-copy {
    width: 92vw;
    max-width: 600px;
    position: absolute;
    top: -16.5vw;
    left: 50%;
    transform: translateX(-50%);
  }
  .bb .bb-contents .content-product .product-pic .med-mark {
    margin: 2px 0 0 auto;
    width: 60px;
  }
  .bb .bb-contents .content-product .product-pic .med-mark img {
    transform: translateX(20px);
  }
  .bb .bb-contents .content-detail {
    width: 100%;
    margin: 17px auto 0;
  }
  .bb .bb-contents .content-detail .detail-title-pc {
    display: none;
  }
  .bb .bb-contents .content-detail .detail-txt-01-pc {
    display: none;
  }
  .bb .bb-contents .content-detail .detail-box {
    width: 100%;
    margin: 15px auto 0;
  }
  .bb .bb-contents .content-detail .detail-box .detail-box-head {
    background-color: black;
    color: white;
    line-height: 1em;
    white-space: nowrap;
    text-align: center;
    padding: 15px 0;
    font-size: 13px;
  }
  .bb .bb-contents .content-detail .detail-box .detail-box-head sup {
    font-size: 10px;
  }
  .bb .bb-contents .content-detail .detail-box .detail-box-body {
    padding: 10px 6px 10px 8px;
    border-bottom: 1px solid black;
    font-size: 12px;
    line-height: 1.8em;
    letter-spacing: -0.02em;
  }
  .bb .bb-contents .content-detail .detail-box .detail-box-body .indent {
    text-indent: -1em;
    padding-left: 1em;
    display: inline-block;
  }
  .bb .bb-contents .content-detail .note {
    width: 84vw;
    margin: 15px auto 0;
    font-size: 10px;
    line-height: 1.66em;
  }
  .bb .bb-contents .content-detail .note .m-indent {
    text-indent: -2em;
    padding-left: 2em;
    display: inline-block;
  }
  .bb .bb-contents .content-detail .note .m-indent-2 {
    text-indent: -1em;
    padding-left: 1em;
    display: inline-block;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  .bb {
    margin-top: 90px;
  }
  .bb .bb-contents {
    margin: 40px auto 0;
    width: 1200px;
    display: flex;
    background-image: url("../../../images/campaign/bonding-colormask/bb/bg-bright.jpg");
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-position: center 80px;
  }
  .bb .bb-contents .content-product {
    width: 450px;
    margin-left: 70px;
  }
  .bb .bb-contents .content-product .detail-title-sp {
    display: none;
  }
  .bb .bb-contents .content-product .detail-txt-01-sp {
    display: none;
  }
  .bb .bb-contents .content-product .product-name {
    margin-left: -10px;
    position: relative;
  }
  .bb .bb-contents .content-product .product-name img {
    width: 356px;
  }
  .bb .bb-contents .content-product .product-name .product-name-txt {
    margin-top: 20px;
    font-size: 24px;
    line-height: 1em;
  }
  .bb .bb-contents .content-product .product-pic {
    width: 456px;
    margin: 80px auto 0;
    position: relative;
  }
  .bb .bb-contents .content-product .product-pic img.tx {
    transform: translateX(-10px);
  }
  .bb .bb-contents .content-product .product-pic .product-pic-copy {
    width: 486px;
    position: absolute;
    top: -84px;
    left: -27px;
  }
  .bb .bb-contents .content-product .product-pic .med-mark {
    margin: -10px 0 0 2px;
    width: 65px;
  }
  .bb .bb-contents .content-detail {
    padding-top: 85px;
  }
  .bb .bb-contents .content-detail .detail-title {
    margin-left: 20px;
    width: 459px;
  }
  .bb .bb-contents .content-detail .detail-txt-01 {
    font-size: 18px;
    line-height: 1.77em;
    margin: 10px 0 0 40px;
  }
  .bb .bb-contents .content-detail .detail-box {
    width: 550px;
    margin: 30px 0 0 40px;
  }
  .bb .bb-contents .content-detail .detail-box .detail-box-head {
    background-color: black;
    color: white;
    line-height: 1em;
    white-space: nowrap;
    text-align: center;
    padding: 12px 0;
    font-size: 18px;
  }
  .bb .bb-contents .content-detail .detail-box .detail-box-head sup {
    font-size: 10px;
  }
  .bb .bb-contents .content-detail .detail-box .detail-box-body {
    white-space: nowrap;
    padding: 15px 20px;
    border: 1px solid black;
    font-size: 16px;
    line-height: 2.14em;
  }
  .bb .bb-contents .content-detail .note {
    margin: 10px 0 0 40px;
    font-size: 12px;
    line-height: 2em;
  }
  .bb .bb-contents .content-detail .note .m-indent {
    text-indent: -2em;
    padding-left: 2em;
    display: inline-block;
  }
}

/************************************************************
common
*************************************************************/
/************************************************************
small
*************************************************************/
@media screen and (max-width: 768px) {
  .got2b-products {
    margin-top: -30px;
    padding-top: 70px;
  }
  .got2b-products .got2b-products-title .got2b-products-title-txt {
    font-size: 60px;
    font-weight: 400;
    letter-spacing: -0.02em;
    text-align: center;
    padding-bottom: 1vw;
  }
  .got2b-products .boxes {
    padding: 0 3vw;
  }
  .got2b-products .boxes.boxes-01 {
    margin-top: 30px;
  }
  .got2b-products .boxes.boxes-02 {
    margin-top: 100px;
    padding-bottom: 50px;
  }
  .got2b-products .boxes .box {
    display: block;
    position: relative;
    margin-top: 5vw;
  }
  .got2b-products .boxes .box .box-arrow {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    color: white;
    background-color: black;
    position: absolute;
    bottom: 6px;
    left: 6px;
    font-size: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .got2b-products .boxes .box .box-arrow.box-arrow-white {
    color: black;
    background-color: white;
  }
}

/************************************************************
large
*************************************************************/
@media screen and (min-width: 769px) {
  .got2b-products {
    margin-top: -80px;
    padding-top: 170px;
  }
  .got2b-products .got2b-products-title .got2b-products-title-txt {
    font-size: 100px;
    letter-spacing: -6px;
    text-align: center;
  }
  .got2b-products .boxes {
    width: 1200px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    padding-bottom: 100px;
  }
  .got2b-products .boxes .box {
    width: 580px;
    display: block;
    position: relative;
    margin-top: 40px;
  }
  .got2b-products .boxes .box:hover .box-arrow {
    transform: scale(1.1);
  }
  .got2b-products .boxes .box:nth-child(2n) {
    margin-left: 40px;
  }
  .got2b-products .boxes .box .box-arrow {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    color: white;
    background-color: black;
    position: absolute;
    bottom: 10px;
    left: 10px;
    font-size: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform .2s;
  }
  .got2b-products .boxes .box .box-arrow.box-arrow-white {
    color: black;
    background-color: white;
  }
}

/************************************************************
SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  .floating-cart {
    position: fixed;
    bottom: -100px;
    left: 50%;
    z-index: 150;
    transform: translateX(-50%);
    width: 92vw;
    max-width: 400px;
    height: 50px;
    border-radius: 30px;
    background-color: white;
    border: 2px solid #E74291;
    color: #E74291;
    font-size: 20px;
    font-weight: 700;
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
    transition: bottom 0.5s;
  }
  .floating-cart.show {
    bottom: 10px;
  }
  .floating-cart img {
    width: 30px;
    margin-right: 10px;
  }
}

/************************************************************
LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  .floating-cart {
    display: none;
  }
}

/************************************************************
.store-cta-linker SMALL
*************************************************************/
@media screen and (max-width: 768px) {
  .store-cta-linker {
    padding: 40px 0;
  }
  .store-cta-linker .store-cta-linker-btn {
    padding-top: 8px;
    margin: 0 auto;
    width: 92vw;
    height: 80px;
    background-color: black;
    color: #FFF;
    position: relative;
    display: block;
    text-align: center;
  }
  .store-cta-linker .store-cta-linker-btn .icon {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: white;
    color: black;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    transition: transform .2s;
    will-change: transform;
  }
  .store-cta-linker .store-cta-linker-btn .icon::after {
    content: "\e900";
    font-size: 10px;
    display: inline-block;
    transform: rotate(90deg);
    font-family: 'icon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  .store-cta-linker .store-cta-linker-btn .btn-txt-01 {
    text-align: center;
    /* font-family: "DINNextLTPro-Condensed"; */
    font-family: "din-condensed", sans-serif;
    font-weight: 300;
    font-size: 20px;
    font-style: normal;
    line-height: 170%;
    /* 44.2px */
    display: inline-block;
    position: relative;
  }
  .store-cta-linker .store-cta-linker-btn .btn-txt-01::before {
    content: "";
    display: block;
    width: 1px;
    height: 20px;
    background-color: white;
    position: absolute;
    top: 7px;
    left: -11px;
    transform: rotate(-28deg);
    border-radius: 3px;
  }
  .store-cta-linker .store-cta-linker-btn .btn-txt-01::after {
    content: "";
    display: block;
    width: 1px;
    height: 20px;
    background-color: white;
    position: absolute;
    top: 7px;
    right: -11px;
    transform: rotate(28deg);
    border-radius: 3px;
  }
  .store-cta-linker .store-cta-linker-btn .btn-txt-02 {
    margin-top: -8px;
    color: #FFF;
    text-align: center;
    /* font-family: "A1ゴシック M", sans-serif; */
    font-family: "Noto Sans Jp", sans-serif;
    font-size: 20px;
    letter-spacing: 0.1em;
    font-style: normal;
    font-weight: 600;
    line-height: 170%;
    /* 51px */
  }
}

/************************************************************
.store-cta-linker LARGE
*************************************************************/
@media screen and (min-width: 769px) {
  .store-cta-linker {
    padding: 50px 0;
  }
  .store-cta-linker .store-cta-linker-btn {
    margin: 0 auto;
    width: 1000px;
    height: 100px;
    background-color: black;
    color: #FFF;
    position: relative;
    display: block;
    padding-top: 10px;
    text-align: center;
  }
  .store-cta-linker .store-cta-linker-btn:hover .icon {
    transform: translateY(-50%) scale(1.2);
  }
  .store-cta-linker .store-cta-linker-btn .icon {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: white;
    color: black;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%);
    transition: transform .2s;
    will-change: transform;
  }
  .store-cta-linker .store-cta-linker-btn .icon::after {
    content: "\e900";
    font-size: 10px;
    display: inline-block;
    transform: rotate(90deg);
    font-family: 'icon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  .store-cta-linker .store-cta-linker-btn .btn-txt-01 {
    text-align: center;
    /* font-family: "DINNextLTPro-Condensed"; */
    font-family: "din-condensed", sans-serif;
    font-weight: 300;
    font-size: 26px;
    font-style: normal;
    line-height: 170%;
    /* 44.2px */
    position: relative;
    display: inline-block;
  }
  .store-cta-linker .store-cta-linker-btn .btn-txt-01::before {
    content: "";
    display: block;
    width: 1px;
    height: 30px;
    background-color: white;
    position: absolute;
    top: 6px;
    left: -20px;
    transform: rotate(-28deg);
    border-radius: 3px;
  }
  .store-cta-linker .store-cta-linker-btn .btn-txt-01::after {
    content: "";
    display: block;
    width: 1px;
    height: 30px;
    background-color: white;
    position: absolute;
    top: 6px;
    right: -20px;
    transform: rotate(28deg);
    border-radius: 3px;
  }
  .store-cta-linker .store-cta-linker-btn .btn-txt-02 {
    margin-top: -11px;
    color: #FFF;
    text-align: center;
    /* font-family: "A1ゴシック M", sans-serif; */
    font-family: "Noto Sans Jp", sans-serif;
    font-size: 28px;
    letter-spacing: 0.1em;
    font-style: normal;
    font-weight: 500;
    line-height: 170%;
    /* 51px */
  }
}

/************************************************************
common
*************************************************************/
.color-pink {
  color: #E74291;
}

.inline-block {
  display: inline-block;
}

/************************************************************
small
*************************************************************/
@media screen and (max-width: 768px) {
  body {
    min-width: 100vw;
    overflow: hidden;
  }
  main {
    padding-bottom: 60px;
  }
  .gt-inner {
    width: 82vw;
    margin: 0 auto;
  }
}

/************************************************************
large
*************************************************************/
@media screen and (min-width: 769px) {
  body {
    min-width: 1200px;
    overflow: hidden;
  }
}
